@waku/rln 0.1.3 → 0.1.4-d27db21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (341) hide show
  1. package/README.md +10 -186
  2. package/bundle/_virtual/__node-resolve_empty.js +6 -0
  3. package/bundle/_virtual/_assert.js +3 -0
  4. package/bundle/_virtual/_commonjs-dynamic-modules.js +5 -0
  5. package/bundle/_virtual/_commonjsHelpers.js +32 -0
  6. package/bundle/_virtual/_node-resolve_empty.js +3 -0
  7. package/bundle/_virtual/_sha2.js +3 -0
  8. package/bundle/_virtual/_u64.js +3 -0
  9. package/bundle/_virtual/aes.js +3 -0
  10. package/bundle/_virtual/bn.js +3 -0
  11. package/bundle/_virtual/browser.js +3 -0
  12. package/bundle/_virtual/checksum.js +3 -0
  13. package/bundle/_virtual/cipher.js +3 -0
  14. package/bundle/_virtual/class.js +3 -0
  15. package/bundle/_virtual/common.js +3 -0
  16. package/bundle/_virtual/common2.js +3 -0
  17. package/bundle/_virtual/cryptoBrowser.js +3 -0
  18. package/bundle/_virtual/functional.js +3 -0
  19. package/bundle/_virtual/hash.js +3 -0
  20. package/bundle/_virtual/hmac.js +3 -0
  21. package/bundle/_virtual/index.js +3 -0
  22. package/bundle/_virtual/index2.js +6 -0
  23. package/bundle/_virtual/inherits_browser.js +3 -0
  24. package/bundle/_virtual/kdf.js +3 -0
  25. package/bundle/_virtual/lodash.js +3 -0
  26. package/bundle/_virtual/password.js +3 -0
  27. package/bundle/_virtual/pbkdf2.js +3 -0
  28. package/bundle/_virtual/pbkdf22.js +3 -0
  29. package/bundle/_virtual/random.js +3 -0
  30. package/bundle/_virtual/ripemd.js +3 -0
  31. package/bundle/_virtual/schema-validation-generated.js +3 -0
  32. package/bundle/_virtual/schema-validation.js +3 -0
  33. package/bundle/_virtual/scrypt.js +3 -0
  34. package/bundle/_virtual/scrypt2.js +3 -0
  35. package/bundle/_virtual/sha.js +3 -0
  36. package/bundle/_virtual/sha256.js +3 -0
  37. package/bundle/_virtual/sha2562.js +3 -0
  38. package/bundle/_virtual/sha3.js +3 -0
  39. package/bundle/_virtual/sha512.js +3 -0
  40. package/bundle/_virtual/types.js +3 -0
  41. package/bundle/_virtual/utils.js +3 -0
  42. package/bundle/_virtual/utils2.js +3 -0
  43. package/bundle/_virtual/utils3.js +3 -0
  44. package/bundle/index.js +12 -74804
  45. package/bundle/node_modules/@ethersproject/abi/lib.esm/_version.js +3 -0
  46. package/bundle/node_modules/@ethersproject/abi/lib.esm/abi-coder.js +96 -0
  47. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/abstract-coder.js +148 -0
  48. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/address.js +26 -0
  49. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/anonymous.js +20 -0
  50. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/array.js +210 -0
  51. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/boolean.js +18 -0
  52. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/bytes.js +30 -0
  53. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/fixed-bytes.js +26 -0
  54. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/null.js +22 -0
  55. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/number.js +43 -0
  56. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/string.js +19 -0
  57. package/bundle/node_modules/@ethersproject/abi/lib.esm/coders/tuple.js +58 -0
  58. package/bundle/node_modules/@ethersproject/abi/lib.esm/fragments.js +854 -0
  59. package/bundle/node_modules/@ethersproject/abi/lib.esm/interface.js +609 -0
  60. package/bundle/node_modules/@ethersproject/abstract-provider/lib.esm/_version.js +3 -0
  61. package/bundle/node_modules/@ethersproject/abstract-provider/lib.esm/index.js +66 -0
  62. package/bundle/node_modules/@ethersproject/abstract-signer/lib.esm/_version.js +3 -0
  63. package/bundle/node_modules/@ethersproject/abstract-signer/lib.esm/index.js +302 -0
  64. package/bundle/node_modules/@ethersproject/address/lib.esm/_version.js +3 -0
  65. package/bundle/node_modules/@ethersproject/address/lib.esm/index.js +110 -0
  66. package/bundle/node_modules/@ethersproject/base64/lib.esm/base64.js +20 -0
  67. package/bundle/node_modules/@ethersproject/basex/lib.esm/index.js +120 -0
  68. package/bundle/node_modules/@ethersproject/bignumber/lib.esm/_version.js +3 -0
  69. package/bundle/node_modules/@ethersproject/bignumber/lib.esm/bignumber.js +287 -0
  70. package/bundle/node_modules/@ethersproject/bytes/lib.esm/_version.js +3 -0
  71. package/bundle/node_modules/@ethersproject/bytes/lib.esm/index.js +402 -0
  72. package/bundle/node_modules/@ethersproject/constants/lib.esm/addresses.js +3 -0
  73. package/bundle/node_modules/@ethersproject/constants/lib.esm/bignumbers.js +8 -0
  74. package/bundle/node_modules/@ethersproject/constants/lib.esm/hashes.js +3 -0
  75. package/bundle/node_modules/@ethersproject/contracts/lib.esm/_version.js +3 -0
  76. package/bundle/node_modules/@ethersproject/contracts/lib.esm/index.js +893 -0
  77. package/bundle/node_modules/@ethersproject/hash/lib.esm/_version.js +3 -0
  78. package/bundle/node_modules/@ethersproject/hash/lib.esm/ens-normalize/decoder.js +256 -0
  79. package/bundle/node_modules/@ethersproject/hash/lib.esm/ens-normalize/include.js +36 -0
  80. package/bundle/node_modules/@ethersproject/hash/lib.esm/ens-normalize/lib.js +135 -0
  81. package/bundle/node_modules/@ethersproject/hash/lib.esm/id.js +8 -0
  82. package/bundle/node_modules/@ethersproject/hash/lib.esm/namehash.js +64 -0
  83. package/bundle/node_modules/@ethersproject/hash/lib.esm/typed-data.js +443 -0
  84. package/bundle/node_modules/@ethersproject/keccak256/lib.esm/index.js +8 -0
  85. package/bundle/node_modules/@ethersproject/keccak256/node_modules/js-sha3/src/sha3.js +660 -0
  86. package/bundle/node_modules/@ethersproject/logger/lib.esm/_version.js +3 -0
  87. package/bundle/node_modules/@ethersproject/logger/lib.esm/index.js +352 -0
  88. package/bundle/node_modules/@ethersproject/networks/lib.esm/_version.js +3 -0
  89. package/bundle/node_modules/@ethersproject/networks/lib.esm/index.js +248 -0
  90. package/bundle/node_modules/@ethersproject/properties/lib.esm/_version.js +3 -0
  91. package/bundle/node_modules/@ethersproject/properties/lib.esm/index.js +127 -0
  92. package/bundle/node_modules/@ethersproject/providers/lib.esm/_version.js +3 -0
  93. package/bundle/node_modules/@ethersproject/providers/lib.esm/base-provider.js +2007 -0
  94. package/bundle/node_modules/@ethersproject/providers/lib.esm/formatter.js +422 -0
  95. package/bundle/node_modules/@ethersproject/providers/lib.esm/json-rpc-provider.js +674 -0
  96. package/bundle/node_modules/@ethersproject/providers/lib.esm/web3-provider.js +132 -0
  97. package/bundle/node_modules/@ethersproject/rlp/lib.esm/_version.js +3 -0
  98. package/bundle/node_modules/@ethersproject/rlp/lib.esm/index.js +120 -0
  99. package/bundle/node_modules/@ethersproject/sha2/lib.esm/sha2.js +8 -0
  100. package/bundle/node_modules/@ethersproject/signing-key/lib.esm/_version.js +3 -0
  101. package/bundle/node_modules/@ethersproject/signing-key/lib.esm/elliptic.js +2430 -0
  102. package/bundle/node_modules/@ethersproject/signing-key/lib.esm/index.js +76 -0
  103. package/bundle/node_modules/@ethersproject/strings/lib.esm/_version.js +3 -0
  104. package/bundle/node_modules/@ethersproject/strings/lib.esm/utf8.js +219 -0
  105. package/bundle/node_modules/@ethersproject/transactions/lib.esm/_version.js +3 -0
  106. package/bundle/node_modules/@ethersproject/transactions/lib.esm/index.js +279 -0
  107. package/bundle/node_modules/@ethersproject/web/lib.esm/_version.js +3 -0
  108. package/bundle/node_modules/@ethersproject/web/lib.esm/geturl.js +69 -0
  109. package/bundle/node_modules/@ethersproject/web/lib.esm/index.js +404 -0
  110. package/bundle/node_modules/@multiformats/multiaddr/dist/src/convert.js +15 -0
  111. package/bundle/node_modules/@multiformats/multiaddr/dist/src/multiaddr.js +20 -0
  112. package/bundle/node_modules/@multiformats/multiaddr/dist/src/protocols-table.js +92 -0
  113. package/bundle/node_modules/@noble/hashes/esm/_assert.js +37 -0
  114. package/bundle/node_modules/@noble/hashes/esm/_md.js +132 -0
  115. package/bundle/node_modules/@noble/hashes/esm/_u64.js +29 -0
  116. package/bundle/node_modules/@noble/hashes/esm/sha256.js +113 -0
  117. package/bundle/node_modules/@noble/hashes/esm/sha3.js +210 -0
  118. package/bundle/node_modules/@noble/hashes/esm/utils.js +144 -0
  119. package/bundle/node_modules/@waku/zerokit-rln-wasm/rln_wasm.js +756 -0
  120. package/bundle/node_modules/bech32/index.js +187 -0
  121. package/bundle/node_modules/bn.js/lib/bn.js +3361 -0
  122. package/bundle/node_modules/debug/src/browser.js +283 -0
  123. package/bundle/node_modules/debug/src/common.js +295 -0
  124. package/bundle/node_modules/ethereum-cryptography/esm/keccak.js +10 -0
  125. package/bundle/node_modules/ethereum-cryptography/esm/sha256.js +6 -0
  126. package/bundle/node_modules/ethereum-cryptography/esm/utils.js +24 -0
  127. package/bundle/node_modules/hash.js/lib/hash/common.js +97 -0
  128. package/bundle/node_modules/hash.js/lib/hash/hmac.js +51 -0
  129. package/bundle/node_modules/hash.js/lib/hash/ripemd.js +152 -0
  130. package/bundle/node_modules/hash.js/lib/hash/sha/1.js +81 -0
  131. package/bundle/node_modules/hash.js/lib/hash/sha/224.js +33 -0
  132. package/bundle/node_modules/hash.js/lib/hash/sha/256.js +113 -0
  133. package/bundle/node_modules/hash.js/lib/hash/sha/384.js +39 -0
  134. package/bundle/node_modules/hash.js/lib/hash/sha/512.js +336 -0
  135. package/bundle/node_modules/hash.js/lib/hash/sha/common.js +53 -0
  136. package/bundle/node_modules/hash.js/lib/hash/sha.js +14 -0
  137. package/bundle/node_modules/hash.js/lib/hash/utils.js +282 -0
  138. package/bundle/node_modules/hash.js/lib/hash.js +33 -0
  139. package/bundle/node_modules/inherits/inherits_browser.js +33 -0
  140. package/bundle/node_modules/it-length-prefixed/dist/src/decode.js +6 -0
  141. package/bundle/node_modules/lodash/lodash.js +17207 -0
  142. package/bundle/node_modules/minimalistic-assert/index.js +13 -0
  143. package/bundle/node_modules/ms/index.js +172 -0
  144. package/bundle/node_modules/multiformats/dist/src/bases/base.js +205 -0
  145. package/bundle/node_modules/multiformats/dist/src/bases/base10.js +9 -0
  146. package/bundle/node_modules/multiformats/dist/src/bases/base16.js +16 -0
  147. package/bundle/node_modules/multiformats/dist/src/bases/base2.js +10 -0
  148. package/bundle/node_modules/multiformats/dist/src/bases/base256emoji.js +41 -0
  149. package/bundle/node_modules/multiformats/dist/src/bases/base32.js +58 -0
  150. package/bundle/node_modules/multiformats/dist/src/bases/base36.js +14 -0
  151. package/bundle/node_modules/multiformats/dist/src/bases/base58.js +14 -0
  152. package/bundle/node_modules/multiformats/dist/src/bases/base64.js +28 -0
  153. package/bundle/node_modules/multiformats/dist/src/bases/base8.js +10 -0
  154. package/bundle/node_modules/multiformats/dist/src/bases/identity.js +11 -0
  155. package/bundle/node_modules/multiformats/dist/src/basics.js +15 -0
  156. package/bundle/node_modules/multiformats/dist/src/bytes.js +18 -0
  157. package/bundle/node_modules/multiformats/dist/src/codecs/json.js +2 -0
  158. package/bundle/node_modules/multiformats/dist/src/vendor/base-x.js +170 -0
  159. package/bundle/node_modules/protons-runtime/dist/src/codec.js +20 -0
  160. package/bundle/node_modules/protons-runtime/dist/src/codecs/enum.js +24 -0
  161. package/bundle/node_modules/protons-runtime/dist/src/codecs/message.js +7 -0
  162. package/bundle/node_modules/protons-runtime/dist/src/decode.js +8 -0
  163. package/bundle/node_modules/protons-runtime/dist/src/encode.js +11 -0
  164. package/bundle/node_modules/protons-runtime/dist/src/index.js +30 -0
  165. package/bundle/node_modules/protons-runtime/dist/src/utils/float.js +54 -0
  166. package/bundle/node_modules/protons-runtime/dist/src/utils/longbits.js +175 -0
  167. package/bundle/node_modules/protons-runtime/dist/src/utils/pool.js +28 -0
  168. package/bundle/node_modules/protons-runtime/dist/src/utils/reader.js +367 -0
  169. package/bundle/node_modules/protons-runtime/dist/src/utils/utf8.js +99 -0
  170. package/bundle/node_modules/protons-runtime/dist/src/utils/writer.js +438 -0
  171. package/bundle/node_modules/uint8-varint/dist/src/index.js +124 -0
  172. package/bundle/node_modules/uint8arrays/dist/src/alloc.js +17 -0
  173. package/bundle/node_modules/uint8arrays/dist/src/from-string.js +19 -0
  174. package/bundle/node_modules/uint8arrays/dist/src/util/bases.js +49 -0
  175. package/bundle/packages/core/dist/lib/connection_manager/connection_manager.js +21 -0
  176. package/bundle/packages/core/dist/lib/connection_manager/keep_alive_manager.js +18 -0
  177. package/bundle/packages/core/dist/lib/filter/filter.js +27 -0
  178. package/bundle/packages/core/dist/lib/light_push/light_push.js +27 -0
  179. package/bundle/packages/core/dist/lib/message/version_0.js +154 -0
  180. package/bundle/packages/core/dist/lib/metadata/metadata.js +27 -0
  181. package/bundle/packages/core/dist/lib/store/store.js +27 -0
  182. package/bundle/packages/interfaces/dist/connection_manager.js +19 -0
  183. package/bundle/packages/interfaces/dist/constants.js +6 -0
  184. package/bundle/packages/interfaces/dist/health_indicator.js +12 -0
  185. package/bundle/packages/interfaces/dist/protocols.js +92 -0
  186. package/bundle/packages/proto/dist/generated/filter.js +445 -0
  187. package/bundle/packages/proto/dist/generated/filter_v2.js +424 -0
  188. package/bundle/packages/proto/dist/generated/light_push.js +389 -0
  189. package/bundle/packages/proto/dist/generated/message.js +213 -0
  190. package/bundle/packages/proto/dist/generated/metadata.js +130 -0
  191. package/bundle/packages/proto/dist/generated/peer_exchange.js +209 -0
  192. package/bundle/packages/proto/dist/generated/sds_message.js +105 -0
  193. package/bundle/packages/proto/dist/generated/store_v3.js +490 -0
  194. package/bundle/packages/proto/dist/generated/topic_only_message.js +61 -0
  195. package/bundle/packages/rln/dist/codec.js +93 -0
  196. package/bundle/packages/rln/dist/contract/abi.js +394 -0
  197. package/bundle/packages/rln/dist/contract/constants.js +27 -0
  198. package/bundle/packages/rln/dist/contract/rln_contract.js +438 -0
  199. package/bundle/packages/rln/dist/create.js +9 -0
  200. package/bundle/packages/rln/dist/identity.js +30 -0
  201. package/bundle/packages/rln/dist/keystore/cipher.js +31 -0
  202. package/bundle/packages/rln/dist/keystore/credential_validation_generated.js +119 -0
  203. package/bundle/packages/rln/dist/keystore/keystore.js +223 -0
  204. package/bundle/packages/rln/dist/keystore/keystore_validation_generated.js +74 -0
  205. package/bundle/packages/rln/dist/keystore/schema_validator.js +20 -0
  206. package/bundle/packages/rln/dist/message.js +51 -0
  207. package/bundle/packages/rln/dist/proof.js +54 -0
  208. package/bundle/packages/rln/dist/resources/verification_key.js +112 -0
  209. package/bundle/packages/rln/dist/resources/witness_calculator.js +330 -0
  210. package/bundle/packages/rln/dist/rln.js +220 -0
  211. package/bundle/packages/rln/dist/root_tracker.js +76 -0
  212. package/bundle/packages/rln/dist/utils/bytes.js +65 -0
  213. package/bundle/packages/rln/dist/utils/epoch.js +39 -0
  214. package/bundle/packages/rln/dist/utils/hash.js +10 -0
  215. package/bundle/packages/rln/dist/utils/metamask.js +14 -0
  216. package/bundle/packages/rln/dist/zerokit.js +128 -0
  217. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/checksum.js +52 -0
  218. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/cipher.js +65 -0
  219. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/class.js +99 -0
  220. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/functional.js +103 -0
  221. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/index.js +28 -0
  222. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/kdf.js +78 -0
  223. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/password.js +17 -0
  224. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/schema-validation-generated.js +1253 -0
  225. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/schema-validation.js +40 -0
  226. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/lib/types.js +5 -0
  227. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/aes.js +103 -0
  228. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/pbkdf2.js +41 -0
  229. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/random.js +17 -0
  230. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/scrypt.js +23 -0
  231. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/sha256.js +12 -0
  232. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/utils.js +77 -0
  233. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/index.js +9 -0
  234. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/md5.js +215 -0
  235. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/nil.js +3 -0
  236. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/parse.js +35 -0
  237. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/regex.js +3 -0
  238. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/rng.js +21 -0
  239. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/sha1.js +96 -0
  240. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/stringify.js +31 -0
  241. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v1.js +96 -0
  242. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v3.js +6 -0
  243. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v35.js +66 -0
  244. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v4.js +24 -0
  245. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v5.js +6 -0
  246. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/validate.js +7 -0
  247. package/bundle/packages/rln/node_modules/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/version.js +11 -0
  248. package/bundle/packages/rln/node_modules/@noble/hashes/_assert.js +52 -0
  249. package/bundle/packages/rln/node_modules/@noble/hashes/_sha2.js +124 -0
  250. package/bundle/packages/rln/node_modules/@noble/hashes/_u64.js +71 -0
  251. package/bundle/packages/rln/node_modules/@noble/hashes/cryptoBrowser.js +10 -0
  252. package/bundle/packages/rln/node_modules/@noble/hashes/hmac.js +88 -0
  253. package/bundle/packages/rln/node_modules/@noble/hashes/pbkdf2.js +99 -0
  254. package/bundle/packages/rln/node_modules/@noble/hashes/scrypt.js +233 -0
  255. package/bundle/packages/rln/node_modules/@noble/hashes/sha256.js +133 -0
  256. package/bundle/packages/rln/node_modules/@noble/hashes/sha512.js +243 -0
  257. package/bundle/packages/rln/node_modules/@noble/hashes/utils.js +167 -0
  258. package/bundle/packages/rln/node_modules/uuid/dist/esm-browser/native.js +4 -0
  259. package/bundle/packages/rln/node_modules/uuid/dist/esm-browser/rng.js +13 -0
  260. package/bundle/packages/rln/node_modules/uuid/dist/esm-browser/stringify.js +28 -0
  261. package/bundle/packages/rln/node_modules/uuid/dist/esm-browser/v4.js +19 -0
  262. package/bundle/packages/utils/dist/bytes/index.js +44 -0
  263. package/bundle/packages/utils/dist/common/sharding/index.js +91 -0
  264. package/bundle/packages/utils/dist/logger/index.js +31 -0
  265. package/bundle/resources/verification_key.d.ts +13 -0
  266. package/bundle/resources/verification_key.js +112 -0
  267. package/bundle/resources/witness_calculator.d.ts +11 -0
  268. package/bundle/resources/witness_calculator.js +328 -0
  269. package/dist/.tsbuildinfo +1 -0
  270. package/dist/codec.d.ts +5 -5
  271. package/dist/codec.js +6 -6
  272. package/dist/codec.js.map +1 -1
  273. package/dist/contract/abi.d.ts +42 -0
  274. package/dist/contract/abi.js +393 -0
  275. package/dist/contract/abi.js.map +1 -0
  276. package/dist/contract/constants.d.ts +59 -3
  277. package/dist/contract/constants.js +21 -63
  278. package/dist/contract/constants.js.map +1 -1
  279. package/dist/contract/rln_contract.d.ts +98 -17
  280. package/dist/contract/rln_contract.js +292 -71
  281. package/dist/contract/rln_contract.js.map +1 -1
  282. package/dist/identity.js +5 -2
  283. package/dist/identity.js.map +1 -1
  284. package/dist/index.d.ts +3 -3
  285. package/dist/index.js +3 -3
  286. package/dist/index.js.map +1 -1
  287. package/dist/keystore/cipher.js +3 -3
  288. package/dist/keystore/cipher.js.map +1 -1
  289. package/dist/keystore/credential_validation_generated.js.map +1 -1
  290. package/dist/keystore/keystore.js +4 -4
  291. package/dist/keystore/keystore.js.map +1 -1
  292. package/dist/keystore/keystore_validation_generated.js.map +1 -1
  293. package/dist/message.js +3 -3
  294. package/dist/message.js.map +1 -1
  295. package/dist/proof.js +3 -2
  296. package/dist/proof.js.map +1 -1
  297. package/dist/resources/verification_key.d.ts +12 -11
  298. package/dist/resources/verification_key.js +103 -103
  299. package/dist/resources/witness_calculator.d.ts +10 -15
  300. package/dist/resources/witness_calculator.js +302 -265
  301. package/dist/rln.d.ts +5 -1
  302. package/dist/rln.js +56 -28
  303. package/dist/rln.js.map +1 -1
  304. package/dist/root_tracker.js.map +1 -1
  305. package/dist/utils/epoch.js +5 -5
  306. package/dist/utils/epoch.js.map +1 -1
  307. package/dist/zerokit.d.ts +13 -9
  308. package/dist/zerokit.js +40 -20
  309. package/dist/zerokit.js.map +1 -1
  310. package/package.json +1 -146
  311. package/src/codec.ts +26 -22
  312. package/src/contract/abi.ts +392 -0
  313. package/src/contract/constants.ts +28 -0
  314. package/src/contract/index.ts +2 -0
  315. package/src/contract/rln_contract.ts +686 -0
  316. package/src/identity.ts +8 -4
  317. package/src/index.ts +4 -9
  318. package/src/keystore/cipher.ts +54 -0
  319. package/src/keystore/credential_validation_generated.ts +7 -0
  320. package/src/keystore/index.ts +5 -0
  321. package/src/keystore/keystore.ts +330 -0
  322. package/src/keystore/keystore_validation_generated.ts +7 -0
  323. package/src/keystore/schema_validator.ts +34 -0
  324. package/src/keystore/types.ts +36 -0
  325. package/src/message.ts +10 -10
  326. package/src/proof.ts +13 -11
  327. package/src/resources/verification_key.d.ts +13 -0
  328. package/src/resources/witness_calculator.d.ts +11 -0
  329. package/src/rln.ts +76 -31
  330. package/src/root_tracker.ts +7 -6
  331. package/src/utils/bytes.ts +84 -0
  332. package/src/utils/epoch.ts +30 -0
  333. package/src/utils/hash.ts +15 -0
  334. package/src/utils/index.ts +9 -0
  335. package/src/utils/metamask.ts +17 -0
  336. package/src/zerokit.ts +95 -33
  337. package/bundle/assets/rln_wasm_bg-a503e304.wasm +0 -0
  338. package/dist/resources/verification_key.js.map +0 -1
  339. package/dist/resources/witness_calculator.js.map +0 -1
  340. /package/bundle/{assets/rln-6ded2896.wasm → resources/rln.wasm} +0 -0
  341. /package/bundle/{assets/rln_final-8b299152.zkey → resources/rln_final.zkey} +0 -0
