Skip to content

Commit

Permalink
feat(circuits): remove circomlib fork in favour of latest and zk-kit
Browse files Browse the repository at this point in the history
Remove circomlib fork for poseidon decryption circuit, and use zk-kit instead. Also update circomlib
to the latest version and use circomkit for circuits management and testing

fix #772
  • Loading branch information
ctrlc03 committed Jan 12, 2024
1 parent dcca295 commit 8f9e0fa
Show file tree
Hide file tree
Showing 80 changed files with 950 additions and 703 deletions.
18 changes: 14 additions & 4 deletions .github/workflows/nightly.yml
Original file line number Diff line number Diff line change
Expand Up @@ -62,13 +62,23 @@ jobs:
wget -qO /home/runner/work/maci/.local/bin/circom https://github.com/iden3/circom/releases/download/v2.1.6/circom-linux-amd64
chmod +x /home/runner/work/maci/.local/bin/circom
- name: Generate zkeys
- name: Create zkeys folder
run: |
cd cli
mkdir -p zkeys
wget -qO zkeys/powersOfTau28_hez_final_20.ptau https://maci-devops-zkeys.s3.ap-northeast-2.amazonaws.com/powersOfTau28_hez_final_20.ptau
pnpm exec zkey-manager compile -c ./zkeys.config.yml
pnpm exec zkey-manager genZkeys -c ./zkeys.config.yml
- name: Compile circuits
run: |
cd circuits
pnpm run build-test-circuits-c
mv ../build/test/* ../cli/zkeys
- name: Generate zkeys
run: |
cd cli
wget -qO zkeys/powersOfTau28_hez_final_20.ptau https://storage.googleapis.com/zkevm/ptau/powersOfTau28_hez_final_20.ptau
pnpm snarkjs groth16 setup zkeys/processMessages_test.r1cs zkeys/powersOfTau28_hez_final_20.ptau zkeys/ProcessMessages_10-2-1-2_test.0.zkey
pnpm snarkjs groth16 setup zkeys/tallyVotes_test.r1cs zkeys/powersOfTau28_hez_final_20.ptau zkeys/TallyVotes_10-1-2_test.0.zkey
- name: ${{ matrix.command }}
run: pnpm run ${{ matrix.command }}
Expand Down
21 changes: 17 additions & 4 deletions .github/workflows/reusable-e2e.yml
Original file line number Diff line number Diff line change
Expand Up @@ -79,14 +79,27 @@ jobs:
wget -qO /home/runner/work/maci/.local/bin/circom https://github.com/iden3/circom/releases/download/v2.1.6/circom-linux-amd64
chmod +x /home/runner/work/maci/.local/bin/circom
- name: Generate zkeys
- name: Create zkeys folder
if: ${{ env.CHANGED == 'true' }}
run: |
cd cli
mkdir -p zkeys
wget -qO zkeys/powersOfTau28_hez_final_20.ptau https://maci-devops-zkeys.s3.ap-northeast-2.amazonaws.com/powersOfTau28_hez_final_20.ptau
pnpm exec zkey-manager compile -c ./zkeys.config.yml
pnpm exec zkey-manager genZkeys -c ./zkeys.config.yml
- name: Compile circuits
if: ${{ env.CHANGED == 'true' }}
run: |
cd circuits
pnpm run build-test-circuits-c
mv ../build/test/* ../cli/zkeys
- name: Generate zkeys
if: ${{ env.CHANGED == 'true' }}
run: |
cd cli
wget -qO zkeys/powersOfTau28_hez_final_20.ptau https://storage.googleapis.com/zkevm/ptau/powersOfTau28_hez_final_20.ptau
pnpm snarkjs groth16 setup zkeys/processMessages_test.r1cs zkeys/powersOfTau28_hez_final_20.ptau zkeys/ProcessMessages_10-2-1-2_test.0.zkey
pnpm snarkjs groth16 setup zkeys/tallyVotes_test.r1cs zkeys/powersOfTau28_hez_final_20.ptau zkeys/TallyVotes_10-1-2_test.0.zkey
pnpm snarkjs groth16 setup zkeys/subsidyPerBatch_test.r1cs zkeys/powersOfTau28_hez_final_20.ptau zkeys/SubsidyPerBatch_10-1-2_test.0.zkey
- name: Download zkeys
if: ${{ env.CHANGED == 'false' }}
Expand Down
12 changes: 12 additions & 0 deletions circuits/circom/circuits.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"processMessages": {
"file": "processMessages",
"template": "ProcessMessages",
"params": [6, 8, 2, 3]
},
"tallyVotes": {
"file": "tallyVotes",
"template": "TallyVotes",
"params": [6, 2, 3]
}
}
5 changes: 3 additions & 2 deletions circuits/circom/ecdh.circom
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
pragma circom 2.0.0;
include "../node_modules/circomlib/circuits/bitify.circom";
include "../node_modules/circomlib/circuits/escalarmulany.circom";

include "./bitify.circom";
include "./escalarmulany.circom";

template Ecdh() {
// Note: the private key needs to be hashed and pruned first
Expand Down
1 change: 1 addition & 0 deletions circuits/circom/float.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "../node_modules/circomlib/circuits/bitify.circom";
include "../node_modules/circomlib/circuits/comparators.circom";
include "../node_modules/circomlib/circuits/mux1.circom";
Expand Down
1 change: 1 addition & 0 deletions circuits/circom/hasherPoseidon.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "./poseidon/poseidonHashT3.circom";
include "./poseidon/poseidonHashT4.circom";
include "./poseidon/poseidonHashT5.circom";
Expand Down
1 change: 1 addition & 0 deletions circuits/circom/hasherSha256.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "../node_modules/circomlib/circuits/sha256/sha256.circom";
include "../node_modules/circomlib/circuits/bitify.circom";

Expand Down
1 change: 1 addition & 0 deletions circuits/circom/messageHasher.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "./hasherPoseidon.circom";

// hash a MACI message together with the public key
Expand Down
4 changes: 3 additions & 1 deletion circuits/circom/messageToCommand.circom
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
pragma circom 2.0.0;

include "./ecdh.circom";
include "./unpackElement.circom";

include "../node_modules/circomlib/circuits/bitify.circom";
include "../node_modules/circomlib/circuits/poseidon.circom";
include "../node_modules/@zk-kit/circuits/circom/poseidon-cipher.circom";

// template that converts a MACI message
// to a command (decrypts it)
Expand Down
1 change: 1 addition & 0 deletions circuits/circom/messageValidator.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "./verifySignature.circom";
include "./utils.circom";

Expand Down
16 changes: 16 additions & 0 deletions circuits/circom/poseidon/poseidon.circom
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
pragma circom 2.0.0;

// https://github.com/weijiekoh/circomlib/blob/feat/poseidon-encryption/circuits/poseidon.circom
include "./poseidon-cipher.circom";

template Poseidon_OLD(nInputs) {
signal input inputs[nInputs];
signal output out;

component strategy = PoseidonPerm(nInputs + 1);
strategy.inputs[0] <== 0;
for (var i = 0; i < nInputs; i ++) {
strategy.inputs[i + 1] <== inputs[i];
}
out <== strategy.out[0];
}
5 changes: 3 additions & 2 deletions circuits/circom/poseidon/poseidonHashT3.circom
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
pragma circom 2.0.0;
include "../../node_modules/circomlib/circuits/poseidon.circom";

include "./poseidon.circom";

template PoseidonHashT3() {
var nInputs = 2;
signal input inputs[nInputs];
signal output out;

component hasher = Poseidon(nInputs);
component hasher = Poseidon_OLD(nInputs);
for (var i = 0; i < nInputs; i ++) {
hasher.inputs[i] <== inputs[i];
}
Expand Down
5 changes: 3 additions & 2 deletions circuits/circom/poseidon/poseidonHashT4.circom
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
pragma circom 2.0.0;
include "../../node_modules/circomlib/circuits/poseidon.circom";

include "./poseidon.circom";

template PoseidonHashT4() {
var nInputs = 3;
signal input inputs[nInputs];
signal output out;

component hasher = Poseidon(nInputs);
component hasher = Poseidon_OLD(nInputs);
for (var i = 0; i < nInputs; i ++) {
hasher.inputs[i] <== inputs[i];
}
Expand Down
5 changes: 3 additions & 2 deletions circuits/circom/poseidon/poseidonHashT5.circom
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
pragma circom 2.0.0;
include "../../node_modules/circomlib/circuits/poseidon.circom";

include "./poseidon.circom";

template PoseidonHashT5() {
var nInputs = 4;
signal input inputs[nInputs];
signal output out;

component hasher = Poseidon(nInputs);
component hasher = Poseidon_OLD(nInputs);
for (var i = 0; i < nInputs; i ++) {
hasher.inputs[i] <== inputs[i];
}
Expand Down
5 changes: 3 additions & 2 deletions circuits/circom/poseidon/poseidonHashT6.circom
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
pragma circom 2.0.0;
include "../../node_modules/circomlib/circuits/poseidon.circom";

include "./poseidon.circom";

template PoseidonHashT6() {
var nInputs = 5;
signal input inputs[nInputs];
signal output out;

component hasher = Poseidon(nInputs);
component hasher = Poseidon_OLD(nInputs);
for (var i = 0; i < nInputs; i ++) {
hasher.inputs[i] <== inputs[i];
}
Expand Down
1 change: 1 addition & 0 deletions circuits/circom/privToPubKey.circom
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
pragma circom 2.0.0;

include "../node_modules/circomlib/circuits/bitify.circom";
include "../node_modules/circomlib/circuits/escalarmulfix.circom";

Expand Down
4 changes: 3 additions & 1 deletion circuits/circom/processMessages.circom
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
pragma circom 2.0.0;

include "./hasherSha256.circom";
include "./messageHasher.circom";
include "./messageToCommand.circom";
include "./privToPubKey.circom";
include "./stateLeafAndBallotTransformer.circom";
include "./trees/incrementalQuinTree.circom";
include "../node_modules/circomlib/circuits/mux1.circom";
include "./utils.circom";

include "../node_modules/circomlib/circuits/mux1.circom";

// Proves the correctness of processing a batch of messages.
template ProcessMessages(
stateTreeDepth,
Expand Down
2 changes: 2 additions & 0 deletions circuits/circom/stateLeafAndBallotTransformer.circom
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
pragma circom 2.0.0;

include "./messageValidator.circom";

include "../node_modules/circomlib/circuits/mux1.circom";

// Apply a command to a state leaf and ballot.
Expand Down
5 changes: 3 additions & 2 deletions circuits/circom/subsidy.circom
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
pragma circom 2.0.0;
include "../node_modules/circomlib/circuits/comparators.circom";

include "./trees/incrementalQuinTree.circom";
include "./trees/calculateTotal.circom";
include "./trees/checkRoot.circom";
include "./hasherSha256.circom";
include "./hasherPoseidon.circom";
include "./unpackElement.circom";

include "./float.circom";

include "../node_modules/circomlib/circuits/comparators.circom";

/*
* calculate subsidy, batch by batch.
*/
Expand Down
4 changes: 3 additions & 1 deletion circuits/circom/tallyVotes.circom
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
pragma circom 2.0.0;
include "../node_modules/circomlib/circuits/comparators.circom";

