@waku/rln 0.1.4 → 0.1.5-1d384f2.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 (141) hide show
  1. package/README.md +5 -0
  2. package/bundle/_virtual/index2.js +1 -1
  3. package/bundle/index.js +3 -1
  4. package/bundle/node_modules/@ethersproject/abi/lib.esm/_version.js +1 -1
  5. package/bundle/node_modules/@ethersproject/abstract-provider/lib.esm/_version.js +1 -1
  6. package/bundle/node_modules/@ethersproject/abstract-signer/lib.esm/_version.js +1 -1
  7. package/bundle/node_modules/@ethersproject/address/lib.esm/_version.js +1 -1
  8. package/bundle/node_modules/@ethersproject/bignumber/lib.esm/_version.js +1 -1
  9. package/bundle/node_modules/@ethersproject/contracts/lib.esm/_version.js +1 -1
  10. package/bundle/node_modules/@ethersproject/contracts/lib.esm/index.js +1 -1
  11. package/bundle/node_modules/@ethersproject/hash/lib.esm/_version.js +1 -1
  12. package/bundle/node_modules/@ethersproject/keccak256/lib.esm/index.js +1 -1
  13. package/bundle/node_modules/{js-sha3 → @ethersproject/keccak256/node_modules/js-sha3}/src/sha3.js +2 -2
  14. package/bundle/node_modules/@ethersproject/networks/lib.esm/_version.js +1 -1
  15. package/bundle/node_modules/@ethersproject/networks/lib.esm/index.js +1 -19
  16. package/bundle/node_modules/@ethersproject/properties/lib.esm/_version.js +1 -1
  17. package/bundle/node_modules/@ethersproject/providers/lib.esm/_version.js +1 -1
  18. package/bundle/node_modules/@ethersproject/signing-key/lib.esm/_version.js +1 -1
  19. package/bundle/node_modules/@ethersproject/signing-key/lib.esm/elliptic.js +10 -58
  20. package/bundle/node_modules/@ethersproject/strings/lib.esm/_version.js +1 -1
  21. package/bundle/node_modules/@ethersproject/transactions/lib.esm/_version.js +1 -1
  22. package/bundle/node_modules/@ethersproject/web/lib.esm/_version.js +1 -1
  23. package/bundle/packages/rln/dist/contract/abi.js +502 -248
  24. package/bundle/packages/rln/dist/contract/constants.js +4 -4
  25. package/bundle/packages/rln/dist/contract/rln_base_contract.js +477 -0
  26. package/bundle/packages/rln/dist/contract/rln_contract.js +31 -357
  27. package/bundle/packages/rln/dist/contract/types.js +9 -0
  28. package/bundle/packages/rln/dist/create.js +1 -1
  29. package/bundle/packages/rln/dist/credentials_manager.js +215 -0
  30. package/bundle/packages/rln/dist/keystore/cipher.js +3 -3
  31. package/bundle/packages/rln/dist/keystore/keystore.js +12 -7
  32. package/bundle/packages/rln/dist/rln.js +56 -166
  33. package/bundle/packages/rln/dist/zerokit.js +5 -5
  34. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/checksum.js +3 -3
  35. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/cipher.js +4 -4
  36. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/class.js +7 -7
  37. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/functional.js +7 -7
  38. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/index.js +6 -6
  39. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/kdf.js +5 -5
  40. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/password.js +1 -1
  41. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/schema-validation-generated.js +1 -1
  42. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/schema-validation.js +2 -2
  43. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/lib/types.js +1 -1
  44. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/aes.js +3 -3
  45. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/pbkdf2.js +7 -7
  46. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/random.js +3 -3
  47. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/scrypt.js +3 -3
  48. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/sha256.js +3 -3
  49. package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/ethereum-cryptography/utils.js +7 -7
  50. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/_assert.js +1 -1
  51. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/_sha2.js +3 -3
  52. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/_u64.js +1 -1
  53. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/cryptoBrowser.js +1 -1
  54. package/bundle/packages/rln/node_modules/@noble/hashes/esm/_assert.js +43 -0
  55. package/bundle/packages/rln/node_modules/@noble/hashes/esm/_sha2.js +116 -0
  56. package/bundle/packages/rln/node_modules/@noble/hashes/esm/hmac.js +79 -0
  57. package/bundle/packages/rln/node_modules/@noble/hashes/esm/sha256.js +126 -0
  58. package/bundle/packages/rln/node_modules/@noble/hashes/esm/utils.js +43 -0
  59. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/hmac.js +3 -3
  60. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/pbkdf2.js +4 -4
  61. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/scrypt.js +5 -5
  62. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/sha256.js +3 -3
  63. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/sha512.js +4 -4
  64. package/bundle/{node_modules/@chainsafe/bls-keystore → packages/rln}/node_modules/@noble/hashes/utils.js +2 -2
  65. package/dist/.tsbuildinfo +1 -1
  66. package/dist/codec.test-utils.d.ts +36 -0
  67. package/dist/codec.test-utils.js +56 -0
  68. package/dist/codec.test-utils.js.map +1 -0
  69. package/dist/contract/abi.d.ts +21 -17
  70. package/dist/contract/abi.js +502 -248
  71. package/dist/contract/abi.js.map +1 -1
  72. package/dist/contract/constants.d.ts +22 -18
  73. package/dist/contract/constants.js +3 -3
  74. package/dist/contract/constants.js.map +1 -1
  75. package/dist/contract/rln_base_contract.d.ts +96 -0
  76. package/dist/contract/rln_base_contract.js +460 -0
  77. package/dist/contract/rln_base_contract.js.map +1 -0
  78. package/dist/contract/rln_contract.d.ts +5 -115
  79. package/dist/contract/rln_contract.js +30 -355
  80. package/dist/contract/rln_contract.js.map +1 -1
  81. package/dist/contract/test-setup.d.ts +26 -0
  82. package/dist/contract/test-setup.js +56 -0
  83. package/dist/contract/test-setup.js.map +1 -0
  84. package/dist/contract/test-utils.d.ts +39 -0
  85. package/dist/contract/test-utils.js +118 -0
  86. package/dist/contract/test-utils.js.map +1 -0
  87. package/dist/contract/types.d.ts +40 -0
  88. package/dist/contract/types.js +8 -0
  89. package/dist/contract/types.js.map +1 -0
  90. package/dist/create.js +1 -1
  91. package/dist/create.js.map +1 -1
  92. package/dist/credentials_manager.d.ts +44 -0
  93. package/dist/credentials_manager.js +197 -0
  94. package/dist/credentials_manager.js.map +1 -0
  95. package/dist/index.d.ts +5 -2
  96. package/dist/index.js +4 -2
  97. package/dist/index.js.map +1 -1
  98. package/dist/keystore/keystore.js +11 -6
  99. package/dist/keystore/keystore.js.map +1 -1
  100. package/dist/keystore/types.d.ts +2 -1
  101. package/dist/rln.d.ts +9 -52
  102. package/dist/rln.js +54 -163
  103. package/dist/rln.js.map +1 -1
  104. package/dist/types.d.ts +27 -0
  105. package/dist/types.js +2 -0
  106. package/dist/types.js.map +1 -0
  107. package/dist/zerokit.d.ts +3 -3
  108. package/dist/zerokit.js +5 -5
  109. package/dist/zerokit.js.map +1 -1
  110. package/package.json +1 -91
  111. package/src/codec.test-utils.ts +80 -0
  112. package/src/contract/abi.ts +502 -248
  113. package/src/contract/constants.ts +3 -3
  114. package/src/contract/rln_base_contract.ts +707 -0
  115. package/src/contract/rln_contract.ts +37 -579
  116. package/src/contract/test-setup.ts +86 -0
  117. package/src/contract/test-utils.ts +179 -0
  118. package/src/contract/types.ts +48 -0
  119. package/src/create.ts +1 -1
  120. package/src/credentials_manager.ts +282 -0
  121. package/src/index.ts +17 -2
  122. package/src/keystore/keystore.ts +19 -10
  123. package/src/keystore/types.ts +2 -1
  124. package/src/rln.ts +67 -258
  125. package/src/types.ts +31 -0
  126. package/src/zerokit.ts +3 -3
  127. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/index.js +0 -0
  128. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/md5.js +0 -0
  129. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/nil.js +0 -0
  130. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/parse.js +0 -0
  131. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/regex.js +0 -0
  132. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/rng.js +0 -0
  133. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/sha1.js +0 -0
  134. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/stringify.js +0 -0
  135. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v1.js +0 -0
  136. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v3.js +0 -0
  137. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v35.js +0 -0
  138. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v4.js +0 -0
  139. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/v5.js +0 -0
  140. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/validate.js +0 -0
  141. /package/bundle/{node_modules → packages/rln/node_modules}/@chainsafe/bls-keystore/node_modules/uuid/dist/esm-browser/version.js +0 -0
package/dist/rln.d.ts CHANGED
@@ -1,66 +1,23 @@
1
1
  import type { ContentTopic, IDecodedMessage, EncoderOptions as WakuEncoderOptions } from "@waku/interfaces";
2
- import { ethers } from "ethers";
3
2
  import { type RLNDecoder, type RLNEncoder } from "./codec.js";
4
- import { RLNContract } from "./contract/index.js";
5
- import { IdentityCredential } from "./identity.js";
3
+ import { RLNCredentialsManager } from "./credentials_manager.js";
6
4
  import type { DecryptedCredentials, EncryptedCredentials } from "./keystore/index.js";
7
- import { Password } from "./keystore/types.js";
5
+ import { WitnessCalculator } from "./resources/witness_calculator";
8
6
  import { Zerokit } from "./zerokit.js";
9
- /**
10
- * Create an instance of RLN
11
- * @returns RLNInstance
12
- */
13
- export declare function create(): Promise<RLNInstance>;
14
- type StartRLNOptions = {
15
- /**
16
- * If not set - will extract MetaMask account and get signer from it.
17
- */
18
- signer?: ethers.Signer;
19
- /**
20
- * If not set - will use default SEPOLIA_CONTRACT address.
21
- */
22
- address?: string;
23
- /**
24
- * Credentials to use for generating proofs and connecting to the contract and network.
25
- * If provided used for validating the network chainId and connecting to registry contract.
26
- */
27
- credentials?: EncryptedCredentials | DecryptedCredentials;
28
- /**
29
- * Rate limit for the member.
30
- */
31
- rateLimit?: number;
32
- };
33
- type RegisterMembershipOptions = {
34
- signature: string;
35
- } | {
36
- identity: IdentityCredential;
37
- };
38
7
  type WakuRLNEncoderOptions = WakuEncoderOptions & {
39
8
  credentials: EncryptedCredentials | DecryptedCredentials;
40
9
  };
