@waku/rln 0.0.1 → 0.0.2-00f2e75.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 (397) hide show
  1. package/README.md +12 -108
  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 -10
  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 +648 -0
  197. package/bundle/packages/rln/dist/contract/constants.js +28 -0
  198. package/bundle/packages/rln/dist/contract/rln_contract.js +629 -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 +222 -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/rln.wasm +0 -0
  266. package/bundle/resources/rln_final.zkey +0 -0
  267. package/bundle/resources/verification_key.d.ts +13 -0
  268. package/bundle/resources/verification_key.js +112 -0
  269. package/bundle/resources/witness_calculator.d.ts +11 -0
  270. package/bundle/resources/witness_calculator.js +328 -0
  271. package/dist/.tsbuildinfo +1 -1
  272. package/dist/codec.d.ts +39 -0
  273. package/dist/codec.js +77 -0
  274. package/dist/codec.js.map +1 -0
  275. package/dist/contract/abi.d.ts +46 -0
  276. package/dist/contract/abi.js +647 -0
  277. package/dist/contract/abi.js.map +1 -0
  278. package/dist/contract/constants.d.ts +67 -0
  279. package/dist/contract/constants.js +26 -0
  280. package/dist/contract/constants.js.map +1 -0
  281. package/dist/contract/index.d.ts +2 -0
  282. package/dist/contract/index.js +3 -0
  283. package/dist/contract/index.js.map +1 -0
  284. package/dist/contract/rln_contract.d.ts +135 -0
  285. package/dist/contract/rln_contract.js +623 -0
  286. package/dist/contract/rln_contract.js.map +1 -0
  287. package/dist/create.d.ts +2 -0
  288. package/dist/create.js +8 -0
  289. package/dist/create.js.map +1 -0
  290. package/dist/identity.d.ts +9 -0
  291. package/dist/identity.js +27 -0
  292. package/dist/identity.js.map +1 -0
  293. package/dist/index.d.ts +11 -2
  294. package/dist/index.js +11 -8
  295. package/dist/index.js.map +1 -1
  296. package/dist/keystore/cipher.d.ts +4 -0
  297. package/dist/keystore/cipher.js +28 -0
  298. package/dist/keystore/cipher.js.map +1 -0
  299. package/dist/keystore/credential_validation_generated.d.ts +8 -0
  300. package/dist/keystore/credential_validation_generated.js +121 -0
  301. package/dist/keystore/credential_validation_generated.js.map +1 -0
  302. package/dist/keystore/index.d.ts +4 -0
  303. package/dist/keystore/index.js +3 -0
  304. package/dist/keystore/index.js.map +1 -0
  305. package/dist/keystore/keystore.d.ts +50 -0
  306. package/dist/keystore/keystore.js +205 -0
  307. package/dist/keystore/keystore.js.map +1 -0
  308. package/dist/keystore/keystore_validation_generated.d.ts +8 -0
  309. package/dist/keystore/keystore_validation_generated.js +75 -0
  310. package/dist/keystore/keystore_validation_generated.js.map +1 -0
  311. package/dist/keystore/schema_validator.d.ts +2 -0
  312. package/dist/keystore/schema_validator.js +18 -0
  313. package/dist/keystore/schema_validator.js.map +1 -0
  314. package/dist/keystore/types.d.ts +29 -0
  315. package/dist/keystore/types.js +2 -0
  316. package/dist/keystore/types.js.map +1 -0
  317. package/dist/message.d.ts +18 -0
  318. package/dist/message.js +49 -0
  319. package/dist/message.js.map +1 -0
  320. package/dist/proof.d.ts +21 -0
  321. package/dist/proof.js +50 -0
  322. package/dist/proof.js.map +1 -0
  323. package/dist/resources/rln.wasm +0 -0
  324. package/dist/resources/rln_final.zkey +0 -0
  325. package/dist/resources/verification_key.d.ts +13 -0
  326. package/dist/resources/verification_key.js +112 -0
  327. package/dist/resources/witness_calculator.d.ts +11 -0
  328. package/dist/resources/witness_calculator.js +328 -0
  329. package/dist/rln.d.ts +59 -13
  330. package/dist/rln.js +188 -86
  331. package/dist/rln.js.map +1 -1
  332. package/dist/root_tracker.d.ts +10 -0
  333. package/dist/root_tracker.js +75 -0
  334. package/dist/root_tracker.js.map +1 -0
  335. package/dist/utils/bytes.d.ts +20 -0
  336. package/dist/utils/bytes.js +64 -0
  337. package/dist/utils/bytes.js.map +1 -0
  338. package/dist/utils/epoch.d.ts +3 -0
  339. package/dist/utils/epoch.js +23 -0
  340. package/dist/utils/epoch.js.map +1 -0
  341. package/dist/utils/hash.d.ts +2 -0
  342. package/dist/utils/hash.js +13 -0
  343. package/dist/utils/hash.js.map +1 -0
  344. package/dist/utils/index.d.ts +4 -0
  345. package/dist/utils/index.js +5 -0
  346. package/dist/utils/index.js.map +1 -0
  347. package/dist/utils/metamask.d.ts +2 -0
  348. package/dist/utils/metamask.js +12 -0
  349. package/dist/utils/metamask.js.map +1 -0
  350. package/dist/zerokit.d.ts +23 -0
  351. package/dist/zerokit.js +125 -0
  352. package/dist/zerokit.js.map +1 -0
  353. package/package.json +1 -126
  354. package/src/codec.ts +134 -0
  355. package/src/contract/abi.ts +646 -0
  356. package/src/contract/constants.ts +29 -0
  357. package/src/contract/index.ts +2 -0
  358. package/src/contract/rln_contract.ts +972 -0
  359. package/src/create.ts +9 -0
  360. package/src/identity.ts +31 -0
  361. package/src/index.ts +24 -10
  362. package/src/keystore/cipher.ts +54 -0
  363. package/src/keystore/credential_validation_generated.ts +7 -0
  364. package/src/keystore/index.ts +5 -0
  365. package/src/keystore/keystore.ts +330 -0
  366. package/src/keystore/keystore_validation_generated.ts +7 -0
  367. package/src/keystore/schema_validator.ts +34 -0
  368. package/src/keystore/types.ts +36 -0
  369. package/src/message.ts +70 -0
  370. package/src/proof.ts +69 -0
  371. package/src/resources/verification_key.d.ts +13 -0
  372. package/src/resources/witness_calculator.d.ts +11 -0
  373. package/src/rln.ts +301 -103
  374. package/src/root_tracker.ts +92 -0
  375. package/src/utils/bytes.ts +84 -0
  376. package/src/utils/epoch.ts +30 -0
  377. package/src/utils/hash.ts +15 -0
  378. package/src/utils/index.ts +9 -0
  379. package/src/utils/metamask.ts +17 -0
  380. package/src/zerokit.ts +243 -0
  381. package/bundle/02bce7e5f3bcf834.wasm +0 -0
  382. package/bundle/rln-f87f6dbe.js +0 -563
  383. package/dist/resources.d.ts +0 -4
  384. package/dist/resources.js +0 -5
  385. package/dist/resources.js.map +0 -1
  386. package/dist/witness_calculator.d.ts +0 -16
  387. package/dist/witness_calculator.js +0 -291
  388. package/dist/witness_calculator.js.map +0 -1
  389. package/dist/zerokit/rln_wasm.d.ts +0 -1
  390. package/dist/zerokit/rln_wasm.js +0 -2
  391. package/dist/zerokit/rln_wasm.js.map +0 -1
  392. package/dist/zerokit/rln_wasm_bg.d.ts +0 -108
  393. package/dist/zerokit/rln_wasm_bg.js +0 -592
  394. package/dist/zerokit/rln_wasm_bg.js.map +0 -1
  395. package/dist/zerokit/rln_wasm_bg.wasm +0 -0
  396. package/src/resources.ts +0 -10
  397. package/src/witness_calculator.d.ts +0 -4