include "./trees/incrementalQuinTree.circom";
include "./trees/calculateTotal.circom";
include "./trees/checkRoot.circom";
include "./hasherSha256.circom";
include "./hasherPoseidon.circom";
include "./unpackElement.circom";

include "../node_modules/circomlib/circuits/comparators.circom";

// Tally votes in the ballots, batch by batch.
template TallyVotes(
stateTreeDepth,
Expand Down
4 changes: 0 additions & 4 deletions circuits/circom/test/calculateTotal_test.circom

This file was deleted.

10 changes: 0 additions & 10 deletions circuits/circom/test/ceremonyParams/processMessages_test.circom

This file was deleted.

7 changes: 0 additions & 7 deletions circuits/circom/test/ceremonyParams/tallyVotes_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/ecdh_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/hasher13_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/hasher3_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/hasher4_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/hasher5_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/hashleftright_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/merkleTreeCheckRoot_test.circom

This file was deleted.

5 changes: 0 additions & 5 deletions circuits/circom/test/merkleTreeInclusionProof_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/merkleTreeLeafExists_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/messageHasher_test.circom

This file was deleted.

5 changes: 0 additions & 5 deletions circuits/circom/test/messageToCommand_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/messageValidator_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/privToPubKey_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/processMessagesInputHasher_test.circom

This file was deleted.

2 changes: 2 additions & 0 deletions circuits/circom/test/processMessages_test.circom
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
pragma circom 2.0.0;

include "../processMessages.circom";

/*
stateTreeDepth,
msgTreeDepth,
Expand Down
4 changes: 0 additions & 4 deletions circuits/circom/test/quinBatchLeavesExists_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/quinGeneratePathIndices_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/quinSelector_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/quinTreeCheckRoot_test.circom

This file was deleted.

4 changes: 0 additions & 4 deletions circuits/circom/test/quinTreeInclusionProof_test.circom

This file was deleted.

Loading

0 comments on commit 8f9e0fa

Please sign in to comment.