Distributing an airdrop to users is simple if you already have their public keys, but protocols may want to do so according to off-chain activities. Although one could request addresses from users over a public or private channel, many users would prefer not to disclose their public keys.
This repo demonstrates a strategy for distributing tokens where users can provide a message (known as the 'commitment') over a public channel and later claim their portion of the airdrop by providing a zero-knowledge proof that they belong in the Merkle tree. Claiming tokens in this manner mixes them with all other users entitled to an airdrop, protecting their anonymity.
A self-contained library for generating claim proofs and interacting with these contracts can be found at a16z/zkdrops/zkdrops-lib, and an example front-end can be found at a16z/zkdrops/client-ex.
The smart contract for distributions (zkdrops-contracts/contracts/PrivateAirdrop.sol) includes an updateRoot function which allows the owner to modify the Merkle tree after launch, but can be made immutable by removing that function if desired.
- Users create a keyand asecret, and concatenatehash(key + secret)to create thecommitment.
- The commitmentcan then be transmitted across a public or private channel without leaking information.
- An admin assembles a Merkle tree of these commitmentsand deploys the smart contracts.
- Users can then redeem with a zero-knoweldge proof that they belong in the Merkle tree without revealing which commitmentis associated with their public key.
- Note that on-chain verification requires ~350k gas.
- gh repo clone a16z/zkdrops
- yarn install
- For generating circuits: Circom 2.0 install + snarkjs
- yarn compile
- yarn start-backend
- (new terminal window)
- yarn deploy
- yarn start-client
- Navigate to localhost:3000and point wallet atlocalhost:8545
- Tornado.cash: the methods, tools, and concepts come from a simplified version of the original tornado cash protocol. Much of the circuit is lifted directly.
- circom for compiling zkSnarks.
- snarkjs for various utilities.
- circomlibjs for JavaScript equivalents of cryptographic functions.
- Polygon Hermez's PowersOfTau ptau file in ./zkdrops-contracts/build/pot16_final.ptaufor trusted setup.
These smart contracts are being provided as is. No guarantee, representation or warranty is being made, express or implied, as to the safety or correctness of the user interface or the smart contracts. They have not been audited and as such there can be no assurance they will work as intended, and users may experience delays, failures, errors, omissions or loss of transmitted information. In addition, any airdrop using these smart contracts should be conducted in accordance with applicable law. Nothing in this repo should be construed as investment advice or legal advice for any particular facts or circumstances and is not meant to replace competent counsel. It is strongly advised for you to contact a reputable attorney in your jurisdiction for any questions or concerns with respect thereto. a16z is not liable for any use of the foregoing, and users should proceed with caution and use at their own risk. See a16z.com/disclosure for more info.