package/src/codec.ts CHANGED
@@ -6,40 +6,42 @@ import type {
6
6
  IProtoMessage,
7
7
  IRateLimitProof
8
8
  } from "@waku/interfaces";
9
- import debug from "debug";
9
+ import { Logger } from "@waku/utils";
10
10
 
11
11
  import type { IdentityCredential } from "./identity.js";
12
12
  import { RlnMessage, toRLNSignal } from "./message.js";
13
13
  import { RLNInstance } from "./rln.js";
14
14
 
15
- const log = debug("waku:rln:encoder");
15
+ const log = new Logger("waku:rln:encoder");
16
16
 
17
17
  export class RLNEncoder implements IEncoder {
18
18
  private readonly idSecretHash: Uint8Array;
19
19
 
20
- constructor(
21
- private encoder: IEncoder,
22
- private rlnInstance: RLNInstance,
23
- private index: number,
20
+ public constructor(
21
+ private readonly encoder: IEncoder,
22
+ private readonly rlnInstance: RLNInstance,
23
+ private readonly index: number,
24
24
  identityCredential: IdentityCredential
25
25
  ) {
26
- if (index < 0) throw "invalid membership index";
26
+ if (index < 0) throw new Error("Invalid membership index");
27
27
  this.idSecretHash = identityCredential.IDSecretHash;
28
28
  }
29
29
 
30
- async toWire(message: IMessage): Promise<Uint8Array | undefined> {
30
+ public async toWire(message: IMessage): Promise<Uint8Array | undefined> {
31
31
  message.rateLimitProof = await this.generateProof(message);
32
- log("Proof generated", message.rateLimitProof);
32
+ log.info("Proof generated", message.rateLimitProof);
33
33
  return this.encoder.toWire(message);
34
34
  }
35
35
 
36
- async toProtoObj(message: IMessage): Promise<IProtoMessage | undefined> {
36
+ public async toProtoObj(
37
+ message: IMessage
38
+ ): Promise<IProtoMessage | undefined> {
37
39
  const protoMessage = await this.encoder.toProtoObj(message);
38
40
  if (!protoMessage) return;
39
41
 
40
42
  protoMessage.contentTopic = this.contentTopic;
41
43
  protoMessage.rateLimitProof = await this.generateProof(message);
42
- log("Proof generated", protoMessage.rateLimitProof);
44
+ log.info("Proof generated", protoMessage.rateLimitProof);
43
45
  return protoMessage;
44
46
  }
45
47
 
@@ -54,15 +56,15 @@ export class RLNEncoder implements IEncoder {
54
56
  return proof;
55
57
  }
56
58
 
57
- get pubsubTopic(): string {
59
+ public get pubsubTopic(): string {
58
60
  return this.encoder.pubsubTopic;
59
61
  }
60
62
 
61
- get contentTopic(): string {
63
+ public get contentTopic(): string {
62
64
  return this.encoder.contentTopic;
63
65
  }
64
66
 
65
- get ephemeral(): boolean {
67
+ public get ephemeral(): boolean {
66
68
  return this.encoder.ephemeral;
67
69
  }
68
70
  }
@@ -86,26 +88,28 @@ export const createRLNEncoder = (options: RLNEncoderOptions): RLNEncoder => {
86
88
  export class RLNDecoder<T extends IDecodedMessage>
87
89
  implements IDecoder<RlnMessage<T>>
88
90
  {
89
- constructor(
90
- private rlnInstance: RLNInstance,
91
- private decoder: IDecoder<T>
91
+ public constructor(
92
+ private readonly rlnInstance: RLNInstance,
93
+ private readonly decoder: IDecoder<T>
92
94
  ) {}
93
95
 
94
- get pubsubTopic(): string {
96
+ public get pubsubTopic(): string {
95
97
  return this.decoder.pubsubTopic;
96
98
  }
97
99
 
98
- get contentTopic(): string {
100
+ public get contentTopic(): string {
99
101
  return this.decoder.contentTopic;
100
102
  }
101
103
 
102
- fromWireToProtoObj(bytes: Uint8Array): Promise<IProtoMessage | undefined> {
104
+ public fromWireToProtoObj(
105
+ bytes: Uint8Array
106
+ ): Promise<IProtoMessage | undefined> {
103
107
  const protoMessage = this.decoder.fromWireToProtoObj(bytes);
104
- log("Message decoded", protoMessage);
108
+ log.info("Message decoded", protoMessage);
105
109
  return Promise.resolve(protoMessage);
106
110
  }
107
111
 
108
- async fromProtoObj(
112
+ public async fromProtoObj(
109
113
  pubsubTopic: string,
110
114
  proto: IProtoMessage
111
115
  ): Promise<RlnMessage<T> | undefined> {
@@ -0,0 +1,392 @@
1
+ export const RLN_ABI = [
2
+ {
3
+ type: "constructor",
4
+ inputs: [],
5
+ stateMutability: "nonpayable"
6
+ },
7
+ {
8
+ type: "error",
9
+ name: "DuplicateIdCommitment",
10
+ inputs: []
11
+ },
12
+ {
13
+ type: "error",
14
+ name: "InvalidIdCommitment",
15
+ inputs: [
16
+ {
17
+ name: "idCommitment",
18
+ type: "uint256"
19
+ }
20
+ ]
21
+ },
22
+ {
23
+ type: "error",
24
+ name: "InvalidPaginationQuery",
25
+ inputs: [
26
+ {
27
+ name: "startIndex",
28
+ type: "uint256"
29
+ },
30
+ {
31
+ name: "endIndex",
32
+ type: "uint256"
33
+ }
34
+ ]
35
+ },
36
+ {
37
+ type: "function",
38
+ name: "MAX_MEMBERSHIP_SET_SIZE",
39
+ inputs: [],
40
+ outputs: [
41
+ {
42
+ name: "",
43
+ type: "uint32"
44
+ }
45
+ ],
46
+ stateMutability: "view"
47
+ },
48
+ {
49
+ type: "function",
50
+ name: "MERKLE_TREE_DEPTH",
51
+ inputs: [],
52
+ outputs: [
53
+ {
54
+ name: "",
55
+ type: "uint8"
56
+ }
57
+ ],
58
+ stateMutability: "view"
59
+ },
60
+ {
61
+ type: "function",
62
+ name: "Q",
63
+ inputs: [],
64
+ outputs: [
65
+ {
66
+ name: "",
67
+ type: "uint256"
68
+ }
69
+ ],
70
+ stateMutability: "view"
71
+ },
72
+ {
73
+ type: "function",
74
+ name: "activeDurationForNewMemberships",
75
+ inputs: [],
76
+ outputs: [
77
+ {
78
+ name: "",
79
+ type: "uint32"
80
+ }
81
+ ],
82
+ stateMutability: "view"
83
+ },
84
+ {
85
+ type: "function",
86
+ name: "currentTotalRateLimit",
87
+ inputs: [],
88
+ outputs: [
89
+ {
90
+ name: "",
91
+ type: "uint256"
92
+ }
93
+ ],
94
+ stateMutability: "view"
95
+ },
96
+ {
97
+ type: "function",
98
+ name: "deployedBlockNumber",
99
+ inputs: [],
100
+ outputs: [
101
+ {
102
+ name: "",
103
+ type: "uint32"
104
+ }
105
+ ],
106
+ stateMutability: "view"
107
+ },
108
+ {
109
+ type: "function",
110
+ name: "depositsToWithdraw",
111
+ inputs: [
112
+ {
113
+ name: "holder",
114
+ type: "address"
115
+ },
116
+ {
117
+ name: "token",
118
+ type: "address"
119
+ }
120
+ ],
121
+ outputs: [
122
+ {
123
+ name: "balance",
124
+ type: "uint256"
125
+ }
126
+ ],
127
+ stateMutability: "view"
128
+ },
129
+ {
130
+ type: "function",
131
+ name: "eraseMemberships",
132
+ inputs: [
133
+ {
134
+ name: "idCommitments",
135
+ type: "uint256[]"
136
+ }
137
+ ],
138
+ outputs: [],
139
+ stateMutability: "nonpayable"
140
+ },
141
+ {
142
+ type: "function",
143
+ name: "eraseMemberships",
144
+ inputs: [
145
+ {
146
+ name: "idCommitments",
147
+ type: "uint256[]"
148
+ },
149
+ {
150
+ name: "eraseFromMembershipSet",
151
+ type: "bool"
152
+ }
153
+ ],
154
+ outputs: [],
155
+ stateMutability: "nonpayable"
156
+ },
157
+ {
158
+ type: "function",
159
+ name: "extendMemberships",
160
+ inputs: [
161
+ {
162
+ name: "idCommitments",
163
+ type: "uint256[]"
164
+ }
165
+ ],
166
+ outputs: [],
167
+ stateMutability: "nonpayable"
168
+ },
169
+ {
170
+ type: "function",
171
+ name: "getMembershipInfo",
172
+ inputs: [
173
+ {
174
+ name: "idCommitment",
175
+ type: "uint256"
176
+ }
177
+ ],
178
+ outputs: [
179
+ {
180
+ name: "",
181
+ type: "uint32"
182
+ },
183
+ {
184
+ name: "",
185
+ type: "uint32"
186
+ },
187
+ {
188
+ name: "",
189
+ type: "uint256"
190
+ }
191
+ ],
192
+ stateMutability: "view"
193
+ },
194
+ {
195
+ type: "function",
196
+ name: "getMerkleProof",
197
+ inputs: [
198
+ {
199
+ name: "index",
200
+ type: "uint40"
201
+ }
202
+ ],
203
+ outputs: [
204
+ {
205
+ name: "",
206
+ type: "uint256[20]"
207
+ }
208
+ ],
209
+ stateMutability: "view"
210
+ },
211
+ {
212
+ type: "function",
213
+ name: "getRateCommitmentsInRangeBoundsInclusive",
214
+ inputs: [
215
+ {
216
+ name: "startIndex",
217
+ type: "uint32"
218
+ },
219
+ {
220
+ name: "endIndex",
221
+ type: "uint32"
222
+ }
223
+ ],
224
+ outputs: [
225
+ {
226
+ name: "",
227
+ type: "uint256[]"
228
+ }
229
+ ],
230
+ stateMutability: "view"
231
+ },
232
+ {
233
+ type: "function",
234
+ name: "gracePeriodDurationForNewMemberships",
235
+ inputs: [],
236
+ outputs: [
237
+ {
238
+ name: "",
239
+ type: "uint32"
240
+ }
241
+ ],
242
+ stateMutability: "view"
243
+ },
244
+ {
245
+ type: "function",
246
+ name: "initialize",
247
+ inputs: [
248
+ {
249
+ name: "_priceCalculator",
250
+ type: "address"
251
+ },
252
+ {
253
+ name: "_maxTotalRateLimit",
254
+ type: "uint32"
255
+ },
256
+ {
257
+ name: "_minMembershipRateLimit",
258
+ type: "uint32"
259
+ },
260
+ {
261
+ name: "_maxMembershipRateLimit",
262
+ type: "uint32"
263
+ },
264
+ {
265
+ name: "_activeDuration",
266
+ type: "uint32"
267
+ },
268
+ {
269
+ name: "_gracePeriod",
270
+ type: "uint32"
271
+ }
272
+ ],
273
+ outputs: [],
274
+ stateMutability: "nonpayable"
275
+ },
276
+ {
277
+ type: "function",
278
+ name: "isExpired",
279
+ inputs: [
280
+ {
281
+ name: "_idCommitment",
282
+ type: "uint256"
283
+ }
284
+ ],
285
+ outputs: [
286
+ {
287
+ name: "",
288
+ type: "bool"
289
+ }
290
+ ],
291
+ stateMutability: "view"
292
+ },
293
+ {
294
+ type: "function",
295
+ name: "register",
296
+ inputs: [
297
+ {
298
+ name: "idCommitment",
299
+ type: "uint256"
300
+ },
301
+ {
302
+ name: "rateLimit",
303
+ type: "uint32"
304
+ },
305
+ {
306
+ name: "idCommitmentsToErase",
307
+ type: "uint256[]"
308
+ }
309
+ ],
310
+ outputs: [],
311
+ stateMutability: "nonpayable"
312
+ },
313
+ {
314
+ type: "function",
315
+ name: "registerWithPermit",
316
+ inputs: [
317
+ {
318
+ name: "owner",
319
+ type: "address"
320
+ },
321
+ {
322
+ name: "deadline",
323
+ type: "uint256"
324
+ },
325
+ {
326
+ name: "v",
327
+ type: "uint8"
328
+ },
329
+ {
330
+ name: "r",
331
+ type: "bytes32"
332
+ },
333
+ {
334
+ name: "s",
335
+ type: "bytes32"
336
+ },
337
+ {
338
+ name: "idCommitment",
339
+ type: "uint256"
340
+ },
341
+ {
342
+ name: "rateLimit",
343
+ type: "uint32"
344
+ },
345
+ {
346
+ name: "idCommitmentsToErase",
347
+ type: "uint256[]"
348
+ }
349
+ ],
350
+ outputs: [],
351
+ stateMutability: "nonpayable"
352
+ },
353
+ {
354
+ type: "event",
355
+ name: "MembershipRegistered",
356
+ inputs: [
357
+ {
358
+ name: "idCommitment",
359
+ type: "uint256",
360
+ indexed: false
361
+ },
362
+ {
363
+ name: "rateLimit",
364
+ type: "uint32",
365
+ indexed: false
366
+ },
367
+ {
368
+ name: "index",
369
+ type: "uint256",
370
+ indexed: false
371
+ }
372
+ ],
373
+ anonymous: false
374
+ },
375
+ {
376
+ type: "event",
377
+ name: "MembershipRemoved",
378
+ inputs: [
379
+ {
380
+ name: "idCommitment",
381
+ type: "uint256",
382
+ indexed: false
383
+ },
384
+ {
385
+ name: "index",
386
+ type: "uint256",
387
+ indexed: false
388
+ }
389
+ ],
390
+ anonymous: false
391
+ }
392
+ ];
@@ -0,0 +1,28 @@
1
+ import { RLN_ABI } from "./abi.js";
2
+
3
+ export const SEPOLIA_CONTRACT = {
4
+ chainId: 11155111,
5
+ address: "0xCB33Aa5B38d79E3D9Fa8B10afF38AA201399a7e3",
6
+ abi: RLN_ABI
7
+ };
8
+
9
+ /**
10
+ * Rate limit tiers (messages per epoch)
11
+ * Each membership can specify a rate limit within these bounds.
12
+ * @see https://github.com/waku-org/specs/blob/master/standards/core/rln-contract.md#implementation-suggestions
13
+ */
14
+ export const RATE_LIMIT_TIERS = {
15
+ LOW: 20, // Suggested minimum rate - 20 messages per epoch
16
+ MEDIUM: 200,
17
+ HIGH: 600 // Suggested maximum rate - 600 messages per epoch
18
+ } as const;
19
+
20
+ // Global rate limit parameters
21
+ export const RATE_LIMIT_PARAMS = {
22
+ MIN_RATE: RATE_LIMIT_TIERS.LOW,
23
+ MAX_RATE: RATE_LIMIT_TIERS.HIGH,
24
+ MAX_TOTAL_RATE: 160_000, // Maximum total rate limit across all memberships
25
+ EPOCH_LENGTH: 600 // Epoch length in seconds (10 minutes)
26
+ } as const;
27
+
28
+ export const DEFAULT_RATE_LIMIT = RATE_LIMIT_PARAMS.MAX_RATE;
@@ -0,0 +1,2 @@
1
+ export { RLNContract } from "./rln_contract.js";
2
+ export * from "./constants.js";