Visible to the public ZeeStar: Private Smart Contracts by Homomorphic Encryption and Zero-knowledge Proofs

TitleZeeStar: Private Smart Contracts by Homomorphic Encryption and Zero-knowledge Proofs
Publication TypeConference Paper
Year of Publication2022
AuthorsSteffen, Samuel, Bichsel, Benjamin, Baumgartner, Roger, Vechev, Martin
Conference Name2022 IEEE Symposium on Security and Privacy (SP)
Keywordsannotations, blockchain, blockchains, Compilation, Costs, data privacy, encoding, ethereum, expert systems, homomorphic encryption, Human Behavior, privacy, programming language, pubcrawl, resilience, Resiliency, Scalability, smart contracts, zero-knowledge proofs
AbstractData privacy is a key concern for smart contracts handling sensitive data. The existing work zkay addresses this concern by allowing developers without cryptographic expertise to enforce data privacy. However, while zkay avoids fundamental limitations of other private smart contract systems, it cannot express key applications that involve operations on foreign data.We present ZeeStar, a language and compiler allowing non-experts to instantiate private smart contracts and supporting operations on foreign data. The ZeeStar language allows developers to ergonomically specify privacy constraints using zkay's privacy annotations. The ZeeStar compiler then provably realizes these constraints by combining non-interactive zero-knowledge proofs and additively homomorphic encryption.We implemented ZeeStar for the public blockchain Ethereum. We demonstrated its expressiveness by encoding 12 example contracts, including oblivious transfer and a private payment system like Zether. ZeeStar is practical: it prepares transactions for our contracts in at most 54.7s, at an average cost of 339k gas.
DOI10.1109/SP46214.2022.9833732
Citation Keysteffen_zeestar_2022