Skip to content
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

Merge features exclude content #490

Draft
wants to merge 100 commits into
base: develop
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 87 commits
Commits
Show all changes
100 commits
Select commit Hold shift + click to select a range
d3a863f
Add KYC explanations
samajammin Dec 14, 2021
4f64355
Update ProjectAdded copy
samajammin Dec 16, 2021
4d345a2
Update Twitter account for info
samajammin Dec 16, 2021
eb84090
Update recipient guide copy
samajammin Dec 16, 2021
6b99c62
Merge pull request #415 from ethereum/develop
daodesigner Dec 16, 2021
42c2a73
Add netlify config
samajammin Dec 16, 2021
7911074
Add null checks on registryInfo
samajammin Dec 16, 2021
3ef7fbe
Add required documents
samajammin Dec 22, 2021
b56ff09
Add specification of address within last 3 months
samajammin Jan 3, 2022
a98c1d3
Add staking-specific copy
samajammin Jan 8, 2022
151b78f
Add more staking mentions
samajammin Jan 8, 2022
bc96411
Add "Ethereum" copy
samajammin Jan 8, 2022
7b200ec
Add changes from Danny's feedback
samajammin Jan 8, 2022
ff5fdbd
Merge pull request #490 from ethereum/staking-copy
samajammin Jan 10, 2022
294769e
Merge pull request #480 from ethereum/kyc-info
samajammin Jan 10, 2022
43cda19
Merge pull request #425 from clrfund/develop
daodesigner Jan 10, 2022
1c40a47
Merge pull request #426 from ethereum/staking-round
daodesigner Jan 10, 2022
2c966b8
Merge branch 'develop' into staking-round
samajammin Jan 10, 2022
f2d3c59
Update L2 ETH references
samajammin Jan 10, 2022
3b9d247
Add notifications of recipient cap
samajammin Jan 10, 2022
9ca031a
Merge pull request #500 from ethereum/recipient-cap
samajammin Jan 10, 2022
60011a5
Clean up how it works copy
samajammin Jan 10, 2022
ffa25d9
Merge pull request #498 from ethereum/l2-eth
samajammin Jan 11, 2022
26bd028
Simplify round criteria
samajammin Jan 11, 2022
d014aa0
Merge pull request #501 from ethereum/staking-criteria-updates
samajammin Jan 11, 2022
9614af6
remove breadcrumbs from join form
corwintines Jan 11, 2022
a4a230d
Merge pull request #502 from ethereum/hide-breadcrumbs
samajammin Jan 11, 2022
25e96cd
Re-sort criteria
samajammin Jan 12, 2022
6e45ee3
make executeRequest only owner (#503)
pettinarip Jan 17, 2022
d0cb664
Refactor: maxRecipients getter (#505)
pettinarip Jan 19, 2022
c3690f4
Fix about pages (#504)
pettinarip Jan 24, 2022
31f09d9
fix transaction modal which now expects a promise of a tx (#507)
pettinarip Jan 24, 2022
1911485
Refactor: maxRecipients getter (#505) (#506)
pettinarip Jan 24, 2022
1ca9a8e
Merge branch 'develop' into staking-round
pettinarip Jan 24, 2022
25db19f
update netlify toml with new factory instance
pettinarip Jan 25, 2022
08adfa1
Update scripts to support prod circuits with 16 batch size (#508)
daodesigner Jan 27, 2022
8e74169
Merge branch 'develop' into staking-round
pettinarip Jan 28, 2022
b48c943
select working sheet by name
pettinarip Feb 11, 2022
9b2e10f
Merge pull request #510 from ethereum/google-sheet-by-title
samajammin Feb 11, 2022
23cd955
Merge branch 'develop' into staking-round
pettinarip Feb 11, 2022
abf3f57
Update branding to ES
auryn-macmillan Mar 1, 2022
a20931a
Fix some awkward sentences
auryn-macmillan Mar 1, 2022
b2dcd6f
Merge branch 'cohort/EthStaker' into staking-round
pettinarip Mar 1, 2022
63013c1
update scripts to use custom verifiers (#514)
daodesigner Mar 1, 2022
6377d99
Merge pull request #433 from ethereum/staking-round
daodesigner Mar 1, 2022
d91760b
Update meta image to absolute URL
samajammin Mar 3, 2022
98eac01
Add og & twitter metadata
samajammin Mar 3, 2022
56036c4
Merge pull request #470 from clrfund/meta-image-fix
auryn-macmillan Mar 3, 2022
76d688a
Add VUE_APP_FIRST_ROUND to ignore old rounds
samajammin Mar 8, 2022
1269881
sort getRounds query by starttime
pettinarip Mar 8, 2022
5133241
Remove /rounds route
samajammin Mar 8, 2022
f4fb0eb
Default VUE_APP_FIRST_ROUND to 0
samajammin Mar 9, 2022
b87fe73
Merge pull request #474 from ethereum/first-round-env-var
auryn-macmillan Mar 9, 2022
5296f33
Update criteria to match announcement copy
samajammin Mar 10, 2022
1504e76
Merge pull request #479 from clrfund/criteria-update
auryn-macmillan Mar 10, 2022
8054ad5
Add announcement link to round info
samajammin Apr 19, 2022
a25f8f3
Merge pull request #485 from clrfund/ethstaker-dates
auryn-macmillan Apr 19, 2022
d1412b5
fetch user registry address from the factory when there is no current…
pettinarip Apr 24, 2022
31dd277
Merge pull request #486 from ethereum/user-registry-factory
samajammin Apr 24, 2022
4b967ae
Add optional ENV variable to customize matching pool
samajammin May 5, 2022
37da086
Update frontend to query ENV variable
samajammin May 5, 2022
5bfe357
Remove matching pool overwrite query
samajammin May 8, 2022
ca223d2
Remove unused import
samajammin May 8, 2022
019d7e3
Fix broken link
samajammin May 8, 2022
ec10ab2
Merge pull request #487 from clrfund/custom-matching-pool
auryn-macmillan May 9, 2022
089bd7a
Merge pull request #489 from clrfund/fix-brightid-link
auryn-macmillan May 9, 2022
b011f35
fix condition to check if the round has started
pettinarip May 10, 2022
c380dfa
adjust markdown imgs and pre code to be able to shrink the screen
pettinarip May 10, 2022
f18d920
Merge pull request #491 from ethereum/fix-join-message
samajammin May 11, 2022
505ccc6
Merge pull request #492 from ethereum/fix-markdown-content
samajammin May 11, 2022
b68e9e9
check existing balance before formatting it
pettinarip May 14, 2022
f4ab844
Merge pull request #494 from ethereum/fix-bignumber-format
daodesigner May 14, 2022
e9d990a
change max cart size to 8
pettinarip May 14, 2022
7c498b2
Merge pull request #495 from ethereum/max-cart-size
auryn-macmillan May 14, 2022
c31778c
only render brightid link if available
yuetloo May 16, 2022
cd3c2d2
Merge pull request #496 from clrfund/fix/brightid-link-not-found
daodesigner May 16, 2022
6431bb8
fetch round contributions balance from the contract
pettinarip May 20, 2022
d44ba36
Merge pull request #497 from ethereum/fix-contributions-balances
auryn-macmillan May 20, 2022
349b3b0
refactor and fix race conditions while loading round & user data
pettinarip May 23, 2022
0915a92
Merge pull request #499 from ethereum/refactor-loading-data
auryn-macmillan May 27, 2022
60e61cb
detect invalid date when challenge period is too large
yuetloo Jun 1, 2022
c981515
Merge pull request #505 from clrfund/fix/join-deadline
auryn-macmillan Jun 16, 2022
371a264
merged with the develop branch
yuetloo Jul 4, 2022
482cb07
remove obsolete code
yuetloo Jul 4, 2022
63c72a9
fix test failure by reverting ethStaker changes
yuetloo Jul 4, 2022
e10b68f
remove ethStaker content
yuetloo Jul 4, 2022
50bbfaa
remove unused file
yuetloo Jul 4, 2022
e81f81f
removed ethStaker specific deploymnet script
yuetloo Jul 6, 2022
96da1a3
revert changes to remove round list
yuetloo Jul 6, 2022
7970a7c
add PermissionedRecipientRegistry
yuetloo Jul 7, 2022
a2b1f3f
fix error from empty round address if round is loaded from VUE_APP_EX…
yuetloo Jul 7, 2022
a1a670a
Revert "fix error from empty round address if round is loaded from VU…
yuetloo Jul 7, 2022
6b514e1
Revert "add PermissionedRecipientRegistry"
yuetloo Jul 7, 2022
30485dd
Revert "revert changes to remove round list"
yuetloo Jul 7, 2022
a6f4348
Revert "removed ethStaker specific deploymnet script"
yuetloo Jul 7, 2022
39b0967
Revert "remove unused file"
yuetloo Jul 7, 2022
6399118
Revert "remove ethStaker content"
yuetloo Jul 7, 2022
d949482
Revert "fix test failure by reverting ethStaker changes"
yuetloo Jul 7, 2022
da41f0e
Revert "remove obsolete code"
yuetloo Jul 7, 2022
ee60330
Revert "merged with the develop branch"
yuetloo Jul 7, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view

Large diffs are not rendered by default.

Large diffs are not rendered by default.

240 changes: 240 additions & 0 deletions contracts/contracts/snarkVerifiers/QuadVoteTallyVerifier32Batch16.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,240 @@
// SPDX-License-Identifier: MIT

// Copyright 2017 Christian Reitwiessner
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
yuetloo marked this conversation as resolved.
Show resolved Hide resolved
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
// IN THE SOFTWARE.

// 2019 OKIMS

pragma solidity ^0.6.12;

library Pairing {

uint256 constant PRIME_Q = 21888242871839275222246405745257275088696311157297823662689037894645226208583;

struct G1Point {
uint256 X;
uint256 Y;
}

// Encoding of field elements is: X[0] * z + X[1]
struct G2Point {
uint256[2] X;
uint256[2] Y;
}

/*
* @return The negation of p, i.e. p.plus(p.negate()) should be zero.
*/
function negate(G1Point memory p) internal pure returns (G1Point memory) {

// The prime q in the base field F_q for G1
if (p.X == 0 && p.Y == 0) {
return G1Point(0, 0);
} else {
return G1Point(p.X, PRIME_Q - (p.Y % PRIME_Q));
}
}

/*
* @return The sum of two points of G1
*/
function plus(
G1Point memory p1,
G1Point memory p2
) internal view returns (G1Point memory r) {

uint256[4] memory input;
input[0] = p1.X;
input[1] = p1.Y;
input[2] = p2.X;
input[3] = p2.Y;
bool success;

// solium-disable-next-line security/no-inline-assembly
assembly {
success := staticcall(sub(gas(), 2000), 6, input, 0xc0, r, 0x60)
// Use "invalid" to make gas estimation work
switch success case 0 { invalid() }
}

require(success,"pairing-add-failed");
}

/*
* @return The product of a point on G1 and a scalar, i.e.
* p == p.scalar_mul(1) and p.plus(p) == p.scalar_mul(2) for all
* points p.
*/
function scalar_mul(G1Point memory p, uint256 s) internal view returns (G1Point memory r) {

uint256[3] memory input;
input[0] = p.X;
input[1] = p.Y;
input[2] = s;
bool success;
// solium-disable-next-line security/no-inline-assembly
assembly {
success := staticcall(sub(gas(), 2000), 7, input, 0x80, r, 0x60)
// Use "invalid" to make gas estimation work
switch success case 0 { invalid() }
}
require (success,"pairing-mul-failed");
}

/* @return The result of computing the pairing check
* e(p1[0], p2[0]) * .... * e(p1[n], p2[n]) == 1
* For example,
* pairing([P1(), P1().negate()], [P2(), P2()]) should return true.
*/
function pairing(
G1Point memory a1,
G2Point memory a2,
G1Point memory b1,
G2Point memory b2,
G1Point memory c1,
G2Point memory c2,
G1Point memory d1,
G2Point memory d2
) internal view returns (bool) {

G1Point[4] memory p1 = [a1, b1, c1, d1];
G2Point[4] memory p2 = [a2, b2, c2, d2];

uint256 inputSize = 24;
uint256[] memory input = new uint256[](inputSize);

for (uint256 i = 0; i < 4; i++) {
uint256 j = i * 6;
input[j + 0] = p1[i].X;
input[j + 1] = p1[i].Y;
input[j + 2] = p2[i].X[0];
input[j + 3] = p2[i].X[1];
input[j + 4] = p2[i].Y[0];
input[j + 5] = p2[i].Y[1];
}

uint256[1] memory out;
bool success;

// solium-disable-next-line security/no-inline-assembly
assembly {
success := staticcall(sub(gas(), 2000), 8, add(input, 0x20), mul(inputSize, 0x20), out, 0x20)
// Use "invalid" to make gas estimation work
switch success case 0 { invalid() }
}

require(success,"pairing-opcode-failed");

return out[0] != 0;
}
}

contract QuadVoteTallyVerifier32Batch16 {

using Pairing for *;

uint256 constant SNARK_SCALAR_FIELD = 21888242871839275222246405745257275088548364400416034343698204186575808495617;
uint256 constant PRIME_Q = 21888242871839275222246405745257275088696311157297823662689037894645226208583;

struct VerifyingKey {
Pairing.G1Point alpha1;
Pairing.G2Point beta2;
Pairing.G2Point gamma2;
Pairing.G2Point delta2;
Pairing.G1Point[11] IC;
}

struct Proof {
Pairing.G1Point A;
Pairing.G2Point B;
Pairing.G1Point C;
}

function verifyingKey() internal pure returns (VerifyingKey memory vk) {
vk.alpha1 = Pairing.G1Point(uint256(3931802286032916768722587566330261370902955393767942929056531203487688137529),uint256(10293105233586296031473050653492052327805448683376110761534611791713915549265));
vk.beta2 = Pairing.G2Point([uint256(21113959492300078886023582393043413128535975125428858805958839308822991748856),uint256(12222282698476210310273536080661281164688722800089362655366747391082242682958)], [uint256(20739573447354048976161197946493569928714465565589532971602923073536082697608),uint256(12941541312444627642958656716514029404685754754869818026526533196090365546374)]);
vk.gamma2 = Pairing.G2Point([uint256(14670836137271604202540255380769830849745744579684969689183516705496317922507),uint256(12178657156513808651243577987886528335149661869282225179912079606061386989744)], [uint256(1125902728883689137508324551765647737011904363437526425591650949891310723812),uint256(15919834918458423371681379777897287057084498811382451098590568497815773165692)]);
vk.delta2 = Pairing.G2Point([uint256(2231852960373618563799433391860999041123211180191070579878255252716013298732),uint256(14291274065364399133654336098495355501982202302398283580502954673818060696633)], [uint256(3168628806727684542778047539988455291220201924183716864807010176642260685841),uint256(12606002808572759608577415926932586006638023328815450374325080704700677189688)]);
vk.IC[0] = Pairing.G1Point(uint256(12848020380718535565089853534681145843006092696634142199856299025847321502371),uint256(6468756580219346512614969481554956146762400832923090074339557565951026058536));
vk.IC[1] = Pairing.G1Point(uint256(789092430114940371944840041796419370450123967868354406244601329700742570445),uint256(11703230415288173665088837798624967250284180660322246777462631600764972864812));
vk.IC[2] = Pairing.G1Point(uint256(16252197430844492890521435281772316410665185290137018091020232186750112907512),uint256(20861485175504002710376158881527553699531789728793309486150649246737774028347));
vk.IC[3] = Pairing.G1Point(uint256(16969171625806775801891191965047460974818115969312194891897374689668597542196),uint256(14389419046525510722177847778450425484834864589330386321604392542455541983572));
vk.IC[4] = Pairing.G1Point(uint256(13928883789499754049998767198742842124977905594692254232979837689918838899511),uint256(6757216204221511030872544186493375503384465407204524181513380457112801460878));
vk.IC[5] = Pairing.G1Point(uint256(12615105472464956174046705416720445236758313003314061110048664932376957788951),uint256(1115476865907623432334995719744390855110066393577587591466560011685797098103));
vk.IC[6] = Pairing.G1Point(uint256(12126180897004602060892141406139130628195608764592739755066384985876875328223),uint256(837414672224275155302376389224725114262382901229023048656048324984574980028));
vk.IC[7] = Pairing.G1Point(uint256(721442001352764820041409242091349606527760014067614573870735409795650532250),uint256(5871690341119940542207233131936464616602051666920986699510353544932455895913));
vk.IC[8] = Pairing.G1Point(uint256(11936590707137322489603100954274435093115715779097755089203405884503252799861),uint256(5832382048375298946996376174464817616061448358844675910441699738844607159400));
vk.IC[9] = Pairing.G1Point(uint256(1150487096467611973629613424410317323826245588905051816727229632029031650443),uint256(19621934380117246037511579161242972091034040331100068879508644849318614270487));
vk.IC[10] = Pairing.G1Point(uint256(14447725242028063610944438927433683612461991907837633029384208510392253681728),uint256(15642702797143402072429225245488363130997179355079100914641555016655302069615));

}

/*
* @returns Whether the proof is valid given the hardcoded verifying key
* above and the public inputs
*/
function verifyProof(
uint256[2] memory a,
uint256[2][2] memory b,
uint256[2] memory c,
uint256[] memory input
) public view returns (bool) {

Proof memory proof;
proof.A = Pairing.G1Point(a[0], a[1]);
proof.B = Pairing.G2Point([b[0][0], b[0][1]], [b[1][0], b[1][1]]);
proof.C = Pairing.G1Point(c[0], c[1]);

VerifyingKey memory vk = verifyingKey();

// Compute the linear combination vk_x
Pairing.G1Point memory vk_x = Pairing.G1Point(0, 0);

// Make sure that proof.A, B, and C are each less than the prime q
require(proof.A.X < PRIME_Q, "verifier-aX-gte-prime-q");
require(proof.A.Y < PRIME_Q, "verifier-aY-gte-prime-q");

require(proof.B.X[0] < PRIME_Q, "verifier-bX0-gte-prime-q");
require(proof.B.Y[0] < PRIME_Q, "verifier-bY0-gte-prime-q");

require(proof.B.X[1] < PRIME_Q, "verifier-bX1-gte-prime-q");
require(proof.B.Y[1] < PRIME_Q, "verifier-bY1-gte-prime-q");

require(proof.C.X < PRIME_Q, "verifier-cX-gte-prime-q");
require(proof.C.Y < PRIME_Q, "verifier-cY-gte-prime-q");

// Make sure that every input is less than the snark scalar field
//for (uint256 i = 0; i < input.length; i++) {
for (uint256 i = 0; i < 10; i++) {
require(input[i] < SNARK_SCALAR_FIELD,"verifier-gte-snark-scalar-field");
vk_x = Pairing.plus(vk_x, Pairing.scalar_mul(vk.IC[i + 1], input[i]));
}

vk_x = Pairing.plus(vk_x, vk.IC[0]);

return Pairing.pairing(
Pairing.negate(proof.A),
proof.B,
vk.alpha1,
vk.beta2,
vk_x,
vk.gamma2,
proof.C,
vk.delta2
);
}
}
Loading