-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Build a Confidential Single-Price Auction for Tokens with Sealed Bids using Zama's fhEVM #136
Comments
Hello, I am considering selling the good (e.g., ERC20) using encrypted ERC20 (ConfidentialERC20). My motivation is that ConfidentialERC20 would allow to hide the amounts of locked deposits from bidders, as well as the final payment amounts at the end of the auction. Would this approach be acceptable/preferable? Or is it mandatory to sell "using either Ether or an ERC20 token"? I understand the practical aspects of the latter option, but I wanted to confirm. Thank you. |
Hi @zaccherinij, There's a minor mistake in the example scenario. The settlement price will be 0.000002 ether, as Bob's bid price is the one at which the last token is bought. Therefore, Alice collects 0.000002 * 1,000,000 = 2 ethers which is now correct. |
Hello, you can use https://github.com/zama-ai/fhevm-contracts/blob/main/contracts/token/ERC20/ConfidentialERC20Wrapped.sol |
is it correct that the original offer and the outcome of the auction can be public? |
Overview
Create a Single Price auction for a quantity of tokens with sealed bids using Solidity and the FHEVM. The single price should be the lowest price from the bid required to purchase the last token sold.
Description
An auction owner can create/launch a Single-Price Auction for a quantity of assets (e.g. ERC20) to be sold using either ether or an ERC20 token.
Each participant, who wants to buy assets, can place an encrypted bid (the number of tokens to purchase and the price that each participant is willing to pay). The settlement price is the price at which the last token is bought. This price is paid by everyone regardless on the initial bids.
If the auction does not sell fully (e.g. no participant, not enough participant), it is up to the developer to decide what should be the best resolution mechanism (e.g. refund mechanism, execution at the lowest price).
Other corner/edge cases may include:
Tip
Design choices should be clearly documented. All corner/edge cases must be handled by the developer.
Example
Initialization: Alice creates an auction to sell 1,000,000 tokens in ether.
Bidding: Bob bids 0.000002 ether per token for 500,000 tokens, Carol bids 0.000008 ether per token for 600,000 tokens, David bids 0.00000000001 per token for 1,000,000 tokens.
Resolution: Carol gets 600,000 tokens, Bob gets 400,000 tokens (
min((1,000,000 - 600,000), 500,000) = 400,000
), David gets 0 token. The settlement price is 0.000002 ether. Alice collects 0.000002 * 1,000,000 = 2 ethers.Judging criteria
Reward
🥇Best submission: up to $5,000
To be considered best submission, a solution must be efficient, effective and demonstrate a deep understanding of the core problem. Alongside the technical correctness, it should also be submitted with a clean code, clear explanations and a complete documentation.
🥈Second-best submission: up to $3,000
For a solution to be considered the second best submission, it should be both efficient and effective. The code should be neat and readable, while its documentation might not be as exhaustive as the best submission, it should cover the key aspects of the solution.
🥉Third-best submission: up to $2,000
The third best submission is one that presents a solution that effectively tackles the challenge at hand, even if it may have certain areas of improvement in terms of efficiency or depth of understanding. Documentation should be present, covering the essential components of the solution.
👉 Register
Step 1: Registration
Click here to register for the fhEVM Bounty. Fill out the registration form with your information. Once you fill out the form, you will receive a confirmation email with a link to the submission portal for when you are ready to submit your code.
Note
Check your spam folder in case you don't receive the confirmation email. If you haven't received it within 24 hour, please contact us by email at [email protected].
Step 2: Work on the Challenge
Read through the Bounty details and requirements carefully. Use the provided resources and create your own GitHub repository to store your code.
If you have any questions during your work, feel free to comment directly in the Bounty issue and our team will be happy to assist you.
Step 3: Submission
Once you have completed your work, upload your completed work to the submission portal using the link provided in the confirmation email.
Note
The deadline for submission is February, 9th 2025 (23:59, Anywhere On Earth). Late submissions will not be considered.
We wish you the best of luck with the challenge!
✅ Support
The text was updated successfully, but these errors were encountered: