-
Notifications
You must be signed in to change notification settings - Fork 153
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
101 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
--- | ||
slug: 2024-v2 | ||
title: MACI v2.0 Release | ||
description: What is new in MACI v2 | ||
authors: | ||
name: ctrlc03 | ||
title: MACI team lead | ||
url: https://x.com/ctrlc03 | ||
image_url: https://avatars.githubusercontent.com/u/93448202?v=4 | ||
tags: [voting, security, anonymity, roadmap, grants] | ||
--- | ||
|
||
# MACI v2.0 Release | ||
|
||
We are pleased to announce the release of MACI [v2.0.0](https://github.com/privacy-scaling-explorations/maci/releases/tag/v2.0.0)! | ||
|
||
This is our second big release of the year, after the [MACI v1.2](/blog/maci-v1-2.0) release in February of this year. MACI v2.0 brings a more secure and efficient protocol, with improved developer experience, and clearer documentation for users looking to learn about and use MACI. | ||
|
||
## Background | ||
|
||
MACI - Minimal Anti-Collusion Infrastructure - is an application that provides privacy and collusion resistance for on-chain voting. If you're new to MACI, we first recommend reading our [documentation](/docs/introduction) for background information and technical details. | ||
|
||
## New Features and improvements | ||
|
||
### More compact codebase | ||
|
||
We have removed some features that were never used in production, namely [Topup](https://github.com/privacy-scaling-explorations/maci/issues/1384) and [Subsidy](https://github.com/privacy-scaling-explorations/maci/issues/1348). This allowed us to reduce the codebase size, making it cheaper to deploy, as well as reducing the complexity of the zk-SNARK circuits. | ||
|
||
We highly thank [Chao](https://github.com/chaosma) for his work on these two features over the past years, and look forward to integrating similar features in the future as we come up with new use cases and performance improvements. | ||
|
||
On top of that, the [merkle tree-like structure](https://maci.pse.dev/docs/developers-references/smart-contracts/AccQueue) holding the signups has been swapped out for a more efficient incremental merkle tree ([LazyIMT](https://github.com/privacy-scaling-explorations/zk-kit.solidity/tree/main/packages/lazy-imt)). This offers some savings for users signing up, as well as simplifies the steps required to finalise a poll, by merging all leaves together and removing the need to compute the subroots and root of the tree. | ||
|
||
### Improved contract tasks | ||
|
||
It is now possible to deploy contracts and finalise polls using the contracts tasks only. This makes the protocol much easier to use, as there is no need to use the maci-cli anymore, which often came with a large number of flags and options. You will just need to fill a [json file](https://maci.pse.dev/docs/quick-start/deployment#deployment-using-maci-contracts-hardhat-tasks) with the correct parameters and run [few simple commands](https://maci.pse.dev/docs/quick-start/deployment#deployment-using-maci-contracts-hardhat-tasks). | ||
|
||
### Concurrent Polls | ||
|
||
It is now finally possible to run multiple polls concurrently from a single MACI instance. Users will no longer need to signup again to vote on proposals published by a single organiser. One thing to note is that each poll will have the same amount of voting power, and new users will need to pass the same gating process as existing users. | ||
|
||
We believe this feature will work best when used for coordinating several polls for the participants of a single event where signup is gated by the conference ticket and there are multiple voting rounds, like at Devcon or Devconnect. | ||
|
||
### New Gatekeepers | ||
|
||
Custom Gatekeepers are a great way to guard MACI against Sybil attacks, and with this release we have integrated a number of new protocols, together with the help of our community: | ||
|
||
- [Hats Protocol](https://www.hatsprotocol.xyz/) | ||
- [Gitcoin Passport](https://passport.gitcoin.co/) | ||
- [Zupass](https://zupass.org/) | ||
- [Semaphore](https://semaphore.pse.dev/) | ||
|
||
For instance, with Gitcoin Passport as the gatekeeper, the MACI round organiser can set a threshold score and only allow new users with a passport score greater or equal to that threshold. Additionally, with Zupass, we can now gate access to holders of specific event tickets. | ||
|
||
We expect to continue to expand our [gatekeeper capabilities](https://github.com/privacy-scaling-explorations/maci/tree/dev/contracts/contracts/gatekeepers) and welcome the community to come up with new and innovative ways to grant access to MACI's rounds, helping make MACI more customizable and sybil-resilient. | ||
|
||
## Documentation | ||
|
||
You gave us the feedback that the MACI documentation was way too tough to digest, and we heard you! To make it easier to understand, we have grouped documentation entries under a more logic structure, with different sections for different audiences and objectives. | ||
|
||
We continue to use [our docs website](/) as the definitive resource for all information related to MACI, including [blog](/blog) releases, [documentation](/docs/introduction) updates, and [roadmap](/roadmap) progress. As always, we welcome suggestions on how to make it better and encourage you to report any inconsistencies you may find. | ||
|
||
## Security Audit | ||
|
||
As usual before a major release, the protocol has been thoroughly audited by PSE's internal Audit team, and this time no significant issues were found. However, thanks to the auditors' hard work, we have been able to further optimise the protocol and clean up our technical documentation. | ||
|
||
For more details on this recent audit, please refer to our [audit docs](/docs/security/audit#pse-audit-2024-07) or [view the full report](/audit_reports/20240223_PSE_Audit_audit_report.pdf). | ||
|
||
With more and more eyes on the protocol, we feel more and more confident about MACI's security posture. | ||
|
||
## Trusted Setup Ceremony | ||
|
||
We are preparing for a new ceremony to cover the changes in our v2.0.0 circuits. To accomplish this, we'll leverage the tooling of [p0tion](https://github.com/privacy-scaling-explorations/p0tion), which helps to streamline and automate Groth16 phase2 ceremonies. | ||
|
||
We'll update [this page](/docs/security/trusted-setup) after the ceremony completes to include the production-ready zkey artifacts. In the meantime, the artifacts for v.1.2 can be found on our [website](/docs/security/trusted-setup), and the artifacts can still be used in production for releases [1.2.0 up to 1.2.5](https://github.com/privacy-scaling-explorations/maci/tags). | ||
|
||
## Get Involved | ||
|
||
MACI is deeply committed to our community, through our open initiatives like [public roadmaps](https://maci.pse.dev/roadmap), transparent [repository management](https://github.com/privacy-scaling-explorations/maci/discussions/847), and a [public Discord channel](https://discord.com/invite/sF5CT5rzrR) for interaction with our team. | ||
|
||
With every issue, PR, feature and roadmap iteration, we welcome feedback to ensure that the continued development of MACI reflects your and the community's needs. Keep an eye on our [documentation](/), [GitHub discussions](https://github.com/privacy-scaling-explorations/maci/discussions) and our official [Twitter/X account](https://twitter.com/zkMACI) for updates. | ||
|
||
For those looking to contribute directly, report bugs, or offer feedback, our [GitHub repository](https://github.com/privacy-scaling-explorations/maci) is open for issues and discussions. We're eager to assist with your projects or contributions. | ||
|
||
For practical implementation insights, review our docs as well as the [clr.fund](https://github.com/clrfund/monorepo/), [Allo Stack with MACI](https://github.com/gitcoinco/MACI_QF), and [maci-rpgf](https://github.com/privacy-scaling-explorations/maci-rpgf) repositories as reference implementations. The first two integrations are quadratic funding implementations, a mechanism which otherwise is highly susceptible to collusion and bribery. | ||
|
||
For any other questions or feedback, please reach out to us via [PSE's Discord](https://discord.com/invite/sF5CT5rzrR), in our [`#🗳️-maci` channel](https://https//discord.com/channels/943612659163602974/1164613809730748507). We're excited to connect and collaborate with you! | ||
|
||
## References | ||
|
||
- [MACI GitHub repository](https://github.com/privacy-scaling-explorations/maci) | ||
- [MACI documentation](/docs/introduction) | ||
- [A technical introduction to MACI 1.0 - Kyle Charbonnet](/blog/maci-1-0-technical-introduction) | ||
- [Minimal anti-collusion infrastructure - Vitalik](https://ethresear.ch/t/minimal-anti-collusion-infrastructure/5413) | ||
- [PSE Discord server](https://discord.com/invite/sF5CT5rzrR) | ||
- [Allo Stack with MACI](https://github.com/gitcoinco/MACI_QF) | ||
- [maci-rpgf](https://github.com/privacy-scaling-explorations/maci-rpgf) | ||
- [clr.fund](https://github.com/clrfund/monorepo/) | ||
|
||
## Release | ||
|
||
Here's the link to the new release code in GitHub: [v2.0.0 Release](https://github.com/privacy-scaling-explorations/maci/releases/tag/v2.0.0). |