2021-07-22 08:43:41 +00:00
{. push raises : [ Defect ] . }
2022-05-10 21:09:18 +00:00
import
2021-11-23 22:48:40 +00:00
std / tables ,
2021-07-22 08:43:41 +00:00
options , chronos , stint ,
2021-06-08 18:56:32 +00:00
web3 ,
2021-10-20 00:37:29 +00:00
eth / keys ,
libp2p / protobuf / minprotobuf ,
2022-06-16 14:04:47 +00:00
stew / arrayops ,
.. / .. / utils / protobuf
2021-06-08 18:56:32 +00:00
2022-08-05 20:58:19 +00:00
when defined ( rln ) or ( not defined ( rln ) and not defined ( rlnzerokit ) ) :
## Bn256 and RLN are Nim wrappers for the data types used in
## the rln library https://github.com/kilic/rln/blob/3bbec368a4adc68cd5f9bfae80b17e1bbb4ef373/src/ffi.rs
type Bn256 * = pointer
type RLN * [ E ] = pointer
2021-08-24 19:25:29 +00:00
2022-08-05 20:58:19 +00:00
when defined ( rlnzerokit ) :
## RLN is a Nim wrapper for the data types used in zerokit RLN
type RLN * {. incompleteStruct . } = object
2021-06-08 18:56:32 +00:00
2022-05-10 21:09:18 +00:00
type
2021-10-20 00:37:29 +00:00
# identity key as defined in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Membership
IDKey * = array [ 32 , byte ]
# hash of identity key as defined ed in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Membership
IDCommitment * = array [ 32 , byte ]
2022-05-10 21:09:18 +00:00
type
MerkleNode * = array [ 32 , byte ] # Each node of the Merkle tee is a Poseidon hash which is a 32 byte value
Nullifier * = array [ 32 , byte ]
Epoch * = array [ 32 , byte ]
2021-08-26 23:14:51 +00:00
2022-08-05 20:58:19 +00:00
when defined ( rln ) or ( not defined ( rln ) and not defined ( rlnzerokit ) ) :
type
ZKSNARK * = array [ 256 , byte ]
when defined ( rlnzerokit ) :
type
ZKSNARK * = array [ 128 , byte ]
RlnIdentifier * = array [ 32 , byte ]
2021-06-08 18:56:32 +00:00
# Custom data types defined for waku rln relay -------------------------
2022-05-10 21:09:18 +00:00
type MembershipKeyPair * = object
## user's identity key (a secret key) which is selected randomly
2021-10-20 00:37:29 +00:00
## see details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Membership
2022-05-10 21:09:18 +00:00
idKey * : IDKey
# hash of user's identity key generated by
2021-08-26 23:14:51 +00:00
# Poseidon hash function implemented in rln lib
2021-10-20 00:37:29 +00:00
# more details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Membership
2022-05-10 21:09:18 +00:00
idCommitment * : IDCommitment
2021-06-08 18:56:32 +00:00
2022-08-05 20:58:19 +00:00
when defined ( rln ) or ( not defined ( rln ) and not defined ( rlnzerokit ) ) :
type RateLimitProof * = object
## RateLimitProof holds the public inputs to rln circuit as
## defined in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Public-Inputs
## the `proof` field carries the actual zkSNARK proof
proof * : ZKSNARK
## the root of Merkle tree used for the generation of the `proof`
merkleRoot * : MerkleNode
## the epoch used for the generation of the `proof`
epoch * : Epoch
## shareX and shareY are shares of user's identity key
## these shares are created using Shamir secret sharing scheme
## see details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Linear-Equation-amp-SSS
shareX * : MerkleNode
shareY * : MerkleNode
## nullifier enables linking two messages published during the same epoch
## see details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Nullifiers
nullifier * : Nullifier
when defined ( rlnzerokit ) :
type RateLimitProof * = object
## RateLimitProof holds the public inputs to rln circuit as
## defined in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Public-Inputs
## the `proof` field carries the actual zkSNARK proof
proof * : ZKSNARK
## the root of Merkle tree used for the generation of the `proof`
merkleRoot * : MerkleNode
## the epoch used for the generation of the `proof`
epoch * : Epoch
## shareX and shareY are shares of user's identity key
## these shares are created using Shamir secret sharing scheme
## see details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Linear-Equation-amp-SSS
shareX * : MerkleNode
shareY * : MerkleNode
## nullifier enables linking two messages published during the same epoch
## see details in https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Nullifiers
nullifier * : Nullifier
## Application specific RLN Identifier
rlnIdentifier * : RlnIdentifier
2022-08-05 10:48:01 +00:00
type MembershipIndex * = uint
type RlnMembershipCredentials * = object
membershipKeyPair * : MembershipKeyPair
rlnIndex * : MembershipIndex
2021-11-23 22:48:40 +00:00
type ProofMetadata * = object
nullifier * : Nullifier
shareX * : MerkleNode
shareY * : MerkleNode
2022-08-05 20:58:19 +00:00
when defined ( rln ) or ( not defined ( rln ) and not defined ( rlnzerokit ) ) :
type WakuRLNRelay * = ref object
membershipKeyPair * : MembershipKeyPair
# membershipIndex denotes the index of a leaf in the Merkle tree
# that contains the pk of the current peer
# this index is used to retrieve the peer's authentication path
membershipIndex * : MembershipIndex
membershipContractAddress * : Address
ethClientAddress * : string
ethAccountAddress * : Address
# this field is required for signing transactions
# TODO may need to erase this ethAccountPrivateKey when is not used
# TODO may need to make ethAccountPrivateKey mandatory
ethAccountPrivateKey * : Option [ PrivateKey ]
rlnInstance * : RLN [ Bn256 ]
pubsubTopic * : string # the pubsub topic for which rln relay is mounted
# contentTopic should be of type waku_message.ContentTopic, however, due to recursive module dependency, the underlying type of ContentTopic is used instead
# TODO a long-term solution is to place types with recursive dependency inside one file
contentTopic * : string
# the log of nullifiers and Shamir shares of the past messages grouped per epoch
nullifierLog * : Table [ Epoch , seq [ ProofMetadata ] ]
when defined ( rlnzerokit ) :
type WakuRLNRelay * = ref object
membershipKeyPair * : MembershipKeyPair
# membershipIndex denotes the index of a leaf in the Merkle tree
# that contains the pk of the current peer
# this index is used to retrieve the peer's authentication path
membershipIndex * : MembershipIndex
membershipContractAddress * : Address
ethClientAddress * : string
ethAccountAddress * : Address
# this field is required for signing transactions
# TODO may need to erase this ethAccountPrivateKey when is not used
# TODO may need to make ethAccountPrivateKey mandatory
ethAccountPrivateKey * : Option [ PrivateKey ]
rlnInstance * : ptr RLN
pubsubTopic * : string # the pubsub topic for which rln relay is mounted
# contentTopic should be of type waku_message.ContentTopic, however, due to recursive module dependency, the underlying type of ContentTopic is used instead
# TODO a long-term solution is to place types with recursive dependency inside one file
contentTopic * : string
# the log of nullifiers and Shamir shares of the past messages grouped per epoch
nullifierLog * : Table [ Epoch , seq [ ProofMetadata ] ]
2021-11-23 22:48:40 +00:00
type MessageValidationResult * {. pure . } = enum
2022-05-10 21:09:18 +00:00
Valid , Invalid , Spam
2021-06-08 18:56:32 +00:00
2022-08-05 10:48:01 +00:00
# RLN membership key and index files path
const
RLN_CREDENTIALS_FILEPATH * = " rlnCredentials.txt "
2022-08-05 20:58:19 +00:00
2021-06-08 18:56:32 +00:00
# inputs of the membership contract constructor
# TODO may be able to make these constants private and put them inside the waku_rln_relay_utils
2022-05-10 21:09:18 +00:00
const
2022-07-01 01:05:38 +00:00
MEMBERSHIP_FEE * = 1000000000000000 . u256
# the current implementation of the rln lib supports a circuit for Merkle tree with depth 20
2021-09-28 19:03:53 +00:00
MERKLE_TREE_DEPTH * = 20
2021-09-17 17:31:25 +00:00
# TODO the ETH_CLIENT should be an input to the rln-relay, though hardcoded for now
# the current address is the address of ganache-cli when run locally
ETH_CLIENT * = " ws://localhost:8540/ "
2022-05-10 21:09:18 +00:00
const
2021-09-17 17:31:25 +00:00
# the size of poseidon hash output in bits
2022-05-10 21:09:18 +00:00
HASH_BIT_SIZE * = 256
2021-09-17 17:31:25 +00:00
# the size of poseidon hash output as the number hex digits
HASH_HEX_SIZE * = int ( HASH_BIT_SIZE / 4 )
2022-08-05 20:58:19 +00:00
when defined ( rlnzerokit ) :
const
# The relative folder where the circuit, proving and verification key for RLN can be found
# Note that resources has to be compiled with respect to the above MERKLE_TREE_DEPTH
RLN_RESOURCE_FOLDER * = " vendor/zerokit/rln/resources/tree_height_ " & $ MERKLE_TREE_DEPTH & " / "
2021-09-17 17:31:25 +00:00
# temporary variables to test waku-rln-relay performance in the static group mode
const
STATIC_GROUP_SIZE * = 100
2022-05-10 21:09:18 +00:00
# STATIC_GROUP_KEYS is a static list of 100 membership keys in the form of (identity key, identity commitment)
# keys are created locally, using createMembershipList proc from waku_rln_relay_utils module, and the results are hardcoded in here
2021-09-17 17:31:25 +00:00
# this list is temporary and is created to test the performance of waku-rln-relay for the static groups
# in the later versions, this static hardcoded group will be replaced with a dynamic one
2022-08-17 10:11:46 +00:00
when defined ( rln ) :
2022-08-05 20:58:19 +00:00
const
2022-08-17 10:11:46 +00:00
STATIC_GROUP_KEYS * = @ [ ( " e9a4d05b1f539d65c59015a079ee89aabeafbcfc9734342d9559f81601e85417 " ,
" b74d3a5b3200ab1126fbee393496f33da497d4d9a7c56693f44d6155c0c34e13 " ) , (
" 27b2bfc25257e53819beaf36ce1070007e04e7aad2e440a1f1fc066f59a61123 " ,
" 522ce51aff96041e79a8476f508fb9661f146f189e288f83cb4837517cfc0127 " ) , (
" 66392eaae6674267c55fe393d39443ba90317a709d6e8f92a9f3e4abc18eff1d " ,
" e3dc235e48c1811943fc249fecd0f1415a50ebe839ccefb0bd820a76fb77ba2a " ) , (
" e7462eebb81405230db8014b052d65fe7b269c3870e40b12cf64668ed6c2d40e " ,
" 727df0965e34144ea637be18208cc81e57e423010b3159c20f0ccff45c42212a " ) , (
" 1ad8528b4c7075013a2d6561a02517b0482c0733dc018ac68774db857deb5004 " ,
" 5df3a77577135784da2a9ee78f5026092b7d6bb9e6e95882d6cb172c0cb62208 " ) , (
" aa0ff53bfc50861f871d94df18c3ac0b97f44ceb13436b33490cec5f6ce8e700 " ,
" 30421d05b905aeaec0473ba29ace034bf73c406866d7dc23007eb9c34a596827 " ) , (
" 0448c0a6ed57b177c4c45de478b58d29f24e7ea842814305443e87188ae24324 " ,
" 5ea1a704d8972af5a028367c8e3fb48ee61a603c6ea3a4c9247b0f611a6ab002 " ) , (
" 4b6a6edbdd11e69befe3f4a3c976baca320c4bcb188f129b603ebb198f663000 " ,
" 451d6185e8ad2c8873f034683b9caca43ea7ceb1b839abd3e01c3f19f3e6bd1e " ) , (
" c3fba34855b33f025696326d2980ddc3fb47d90459ed6a4488fbb2e4e12ccf2b " ,
" 74674a86144ea866ad8fe633e256783bda4a07b997cb412c53a5eaf4cc7b6a0e " ) , (
" 0c35b8b94a720f1c26d7c6241c9f3ea5332a87cf3730b25ef31b68854c10e405 " ,
" 6915df8d8ad19ec17be37c299eed762f9b63e841cd7963e13e8db6890dba082d " ) , (
" a60b021677da95ba46c8c3411ac77f3e3b06937a8d189517111c045880029909 " ,
" bbfcd22ecb44cec6fd0717cd0f21b26e6e8b2c91e1a6cb5d8610e2f2ad41c90f " ) , (
" 2f4d662e66fbe754b708b87ea3d75a01d2ea4d7bf33c615c2376211dcc3b560f " ,
" c67f7e622c3293028b9f86571e82c49551eb5fd308a35eb663498cffac208810 " ) , (
" d90a1afa96c14c8d3b989a9cf23d6e8b9907da42724e44a3ac74ae015b6ce22e " ,
" f0795b1bdd0a907252b6ab047642d97be076a16ea69d463f1a4bec00c817202e " ) , (
" dfa0764d89c8da10777504e5274f1baccf8b4145deba72b26503474318fb6410 " ,
" 9f8aa8e833ea2f13cccfb6d9f2f04fd7be9c9f3019540c05c1986b3bce254e25 " ) , (
" e17490013b6b53a40964ff1067b922d4d73521e32fe394527b39c1bfd4a5e712 " ,
" 7a8fa23a0e4b14a36f2818a7d98639f6e4934c028da780a6cc658fbf76e80a26 " ) , (
" 7a9328d1075373dddb1b1100e8217ffaa1f9b632911b95a8fdc08870b15a8410 " ,
" 94b2ae70c046b94873098c19fe18e7b17db2d31fe6a7eb73fea8168395e3c122 " ) , (
" ce319bb1447da5bf51a88ab3379dbea539b5a431d3c4f131048cf7b05c52161d " ,
" cdfa264ab8a51bbc9fff5732cf544bb06abba7e807a8c252a5f9ce785c6ff22c " ) , (
" d3818503bfcbef9ca03fc4472be77cb4936a1720001fc5e54852f769448fd313 " ,
" e72792abd906976c75a5670de514894a720c5293cf74338a9c2987640a949c0b " ) , (
" 4f9b8d118460736eb62602d12d3aed62938d4d4374b8c88704cf40c415c0901e " ,
" 2ecbe4588ade31924a1053fe0204950a0b4924878b312e56b2d0522f92a5f01c " ) , (
" 39b59fd96adaf9633edcc8cef10049cddf5f7df8ac80af8aafa436d62ee7f905 " ,
" b94f7a979df8a95fc2766a9a96308ff39a14daf7b7d6bc48591d2ea4c764bf00 " ) , (
" 73cb0d25995d182b361c8237852bafeab8bb951de99f730da2913a239400c322 " ,
" da04e6e4446b6bcd54667b741444d826abbc5b76572d28474dfa94db91144606 " ) , (
" 2753423b83bba5bb8b2799bc58125c46fb03ec05e8579d772cdc6e75b0875009 " ,
" ee040010ec20e7293431a3692d06416f71162d176a316b0329a76edf6f3fb30d " ) , (
" cb73ec9b67355ce6275b51144a0759de28bb9390aab20514ee49a3bd8ce5361b " ,
" c7c6e2ad3efe1f03b398241bddb67b008dd5e8caf1a17db9c33d2e2388d58e0d " ) , (
" bdb386d9f3fe5613ede926d80246682a5d32392f7f6c9d818a80d8e7a12e371b " ,
" 21d48c74f422ef72cb9db18799916b3c11d0cb99cec808563e2db22047840902 " ) , (
" 60f2fcfe341034449046c1fa330f6aceff737a9837a7d6d3a4885f8afce4a809 " ,
" e4c8f26f9e4127511b5ab21f1705913d7beaa2767cb7d033564e36bd2693370c " ) , (
" 1223d64fb5c44921c1ae66d91543780634c2f7bae7e184e09c4e5447e6d1180b " ,
" 290ab84714fc3534c5ba22b2aa7696ac03ed12c9cf1c409a777bac05475ea406 " ) , (
" b79c593316c42280d316bb7f3b43c7a5f5e29786d1ca6c0424463470eefe2b2f " ,
" f4e44ac9574c4d32ab403e71dd00554eee0d8e34d04611b66ab2e59c49bff025 " ) , (
" e6548f669ebe655cb6600432e1af14c43da7286e3620289b51cc947517db9c14 " ,
" ace261e3964a1dcb389a693f52104018cd475e6856ae37fe4892df9482954902 " ) , (
" 81be54409c9364f4842209e0f79b190afd9df017cc9790e11196d4bf5108f100 " ,
" d986b22e422703e065f12b6fd608813028ff913d4ffeb54b19e6537456391b23 " ) , (
" 940ff0d3b4549d1baf7ad900cf6aedde02833b777e39c411e6efe7bcdd2ef305 " ,
" d672bb8a6e75b47fdbb365de0516f3fa827b287c9666e64d1b6768e2c8949412 " ) , (
" b4fe300aa1c8c836b3cc4c167df86d08fb7213200b8d9f7ba7963170e6dc8c0a " ,
" 5f7db6a9867f3f5c9fd1955c02cf96056d1225be950cd432818f8f1c16152020 " ) , (
" 2c34a2bdb3738cb78270207dcae40ae47178bf4216bd2044ba124ec49240522a " ,
" 8c490c78d7d735ab32493510cc2ec9c3742d3f47e46cfd754859e91271673e15 " ) , (
" fc03857a3ff92d17d40bf9bb9b99e01e85fe4c698450147dc74cde60b2e9fa2d " ,
" c0a22acdababbc42bba5bc0245a2ef9f2c74b215663440aed37c8e0bd7e00809 " ) , (
" a267a96a35c63b03788e90bb9a440da9ac832b0be02537b6f0ecc928ea989223 " ,
" 636ceacda5bce999ca303b7df32e9352af10083c6db6ed93c8a221efc385172d " ) , (
" ce4e15a2c1667a9dac4c4732de6c91f8c523c449f8c9be6b895644460717a209 " ,
" d55c6523f40b36d2519b30292873bd469aeda6dbdbafe7c5fd405438dcc6bd12 " ) , (
" 4c617cdea4e3cb008c396c59b701375409304d84cfa17fe9d6d91a15fa412306 " ,
" a6dc21a9c35418a39c69f2d8e9df738db0b36fecc44eddf364846b84c5362819 " ) , (
" 8c33aa2b3d94f9b11cc62ed1a304b92be370384ebbbf67c886dcd6ce544cc806 " ,
" 7caca2b1ab8c70b58ba36794a988fd6ec50c2a04dd09d7cd28e67ca1f1401d2c " ) , (
" 1b6fc8f4007e6cdcf89a496cf0e711b0a3bbdbbae66830450a9744f5c802a228 " ,
" c3b79478bd32feb99a0c92001efb97953efdad8c2338ed2ac14a313592c12418 " ) , (
" 0c6837e83ee0f1b1e5fe31bdf0960aefa2162ef7de7c0c886df930839bd4db06 " ,
" 8b2667b5151ab13f0f87fb014cd3ebb7ab1e92a528f00ebd91b514ea61b8f52b " ) , (
" 8da38060963597c34544d8b10432a2e34d8eada7d1479f4fa5e96dca32250c27 " ,
" 7bf525115a8e6f772feb6d4db0f2a6b0d4233e0ff85e180c3249e18f0d08f42e " ) , (
" 50b0c6d85f6a9d11fc52f1fc9e43b778380bdf936ddfd293940c77e79bc8340d " ,
" bbb9e297de81ef341e032484d7b33b29e7d9e3be1414feaf2bbc0957ba408811 " ) , (
" 6e8fd3ad20cf32ff8ba6e4bd8d4f05f3cc20d88631cbd3aa5f7f98446d725108 " ,
" a9fe7404613b040412049a205301f2175b53d7012087047a8dc7501a381f5210 " ) , (
" c291bb32d69cfef7e80b6dadd2a1198d05ac23eb30be6503d1c4c04350de2028 " ,
" f44f8ca09d849551f72a6692c793319eefaa0c02d3301ae79c2f869f4251d422 " ) , (
" 116d4c2e21101f819a87f0de31dec56a4649c9ad9e539b71680dd439b288681d " ,
" 9f4df65e05390be63bd6e3e38d8afb6117d5d357d56f35ecf63406096fdd810c " ) , (
" 1813ed3760299a16e623084a852de9b12caaf8138744f8903a357fa9a2dbb00c " ,
" f37baacccd07bc489f50b851f807c88a425e41dd9dda8068e75cffb8bf653a0f " ) , (
" 545e62d72cbb89db1c17e7ad8bb0660a74f8bc411b16eb0452d9a2d7c3e5b01e " ,
" 96ddc93a86b091c7b1951d7371f80a352d85c38606e450aa2af272e8929fae19 " ) , (
" 0f5d5941474697c21ea6aecc29ff7cadbd28dbf29531431a40aaea3b7acd1514 " ,
" e83d0ff3ab4db81fb19c1b6125d7d2e4a34a83a8d463049d06df4870dbb2a525 " ) , (
" 52605bc1f48092f9d5ad4c2a840a60f129e6aef2eef9c92474951ed1e10e381c " ,
" 222df3afb8b20685c872f29ebfc7e4056fcdafe1d8a77a9f9ba08ac8f426190c " ) , (
" eee8cdee57e9f11ad0174c1514bba4c3a2c2a10d099876195726217445462f0b " ,
" a000e5799ac933154bae228c09b522c714fb9a57f530d1954947277be9db0a24 " ) , (
" 8c7d04dc3916370f8186dcffc92ad482294ab49c9ce36a5bd13473dc7c4d491a " ,
" 788e35bcd82efbce15b3444f36330337ce3adb67bfc6329149cd25069ac9eb19 " ) , (
" 004a720f9edabb7f82eb30a78da45aceccbca5eb69583e1e8018ec1359a61f27 " ,
" e3d319d64bea8069a649acd33859b22361da799e0296f3d4f5117e16feb18e16 " ) , (
" 38716f1d7cde7e37795a5b2d6d6317eecbf0adc6dcf7dcc6ee02cc25d1efb22f " ,
" 95c229d0cfc1485f2be0a23de6e49601a2ea55652beead84a67cd727c21a1301 " ) , (
" 22cac7a49e99f3d071812abb0addafa4bf9a65308769728e4cd53cc7486f6c13 " ,
" a2e5b90606809964bc20d776b9cbcaab93a2f25124998ae3bd698d061f7afd00 " ) , (
" 5109c7a41f73baa4787358b72ff1095439602add7a86a034b87b74360ee2e20f " ,
" a31b3e2033ed828b5a51b9428f8f6ea40267259df08fdcd2c0e34dd335bdf90c " ) , (
" 957a87470f29a135567085c3d6d6ed14885bab4eb659725534a45a9f100a471c " ,
" 8f3005df282d5a87fa33405e35a313233d05731e87cfcbe060fa067596fa3013 " ) , (
" e0dad57606c2b293dc7c841c965cb29736d2411003e9284a0ae94d13e3d03d2e " ,
" 0543643ef0b617030dcc292451ebcace8bad20706528cb6aedb98dcea66aba27 " ) , (
" f1f10938c8a55b6b15b3f12beebb702133401135937c5c3f2d7fba702f24da09 " ,
" dc862a8a5ad5107421d550731a7f561e4064878c3654bf88b230cc249e91091d " ) , (
" 4bbc08d78c9970235778d6bd9939c7b2b1bd88b9d1cde6473663ae96ae776911 " ,
" 3584be9ce31a7fb3aae8515011f4d3eeb86a573b225a88577e4911050bc35013 " ) , (
" c8325b31c9295757ca23d8f5256eebc5ccc517d28e00bfda5f4d709441d66713 " ,
" b81f360903160485c470625519cb18219b44d8b740273ef742fefc5653daf009 " ) , (
" 69a6b3e22fbe5879efa56cdb5d50605732bf7f311e28ba037916b4db61ae8a14 " ,
" 10ddf800eb3e67da20575456150cb1f0d49506d97ed4ef2d91b951af48966924 " ) , (
" c2a0e3586d4bb49f2ef979686c3a9a1619d0d54ac89641d592b4628b19dee401 " ,
" bc3ba677f6d13ef9f023d4a3b9f073c3eea910ef90cfd24b7f54414d2d02d315 " ) , (
" 5b89051b79ff37457760d7af2ebc68be955e47eb6cdf306fbd369dc19fc52c05 " ,
" 7bfe2a9d5bb2ade0f9058ea27a07c867af21670d2b9e84bdcc8967d4cdc4ba11 " ) , (
" 46ac45f35cbc23bf68906933ad29240054a0a1d89c1832ebb54aa1bc32644105 " ,
" e891e783d5615a1b8ab838f68f6f2ce4e359510ddd40882d4650327d08a5bd11 " ) , (
" 581e067b37c40caf861c190922f816e6cb850540df7ceb159f96c48c1c70cd23 " ,
" 0d49fa8c74202369c36f4121eab0aa3ac9206ad3419fc9517a88493b07d6fb25 " ) , (
" bb7eb4ba2b45a22e14fad963c04eadbe8e7aab6ff912b008c9e7dd2a2c7d3615 " ,
" 758ed0c8cef51f82508072fa758265f0f0eef6c7b2401b94ebe27a638ce33125 " ) , (
" a08f3cc9904f672b94d1f5a14dedbdef4ed229da5b66eca0135090d6f0ba0728 " ,
" 542c952395d241cfa15bd48922e9c7fc292dbdd120daa3d66dad67fb3abb700a " ) , (
" 105bac5c449441bd5f5cf39b431f703e2e8f6a30a90d86cfdf425ec728fdbd08 " ,
" b59206f1d556fb98329a7111e3c89bf1e6a4861ec38c82eafa81cff70b713e0d " ) , (
" 45df2edfaea234dab99efa9a402c0d2feaa841ff3c990c926473173283d95913 " ,
" db008cf922c3a50549373a14f5f18b2dc827bd6e168402dfe3e6ece4cb137527 " ) , (
" 488dd6437c15ef5b85e84407b7e599cc078c195ed2fc27b366ddac7739f1eb14 " ,
" 0448887f55c677464e7e540adf107ba10fc6713e8a2718fe92cbd4794ef4be17 " ) , (
" 3fe697698f3504e15eb5d509efa91624d9aa4eae24beeb42ffcb3c6ea8372a30 " ,
" 441ccb28e7c6c1893a58f7513c9b7c1c5d0adf3de452644a837d7e08e1ab8117 " ) , (
" 9bb5801272264c74db75f1c6812747bf338ea6880fa4dd2d51ef651ef73c2e04 " ,
" e2eefd80e838c30b3f1fb0313fcfcb1e1556439d0346d17334df83c33247b20e " ) , (
" bad37a1467c4fe875b78508656f2816414ef602ae2ccd4e9430d94ca5c1cd911 " ,
" 21c72ccdbaed2e3ea9dac3881531467b64c9322199127f2ae2fa4bb31bad591d " ) , (
" 95c72237ccbaedc185b1abfc59059c454175df81bb3ff65e5a61e2cb5263ed0d " ,
" 1040728a4775ac5cf7a9c75dda2f0aee1fabd6b202b5e916636e3aec73a09d0d " ) , (
" 738e8b9af4d199bc95f70b2a9b25e999b39af15c6a02f2eca058326078745f2a " ,
" 004835960aa03e101d818907df453cefdfb910b44ad9bd056a83b2ef40a5ca0d " ) , (
" 0d88caf486f2fe60bfc08697d1b617b586ec880e38e4ff56f145a5db0ab6d12e " ,
" a7b19323815295bc84c50535b62c3d4d53dbfc434441eb3c009568fb8f7b2b1a " ) , (
" b37af7fd314d90590fba8ebf730397cfdaa97f86d3f31d1a7ddc817ff303791f " ,
" 8296a80eceae97f92784642da34f121e29db2c5f3baf9a2722896db22e98b703 " ) , (
" 6b67dd3051a8cb113431f5a14e279d910b7b4798ccb03ff588cf312ffe366a0b " ,
" 9c38cc543a0b793be4a0d66de3b2cd30b1f33d36c4402a165da924d7e6f89a12 " ) , (
" 72fc4c40e406b9d1b34daba614460922fc53951abd6db5834e1f1b07fa319f27 " ,
" daa4d50481ba47c4a78ae3848a9b268b1d8e0579b4967ebcdece47d386410d02 " ) , (
" a4ce5cb2b2a23dcf019f275058a4092901c4793e6ee7d29282e755dd0d0df000 " ,
" 00749453d23051f3587911c34d52e2c2d093273d2283cd6dfba94d7a89cdb226 " ) , (
" 9e00df0216e8ac8e72abfeab1106373a13699714c691f04a549f6b58ea974521 " ,
" 0e69dbfd9023b8bb58ce7e17972d7c94d49e8464f9c22161d7564ed32c53ef27 " ) , (
" fe1a558c6315f425fea7c04dcf6db869acd7b62b1b848200d5709e73d53de71b " ,
" 66cd33cc8d61cb807092d76ac0e506014fc55624a39ee2afa67f9ba58eb21022 " ) , (
" 3ca542e17e4cbc74f47afb399b12295d15dfbae5e966509b7e6cae2df61a430a " ,
" 57a0df429ed3720dee61ca720a4617243b41472f0c7766cc7ce625afddb3b41b " ) , (
" c1a77855e9b0b1f7381c9acd69ff68fdfa65f1f753dcea22de5a28ed088c2b2e " ,
" 4fce521d725abb8a30d8c39a2a22f496b374d8512b7a76afd3803f7200c86d19 " ) , (
" 17cda8d590adf3042bbf1452fe3d79b959f284f3df1e15ee3c696286f0ba832e " ,
" 8919e92a175b55003379ca6e546a04228aa9da861a9669e0e9b106e4a204d404 " ) , (
" 959fa9337b4b479ce5fcff7ff9096a344acf7fcde2f8852e28904236472f2f02 " ,
" 79e688ecfece239223b745e4b95460bfcb02aee12b154e15db616fda857dcd06 " ) , (
" d062d34cbdfbc50004a631e3dd8f21b446673b53830aa71fdcbc741e7d4fb31c " ,
" 2203af0127657f4e8a1c5ec44bb25028e64ad388efd0b9bfe2105f4f3ff66d0f " ) , (
" d2d3e3034864944914709549ce27068b5f27bd18b0edc940593df2dc5c5dae23 " ,
" 5ae75206bfdc8f54a8673d5d4c4b464ba1e84ae2410418b5c5e98fa993608113 " ) , (
" 4ab457d6478fb27214345f0bc2e00cbb29cd55bed1f8e05c23b8f7810e134a1f " ,
" 3db37711e355ed46ea81bb6e31ae87b37b706a8d17e2aa976c7c7706c8e18d19 " ) , (
" 5aa17884c96ecdaf81e2b343dbf051e4ace41935e53378ac10a4387e2cb0c404 " ,
" 7118986268a748881f6144fc1008e90b40afc702be53784ed4cbceb8606e0714 " ) , (
" 82f4ca6b751ac067e451ae1d5115806e7a1d14ab444084a8ac48046b88b43b30 " ,
" 8a09186c2a5cb0f16e273be6a8710620006a77afe7c54149bea3dce906345a02 " ) , (
" 55d5d97de81e0cc4d2ac97e507d4d6d9874cb55e1522b89ed2050ff3c20a4912 " ,
" 27facefe4e2041e11a21889205af6c11eba73e3e8779b801bf3f7253730f1d04 " ) , (
" 845177f4584f61071ddea21e9a6c0a17e1a9408e0c073047c339498ff383c109 " ,
" 25bc572d1c861fe80156c2fd440e7d9110be8252723d276e806dcc012f8da103 " ) , (
" ecec46dfdaf45f49f82ee78fd9c8c747c049de9becaf440f90391c04dd119002 " ,
" b922e1a7caf72db69dcc062424c7ce75728d010c4c201c2ed8e635a617c81a1f " ) , (
" 8e265fd9f2a4b158a5eb4bda000a6124af909e118b7510f0ec418559aad85825 " ,
" aed92a21e9933bd2ce6c9f09bb7753b46ea31248b324c12726cff08e464bdd0c " ) , (
" 99d7181572d3ae637a277dcc0c35b9b98bbb6ecf3cdcc69af3e946a5bfeb520f " ,
" 89217b554371a2495ee473f867b2e26ea70d4245aceb462a98dd31a37d2d5330 " ) , (
" a5e1fd149ae27f34e7902ebf380277c0b7f09f37e8809d25a0b8df2965d24e29 " ,
" 2d6a16a254cfc3894d5500f8c40feb1e84876bc51c68c381109e83f001b41c2f " ) , (
" 7fd221da235bb6e5fd0ae047f1aa49615ddbeecfb71ccb976bf3e0534425661c " ,
" 9ea41ccc3e09572927b0d9f618e1135d384f33618b6a0f80002f0a70be5eb324 " ) , (
" b125c1b45daa68f96be6a5b3e4dd24e4a0e49e46226d841eb73754a498c43b21 " ,
" 360b9c39d25451ae58cf651c530155f91e324292b55475a92506de726f153c18 " ) , (
" d64536234849ababefa90b84f7b7cacf4b073809aa9b0c35581426521f18d81a " ,
" d2dae030312cd4325bb036aa3436b26b9bed69b4d78d68bd49dbdde3173f1510 " ) , (
" d1ce3aea6cfb7be132d17e8d76fcbe4b7e34cef3979b4b905acfeff2f6d19724 " ,
" be47b76297791f535f4b56f973a19f07ec22d4eede2a41ff23c696089938bb21 " ) ]
2022-08-05 20:58:19 +00:00
# STATIC_GROUP_MERKLE_ROOT is the root of the Merkle tree constructed from the STATIC_GROUP_KEYS above
# only identity commitments are used for the Merkle tree construction
# the root is created locally, using createMembershipList proc from waku_rln_relay_utils module, and the result is hardcoded in here
STATIC_GROUP_MERKLE_ROOT * = " a1877a553eff12e1b21632a0545a916a5c5b8060ad7cc6c69956741134397b2d "
2022-08-17 10:11:46 +00:00
2022-08-05 20:58:19 +00:00
when defined ( rlnzerokit ) :
const
2022-08-17 10:11:46 +00:00
STATIC_GROUP_KEYS * = @ [ ( " c12d11c3b8ee882559ef48f7a42633d81b1e13fc589e6caca028281a1098012c " ,
" b3ec8a9138817be401b9ed2c683f6969d87f70ad87cbc514dee24146a542a71c " ) , (
" 1a19a8d1709ffa10882673962fa4b6fcecdd2ae3c95f9cc2db294633fd775109 " ,
" eb599e4681f8fd50730d22d2b0d0e9e4efcc659d2d310bd6cb3ff5600a81300e " ) , (
" 6317e72b74ad1395ce77777bcde06b7b5dd02ca69ad6fdc7affeb3bf4d6d1c13 " ,
" 151a533bc8927e97be9ba2173644282e3aeada4f9a65c4cc72eda27f3ba10c11 " ) , (
" d5d375f61fc9f9b4702aee9473ce304abca838d224dbc0dcfabffa0e3d04452f " ,
" f538609579c413bca2d395a772b026498eba0c00a1cdd5f7127d526bd96da723 " ) , (
" f47b36d2df712cb16eb21797c2d0672e12a60e0a7807edcfb15e7213f072a20c " ,
" d4d12cce11c6d8311c15353d35926f298b886ac66cf6420c47ad178231632608 " ) , (
" 3a8360de57f4ab8cad701459a73019c71b0d84927dcec0384bafb2586356080d " ,
" 08a8b713036264b878bdb8051cd6a6ccc9acf9e094daff690d167e699a90c628 " ) , (
" 661b5eb69735c9e8a181bcbf34563b96aff763d4996d60ef88c439e82549b622 " ,
" c1fffac2bc6d8b78eb24ba052d72bb88fe5cdb40e86eb3ebadbd57aff47b1e2c " ) , (
" 79fe1ac6ee536412d737091c7e53f003cfd4e4d1a96b1ebc1d27faff4527101c " ,
" ae1b33ed18cb164c4b3227d8acaf75eb480a58c07d04792361d3e7688437572e " ) , (
" 88f35905877c4417d418a75994eb2ccf7da052b1032bae782c935b107bcaf12e " ,
" 0e3cf8fee2c863470dfefabea0162e98a3cb0b5aed1387d9aa2990710ae6b705 " ) , (
" 771b20194afc2d043d133213a39c99f88a50f6459eb7bb7a8b19cd468fdace1a " ,
" 408f8624260e2a85ea354959cff0e7550d89ba666e4a5d646fe1ab8a9b253d2f " ) , (
" 1e40c14bbe937cc3baac06f4b9c1e9d15374064a12462a505ee3c85b59e12d20 " ,
" c5ea8270d54c3919ffc5659bef2b4f00f55a9b7e8a655875ca864837cf66561f " ) , (
" 23dae2b032cf45c17378778786b91fe53c7aad7928391c5c4613b5683ef22c16 " ,
" 9f6e20cc9f6df9e64cabcbb765c92faabe25257d92a00f746d13cf1e5f113f1f " ) , (
" f3213ee18ebd73ee5813ef6267d54e0af7bff2a62ebd329adfe41a42e1d7451c " ,
" 839c3c58a2ecc4c181b8f298ce6aaeeace4e0777e8774cc1fbc4279c3e001724 " ) , (
" f96996f6df01ebe12b75f96ec634458e5e96d8bc9b2983b211d943d8093d0b0b " ,
" 8ce6a29f023aa78d5a4de75b3e12c3cc673bba9dcafd5a2968f4a1b9707c5b11 " ) , (
" c9d5403ed3ee20b29cb49c16312464a52109c553cb7c3e2e760488bc1f4f1b1b " ,
" 96a4069fa8485b11c9fcd9502c384caa6a1db2a90d45559a2aba51d5ea21782b " ) , (
" 3de4f01667d317d52e2718926646dcf559f2fb7266b6977a47401b976b457b06 " ,
" 6eff6bbee3d3bd885c7f900b362dbf245e97a523afdbb62d25eefb9afeba4c0f " ) , (
" 89453ee367a782654502062cba7da961d638b4160121ba0ac88abe7a2f82ee18 " ,
" 551f19081516e49a4e94dd97af53da2b35b603c321ad02d29f85b9d5ff12f802 " ) , (
" 32c5a512efe5d41504bea17a4e3bb865c8d54e9c6732a3bce77962e52e1fc414 " ,
" 3b8dab877f10640659e99bc6dba2367664aca2f4e3f87b38ffd532f326332f12 " ) , (
" a74c13d3813e7452fd8680074c31dcc8d6e79e95086175205129f77f37feb129 " ,
" c55985f3a99a3fd1a2619a54b87e433e4114f59d1a59c3a911e957790bec471e " ) , (
" 9b1c420aa3dc252e9f290bba21136c97d4bea618ee298a4167eeb445d3b6d517 " ,
" 66f0efae6899a6f851a2dab31df7e936238b8aba4e961c9b65c6b1d113f13e23 " ) , (
" d4821c14ed5e7b8f4febc8cecc26e1d0ae6fd97a7324566c06920300110de414 " ,
" 9653e0cbb946b534f0468e42bf124e5806adb4bdb93e91665610d69037b28b1d " ) , (
" 26c453348bae0b3398691e39d5032021c15f7fcf8efb5666f2ffb3bf0c609804 " ,
" a366c39b7cfd462063aa394c31642d36cd3ea5fe89ed0d7db423f2791cf74429 " ) , (
" 4a50a8c66d78ea1850ef9e6ff3d082fb6aea7a380d267b89e449826c8e7c1319 " ,
" e353c38ea40b59565dbbdcbc03c0c9f99a017551ae912afca8d5b6cb028bbd2d " ) , (
" d04788fe9a750986d14596580b48edb0415b18466872d4b431ebbe80c0276f17 " ,
" 234ecb8bd50f758f80a48484b6997b4d0a64a1f67941aca1bb31661797d63010 " ) , (
" c5a3e4885e1b16a26ba3d938659e6a4d37e3f66d3f4a8d82ff6e22145ea58303 " ,
" 2921633b6bc30dacadba9ee3956ec7e3024971d9db600ef99c4ffeb1ccb8e425 " ) , (
" 485887237db885ac07ce8eaf4e881fdc3fbcd4454cf0c56f0bee6b7213de570c " ,
" 061186e353aa3a59c4bc1d98e926c17b3450081dbcae63d2d0841a3fb3cef422 " ) , (
" ca0f9ff876c78957564b303c9e99598036293efe635ec29e0e4bbc59ec59d106 " ,
" 48e04ce11bf78ef28261067eec8e5a47ab8632b2d35dcf2e28d229e1e2894714 " ) , (
" 9d7965f433303388ced9097e0563c2871c7ce0b286f108bb53e7a68f77102b24 " ,
" b6afb6e2de8fd30417e4b8d1fe4559ec73aa9e96726d0448eef104a0f099eb2f " ) , (
" db1ef92e473d8bdad5654525d9a9fd9fc0febfe7101eed67c8031d697fff5913 " ,
" 34d5b8bb8893c4f4fcf0aa4cb6bc13187bd4867bf0b4b32b57387bd371406f01 " ) , (
" d43e059b5a5a2cb6b4200ac3832fd4ae6a33c69bcd784eaa3e662007a43c2614 " ,
" 560683915ff850883b2344e9c64543cd40b2a544c099edb1e37932a7c21a1d12 " ) , (
" a1cf07a46e8696f4a6f6838d246c4e9fbfe6db33149c99fa563f233b16317e01 " ,
" 3904003e9ec020a567d23301a8f381a7395d129020ad320fb2b11f57680de027 " ) , (
" 178c9c8612a61f62506da40443cbf6d6fccbc9406303b6f88d9536b42c506826 " ,
" 2c81906219408328fa05a005247c9baf796c459ecc3ab0e1a70195c180e47705 " ) , (
" f84b9362f81ec147c40f43cde64f3ce883bd80b40230c435978794b54431be1c " ,
" ca524f39724400999116252fdd67316cc0caf586c3ee0bd98c132ab2fdb7f30f " ) , (
" a2fbcc2ebb6f728e42c2967bde68461af69c2b10c5305fd40053eb01d1db1e22 " ,
" 4ef48e82ffc90c273c6a1627eed225a1ecf5d34bfa33026758306601a08ee71e " ) , (
" 91a7de9363388d15501cf72449b053a036ec5fa16faddb0bfdb6aca0a0c1f409 " ,
" fa5bc2eb977165e92a45d92d5da48e0b1e95e2d13e2d8d42dcf9e99f8761f20a " ) , (
" 6e2598bf6a6975a578abc5615e0791c678ff1776176a771f025c17a67777791c " ,
" 22afc07a5715a0d1a47ba27403e83660837d2c7b9a5902c22c0fed861ff5ac14 " ) , (
" e788d7b78798f2edc1d5575e35dfa3c17b6c15b6642df72ea6ee28297422b011 " ,
" ba9a4176a20d61efabf8b3a6e2197b8dcd26b0337c26b567c2fc4b3ccf67aa15 " ) , (
" bd13c15935c3a49b2f19058e784d3bf700f4c06c0641fa771822194e543a3200 " ,
" 1535c97c68abc851042f117cf98be4130a25a49acf5f9c910babef342db1fa1a " ) , (
" 7718d0013fe1be1715041b7df3372f21185821111966fc40c5c29b948fecf60f " ,
" e476d8441b12a235c48c24cf1a4edd1b9384c2531d70dbaeaab891aea4c39a09 " ) , (
" 857adf44efeec3ee71001be5172f0796a56021cbc94273ae4c8a58356a0d2003 " ,
" 358eae8e81fd089c3807354d20cf1f878d39b1ce757126e787d4487af65d7821 " ) , (
" 8dd2491ce49ef575e8e0ebfd675b6b831e8d19c90d6110ebe57a60d3a9fff622 " ,
" 88ef9b9cadb4395c03d57ca9c0a84fc76988b1285d716d4ed3a6340aa7f85a28 " ) , (
" 95a421fd9f866bf28eae38fff084ed0d300ac08c3c020d73e6c0a432e5731313 " ,
" d86722ca41b4dacfcf1bbcce9a232979722e228e15fb3e2048b8cc271b021726 " ) , (
" 8509921c8c87eeddba208836e3a70d570b39d14d8fc89a0cd988ace585a3ea2d " ,
" 1970a24152128fd6c74ed49315ff705d5af4a58b4dac87d8c82f9be6a6d77507 " ) , (
" f0591ba2f822317b6d5d8b771474ae9518e4d36518469965d83d84d5795ea513 " ,
" 1d78b5d07a822537a1bd8e8a2fe2fa9acd4d858aae251f5e33e57d1f7c462300 " ) , (
" a302906a3fbf5dd8753edad674bc00b9397d1a5bc3dd1d229359044ffa346b0b " ,
" de7690a0fceb4c071f52a09a1fe3e872a74a33c698792a0c30e26fbc8d8b4d20 " ) , (
" 6b425f3cfd5f66616556d9e16698fa1d2cb2e6ea6149b75089c0c403d52bbf07 " ,
" 3254d4f64d9fd0ab8269bff02865dc115841f1717ca4408c8fd21830deba4900 " ) , (
" 570a3f9bb4a293fde27fd13f1407a0aef5c1e1025e2417af400d5c40a043222a " ,
" f3d481d495572a89216be3bf4d3ba719d2c81f59f67ff825f2ac0bed67ab2a11 " ) , (
" d2a4336cfe79faa8695f88d74b7786ef418bac6021a9c4ba1c3db8e433fda122 " ,
" 618888220de5b3f2eb1470ea0ab8188d5385b21e1eef64a691b2f31d066be12d " ) , (
" 5e9db678cd1dfd7e0c598236d25f27b34139e26e5b15b032a68de05b0e394e28 " ,
" 4f2379dc6a1212d0b7029dc3248d0546d003edc23329c848ea62442e3b2a280a " ) , (
" 042dbc17ec31dbd098c87c98fa9cd5d8ce7716045ef9d93aab3c9d6bf6f86e21 " ,
" d30841c4768e3b902d9def72131244717d2a0341540e71b51321aabe81cbcb08 " ) , (
" c5cda9e62ddff24a2f14c8ec8ffd7746e230b3023bc2f87353a6eba7d1e55f1f " ,
" d6252a48c7baa1b9194d0d12a8a07b97f2b624234b48f5eace2d1adc958a8118 " ) , (
" b751b8e0c753c8dd5a07293c0dcc51448a49be3cfad6c8d3fcb8e15703a1f402 " ,
" 297af6aed5d949eb9ca3ce7f0f16ab270fd509ca350376cecb844fc55606f523 " ) , (
" 2c72a6ac20aa6c8ad2500bab50c90fa8c5b2150a17d3f1d249faf29dc48ee81a " ,
" c05528b87b7d9b7f1c96937116cb5b6c1d66fdd7678332e257d95601e98bf108 " ) , (
" 843a2f33499e417fb3370d2b35170dfd89ae3d7296bc2552611a1f04542f2b15 " ,
" 85f5166a1b5c384f6bc9f59e779c9f866c4a4d00443372cd433b5096a7a77e08 " ) , (
" 329f698e99433a9acfe5bde3662d8e2c05b5b68024d29af1a59eb63d3722e40c " ,
" 910b67959ff965ae27ae8679e07bc2dfd3b6f567bdf74f07b7dc3b055d883430 " ) , (
" 2e00f33354bcace1c798690fdae14a40b8b0d5d922c5e7d9b8a7bb17ec72a40e " ,
" 4b50726e2c50f4e404bbc39eea2a8fd711a6cbd194489c4bedce99f32cebb81e " ) , (
" 73c09da2c4cd22b3890ada1d6045a6877d558ea5c3a7088fcdd3b77b229b7620 " ,
" f500793aaae728efa2029825185175fffc286159319347d10586b8a1de01b613 " ) , (
" 25c8efe9ff791b4a0f4478a6dda0867d8df396aa51044c6d6b1ed9427d117c20 " ,
" eb57c5d562ee43c72d8972ae0e8c170b3a7f0e4c89ba67e82186229adb904706 " ) , (
" 863f44e00121079c54d36d7cccc1da51ff5900610386fdb8bc36b3a47483d72e " ,
" c30fd9b1b05ac1a347f432d65b68c82476b4ec0994fa00cfd90f1f7db1571d2c " ) , (
" 6a7311e3f18945a8709eb5e90021a8139375b5b68af6c9cad121615a80ee3f07 " ,
" 1a3d8faa7c7d38d5acb627def5b070d8f5719189f7a25e3861c0a9a879cc611c " ) , (
" 97d27ce44b476664863f34a2073278dd5ef1c8623771a9813fedc3a1455ce92f " ,
" 9fc429eafee88fad27dd8a0b05087a9282c926353152c8174e774f34128a7d13 " ) , (
" a88ab45b5ea8cd975399fa39d3ea5b04b12adc705732b54ba6e5af494863c310 " ,
" 2429cf8b01347e32d2774cc4070928d7ff96ff585e6f39e0a2e06fabce53c81c " ) , (
" 51eba466f4662972616dfc4fe846425b245ca1405730b6809882f51f413b8526 " ,
" f9112ddb4c80bb385a3938959a750e091c3bb9b6e16d717db46c28efbe273a1d " ) , (
" 45e9ff284aa8b4c825ebe16165953b186bbc0b62f209f84dac2eee3382a94e2b " ,
" d932afbbe10120b68c573e1844a4f8f87bc93ff9d359d7c15621952e4ef9821c " ) , (
" d1807c403b8ed2e8022db73486ff6dd2471872404accb8208cda3d757079041c " ,
" 7aed51eb6e3f042a32e44f7add13f9d8cc675839232323094692fa9ec0385e19 " ) , (
" b9c93861237f423f8cb2e96e3a92ba986f290f3852475d9b62cb21a445cdc201 " ,
" e25ae2bb31b01d5d80186f906af11d4c7a6ed172a5aefbabe3b3eeece6750816 " ) , (
" 558ad70ccba7882b6f20cd8098f52b8288afdee8b346bf4db33b5deb8153c71a " ,
" c651377b6f9deb188dfc868df0157ee50dd5f9f7d92ca0e69e82f03355af9821 " ) , (
" b6e4ff38fc18fcb2ca63486314db80183b35f1dc8082e8dffae0726a1c284c25 " ,
" 2eedb645aa09985bf178bbc4c5417f8c1a9907440066096111292f2e72e9a01b " ) , (
" c264ab7d9008339abbc1be91bb96eed30cc5d051d8833a3f5cc94674fccd8627 " ,
" 8fd732c230f79e11d56d8f7cacd5f7095e4ad1a80a3c79b1cf42d9733001fe2b " ) , (
" 8b29b2811047827f356a57f7166f8b3dd4a3aac23b02522daf007c677295801a " ,
" e4b4d00d5d3eeb087c2edfdede5eb92ad39974c359172913abc78e5a5c78ff13 " ) , (
" 30be5db463aef5665c8699f2e5fc69ea2ca209290771e2aaac3b60caee6cf22e " ,
" 3c5e974d664c03b13adbe5ebcf9b03491ed0e4c50095297d7b3115804274d70e " ) , (
" db16b337102ce1b0932fe6e841fc1e7c01473ed4f3765934f2275b821d5b5d2d " ,
" dbcb04a56099034b4eddf402c08810f5842a74d5312cd5fd86d9378a2da54323 " ) , (
" 6f75a23af554d0b3f5ee5a48b5ec1ad8fe9a6f7c2c64b9e44bd9deb644212e17 " ,
" 68cebf8d52280b6484bd14f9b6bdbf89a485fc6f6129f49494bd7c1b40c90624 " ) , (
" e3d00baa245cb4f99dcc282cb33121dfa42c3ae1524139c5be17a043cdf65a28 " ,
" 5710f34c928c76f21871bcb63731f3417f1056437397b083d095e7fd3f49790f " ) , (
" f382f322140415ed6692583c594e8d8fc5bea0f027a159ad01df4a3942771100 " ,
" 4bfb6da22da207b0935868b7ac4574bea7f3358f4a281837e56b1fa3147cb40f " ) , (
" 33e74fde6f16209c57b24d496fc87ce2270dd2f3b04a9a5a701ec743ed9e1d04 " ,
" e1e847e1ba408253c0539af6a7ff0a8700802ac26f8f7aa68906471613f8371f " ) , (
" 3e4b5dc67f25293d3c432cfe6e37ac7905ae19e62c7836c8e1a05b5822ad432c " ,
" c978a79b21c177d102af936de352d5fb2862396157628c8c53b259eaadd60303 " ) , (
" 1468956b2009da0abc540721681516d2d836fbb19692276d07345b6706a53129 " ,
" eef70d99244f8e5de8c938b56d3079990652e399edf4996c7ba3090bd20e652a " ) , (
" c641b2667bc124b26572f9fbbec9ecf839db74c9edec9a75168579b71cbb9901 " ,
" 83b957a57b5ecacc1a4b0231795be7013e488ab0ba2e7cb4122152aa2a14ba18 " ) , (
" 5bc5c3903a9a19dd230310422c11dc42c590c949580f37dedc6bfb528be5c62f " ,
" 5e2dcafd8d018dd8d3ad1e5a7adf58605cd8628dadd96ee48f32bc0f8c4be41b " ) , (
" 9766e135d8b9aa253c90202454fa824b03b9d2d25e0b6c18cd99d87cb328590e " ,
" d3f8885f3dfa8a0416937ef89f89d2ee7df9e71852f09f812ac6d7934fccb60d " ) , (
" feb64610db2ac2f01869a198f5a3fc524d6cf0bd171f118bd291c50db1d54a1c " ,
" 3e27cd9b28b288fb3d1953a7355c986c88428a0a95b56ee39f7e5aeb0bbfdb0f " ) , (
" 571bf13dc817ae45281208cf712cee1917900e203be6d617984bb493e0c24c25 " ,
" 132f0e795cb6f5127e9fbaff53b28e4baf05df08b92dcbdc05d8ea2638d9e70c " ) , (
" fb649a934864788acacdfa654bc262cb71af2842f0e0b65054f37e8bc5332d08 " ,
" 67a5a6e195a43d1492461d65ac8dd2b254b1467bfe85342cec8fe6ae9892ca1e " ) , (
" bd6d4da3fcb81b710dbba70051fe8d565c47419517fea3d20639667edb415413 " ,
" 07fc16e5a1523005ca08be860c4dc58413b773c1c15f9079c6d373f9e2f93228 " ) , (
" e49799e28327a6e8f4a1d1ad7290345a37a263284517b094d325e7e17593971d " ,
" 641a4439c23e414ef21dd7a563cd75f533a3e26b1e11f5d207d29629d5c4d416 " ) , (
" c0ba522a52198ab0a79d935b17eb57611d141f0ac3864e2a37439e4996591e24 " ,
" 78fe086005cd3baaa5315cd138530ef4d7f6febc6e427cd71625329c56419312 " ) , (
" 871ee440ba18913aeec0d7fac20c9671e4ceba8e1cde2dc74e2636ca57de6922 " ,
" 9d2e7c22c6b8b723b06e5960c92b1a7e6cc4cd11619ec7f21b7c1543103aae2a " ) , (
" ab5a1272cd4e16be953511a5c5ef9ea24f0072f8bd976314d260757ed0b30c12 " ,
" ebfc21341bfde18f6f7fe1b883d83b43278a635b5d699525aeaa2eec2aba211e " ) , (
" 2c9e91994096c903e90144689053f6f3d9645bc6e11ce48e82facfb03551c41b " ,
" f9cb618cc78c0e630f3035da914c8606ac1b6629657210308509cf6724748300 " ) , (
" ba41a3b75d7fdd1962feddb3ebabfb1ed01480334dd3bcae3e45f80db0353123 " ,
" 39eecd2d4a751206f4aeed3dba6d9acc0aefddba1897eb91731f767ed94cfd07 " ) , (
" ccf1feef0bca203265ffda1e22d88c7d23db4244658f8b3629cc1c7bec17fe02 " ,
" 093c3209e63e409899050e2b2e17b6397a9e6c9f267056b1300814d9bfadf80c " ) , (
" 7c2f59be680d820f1fdd4b95982b31931cf3d218088e36f1400d07089f1c2211 " ,
" 67eb216710fae6f8cdc776e8edbe6adedb670d2ae92a399e80d35ed1dd82de16 " ) , (
" 94063e3fa709f74b22761cbc400d3b7971b0e32d75de9618c11caa06c6d0c012 " ,
" c2eefc502f09e9098c554d7db21cc4ebe3432baed062fb7f1a70d3ea76044d18 " ) , (
" bd8a78715e32d4d7b263b2f358509157a8f1488a48860cb4dae04501e5040926 " ,
" f9dac2ab11885c3478469582ec619714623485572a65839aa6a6254c7fbfc914 " ) , (
" c742d8f410f594be95b9c70f30ab2b3c752388f5d5c139653e3e1f46a3ea1c2a " ,
" 39a28b57b0341b76c9a6d8d4502702aa79f03b6b4c71b4a8b16ee73289f9a405 " ) , (
" b74ce76b34b4e0bea87c576b4185f6e0e2fe60a1ee29a7be6685ab06f84b340d " ,
" fabe6f436f34a98de98776d7170a537afdc4e697933ef83f3ee083619eb6550b " ) , (
" 89f3b3d0a0563fdb52d340d60bd4a94acb8e9fcb1a078b3784f5d5dd0a76bc2f " ,
" 54e5e2dc8bee937a903dbb41fda7d26855d1a852c10f86e60fadae5284a2d82c " ) , (
" 6a2b21264c42a6fe6968eb4d9539f7d3bd02b0598c58c2a4e709249016720b0d " ,
" a02038d629f056214390c7c3d07b29d9fd2187e671bf68edfc4c4e6d215e2a1d " ) , (
" a7f518c047cb8af54cbab674f684d2114517a5ece15b38511333fe60fa75b10a " ,
" e092a4f17f93aabe3b062cd0a41321a3cef624c1b6cfd943d3a5f1834cb2ae03 " ) ]
2022-08-05 20:58:19 +00:00
# STATIC_GROUP_MERKLE_ROOT is the root of the Merkle tree constructed from the STATIC_GROUP_KEYS above
# only identity commitments are used for the Merkle tree construction
# the root is created locally, using createMembershipList proc from waku_rln_relay_utils module, and the result is hardcoded in here
2022-08-17 10:11:46 +00:00
STATIC_GROUP_MERKLE_ROOT * = " 805be2ac92bc8b21bf093440f5a8055a8a4ec7bf5c5af5e22680d9123a4a5c2b "
2021-09-17 17:31:25 +00:00
2022-05-10 21:09:18 +00:00
const EPOCH_UNIT_SECONDS * = float64 ( 10 ) # the rln-relay epoch length in seconds
2022-02-16 22:52:21 +00:00
const MAX_CLOCK_GAP_SECONDS * = 20 .0 # the maximum clock difference between peers in seconds
2022-05-10 21:09:18 +00:00
# maximum allowed gap between the epochs of messages' RateLimitProofs
const MAX_EPOCH_GAP * = int64 ( MAX_CLOCK_GAP_SECONDS / EPOCH_UNIT_SECONDS )
2021-10-20 00:37:29 +00:00
2021-11-23 22:48:40 +00:00
# Protobufs enc and init
2021-10-20 00:37:29 +00:00
proc init * ( T : type RateLimitProof , buffer : seq [ byte ] ) : ProtoResult [ T ] =
var nsp : RateLimitProof
let pb = initProtoBuffer ( buffer )
var proof : seq [ byte ]
discard ? pb . getField ( 1 , proof )
discard nsp . proof . copyFrom ( proof )
var merkleRoot : seq [ byte ]
discard ? pb . getField ( 2 , merkleRoot )
discard nsp . merkleRoot . copyFrom ( merkleRoot )
var epoch : seq [ byte ]
discard ? pb . getField ( 3 , epoch )
discard nsp . epoch . copyFrom ( epoch )
var shareX : seq [ byte ]
discard ? pb . getField ( 4 , shareX )
discard nsp . shareX . copyFrom ( shareX )
var shareY : seq [ byte ]
discard ? pb . getField ( 5 , shareY )
discard nsp . shareY . copyFrom ( shareY )
var nullifier : seq [ byte ]
discard ? pb . getField ( 6 , nullifier )
discard nsp . nullifier . copyFrom ( nullifier )
2022-08-05 20:58:19 +00:00
when defined ( rlnzerokit ) :
var rlnIdentifier : seq [ byte ]
discard ? pb . getField ( 7 , rlnIdentifier )
discard nsp . rlnIdentifier . copyFrom ( rlnIdentifier )
2022-05-10 21:09:18 +00:00
return ok ( nsp )
2021-10-20 00:37:29 +00:00
2022-05-10 21:09:18 +00:00
proc encode * ( nsp : RateLimitProof ) : ProtoBuffer =
2021-10-20 00:37:29 +00:00
var output = initProtoBuffer ( )
2022-06-16 14:04:47 +00:00
output . write3 ( 1 , nsp . proof )
output . write3 ( 2 , nsp . merkleRoot )
output . write3 ( 3 , nsp . epoch )
output . write3 ( 4 , nsp . shareX )
output . write3 ( 5 , nsp . shareY )
output . write3 ( 6 , nsp . nullifier )
2022-08-05 20:58:19 +00:00
when defined ( rlnzerokit ) :
output . write3 ( 7 , nsp . rlnIdentifier )
2022-06-16 14:04:47 +00:00
output . finish3 ( )
2021-10-20 00:37:29 +00:00
2022-08-05 20:58:19 +00:00
return output