Skip to content

Commit

Permalink
chore: use deployed block number (#27)
Browse files Browse the repository at this point in the history
* chore: add deployedBlockNumber to the constructor

* fix: use uint32 instead of uint256 for deployedBlockNumber
  • Loading branch information
rymnc authored Aug 21, 2023
1 parent d899a0c commit bd8403a
Show file tree
Hide file tree
Showing 3 changed files with 74 additions and 62 deletions.
4 changes: 4 additions & 0 deletions contracts/RlnBase.sol
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,9 @@ abstract contract RlnBase {
/// @notice The groth16 verifier contract
IVerifier public immutable verifier;

/// @notice the deployed block number
uint32 public immutable deployedBlockNumber;

/// Emitted when a new member is added to the set
/// @param idCommitment The idCommitment of the member
/// @param index The index of the member in the set
Expand All @@ -91,6 +94,7 @@ abstract contract RlnBase {
SET_SIZE = 1 << depth;
poseidonHasher = PoseidonHasher(_poseidonHasher);
verifier = IVerifier(_verifier);
deployedBlockNumber = uint32(block.number);
}

/// Allows a user to register as a member
Expand Down
131 changes: 69 additions & 62 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,8 @@ Hashes the input using the Poseidon hash function, n = 2, second input is the co

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| Name | Type | Description |
| ----- | ------- | ----------------- |
| input | uint256 | The input to hash |

## PoseidonHasher
Expand Down Expand Up @@ -834,11 +834,11 @@ Hashes the input using the Poseidon hash function, n = 2, second input is the co

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| Name | Type | Description |
| ----- | ------- | ----------------- |
| input | uint256 | The input to hash |

### _hash
### \_hash

```solidity
function _hash(uint256 input) internal pure returns (uint256 result)
Expand All @@ -852,15 +852,15 @@ function _hash(uint256 input) internal pure returns (uint256 result)
constructor(uint256 membershipDeposit, uint256 depth, address _poseidonHasher, address _verifier) public
```

### _validateRegistration
### \_validateRegistration

```solidity
function _validateRegistration(uint256 idCommitment) internal pure
```

_Inheriting contracts MUST override this function_

### _validateSlash
### \_validateSlash

```solidity
function _validateSlash(uint256 idCommitment, address payable receiver, uint256[8] proof) internal pure
Expand All @@ -884,8 +884,8 @@ Invalid deposit amount

### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| Name | Type | Description |
| -------- | ------- | --------------------------- |
| required | uint256 | The required deposit amount |
| provided | uint256 | The provided deposit amount |

Expand Down Expand Up @@ -1037,6 +1037,14 @@ contract IVerifier verifier

The groth16 verifier contract

### deployedBlockNumber

```solidity
uint32 deployedBlockNumber
```

the deployed block number

### MemberRegistered

```solidity
Expand All @@ -1047,10 +1055,10 @@ Emitted when a new member is added to the set

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| idCommitment | uint256 | The idCommitment of the member |
| index | uint256 | The index of the member in the set |
| Name | Type | Description |
| ------------ | ------- | ---------------------------------- |
| idCommitment | uint256 | The idCommitment of the member |
| index | uint256 | The index of the member in the set |

### MemberWithdrawn

Expand All @@ -1062,10 +1070,10 @@ Emitted when a member is removed from the set

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| idCommitment | uint256 | The idCommitment of the member |
| index | uint256 | The index of the member in the set |
| Name | Type | Description |
| ------------ | ------- | ---------------------------------- |
| idCommitment | uint256 | The idCommitment of the member |
| index | uint256 | The index of the member in the set |

### onlyValidIdCommitment

Expand All @@ -1089,11 +1097,11 @@ Allows a user to register as a member

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| Name | Type | Description |
| ------------ | ------- | ------------------------------ |
| idCommitment | uint256 | The idCommitment of the member |

### _register
### \_register

```solidity
function _register(uint256 idCommitment, uint256 stake) internal virtual
Expand All @@ -1103,12 +1111,12 @@ Registers a member

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| idCommitment | uint256 | The idCommitment of the member |
| stake | uint256 | The amount of eth staked by the member |
| Name | Type | Description |
| ------------ | ------- | -------------------------------------- |
| idCommitment | uint256 | The idCommitment of the member |
| stake | uint256 | The amount of eth staked by the member |

### _validateRegistration
### \_validateRegistration

```solidity
function _validateRegistration(uint256 idCommitment) internal view virtual
Expand All @@ -1126,13 +1134,13 @@ _Allows a user to slash a member_

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| idCommitment | uint256 | The idCommitment of the member |
| receiver | address payable | |
| proof | uint256[8] | |
| Name | Type | Description |
| ------------ | --------------- | ------------------------------ |
| idCommitment | uint256 | The idCommitment of the member |
| receiver | address payable | |
| proof | uint256[8] | |

### _slash
### \_slash

```solidity
function _slash(uint256 idCommitment, address payable receiver, uint256[8] proof) internal virtual
Expand All @@ -1143,13 +1151,13 @@ stake to the receiver's available withdrawal balance_

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| idCommitment | uint256 | The idCommitment of the member |
| receiver | address payable | The address to receive the funds |
| proof | uint256[8] | |
| Name | Type | Description |
| ------------ | --------------- | -------------------------------- |
| idCommitment | uint256 | The idCommitment of the member |
| receiver | address payable | The address to receive the funds |
| proof | uint256[8] | |

### _validateSlash
### \_validateSlash

```solidity
function _validateSlash(uint256 idCommitment, address payable receiver, uint256[8] proof) internal view virtual
Expand All @@ -1174,8 +1182,8 @@ NOTE: The variant of Poseidon we use accepts only 1 input, assume n=2, and the s

#### Parameters

| Name | Type | Description |
| ---- | ---- | ----------- |
| Name | Type | Description |
| ----- | ------- | ----------------- |
| input | uint256 | The value to hash |

### isValidCommitment
Expand All @@ -1184,7 +1192,7 @@ NOTE: The variant of Poseidon we use accepts only 1 input, assume n=2, and the s
function isValidCommitment(uint256 idCommitment) public view returns (bool)
```

### _verifyProof
### \_verifyProof

```solidity
function _verifyProof(uint256 idCommitment, address receiver, uint256[8] proof) internal view virtual returns (bool)
Expand Down Expand Up @@ -1220,9 +1228,9 @@ function P1() internal pure returns (struct Pairing.G1Point)

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| [0] | struct Pairing.G1Point | the generator of G1 |
| Name | Type | Description |
| ---- | ---------------------- | ------------------- |
| [0] | struct Pairing.G1Point | the generator of G1 |

### P2

Expand All @@ -1232,9 +1240,9 @@ function P2() internal pure returns (struct Pairing.G2Point)

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| [0] | struct Pairing.G2Point | the generator of G2 |
| Name | Type | Description |
| ---- | ---------------------- | ------------------- |
| [0] | struct Pairing.G2Point | the generator of G2 |

### negate

Expand All @@ -1244,9 +1252,9 @@ function negate(struct Pairing.G1Point p) internal pure returns (struct Pairing.

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| r | struct Pairing.G1Point | the negation of p, i.e. p.addition(p.negate()) should be zero. |
| Name | Type | Description |
| ---- | ---------------------- | -------------------------------------------------------------- |
| r | struct Pairing.G1Point | the negation of p, i.e. p.addition(p.negate()) should be zero. |

### addition

Expand All @@ -1256,9 +1264,9 @@ function addition(struct Pairing.G1Point p1, struct Pairing.G1Point p2) internal

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| r | struct Pairing.G1Point | the sum of two points of G1 |
| Name | Type | Description |
| ---- | ---------------------- | --------------------------- |
| r | struct Pairing.G1Point | the sum of two points of G1 |

### scalar_mul

Expand All @@ -1268,9 +1276,9 @@ function scalar_mul(struct Pairing.G1Point p, uint256 s) internal view returns (

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| r | struct Pairing.G1Point | the product of a point on G1 and a scalar, i.e. p == p.scalar_mul(1) and p.addition(p) == p.scalar_mul(2) for all points p. |
| Name | Type | Description |
| ---- | ---------------------- | --------------------------------------------------------------------------------------------------------------------------- |
| r | struct Pairing.G1Point | the product of a point on G1 and a scalar, i.e. p == p.scalar_mul(1) and p.addition(p) == p.scalar_mul(2) for all points p. |

### pairing

Expand All @@ -1280,9 +1288,9 @@ function pairing(struct Pairing.G1Point[] p1, struct Pairing.G2Point[] p2) inter

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| [0] | bool | 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. |
| Name | Type | Description |
| ---- | ---- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| [0] | bool | 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. |

### pairingProd2

Expand Down Expand Up @@ -1352,7 +1360,6 @@ function verifyProof(uint256[2] a, uint256[2][2] b, uint256[2] c, uint256[2] inp

#### Return Values

| Name | Type | Description |
| ---- | ---- | ----------- |
| r | bool | bool true if proof is valid |

| Name | Type | Description |
| ---- | ---- | --------------------------- |
| r | bool | bool true if proof is valid |
1 change: 1 addition & 0 deletions test/Rln.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ contract RlnTest is Test {
assertEq(rln.MEMBERSHIP_DEPOSIT(), MEMBERSHIP_DEPOSIT);
assertEq(rln.DEPTH(), DEPTH);
assertEq(rln.SET_SIZE(), SET_SIZE);
assertEq(rln.deployedBlockNumber(), 1);
}

function test__ValidRegistration(uint256 idCommitment) public {
Expand Down

0 comments on commit bd8403a

Please sign in to comment.