41
- export declare class RLNInstance {
10
+ export declare class RLNInstance extends RLNCredentialsManager {
42
11
  zerokit: Zerokit;
43
- private started;
44
- private starting;
45
- private _contract;
46
- private _signer;
47
- private keystore;
48
- private _credentials;
49
- constructor(zerokit: Zerokit);
50
- get contract(): undefined | RLNContract;
51
- get signer(): undefined | ethers.Signer;
52
- start(options?: StartRLNOptions): Promise<void>;
53
- private determineStartOptions;
54
- private static decryptCredentialsIfNeeded;
55
- registerMembership(options: RegisterMembershipOptions): Promise<undefined | DecryptedCredentials>;
56
12
  /**
57
- * Changes credentials in use by relying on provided Keystore earlier in rln.start
58
- * @param id: string, hash of credentials to select from Keystore
59
- * @param password: string or bytes to use to decrypt credentials from Keystore
13
+ * Create an instance of RLN
14
+ * @returns RLNInstance
60
15
  */
61
- useCredentials(id: string, password: Password): Promise<void>;
16
+ static create(): Promise<RLNInstance>;
17
+ private constructor();
62
18
  createEncoder(options: WakuRLNEncoderOptions): Promise<RLNEncoder>;
63
- private verifyCredentialsAgainstContract;
64
19
  createDecoder(contentTopic: ContentTopic): RLNDecoder<IDecodedMessage>;
20
+ static loadWitnessCalculator(): Promise<WitnessCalculator>;
21
+ static loadZkey(): Promise<Uint8Array>;
65
22
  }
66
23
  export {};
package/dist/rln.js CHANGED
@@ -4,164 +4,43 @@ import init from "@waku/zerokit-rln-wasm";
4
4
  import * as zerokitRLN from "@waku/zerokit-rln-wasm";
5
5
  import { createRLNDecoder, createRLNEncoder } from "./codec.js";
6
6
  import { DEFAULT_RATE_LIMIT } from "./contract/constants.js";
7
- import { RLNContract, SEPOLIA_CONTRACT } from "./contract/index.js";
8
- import { Keystore } from "./keystore/index.js";
7
+ import { RLNCredentialsManager } from "./credentials_manager.js";
9
8
  import verificationKey from "./resources/verification_key";
10
9
  import * as wc from "./resources/witness_calculator";
11
- import { extractMetaMaskSigner } from "./utils/index.js";
12
10
  import { Zerokit } from "./zerokit.js";
13
11
  const log = new Logger("waku:rln");
14
- async function loadWitnessCalculator() {
15
- try {
16
- const url = new URL("./resources/rln.wasm", import.meta.url);
17
- const response = await fetch(url);
18
- if (!response.ok) {
19
- throw new Error(`Failed to fetch witness calculator: ${response.status} ${response.statusText}`);
20
- }
21
- return await wc.builder(new Uint8Array(await response.arrayBuffer()), false);
22
- }
23
- catch (error) {
24
- log.error("Error loading witness calculator:", error);
25
- throw new Error(`Failed to load witness calculator: ${error instanceof Error ? error.message : String(error)}`);
26
- }
27
- }
28
- async function loadZkey() {
29
- try {
30
- const url = new URL("./resources/rln_final.zkey", import.meta.url);
31
- const response = await fetch(url);
32
- if (!response.ok) {
33
- throw new Error(`Failed to fetch zkey: ${response.status} ${response.statusText}`);
34
- }
35
- return new Uint8Array(await response.arrayBuffer());
36
- }
37
- catch (error) {
38
- log.error("Error loading zkey:", error);
39
- throw new Error(`Failed to load zkey: ${error instanceof Error ? error.message : String(error)}`);
40
- }
41
- }
42
- /**
43
- * Create an instance of RLN
44
- * @returns RLNInstance
45
- */
46
- export async function create() {
47
- try {
48
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
49
- await init?.();
50
- zerokitRLN.init_panic_hook();
51
- const witnessCalculator = await loadWitnessCalculator();
52
- const zkey = await loadZkey();
53
- const stringEncoder = new TextEncoder();
54
- const vkey = stringEncoder.encode(JSON.stringify(verificationKey));
55
- const DEPTH = 20;
56
- const zkRLN = zerokitRLN.newRLN(DEPTH, zkey, vkey);
57
- const zerokit = new Zerokit(zkRLN, witnessCalculator, DEFAULT_RATE_LIMIT);
58
- return new RLNInstance(zerokit);
59
- }
60
- catch (error) {
61
- log.error("Failed to initialize RLN:", error);
62
- throw error;
63
- }
64
- }
65
- export class RLNInstance {
12
+ export class RLNInstance extends RLNCredentialsManager {
66
13
  zerokit;
67
- started = false;
68
- starting = false;
69
- _contract;
70
- _signer;
71
- keystore = Keystore.create();
72
- _credentials;
73
- constructor(zerokit) {
74
- this.zerokit = zerokit;
75
- }
76
- get contract() {
77
- return this._contract;
78
- }
79
- get signer() {
80
- return this._signer;
81
- }
82
- async start(options = {}) {
83
- if (this.started || this.starting) {
84
- return;
85
- }
86
- this.starting = true;
14
+ /**
15
+ * Create an instance of RLN
16
+ * @returns RLNInstance
17
+ */
18
+ static async create() {
87
19
  try {
88
- const { credentials, keystore } = await RLNInstance.decryptCredentialsIfNeeded(options.credentials);
89
- const { signer, address } = await this.determineStartOptions(options, credentials);
90
- if (keystore) {
91
- this.keystore = keystore;
92
- }
93
- this._credentials = credentials;
94
- this._signer = signer;
95
- this._contract = await RLNContract.init(this, {
96
- address: address,
97
- signer: signer,
98
- rateLimit: options.rateLimit ?? this.zerokit.getRateLimit
99
- });
100
- this.started = true;
20
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
21
+ await init?.();
22
+ zerokitRLN.init_panic_hook();
23
+ const witnessCalculator = await RLNInstance.loadWitnessCalculator();
24
+ const zkey = await RLNInstance.loadZkey();
25
+ const stringEncoder = new TextEncoder();
26
+ const vkey = stringEncoder.encode(JSON.stringify(verificationKey));
27
+ const DEPTH = 20;
28
+ const zkRLN = zerokitRLN.newRLN(DEPTH, zkey, vkey);
29
+ const zerokit = new Zerokit(zkRLN, witnessCalculator, DEFAULT_RATE_LIMIT);
30
+ return new RLNInstance(zerokit);
31
+ }
32
+ catch (error) {
33
+ log.error("Failed to initialize RLN:", error);
34
+ throw error;
101
35
  }
102
- finally {
103
- this.starting = false;
104
- }
105
- }
106
- async determineStartOptions(options, credentials) {
107
- let chainId = credentials?.membership.chainId;
108
- const address = credentials?.membership.address ||
109
- options.address ||
110
- SEPOLIA_CONTRACT.address;
111
- if (address === SEPOLIA_CONTRACT.address) {
112
- chainId = SEPOLIA_CONTRACT.chainId;
113
- }
114
- const signer = options.signer || (await extractMetaMaskSigner());
115
- const currentChainId = await signer.getChainId();
116
- if (chainId && chainId !== currentChainId) {
117
- throw Error(`Failed to start RLN contract, chain ID of contract is different from current one: contract-${chainId}, current network-${currentChainId}`);
118
- }
119
- return {
120
- signer,
121
- address
122
- };
123
36
  }
124
- static async decryptCredentialsIfNeeded(credentials) {
125
- if (!credentials) {
126
- return {};
127
- }
128
- if ("identity" in credentials) {
129
- return { credentials };
130
- }
131
- const keystore = Keystore.fromString(credentials.keystore);
132
- if (!keystore) {
133
- return {};
134
- }
135
- const decryptedCredentials = await keystore.readCredential(credentials.id, credentials.password);
136
- return {
137
- keystore,
138
- credentials: decryptedCredentials
139
- };
140
- }
141
- async registerMembership(options) {
142
- if (!this.contract) {
143
- throw Error("RLN Contract is not initialized.");
144
- }
145
- let identity = "identity" in options && options.identity;
146
- if ("signature" in options) {
147
- identity = this.zerokit.generateSeededIdentityCredential(options.signature);
148
- }
149
- if (!identity) {
150
- throw Error("Missing signature or identity to register membership.");
151
- }
152
- return this.contract.registerWithIdentity(identity);
153
- }
154
- /**
155
- * Changes credentials in use by relying on provided Keystore earlier in rln.start
156
- * @param id: string, hash of credentials to select from Keystore
157
- * @param password: string or bytes to use to decrypt credentials from Keystore
158
- */
159
- async useCredentials(id, password) {
160
- this._credentials = await this.keystore?.readCredential(id, password);
37
+ constructor(zerokit) {
38
+ super(zerokit);
39
+ this.zerokit = zerokit;
161
40
  }
162
41
  async createEncoder(options) {
163
42
  const { credentials: decryptedCredentials } = await RLNInstance.decryptCredentialsIfNeeded(options.credentials);
164
- const credentials = decryptedCredentials || this._credentials;
43
+ const credentials = decryptedCredentials || this.credentials;
165
44
  if (!credentials) {
166
45
  throw Error("Failed to create Encoder: missing RLN credentials. Use createRLNEncoder directly.");
167
46
  }
@@ -173,27 +52,39 @@ export class RLNInstance {
173
52
  credential: credentials.identity
174
53
  });
175
54
  }
176
- async verifyCredentialsAgainstContract(credentials) {
177
- if (!this._contract) {
178
- throw Error("Failed to verify chain coordinates: no contract initialized.");
179
- }
180
- const registryAddress = credentials.membership.address;
181
- const currentRegistryAddress = this._contract.address;
182
- if (registryAddress !== currentRegistryAddress) {
183
- throw Error(`Failed to verify chain coordinates: credentials contract address=${registryAddress} is not equal to registryContract address=${currentRegistryAddress}`);
184
- }
185
- const chainId = credentials.membership.chainId;
186
- const network = await this._contract.provider.getNetwork();
187
- const currentChainId = network.chainId;
188
- if (chainId !== currentChainId) {
189
- throw Error(`Failed to verify chain coordinates: credentials chainID=${chainId} is not equal to registryContract chainID=${currentChainId}`);
190
- }
191
- }
192
55
  createDecoder(contentTopic) {
193
56
  return createRLNDecoder({
194
57
  rlnInstance: this,
195
58
  decoder: createDecoder(contentTopic)
196
59
  });
197
60
  }
61
+ static async loadWitnessCalculator() {
62
+ try {
63
+ const url = new URL("./resources/rln.wasm", import.meta.url);
64
+ const response = await fetch(url);
65
+ if (!response.ok) {
66
+ throw new Error(`Failed to fetch witness calculator: ${response.status} ${response.statusText}`);
67
+ }
68
+ return await wc.builder(new Uint8Array(await response.arrayBuffer()), false);
69
+ }
70
+ catch (error) {
71
+ log.error("Error loading witness calculator:", error);
72
+ throw new Error(`Failed to load witness calculator: ${error instanceof Error ? error.message : String(error)}`);
73
+ }
74
+ }
75
+ static async loadZkey() {
76
+ try {
77
+ const url = new URL("./resources/rln_final.zkey", import.meta.url);
78
+ const response = await fetch(url);
79
+ if (!response.ok) {
80
+ throw new Error(`Failed to fetch zkey: ${response.status} ${response.statusText}`);
81
+ }
82
+ return new Uint8Array(await response.arrayBuffer());
83
+ }
84
+ catch (error) {
85
+ log.error("Error loading zkey:", error);
86
+ throw new Error(`Failed to load zkey: ${error instanceof Error ? error.message : String(error)}`);
87
+ }
88
+ }
198
89
  }
199
90
  //# sourceMappingURL=rln.js.map
package/dist/rln.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"rln.js","sourceRoot":"","sources":["../src/rln.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAM1D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,IAAI,MAAM,wBAAwB,CAAC;AAC1C,OAAO,KAAK,UAAU,MAAM,wBAAwB,CAAC;AAGrD,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EAGjB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEpE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAM/C,OAAO,eAAe,MAAM,8BAA8B,CAAC;AAC3D,OAAO,KAAK,EAAE,MAAM,gCAAgC,CAAC;AAErD,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,UAAU,CAAC,CAAC;AAEnC,KAAK,UAAU,qBAAqB;IAClC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,sBAAsB,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7D,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;QAElC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CACb,uCAAuC,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,UAAU,EAAE,CAChF,CAAC;QACJ,CAAC;QAED,OAAO,MAAM,EAAE,CAAC,OAAO,CACrB,IAAI,UAAU,CAAC,MAAM,QAAQ,CAAC,WAAW,EAAE,CAAC,EAC5C,KAAK,CACN,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;QACtD,MAAM,IAAI,KAAK,CACb,sCAAsC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAC/F,CAAC;IACJ,CAAC;AACH,CAAC;AAED,KAAK,UAAU,QAAQ;IACrB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,4BAA4B,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnE,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;QAElC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CACb,yBAAyB,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,UAAU,EAAE,CAClE,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,UAAU,CAAC,MAAM,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;IACtD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,KAAK,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAC;QACxC,MAAM,IAAI,KAAK,CACb,wBAAwB,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CACjF,CAAC;IACJ,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM;IAC1B,IAAI,CAAC;QACH,8DAA8D;QAC9D,MAAO,IAAY,EAAE,EAAE,CAAC;QACxB,UAAU,CAAC,eAAe,EAAE,CAAC;QAE7B,MAAM,iBAAiB,GAAG,MAAM,qBAAqB,EAAE,CAAC;QACxD,MAAM,IAAI,GAAG,MAAM,QAAQ,EAAE,CAAC;QAE9B,MAAM,aAAa,GAAG,IAAI,WAAW,EAAE,CAAC;QACxC,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC;QAEnE,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,CAAC,CAAC;QAE1E,OAAO,IAAI,WAAW,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,CAAC,CAAC;QAC9C,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC;AA8BD,MAAM,OAAO,WAAW;IAUI;IATlB,OAAO,GAAG,KAAK,CAAC;IAChB,QAAQ,GAAG,KAAK,CAAC;IAEjB,SAAS,CAA0B;IACnC,OAAO,CAA4B;IAEnC,QAAQ,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC;IAC7B,YAAY,CAAmC;IAEvD,YAA0B,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;IAAG,CAAC;IAE9C,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,UAA2B,EAAE;QAC9C,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClC,OAAO;QACT,CAAC;QAED,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,IAAI,CAAC;YACH,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAE,GAC7B,MAAM,WAAW,CAAC,0BAA0B,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACpE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAC1D,OAAO,EACP,WAAW,CACZ,CAAC;YAEF,IAAI,QAAQ,EAAE,CAAC;gBACb,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC3B,CAAC;YAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YAChC,IAAI,CAAC,OAAO,GAAG,MAAO,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE;gBAC5C,OAAO,EAAE,OAAQ;gBACjB,MAAM,EAAE,MAAO;gBACf,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY;aAC1D,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,qBAAqB,CACjC,OAAwB,EACxB,WAAuC;QAEvC,IAAI,OAAO,GAAG,WAAW,EAAE,UAAU,CAAC,OAAO,CAAC;QAC9C,MAAM,OAAO,GACX,WAAW,EAAE,UAAU,CAAC,OAAO;YAC/B,OAAO,CAAC,OAAO;YACf,gBAAgB,CAAC,OAAO,CAAC;QAE3B,IAAI,OAAO,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;YACzC,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC;QACrC,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,MAAM,qBAAqB,EAAE,CAAC,CAAC;QACjE,MAAM,cAAc,GAAG,MAAM,MAAM,CAAC,UAAU,EAAE,CAAC;QAEjD,IAAI,OAAO,IAAI,OAAO,KAAK,cAAc,EAAE,CAAC;YAC1C,MAAM,KAAK,CACT,8FAA8F,OAAO,qBAAqB,cAAc,EAAE,CAC3I,CAAC;QACJ,CAAC;QAED,OAAO;YACL,MAAM;YACN,OAAO;SACR,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAC7C,WAAyD;QAEzD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,UAAU,IAAI,WAAW,EAAE,CAAC;YAC9B,OAAO,EAAE,WAAW,EAAE,CAAC;QACzB,CAAC;QAED,MAAM,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAE3D,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,oBAAoB,GAAG,MAAM,QAAQ,CAAC,cAAc,CACxD,WAAW,CAAC,EAAE,EACd,WAAW,CAAC,QAAQ,CACrB,CAAC;QAEF,OAAO;YACL,QAAQ;YACR,WAAW,EAAE,oBAAoB;SAClC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAC7B,OAAkC;QAElC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,KAAK,CAAC,kCAAkC,CAAC,CAAC;QAClD,CAAC;QAED,IAAI,QAAQ,GAAG,UAAU,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC;QAEzD,IAAI,WAAW,IAAI,OAAO,EAAE,CAAC;YAC3B,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,gCAAgC,CACtD,OAAO,CAAC,SAAS,CAClB,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,KAAK,CAAC,uDAAuD,CAAC,CAAC;QACvE,CAAC;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IACtD,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,cAAc,CAAC,EAAU,EAAE,QAAkB;QACxD,IAAI,CAAC,YAAY,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,cAAc,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;IAEM,KAAK,CAAC,aAAa,CACxB,OAA8B;QAE9B,MAAM,EAAE,WAAW,EAAE,oBAAoB,EAAE,GACzC,MAAM,WAAW,CAAC,0BAA0B,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACpE,MAAM,WAAW,GAAG,oBAAoB,IAAI,IAAI,CAAC,YAAY,CAAC;QAE9D,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,KAAK,CACT,mFAAmF,CACpF,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,CAAC,gCAAgC,CAAC,WAAW,CAAC,CAAC;QAEzD,OAAO,gBAAgB,CAAC;YACtB,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC;YAC/B,WAAW,EAAE,IAAI;YACjB,KAAK,EAAE,WAAW,CAAC,UAAU,CAAC,SAAS;YACvC,UAAU,EAAE,WAAW,CAAC,QAAQ;SACjC,CAAC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,gCAAgC,CAC5C,WAA2B;QAE3B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,MAAM,KAAK,CACT,8DAA8D,CAC/D,CAAC;QACJ,CAAC;QAED,MAAM,eAAe,GAAG,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC;QACvD,MAAM,sBAAsB,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;QACtD,IAAI,eAAe,KAAK,sBAAsB,EAAE,CAAC;YAC/C,MAAM,KAAK,CACT,oEAAoE,eAAe,6CAA6C,sBAAsB,EAAE,CACzJ,CAAC;QACJ,CAAC;QAED,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC;QAC/C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;QAC3D,MAAM,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC;QACvC,IAAI,OAAO,KAAK,cAAc,EAAE,CAAC;YAC/B,MAAM,KAAK,CACT,2DAA2D,OAAO,6CAA6C,cAAc,EAAE,CAChI,CAAC;QACJ,CAAC;IACH,CAAC;IAEM,aAAa,CAClB,YAA0B;QAE1B,OAAO,gBAAgB,CAAC;YACtB,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,aAAa,CAAC,YAAY,CAAC;SACrC,CAAC,CAAC;IACL,CAAC;CACF"}
1
+ {"version":3,"file":"rln.js","sourceRoot":"","sources":["../src/rln.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import { ethers } from "ethers";
2
+ import { IdentityCredential } from "./identity.js";
3
+ import { DecryptedCredentials, EncryptedCredentials } from "./keystore/types.js";
4
+ export type StartRLNOptions = {
5
+ /**
6
+ * If not set - will extract MetaMask account and get signer from it.
7
+ */
8
+ signer?: ethers.Signer;
9
+ /**
10
+ * If not set - will use default SEPOLIA_CONTRACT address.
11
+ */
12
+ address?: string;
13
+ /**
14
+ * Credentials to use for generating proofs and connecting to the contract and network.
15
+ * If provided used for validating the network chainId and connecting to registry contract.
16
+ */
17
+ credentials?: EncryptedCredentials | DecryptedCredentials;
18
+ /**
19
+ * Rate limit for the member.
20
+ */
21
+ rateLimit?: number;
22
+ };
23
+ export type RegisterMembershipOptions = {
24
+ signature: string;
25
+ } | {
26
+ identity: IdentityCredential;
27
+ };
package/dist/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/dist/zerokit.d.ts CHANGED
@@ -4,11 +4,11 @@ import { WitnessCalculator } from "./resources/witness_calculator";
4
4
  export declare class Zerokit {
5
5
  private readonly zkRLN;
6
6
  private readonly witnessCalculator;
7
- private readonly rateLimit;
8
- constructor(zkRLN: number, witnessCalculator: WitnessCalculator, rateLimit?: number);
7
+ private readonly _rateLimit;
8
+ constructor(zkRLN: number, witnessCalculator: WitnessCalculator, _rateLimit?: number);
9
9
  get getZkRLN(): number;
10
10
  get getWitnessCalculator(): WitnessCalculator;
11
- get getRateLimit(): number;
11
+ get rateLimit(): number;
12
12
  generateIdentityCredentials(): IdentityCredential;
13
13
  generateSeededIdentityCredential(seed: string): IdentityCredential;
14
14
  insertMember(idCommitment: Uint8Array): void;
package/dist/zerokit.js CHANGED
@@ -6,11 +6,11 @@ import { concatenate, dateToEpoch, epochIntToBytes, writeUIntLE } from "./utils/
6
6
  export class Zerokit {
7
7
  zkRLN;
8
8
  witnessCalculator;
9
- rateLimit;
10
- constructor(zkRLN, witnessCalculator, rateLimit = DEFAULT_RATE_LIMIT) {
9
+ _rateLimit;
10
+ constructor(zkRLN, witnessCalculator, _rateLimit = DEFAULT_RATE_LIMIT) {
11
11
  this.zkRLN = zkRLN;
12
12
  this.witnessCalculator = witnessCalculator;
13
- this.rateLimit = rateLimit;
13
+ this._rateLimit = _rateLimit;
14
14
  }
15
15
  get getZkRLN() {
16
16
  return this.zkRLN;
@@ -18,8 +18,8 @@ export class Zerokit {
18
18
  get getWitnessCalculator() {
19
19
  return this.witnessCalculator;
20
20
  }
21
- get getRateLimit() {
22
- return this.rateLimit;
21
+ get rateLimit() {
22
+ return this._rateLimit;
23
23
  }
24
24
  generateIdentityCredentials() {
25
25
  const memKeys = zerokitRLN.generateExtendedMembershipKey(this.zkRLN); // TODO: rename this function in zerokit rln-wasm
@@ -1 +1 @@
1
- {"version":3,"file":"zerokit.js","sourceRoot":"","sources":["../src/zerokit.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"zerokit.js","sourceRoot":"","sources":["../src/zerokit.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,91 +1 @@
1
- {
2
- "name": "@waku/rln",
3
- "version": "0.1.4",
4
- "description": "RLN (Rate Limiting Nullifier) implementation for Waku",
5
- "types": "./dist/index.d.ts",
6
- "module": "./dist/index.js",
7
- "exports": {
8
- ".": {
9
- "types": "./dist/index.d.ts",
10
- "import": "./dist/index.js"
11
- }
12
- },
13
- "type": "module",
14
- "homepage": "https://github.com/waku-org/js-waku/tree/master/packages/rln#readme",
15
- "repository": {
16
- "type": "git",
17
- "url": "https://github.com/waku-org/js-waku.git"
18
- },
19
- "bugs": {
20
- "url": "https://github.com/waku-org/js-waku/issues"
21
- },
22
- "license": "MIT OR Apache-2.0",
23
- "keywords": [
24
- "waku",
25
- "rln",
26
- "rate-limiting",
27
- "privacy",
28
- "web3"
29
- ],
30
- "scripts": {
31
- "build": "run-s build:**",
32
- "build:copy": "mkdir -p dist/resources && cp -r src/resources/* dist/resources/",
33
- "build:esm": "tsc",
34
- "build:bundle": "rollup --config rollup.config.js",
35
- "fix": "run-s fix:*",
36
- "fix:lint": "eslint src *.js --fix",
37
- "check": "run-s check:*",
38
- "check:tsc": "tsc -p tsconfig.dev.json",
39
- "check:lint": "eslint \"src/!(resources)/**/*.{ts,js}\" *.js",
40
- "check:spelling": "cspell \"{README.md,src/**/*.ts}\"",
41
- "test": "NODE_ENV=test run-s test:*",
42
- "test:browser": "karma start karma.conf.cjs",
43
- "watch:build": "tsc -p tsconfig.json -w",
44
- "watch:test": "mocha --watch",
45
- "prepublish": "npm run build",
46
- "reset-hard": "git clean -dfx -e .idea && git reset --hard && npm i && npm run build"
47
- },
48
- "engines": {
49
- "node": ">=20"
50
- },
51
- "devDependencies": {
52
- "@rollup/plugin-commonjs": "^25.0.7",
53
- "@rollup/plugin-json": "^6.0.0",
54
- "@rollup/plugin-node-resolve": "^15.2.3",
55
- "@types/chai": "^5.0.1",
56
- "@types/chai-spies": "^1.0.6",
57
- "@types/deep-equal-in-any-order": "^1.0.4",
58
- "@types/lodash": "^4.17.15",
59
- "@types/sinon": "^17.0.3",
60
- "@waku/build-utils": "^1.0.0",
61
- "@waku/message-encryption": "^0.0.32",
62
- "chai": "^5.1.2",
63
- "chai-as-promised": "^8.0.1",
64
- "chai-spies": "^1.1.0",
65
- "chai-subset": "^1.6.0",
66
- "deep-equal-in-any-order": "^2.0.6",
67
- "fast-check": "^3.23.2",
68
- "rollup-plugin-copy": "^3.5.0",
69
- "sinon": "^19.0.2"
70
- },
71
- "files": [
72
- "dist",
73
- "bundle",
74
- "src/**/*.ts",
75
- "!**/*.spec.*",
76
- "!**/*.json",
77
- "CHANGELOG.md",
78
- "LICENSE",
79
- "README.md"
80
- ],
81
- "dependencies": {
82
- "@chainsafe/bls-keystore": "3.0.0",
83
- "@waku/core": "^0.0.34",
84
- "@waku/utils": "^0.0.22",
85
- "@waku/zerokit-rln-wasm": "^0.0.13",
86
- "ethereum-cryptography": "^3.1.0",
87
- "ethers": "^5.7.2",
88
- "lodash": "^4.17.21",
89
- "uuid": "^11.0.5"
90
- }
91
- }
1
+ {"name":"@waku/rln","version":"0.1.5-1d384f2.0","description":"RLN (Rate Limiting Nullifier) implementation for Waku","types":"./dist/index.d.ts","module":"./dist/index.js","exports":{".":{"types":"./dist/index.d.ts","import":"./dist/index.js"}},"type":"module","homepage":"https://github.com/waku-org/js-waku/tree/master/packages/rln#readme","repository":{"type":"git","url":"https://github.com/waku-org/js-waku.git"},"bugs":{"url":"https://github.com/waku-org/js-waku/issues"},"license":"MIT OR Apache-2.0","keywords":["waku","rln","rate-limiting","privacy","web3"],"scripts":{"build":"run-s build:**","build:copy":"mkdir -p dist/resources && cp -r src/resources/* dist/resources/","build:esm":"tsc","build:bundle":"rollup --config rollup.config.js","fix":"run-s fix:*","fix:lint":"eslint src *.js --fix","check":"run-s check:*","check:tsc":"tsc -p tsconfig.dev.json","check:lint":"eslint \"src/!(resources)/**/*.{ts,js}\" *.js","check:spelling":"cspell \"{README.md,src/**/*.ts}\"","test":"NODE_ENV=test run-s test:*","test:browser":"karma start karma.conf.cjs","watch:build":"tsc -p tsconfig.json -w","watch:test":"mocha --watch","prepublish":"npm run build","reset-hard":"git clean -dfx -e .idea && git reset --hard && npm i && npm run build"},"engines":{"node":">=20"},"devDependencies":{"@rollup/plugin-commonjs":"^25.0.7","@rollup/plugin-json":"^6.0.0","@rollup/plugin-node-resolve":"^15.2.3","@types/chai":"^5.0.1","@types/chai-spies":"^1.0.6","@types/deep-equal-in-any-order":"^1.0.4","@types/lodash":"^4.17.15","@types/sinon":"^17.0.3","@waku/build-utils":"^1.0.0","@waku/message-encryption":"0.0.33-1d384f2.0","deep-equal-in-any-order":"^2.0.6","fast-check":"^3.23.2","rollup-plugin-copy":"^3.5.0"},"files":["dist","bundle","src/**/*.ts","!**/*.spec.*","!**/*.json","CHANGELOG.md","LICENSE","README.md"],"dependencies":{"@chainsafe/bls-keystore":"3.0.0","@waku/core":"0.0.35-1d384f2.0","@waku/utils":"0.0.23-1d384f2.0","@noble/hashes":"^1.2.0","@waku/zerokit-rln-wasm":"^0.0.13","ethereum-cryptography":"^3.1.0","ethers":"^5.7.2","lodash":"^4.17.21","uuid":"^11.0.5","chai":"^5.1.2","chai-as-promised":"^8.0.1","chai-spies":"^1.1.0","chai-subset":"^1.6.0","sinon":"^19.0.2"}}
@@ -0,0 +1,80 @@
1
+ import type { IProtoMessage } from "@waku/interfaces";
2
+ import { expect } from "chai";
3
+
4
+ import { createRLN } from "./create.js";
5
+ import type { IdentityCredential } from "./identity.js";
6
+
7
+ export interface TestRLNCodecSetup {
8
+ rlnInstance: any;
9
+ credential: IdentityCredential;
10
+ index: number;
11
+ payload: Uint8Array;
12
+ }
13
+
14
+ export const TEST_CONSTANTS = {
15
+ contentTopic: "/test/1/waku-message/utf8",
16
+ emptyPubsubTopic: "",
17
+ defaultIndex: 0,
18
+ defaultPayload: new Uint8Array([1, 2, 3, 4, 5])
19
+ } as const;
20
+
21
+ export const EMPTY_PROTO_MESSAGE = {
22
+ timestamp: undefined,
23
+ contentTopic: "",
24
+ ephemeral: undefined,
25
+ meta: undefined,
26
+ rateLimitProof: undefined,
27
+ version: undefined
28
+ } as const;
29
+
30
+ /**
31
+ * Creates a basic RLN setup for codec tests
32
+ */
33
+ export async function createTestRLNCodecSetup(): Promise<TestRLNCodecSetup> {
34
+ const rlnInstance = await createRLN();
35
+ const credential = rlnInstance.zerokit.generateIdentityCredentials();
36
+ rlnInstance.zerokit.insertMember(credential.IDCommitment);
37
+
38
+ return {
39
+ rlnInstance,
40
+ credential,
41
+ index: TEST_CONSTANTS.defaultIndex,
42
+ payload: TEST_CONSTANTS.defaultPayload
43
+ };
44
+ }
45
+
46
+ /**
47
+ * Creates a meta setter function for testing
48
+ */
49
+ export function createTestMetaSetter(): (
50
+ msg: IProtoMessage & { meta: undefined }
51
+ ) => Uint8Array {
52
+ return (msg: IProtoMessage & { meta: undefined }): Uint8Array => {
53
+ const buffer = new ArrayBuffer(4);
54
+ const view = new DataView(buffer);
55
+ view.setUint32(0, msg.payload.length, false);
56
+ return new Uint8Array(buffer);
57
+ };
58
+ }
59
+
60
+ /**
61
+ * Verifies common RLN message properties
62
+ */
63
+ export function verifyRLNMessage(
64
+ msg: any,
65
+ payload: Uint8Array,
66
+ contentTopic: string,
67
+ version: number,
68
+ rlnInstance: any
69
+ ): void {
70
+ expect(msg.rateLimitProof).to.not.be.undefined;
71
+ expect(msg.verify([rlnInstance.zerokit.getMerkleRoot()])).to.be.true;
72
+ expect(msg.verifyNoRoot()).to.be.true;
73
+ expect(msg.epoch).to.not.be.undefined;
74
+ expect(msg.epoch).to.be.gt(0);
75
+
76
+ expect(msg.contentTopic).to.eq(contentTopic);
77
+ expect(msg.msg.version).to.eq(version);
78
+ expect(msg.payload).to.deep.eq(payload);
79
+ expect(msg.timestamp).to.not.be.undefined;
80
+ }