-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathAllowListGateKeeper.sol
37 lines (32 loc) · 1.23 KB
/
AllowListGateKeeper.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// SPDX-License-Identifier: Beta Software
pragma solidity ^0.8;
import "./IGateKeeper.sol";
import "openzeppelin/contracts/utils/cryptography/MerkleProof.sol";
/// @notice A gateKeeper that implements a simple allow list per gate.
contract AllowListGateKeeper is IGateKeeper {
uint96 private _lastId;
/// @notice Get the merkle root used by a gate identifyied by it's `id`.
mapping(uint96 => bytes32) public merkleRoots;
/// @inheritdoc IGateKeeper
function isAllowed(
address participant,
bytes12 id,
bytes memory userData
) external view returns (bool) {
bytes32[] memory proof = abi.decode(userData, (bytes32[]));
bytes32 leaf;
assembly {
mstore(0x00, participant)
leaf := keccak256(0x0C, 20)
}
return MerkleProof.verify(proof, merkleRoots[uint96(id)], leaf);
}
/// @notice Create a new gate using `merkleRoot` to implement the allowlist.
/// @param merkleRoot The merkle root to use for the allowlist.
/// @return id The ID of the new gate.
function createGate(bytes32 merkleRoot) external returns (bytes12 id) {
uint96 id_ = ++_lastId;
merkleRoots[id_] = merkleRoot;
id = bytes12(id_);
}
}