From 16015fd000b2237f7ae50a96d095f4e90ebfac12 Mon Sep 17 00:00:00 2001 From: ctrlc03 <93448202+ctrlc03@users.noreply.github.com> Date: Mon, 2 Sep 2024 14:09:44 +0100 Subject: [PATCH] docs: update trusted setup docs and fix links --- .github/scripts/downloadZkeys.ts | 2 +- apps/website/blog/2024-02-28-maci-v1.2.0.md | 2 +- apps/website/blog/2024-05-08-ethdam.md | 2 +- .../blog/2024-06-17-understanding-maci.md | 4 ++-- apps/website/blog/2024-07-23-q2-review.md | 2 +- apps/website/blog/2024-07-30-roadmap-q3.md | 2 +- apps/website/blog/2024-08-10-maci-v2.md | 4 ++-- .../zk-snark-circuits/setup.md | 2 +- .../version-v2.x/security/trusted-setup.md | 18 ++++++++++++------ 9 files changed, 22 insertions(+), 16 deletions(-) diff --git a/.github/scripts/downloadZkeys.ts b/.github/scripts/downloadZkeys.ts index e60be45ac3..fe19ff2bd8 100644 --- a/.github/scripts/downloadZkeys.ts +++ b/.github/scripts/downloadZkeys.ts @@ -7,7 +7,7 @@ import path from "path"; const ZKEY_PATH = path.resolve(process.argv.slice(3)[0]); const ZKEYS_URLS = { test: "https://maci-develop-fra.s3.eu-central-1.amazonaws.com/v2.0.0/maci_artifacts_10-2-1-2_test.tar.gz", - prod: "https://maci-develop-fra.s3.eu-central-1.amazonaws.com/v1.2.0/maci_artifacts_6-9-2-3_prod.tar.gz", + prod: "https://maci-develop-fra.s3.eu-central-1.amazonaws.com/v2.0.0/maci_artifacts_14-9-2-3_prod.tar.gz", }; const ARCHIVE_NAME = path.resolve(ZKEY_PATH, "maci_keys.tar.gz"); diff --git a/apps/website/blog/2024-02-28-maci-v1.2.0.md b/apps/website/blog/2024-02-28-maci-v1.2.0.md index 879c445a1b..3ae70cfb3f 100644 --- a/apps/website/blog/2024-02-28-maci-v1.2.0.md +++ b/apps/website/blog/2024-02-28-maci-v1.2.0.md @@ -72,7 +72,7 @@ As part of configuring a MACI deployment, the coordinator sets a user signup gat With the addition of this new gatekeeper, EAS (and soon™ [Hats Protocol](https://www.hatsprotocol.xyz/), MACI instances could be configured to e.g. only allow Ethereum accounts with a trusted EAS attestation or those designated with a specific role by the Hats Protocol. These modules open up new avenues for access control strategies. -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. The Hats Protocol gatekeeper is [currently in progress](https://github.com/privacy-scaling-explorations/maci/pull/1191) and will be released soon™ (in v1.2.1). +We expect to continue to expand our [gatekeeper capabilities](https://github.com/privacy-scaling-explorations/maci/tree/dev/packages/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. The Hats Protocol gatekeeper is [currently in progress](https://github.com/privacy-scaling-explorations/maci/pull/1191) and will be released soon™ (in v1.2.1). ### Documentation Website diff --git a/apps/website/blog/2024-05-08-ethdam.md b/apps/website/blog/2024-05-08-ethdam.md index 615704c905..0d0b40bea5 100644 --- a/apps/website/blog/2024-05-08-ethdam.md +++ b/apps/website/blog/2024-05-08-ethdam.md @@ -61,7 +61,7 @@ ECDH(coordinatorPrivateKey, randomKeyPair.publicKey) The `randomKeyPair.publicKey` that was sent as `{x: 1, y: 1}` was eventually passed by the coordinator to a zk-SNARK circuit to try and decrypt the corresponding message and perform further processing. -When passed to the circuit, the code would perform the ECDH operation by performing a scalar multiplication between the public and the coordinator private key. This happens inside the [`MessageToCommand`](https://github.com/privacy-scaling-explorations/maci/blob/dev/circuits/circom/utils/messageToCommand.circom#L45) template, which calls the [`ECDH` template](https://github.com/privacy-scaling-explorations/zk-kit/blob/main/packages/circuits/circom/ecdh.circom). Here, there is a call to [`escalarMulAny`](https://github.com/privacy-scaling-explorations/zk-kit/blob/main/packages/circuits/circom/ecdh.circom#L26) which in turns calls [`SegmentMulAny`](https://github.com/iden3/circomlib/blob/master/circuits/escalarmulany.circom#L154), where we encounter the final call to [`Edwards2Montgomery`](https://github.com/iden3/circomlib/blob/master/circuits/escalarmulany.circom#L78) where the error pops up. +When passed to the circuit, the code would perform the ECDH operation by performing a scalar multiplication between the public and the coordinator private key. This happens inside the [`MessageToCommand`](https://github.com/privacy-scaling-explorations/maci/blob/dev/packages/circuits/circom/utils/messageToCommand.circom#L45) template, which calls the [`ECDH` template](https://github.com/privacy-scaling-explorations/zk-kit/blob/main/packages/circuits/circom/ecdh.circom). Here, there is a call to [`escalarMulAny`](https://github.com/privacy-scaling-explorations/zk-kit/blob/main/packages/circuits/circom/ecdh.circom#L26) which in turns calls [`SegmentMulAny`](https://github.com/iden3/circomlib/blob/master/circuits/escalarmulany.circom#L154), where we encounter the final call to [`Edwards2Montgomery`](https://github.com/iden3/circomlib/blob/master/circuits/escalarmulany.circom#L78) where the error pops up. Looking inside the [`Edwards2Montgomery`](https://github.com/iden3/circomlib/blob/master/circuits/montgomery.circom#L21-L40) template, we can see the operation that is performed on the public key. In short, the point is [converted](https://en.wikipedia.org/wiki/Montgomery_curve#Equivalence_with_twisted_Edwards_curves) from the Twisted Edwards form to Montgomery form, as it allows for cheaper operations inside the circuit (whereas outside it is represented in its original Twisted Edward form). diff --git a/apps/website/blog/2024-06-17-understanding-maci.md b/apps/website/blog/2024-06-17-understanding-maci.md index fd7b8c99b7..146d245cee 100644 --- a/apps/website/blog/2024-06-17-understanding-maci.md +++ b/apps/website/blog/2024-06-17-understanding-maci.md @@ -48,7 +48,7 @@ If you’re interested in more of the technical details, check out the MACI docu ## Real-World Applications and Limitations -Imagine a world where funding for public goods, like community projects or open-source software, is decided through fair and transparent voting. This is where MACI shows its true potential. [Quadratic funding](https://qf.pse.dev/quadratic-funding) is already harnessing MACI's capabilities to enhance user privacy and discourage any form of collusion in funding decisions. +Imagine a world where funding for public goods, like community projects or open-source software, is decided through fair and transparent voting. This is where MACI shows its true potential. [Quadratic funding](/docs/use-cases/public-goods-funding/quadratic-funding) is already harnessing MACI's capabilities to enhance user privacy and discourage any form of collusion in funding decisions. However, like any system, MACI isn't perfect. Its effectiveness hinges on the honesty of the coordinator – the entity or person overseeing the voting process and tallying the results. A dishonest coordinator could pose risks, but thankfully, MACI is designed to minimise even this possibility, maintaining a high level of integrity in the voting process. @@ -58,6 +58,6 @@ As we've explored, Minimal Anti-Collusion Infrastructure (MACI) stands as a test Blockchain technology is continually evolving, and with tools like MACI, it's becoming more accessible and trustworthy. Whether you're a blockchain enthusiast, a developer, or someone just starting to explore this exciting field, MACI represents a significant step forward in creating a more democratic and transparent digital world. -We encourage you to delve deeper into MACI and the broader world of blockchain by reading through our [documentation](https://maci.pse.dev/docs/introduction) and installing MACI. Join us too on our [Discord](https://discord.com/invite/sF5CT5rzrR) to report any bugs or to chat with our team. Your involvement can help shape a future where digital voting is not just secure, but also truly representative of the people's voice. +We encourage you to delve deeper into MACI and the broader world of blockchain by reading through our [documentation](/docs/introduction) and installing MACI. Join us too on our [Discord](https://discord.com/invite/sF5CT5rzrR) to report any bugs or to chat with our team. Your involvement can help shape a future where digital voting is not just secure, but also truly representative of the people's voice. Together, let's embrace these advancements and contribute to a fairer, more transparent digital voting landscape. diff --git a/apps/website/blog/2024-07-23-q2-review.md b/apps/website/blog/2024-07-23-q2-review.md index 607ab8a9d6..aea6b0423f 100644 --- a/apps/website/blog/2024-07-23-q2-review.md +++ b/apps/website/blog/2024-07-23-q2-review.md @@ -35,7 +35,7 @@ On the outreach and support side, we also engaged with several communities to ru The use of a Coordinator Service would greatly simplify the operation requirements when running MACI. To better support communities running MACI polls, whether as a QF round or a simple voting application, the team has prioritised the development of a Coordinator Service that can be used by any Round Operator. -In the last three months we successfully completed the first iteration of a [proof generation service](https://github.com/privacy-scaling-explorations/maci/tree/dev/coordinator), which can be used to more easily finalise MACI polls. Additionally, work on a frontend dashboard has started. This dashboard can be used to more easily deploy contracts in a customisable way via an intuitive user interface. +In the last three months we successfully completed the first iteration of a [proof generation service](https://github.com/privacy-scaling-explorations/maci-platform/tree/main/packages/coordinator), which can be used to more easily finalise MACI polls. Additionally, work on a frontend dashboard has started. This dashboard can be used to more easily deploy contracts in a customisable way via an intuitive user interface. ### ✅ MACI Core Protocol Improvements diff --git a/apps/website/blog/2024-07-30-roadmap-q3.md b/apps/website/blog/2024-07-30-roadmap-q3.md index 29cceebc18..5c3a953594 100644 --- a/apps/website/blog/2024-07-30-roadmap-q3.md +++ b/apps/website/blog/2024-07-30-roadmap-q3.md @@ -30,7 +30,7 @@ The team is doubling down efforts to build a comprehensive voting platform with - Move application's data storage from Vercel to IPFS - Support contributing/voting to multiple rounds on the same deployment -Our efforts will include supporting community organisers who want to fork and operate MACI Platform rounds in production. If you're interested in running a round for your community, [please get in touch](https://maci.pse.dev/docs/use-cases/public-goods-funding/quadratic-funding/apply)! +Our efforts will include supporting community organisers who want to fork and operate MACI Platform rounds in production. If you're interested in running a round for your community, [please get in touch](/docs/use-cases/public-goods-funding/quadratic-funding/apply)! ## Coordinator Service diff --git a/apps/website/blog/2024-08-10-maci-v2.md b/apps/website/blog/2024-08-10-maci-v2.md index b16cb1a372..185be16478 100644 --- a/apps/website/blog/2024-08-10-maci-v2.md +++ b/apps/website/blog/2024-08-10-maci-v2.md @@ -29,7 +29,7 @@ We have removed some features that were never used in production, namely [Topup] 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. +On top of that, the [merkle tree-like structure](/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 @@ -52,7 +52,7 @@ Custom Gatekeepers are a great way to guard MACI against Sybil attacks, and with 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. +We expect to continue to expand our [gatekeeper capabilities](https://github.com/privacy-scaling-explorations/maci/tree/dev/packages/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 diff --git a/apps/website/versioned_docs/version-v2.x/developers-references/zk-snark-circuits/setup.md b/apps/website/versioned_docs/version-v2.x/developers-references/zk-snark-circuits/setup.md index 8c6cdbb661..c14a5749ba 100644 --- a/apps/website/versioned_docs/version-v2.x/developers-references/zk-snark-circuits/setup.md +++ b/apps/website/versioned_docs/version-v2.x/developers-references/zk-snark-circuits/setup.md @@ -20,7 +20,7 @@ pnpm build-test-circuits-c -- --out-path $OUT_PATH pnpm build-test-circuits-wasm -- --out-path $OUT_PATH ``` -Please note that the circuits are configured with testing purpose parameters, which means it can only handle a limited amount of messages (up to 25 messages). For more information on the parameters and how to configure them, please refer to the individual circuit documentation within this page. Also, within the [configure-circomkit](https://maci.pse.dev/docs/installation#configure-circomkit) section of the `installation` page, you'll see how you can update the config file with new params. +Please note that the circuits are configured with testing purpose parameters, which means it can only handle a limited amount of messages (up to 25 messages). For more information on the parameters and how to configure them, please refer to the individual circuit documentation within this page. Also, within the [configure-circomkit](/docs/quick-start/installation#configure-circomkit) section of the `installation` page, you'll see how you can update the config file with new params. To compile a single circuit, you can run: diff --git a/apps/website/versioned_docs/version-v2.x/security/trusted-setup.md b/apps/website/versioned_docs/version-v2.x/security/trusted-setup.md index 5a2b5818a6..d63d977863 100644 --- a/apps/website/versioned_docs/version-v2.x/security/trusted-setup.md +++ b/apps/website/versioned_docs/version-v2.x/security/trusted-setup.md @@ -25,17 +25,22 @@ For more info on trusted setup ceremonies please refer to p0tion's [docs](https: ## Maci v2.0 Trusted Setup Ceremony (most recent) :::info -Maci v2.0 Trusted Setup Ceremony is ongoing and the circuits cannot be yet used in production. +Maci v2.0 Trusted Setup Ceremony is now completed and the circuits can be used in production. ::: -To participate in the ceremony please head over to [p0tion's website](https://ceremony.pse.dev/). - -This page will be updated once the ceremony is complete. - For this release, we plan to run two ceremonies, one with smaller size circuits (more accessible to contributors) due to smaller batch sizes for proving on chain, and one with larger circuits and large batch sizes for proving. Smaller size artifacts can be used for smaller rounds or for operators that want to run everything on a local computer vs using a beefy server. On the other hand, we plan to use the artifacts with larger batch sizes for large rounds and solely on a server. ### Small Batch Size Ceremony +:::info +To download the artifacts, please run the following command from within MACI monorepo's root directory: + +```bash +pnpm download-zkeys:ceremony +``` + +::: + Here are the **maximum** values supported by these artifacts: **_ProcessMessages_** @@ -79,9 +84,10 @@ Please be advised that you will not be able to use these artifacts with MACI v2. ::: :::info -You can download all of the artifacts using the following command from maci's monorepo root: +MACI v1.2 artifacts are stored on [Amazon S3](https://maci-develop-fra.s3.eu-central-1.amazonaws.com/v1.2.0/maci_artifacts_6-9-2-3_prod.tar.gz). Please either download directly, or checkout any of the maci v1.2 tags to access the artifacts using the following commands: ```bash +git checkout v1.2.5 download:ceremony-zkeys ```