@@ -0,0 +1,31 @@
1
+ import { cipherDecrypt as cipherDecrypt_1 } from '../../node_modules/@chainsafe/bls-keystore/lib/cipher.js';
2
+ import { kdf as kdf_2 } from '../../node_modules/@chainsafe/bls-keystore/lib/kdf.js';
3
+ import { normalizePassword as normalizePassword_1 } from '../../node_modules/@chainsafe/bls-keystore/lib/password.js';
4
+ import { keccak256 } from '../../../../node_modules/ethereum-cryptography/esm/keccak.js';
5
+ import { hexToBytes } from '../../../../node_modules/ethereum-cryptography/esm/utils.js';
6
+ import { concatBytes, bytesToHex } from '../../../../node_modules/@noble/hashes/esm/utils.js';
7
+
8
+ // eipKeystore supports only sha256 checksum so we just make an assumption it is keccak256
9
+ const validateChecksum = async (password, eipKeystore) => {
10
+ const computedChecksum = await keccak256Checksum(password, eipKeystore);
11
+ return computedChecksum === eipKeystore.crypto.checksum.message;
12
+ };
13
+ // decrypt from @chainsafe/bls-keystore supports only sha256
14
+ // but nwaku uses keccak256
15
+ // https://github.com/waku-org/nwaku/blob/25d6e52e3804d15f9b61bc4cc6dd448540c072a1/waku/waku_keystore/keyfile.nim#L367
16
+ const decryptEipKeystore = async (password, eipKeystore) => {
17
+ const decryptionKey = await kdf_2(eipKeystore.crypto.kdf, normalizePassword_1(password));
18
+ const isChecksumValid = await validateChecksum(password, eipKeystore);
19
+ if (!isChecksumValid) {
20
+ throw Error("Password is invalid.");
21
+ }
22
+ return cipherDecrypt_1(eipKeystore.crypto.cipher, decryptionKey.slice(0, 16));
23
+ };
24
+ const keccak256Checksum = async (password, eipKeystore) => {
25
+ const key = await kdf_2(eipKeystore.crypto.kdf, normalizePassword_1(password));
26
+ const payload = concatBytes(key.slice(16), hexToBytes(eipKeystore.crypto.cipher.message));
27
+ const ciphertext = keccak256(payload);
28
+ return bytesToHex(ciphertext);
29
+ };
30
+
31
+ export { decryptEipKeystore, keccak256Checksum };
@@ -0,0 +1,119 @@
1
+ /* eslint eslint-comments/no-unlimited-disable: "off" */
2
+ // This file was generated by /scripts/schema-validation-codegen.ts
3
+ // Do not modify this file by hand.
4
+ /* eslint-disable */
5
+ // @ts-ignore
6
+ const Credential = validate11;
7
+ function validate11(data, { instancePath = "", parentData, parentDataProperty, rootData = data } = {}) { let vErrors = null; let errors = 0; {
8
+ if (data && typeof data == "object" && !Array.isArray(data)) {
9
+ let missing0;
10
+ if ((data.crypto === undefined) && (missing0 = "crypto")) {
11
+ validate11.errors = [{ instancePath, schemaPath: "#/required", keyword: "required", params: { missingProperty: missing0 }, message: "must have required property '" + missing0 + "'" }];
12
+ return false;
13
+ }
14
+ else {
15
+ if (data.crypto !== undefined) {
16
+ let data0 = data.crypto;
17
+ {
18
+ if (data0 && typeof data0 == "object" && !Array.isArray(data0)) {
19
+ let missing1;
20
+ if (((((((data0.cipher === undefined) && (missing1 = "cipher")) || ((data0.cipherparams === undefined) && (missing1 = "cipherparams"))) || ((data0.ciphertext === undefined) && (missing1 = "ciphertext"))) || ((data0.kdf === undefined) && (missing1 = "kdf"))) || ((data0.kdfparams === undefined) && (missing1 = "kdfparams"))) || ((data0.mac === undefined) && (missing1 = "mac"))) {
21
+ validate11.errors = [{ instancePath: instancePath + "/crypto", schemaPath: "#/properties/crypto/required", keyword: "required", params: { missingProperty: missing1 }, message: "must have required property '" + missing1 + "'" }];
22
+ return false;
23
+ }
24
+ else {
25
+ if (data0.cipher !== undefined) {
26
+ const _errs3 = errors;
27
+ if (typeof data0.cipher !== "string") {
28
+ validate11.errors = [{ instancePath: instancePath + "/crypto/cipher", schemaPath: "#/properties/crypto/properties/cipher/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
29
+ return false;
30
+ }
31
+ var valid1 = _errs3 === errors;
32
+ }
33
+ else {
34
+ var valid1 = true;
35
+ }
36
+ if (valid1) {
37
+ if (data0.cipherparams !== undefined) {
38
+ let data2 = data0.cipherparams;
39
+ const _errs5 = errors;
40
+ if (!(data2 && typeof data2 == "object" && !Array.isArray(data2))) {
41
+ validate11.errors = [{ instancePath: instancePath + "/crypto/cipherparams", schemaPath: "#/properties/crypto/properties/cipherparams/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
42
+ return false;
43
+ }
44
+ var valid1 = _errs5 === errors;
45
+ }
46
+ else {
47
+ var valid1 = true;
48
+ }
49
+ if (valid1) {
50
+ if (data0.ciphertext !== undefined) {
51
+ const _errs7 = errors;
52
+ if (typeof data0.ciphertext !== "string") {
53
+ validate11.errors = [{ instancePath: instancePath + "/crypto/ciphertext", schemaPath: "#/properties/crypto/properties/ciphertext/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
54
+ return false;
55
+ }
56
+ var valid1 = _errs7 === errors;
57
+ }
58
+ else {
59
+ var valid1 = true;
60
+ }
61
+ if (valid1) {
62
+ if (data0.kdf !== undefined) {
63
+ const _errs9 = errors;
64
+ if (typeof data0.kdf !== "string") {
65
+ validate11.errors = [{ instancePath: instancePath + "/crypto/kdf", schemaPath: "#/properties/crypto/properties/kdf/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
66
+ return false;
67
+ }
68
+ var valid1 = _errs9 === errors;
69
+ }
70
+ else {
71
+ var valid1 = true;
72
+ }
73
+ if (valid1) {
74
+ if (data0.kdfparams !== undefined) {
75
+ let data5 = data0.kdfparams;
76
+ const _errs11 = errors;
77
+ if (!(data5 && typeof data5 == "object" && !Array.isArray(data5))) {
78
+ validate11.errors = [{ instancePath: instancePath + "/crypto/kdfparams", schemaPath: "#/properties/crypto/properties/kdfparams/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
79
+ return false;
80
+ }
81
+ var valid1 = _errs11 === errors;
82
+ }
83
+ else {
84
+ var valid1 = true;
85
+ }
86
+ if (valid1) {
87
+ if (data0.mac !== undefined) {
88
+ const _errs13 = errors;
89
+ if (typeof data0.mac !== "string") {
90
+ validate11.errors = [{ instancePath: instancePath + "/crypto/mac", schemaPath: "#/properties/crypto/properties/mac/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
91
+ return false;
92
+ }
93
+ var valid1 = _errs13 === errors;
94
+ }
95
+ else {
96
+ var valid1 = true;
97
+ }
98
+ }
99
+ }
100
+ }
101
+ }
102
+ }
103
+ }
104
+ }
105
+ else {
106
+ validate11.errors = [{ instancePath: instancePath + "/crypto", schemaPath: "#/properties/crypto/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
107
+ return false;
108
+ }
109
+ }
110
+ }
111
+ }
112
+ }
113
+ else {
114
+ validate11.errors = [{ instancePath, schemaPath: "#/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
115
+ return false;
116
+ }
117
+ } validate11.errors = vErrors; return errors === 0; }
118
+
119
+ export { Credential };
@@ -0,0 +1,223 @@
1
+ import '../../node_modules/@chainsafe/bls-keystore/lib/index.js';
2
+ import '../../../interfaces/dist/protocols.js';
3
+ import '../../../interfaces/dist/connection_manager.js';
4
+ import '../../../interfaces/dist/health_indicator.js';
5
+ import '../../../../node_modules/multiformats/dist/src/bases/base10.js';
6
+ import '../../../../node_modules/multiformats/dist/src/bases/base16.js';
7
+ import '../../../../node_modules/multiformats/dist/src/bases/base2.js';
8
+ import '../../../../node_modules/multiformats/dist/src/bases/base256emoji.js';
9
+ import '../../../../node_modules/multiformats/dist/src/bases/base32.js';
10
+ import '../../../../node_modules/multiformats/dist/src/bases/base36.js';
11
+ import '../../../../node_modules/multiformats/dist/src/bases/base58.js';
12
+ import '../../../../node_modules/multiformats/dist/src/bases/base64.js';
13
+ import '../../../../node_modules/multiformats/dist/src/bases/base8.js';
14
+ import '../../../../node_modules/multiformats/dist/src/bases/identity.js';
15
+ import '../../../../node_modules/multiformats/dist/src/codecs/json.js';
16
+ import { Logger } from '../../../utils/dist/logger/index.js';
17
+ import { sha256 } from '../../../../node_modules/ethereum-cryptography/esm/sha256.js';
18
+ import { bytesToUtf8 } from '../../../../node_modules/ethereum-cryptography/esm/utils.js';
19
+ import _ from '../../../../node_modules/lodash/lodash.js';
20
+ import { buildBigIntFromUint8Array } from '../utils/bytes.js';
21
+ import { keccak256Checksum, decryptEipKeystore } from './cipher.js';
22
+ import { isKeystoreValid, isCredentialValid } from './schema_validator.js';
23
+ import { __exports as lib } from '../../../../_virtual/index.js';
24
+ import v4 from '../../node_modules/uuid/dist/esm-browser/v4.js';
25
+ import { bytesToHex, utf8ToBytes } from '../../../../node_modules/@noble/hashes/esm/utils.js';
26
+
27
+ const log = new Logger("waku:rln:keystore");
28
+ class Keystore {
29
+ data;
30
+ constructor(options) {
31
+ this.data = Object.assign({
32
+ application: "waku-rln-relay",
33
+ appIdentifier: "01234567890abcdef",
34
+ version: "0.2",
35
+ credentials: {}
36
+ }, options);
37
+ }
38
+ static create(options = {}) {
39
+ return new Keystore(options);
40
+ }
41
+ // should be valid JSON string that contains Keystore file
42
+ // https://github.com/waku-org/nwaku/blob/f05528d4be3d3c876a8b07f9bb7dfaae8aa8ec6e/waku/waku_keystore/keyfile.nim#L376
43
+ static fromString(str) {
44
+ try {
45
+ const obj = JSON.parse(str);
46
+ if (!Keystore.isValidNwakuStore(obj)) {
47
+ throw Error("Invalid string, does not match Nwaku Keystore format.");
48
+ }
49
+ return new Keystore(obj);
50
+ }
51
+ catch (err) {
52
+ log.error("Cannot create Keystore from string:", err);
53
+ return;
54
+ }
55
+ }
56
+ static fromObject(obj) {
57
+ if (!Keystore.isValidNwakuStore(obj)) {
58
+ throw Error("Invalid object, does not match Nwaku Keystore format.");
59
+ }
60
+ return new Keystore(obj);
61
+ }
62
+ async addCredential(options, password) {
63
+ const membershipHash = Keystore.computeMembershipHash(options.membership);
64
+ if (this.data.credentials[membershipHash]) {
65
+ throw Error("Credential already exists in the store.");
66
+ }
67
+ // these are not important
68
+ const stubPath = "/stub/path";
69
+ const stubPubkey = new Uint8Array([0]);
70
+ const secret = Keystore.fromIdentityToBytes(options);
71
+ const eipKeystore = await lib.create(password, secret, stubPubkey, stubPath);
72
+ // need to re-compute checksum since nwaku uses keccak256 instead of sha256
73
+ const checksum = await keccak256Checksum(password, eipKeystore);
74
+ const nwakuCredential = Keystore.fromEipToCredential(eipKeystore, checksum);
75
+ this.data.credentials[membershipHash] = nwakuCredential;
76
+ return membershipHash;
77
+ }
78
+ async readCredential(membershipHash, password) {
79
+ const nwakuCredential = this.data.credentials[membershipHash];
80
+ if (!nwakuCredential) {
81
+ return;
82
+ }
83
+ const eipKeystore = Keystore.fromCredentialToEip(nwakuCredential);
84
+ const bytes = await decryptEipKeystore(password, eipKeystore);
85
+ return Keystore.fromBytesToIdentity(bytes);
86
+ }
87
+ removeCredential(hash) {
88
+ if (!this.data.credentials[hash]) {
89
+ return;
90
+ }
91
+ delete this.data.credentials[hash];
92
+ }
93
+ toString() {
94
+ return JSON.stringify(this.data);
95
+ }
96
+ toObject() {
97
+ return this.data;
98
+ }
99
+ /**
100
+ * Read array of hashes of current credentials
101
+ * @returns array of keys of credentials in current Keystore
102
+ */
103
+ keys() {
104
+ return Object.keys(this.toObject().credentials || {});
105
+ }
106
+ static isValidNwakuStore(obj) {
107
+ if (!isKeystoreValid(obj)) {
108
+ return false;
109
+ }
110
+ const areCredentialsValid = Object.values(_.get(obj, "credentials", {}))
111
+ .map((c) => isCredentialValid(c))
112
+ .every((v) => v);
113
+ return areCredentialsValid;
114
+ }
115
+ static fromCredentialToEip(credential) {
116
+ const nwakuCrypto = credential.crypto;
117
+ const eipCrypto = {
118
+ kdf: {
119
+ function: nwakuCrypto.kdf,
120
+ params: nwakuCrypto.kdfparams,
121
+ message: ""
122
+ },
123
+ cipher: {
124
+ function: nwakuCrypto.cipher,
125
+ params: nwakuCrypto.cipherparams,
126
+ message: nwakuCrypto.ciphertext
127
+ },
128
+ checksum: {
129
+ // @chainsafe/bls-keystore supports only sha256
130
+ // but nwaku uses keccak256
131
+ // https://github.com/waku-org/nwaku/blob/25d6e52e3804d15f9b61bc4cc6dd448540c072a1/waku/waku_keystore/keyfile.nim#L367
132
+ function: "sha256",
133
+ params: {},
134
+ message: nwakuCrypto.mac
135
+ }
136
+ };
137
+ return {
138
+ version: 4,
139
+ uuid: v4(),
140
+ description: undefined,
141
+ path: "safe to ignore, not important for decrypt",
142
+ pubkey: "safe to ignore, not important for decrypt",
143
+ crypto: eipCrypto
144
+ };
145
+ }
146
+ static fromEipToCredential(eipKeystore, checksum) {
147
+ const eipCrypto = eipKeystore.crypto;
148
+ const eipKdf = eipCrypto.kdf;
149
+ return {
150
+ crypto: {
151
+ cipher: eipCrypto.cipher.function,
152
+ cipherparams: eipCrypto.cipher.params,
153
+ ciphertext: eipCrypto.cipher.message,
154
+ kdf: eipKdf.function,
155
+ kdfparams: eipKdf.params,
156
+ // @chainsafe/bls-keystore generates only sha256
157
+ // but nwaku uses keccak256
158
+ // https://github.com/waku-org/nwaku/blob/25d6e52e3804d15f9b61bc4cc6dd448540c072a1/waku/waku_keystore/keyfile.nim#L367
159
+ mac: checksum
160
+ }
161
+ };
162
+ }
163
+ static fromBytesToIdentity(bytes) {
164
+ try {
165
+ const str = bytesToUtf8(bytes);
166
+ const obj = JSON.parse(str);
167
+ // TODO: add runtime validation of nwaku credentials
168
+ return {
169
+ identity: {
170
+ IDCommitment: Keystore.fromArraylikeToBytes(_.get(obj, "identityCredential.idCommitment", [])),
171
+ IDTrapdoor: Keystore.fromArraylikeToBytes(_.get(obj, "identityCredential.idTrapdoor", [])),
172
+ IDNullifier: Keystore.fromArraylikeToBytes(_.get(obj, "identityCredential.idNullifier", [])),
173
+ IDCommitmentBigInt: buildBigIntFromUint8Array(Keystore.fromArraylikeToBytes(_.get(obj, "identityCredential.idCommitment", []))),
174
+ IDSecretHash: Keystore.fromArraylikeToBytes(_.get(obj, "identityCredential.idSecretHash", []))
175
+ },
176
+ membership: {
177
+ treeIndex: _.get(obj, "treeIndex"),
178
+ chainId: _.get(obj, "membershipContract.chainId"),
179
+ address: _.get(obj, "membershipContract.address")
180
+ }
181
+ };
182
+ }
183
+ catch (err) {
184
+ log.error("Cannot parse bytes to Nwaku Credentials:", err);
185
+ return;
186
+ }
187
+ }
188
+ static fromArraylikeToBytes(obj) {
189
+ const bytes = [];
190
+ let index = 0;
191
+ let lastElement = obj[index];
192
+ while (lastElement !== undefined) {
193
+ bytes.push(lastElement);
194
+ index += 1;
195
+ lastElement = obj[index];
196
+ }
197
+ return new Uint8Array(bytes);
198
+ }
199
+ // follows nwaku implementation
200
+ // https://github.com/waku-org/nwaku/blob/f05528d4be3d3c876a8b07f9bb7dfaae8aa8ec6e/waku/waku_keystore/protocol_types.nim#L111
201
+ static computeMembershipHash(info) {
202
+ return bytesToHex(sha256(utf8ToBytes(`${info.chainId}${info.address}${info.treeIndex}`))).toUpperCase();
203
+ }
204
+ // follows nwaku implementation
205
+ // https://github.com/waku-org/nwaku/blob/f05528d4be3d3c876a8b07f9bb7dfaae8aa8ec6e/waku/waku_keystore/protocol_types.nim#L98
206
+ static fromIdentityToBytes(options) {
207
+ return utf8ToBytes(JSON.stringify({
208
+ treeIndex: options.membership.treeIndex,
209
+ identityCredential: {
210
+ idCommitment: options.identity.IDCommitment,
211
+ idNullifier: options.identity.IDNullifier,
212
+ idSecretHash: options.identity.IDSecretHash,
213
+ idTrapdoor: options.identity.IDTrapdoor
214
+ },
215
+ membershipContract: {
216
+ chainId: options.membership.chainId,
217
+ address: options.membership.address
218
+ }
219
+ }));
220
+ }
221
+ }
222
+
223
+ export { Keystore };
@@ -0,0 +1,74 @@
1
+ /* eslint eslint-comments/no-unlimited-disable: "off" */
2
+ // This file was generated by /scripts/schema-validation-codegen.ts
3
+ // Do not modify this file by hand.
4
+ /* eslint-disable */
5
+ // @ts-ignore
6
+ const Keystore = validate11;
7
+ function validate11(data, { instancePath = "", parentData, parentDataProperty, rootData = data } = {}) { let vErrors = null; let errors = 0; {
8
+ if (data && typeof data == "object" && !Array.isArray(data)) {
9
+ let missing0;
10
+ if (((((data.application === undefined) && (missing0 = "application")) || ((data.appIdentifier === undefined) && (missing0 = "appIdentifier"))) || ((data.credentials === undefined) && (missing0 = "credentials"))) || ((data.version === undefined) && (missing0 = "version"))) {
11
+ validate11.errors = [{ instancePath, schemaPath: "#/required", keyword: "required", params: { missingProperty: missing0 }, message: "must have required property '" + missing0 + "'" }];
12
+ return false;
13
+ }
14
+ else {
15
+ if (data.credentials !== undefined) {
16
+ let data0 = data.credentials;
17
+ const _errs1 = errors;
18
+ if (!(data0 && typeof data0 == "object" && !Array.isArray(data0))) {
19
+ validate11.errors = [{ instancePath: instancePath + "/credentials", schemaPath: "#/properties/credentials/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
20
+ return false;
21
+ }
22
+ var valid0 = _errs1 === errors;
23
+ }
24
+ else {
25
+ var valid0 = true;
26
+ }
27
+ if (valid0) {
28
+ if (data.appIdentifier !== undefined) {
29
+ const _errs3 = errors;
30
+ if (typeof data.appIdentifier !== "string") {
31
+ validate11.errors = [{ instancePath: instancePath + "/appIdentifier", schemaPath: "#/properties/appIdentifier/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
32
+ return false;
33
+ }
34
+ var valid0 = _errs3 === errors;
35
+ }
36
+ else {
37
+ var valid0 = true;
38
+ }
39
+ if (valid0) {
40
+ if (data.version !== undefined) {
41
+ const _errs5 = errors;
42
+ if (typeof data.version !== "string") {
43
+ validate11.errors = [{ instancePath: instancePath + "/version", schemaPath: "#/properties/version/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
44
+ return false;
45
+ }
46
+ var valid0 = _errs5 === errors;
47
+ }
48
+ else {
49
+ var valid0 = true;
50
+ }
51
+ if (valid0) {
52
+ if (data.application !== undefined) {
53
+ const _errs7 = errors;
54
+ if (typeof data.application !== "string") {
55
+ validate11.errors = [{ instancePath: instancePath + "/application", schemaPath: "#/properties/application/type", keyword: "type", params: { type: "string" }, message: "must be string" }];
56
+ return false;
57
+ }
58
+ var valid0 = _errs7 === errors;
59
+ }
60
+ else {
61
+ var valid0 = true;
62
+ }
63
+ }
64
+ }
65
+ }
66
+ }
67
+ }
68
+ else {
69
+ validate11.errors = [{ instancePath, schemaPath: "#/type", keyword: "type", params: { type: "object" }, message: "must be object" }];
70
+ return false;
71
+ }
72
+ } validate11.errors = vErrors; return errors === 0; }
73
+
74
+ export { Keystore };
@@ -0,0 +1,20 @@
1
+ import { Credential } from './credential_validation_generated.js';
2
+ import { Keystore } from './keystore_validation_generated.js';
3
+
4
+ const _validateKeystore = Keystore;
5
+ const _validateCredential = Credential;
6
+ function schemaValidationErrors(validator, data) {
7
+ const validated = validator(data);
8
+ if (validated) {
9
+ return null;
10
+ }
11
+ return validator.errors;
12
+ }
13
+ function isKeystoreValid(keystore) {
14
+ return !schemaValidationErrors(_validateKeystore, keystore);
15
+ }
16
+ function isCredentialValid(credential) {
17
+ return !schemaValidationErrors(_validateCredential, credential);
18
+ }
19
+
20
+ export { isCredentialValid, isKeystoreValid };
@@ -0,0 +1,51 @@
1
+ import { utf8ToBytes } from '../../utils/dist/bytes/index.js';
2
+ import { epochBytesToInt } from './utils/epoch.js';
3
+
4
+ function toRLNSignal(contentTopic, msg) {
5
+ const contentTopicBytes = utf8ToBytes(contentTopic ?? "");
6
+ return new Uint8Array([...(msg.payload ?? []), ...contentTopicBytes]);
7
+ }
8
+ class RlnMessage {
9
+ rlnInstance;
10
+ msg;
11
+ rateLimitProof;
12
+ pubsubTopic = "";
13
+ constructor(rlnInstance, msg, rateLimitProof) {
14
+ this.rlnInstance = rlnInstance;
15
+ this.msg = msg;
16
+ this.rateLimitProof = rateLimitProof;
17
+ }
18
+ verify(roots) {
19
+ return this.rateLimitProof
20
+ ? this.rlnInstance.zerokit.verifyWithRoots(this.rateLimitProof, toRLNSignal(this.msg.contentTopic, this.msg), roots) // this.rlnInstance.verifyRLNProof once issue status-im/nwaku#1248 is fixed
21
+ : undefined;
22
+ }
23
+ verifyNoRoot() {
24
+ return this.rateLimitProof
25
+ ? this.rlnInstance.zerokit.verifyWithNoRoot(this.rateLimitProof, toRLNSignal(this.msg.contentTopic, this.msg)) // this.rlnInstance.verifyRLNProof once issue status-im/nwaku#1248 is fixed
26
+ : undefined;
27
+ }
28
+ get payload() {
29
+ return this.msg.payload;
30
+ }
31
+ get contentTopic() {
32
+ return this.msg.contentTopic;
33
+ }
34
+ get timestamp() {
35
+ return this.msg.timestamp;
36
+ }
37
+ get ephemeral() {
38
+ return this.msg.ephemeral;
39
+ }
40
+ get meta() {
41
+ return this.msg.meta;
42
+ }
43
+ get epoch() {
44
+ const bytes = this.rateLimitProof?.epoch;
45
+ if (!bytes)
46
+ return undefined;
47
+ return epochBytesToInt(bytes);
48
+ }
49
+ }
50
+
51
+ export { RlnMessage, toRLNSignal };
@@ -0,0 +1,54 @@
1
+ import { concatenate } from './utils/bytes.js';
2
+ import { poseidonHash } from './utils/hash.js';
3
+ import './utils/epoch.js';
4
+
5
+ const proofOffset = 128;
6
+ const rootOffset = proofOffset + 32;
7
+ const epochOffset = rootOffset + 32;
8
+ const shareXOffset = epochOffset + 32;
9
+ const shareYOffset = shareXOffset + 32;
10
+ const nullifierOffset = shareYOffset + 32;
11
+ const rlnIdentifierOffset = nullifierOffset + 32;
12
+ class ProofMetadata {
13
+ nullifier;
14
+ shareX;
15
+ shareY;
16
+ externalNullifier;
17
+ constructor(nullifier, shareX, shareY, externalNullifier) {
18
+ this.nullifier = nullifier;
19
+ this.shareX = shareX;
20
+ this.shareY = shareY;
21
+ this.externalNullifier = externalNullifier;
22
+ }
23
+ }
24
+ class Proof {
25
+ proof;
26
+ merkleRoot;
27
+ epoch;
28
+ shareX;
29
+ shareY;
30
+ nullifier;
31
+ rlnIdentifier;
32
+ constructor(proofBytes) {
33
+ if (proofBytes.length < rlnIdentifierOffset) {
34
+ throw new Error("invalid proof");
35
+ }
36
+ // parse the proof as proof<128> | share_y<32> | nullifier<32> | root<32> | epoch<32> | share_x<32> | rln_identifier<32>
37
+ this.proof = proofBytes.subarray(0, proofOffset);
38
+ this.merkleRoot = proofBytes.subarray(proofOffset, rootOffset);
39
+ this.epoch = proofBytes.subarray(rootOffset, epochOffset);
40
+ this.shareX = proofBytes.subarray(epochOffset, shareXOffset);
41
+ this.shareY = proofBytes.subarray(shareXOffset, shareYOffset);
42
+ this.nullifier = proofBytes.subarray(shareYOffset, nullifierOffset);
43
+ this.rlnIdentifier = proofBytes.subarray(nullifierOffset, rlnIdentifierOffset);
44
+ }
45
+ extractMetadata() {
46
+ const externalNullifier = poseidonHash(this.epoch, this.rlnIdentifier);
47
+ return new ProofMetadata(this.nullifier, this.shareX, this.shareY, externalNullifier);
48
+ }
49
+ }
50
+ function proofToBytes(p) {
51
+ return concatenate(p.proof, p.merkleRoot, p.epoch, p.shareX, p.shareY, p.nullifier, p.rlnIdentifier);
52
+ }
53
+
54
+ export { Proof, proofToBytes };