@maci-protocol/coordinator 0.0.0-ci.e3476db → 0.0.0-ci.e47bd6e

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 (96) hide show
  1. package/LICENSE +1 -2
  2. package/README.md +13 -6
  3. package/build/hardhat.config.cjs +3 -0
  4. package/build/hardhat.config.cjs.map +1 -1
  5. package/build/hardhat.config.d.cts +3 -0
  6. package/build/scripts/generateMaciKeyPair.js +2 -2
  7. package/build/scripts/generateMaciKeyPair.js.map +1 -1
  8. package/build/tests/constants.d.ts +0 -1
  9. package/build/tests/constants.d.ts.map +1 -1
  10. package/build/tests/constants.js +0 -1
  11. package/build/tests/constants.js.map +1 -1
  12. package/build/tests/e2e.aa.test.js +17 -22
  13. package/build/tests/e2e.aa.test.js.map +1 -1
  14. package/build/tests/e2e.deploy.test.js +119 -82
  15. package/build/tests/e2e.deploy.test.js.map +1 -1
  16. package/build/tests/utils.d.ts +6 -0
  17. package/build/tests/utils.d.ts.map +1 -1
  18. package/build/tests/utils.js +12 -3
  19. package/build/tests/utils.js.map +1 -1
  20. package/build/ts/common/__tests__/common.test.js +7 -11
  21. package/build/ts/common/__tests__/common.test.js.map +1 -1
  22. package/build/ts/common/accountAbstraction.d.ts +2 -19
  23. package/build/ts/common/accountAbstraction.d.ts.map +1 -1
  24. package/build/ts/common/accountAbstraction.js +15 -44
  25. package/build/ts/common/accountAbstraction.js.map +1 -1
  26. package/build/ts/common/chain.d.ts +16 -0
  27. package/build/ts/common/chain.d.ts.map +1 -0
  28. package/build/ts/common/chain.js +35 -0
  29. package/build/ts/common/chain.js.map +1 -0
  30. package/build/ts/common/errors.d.ts +17 -18
  31. package/build/ts/common/errors.d.ts.map +1 -1
  32. package/build/ts/common/errors.js +17 -18
  33. package/build/ts/common/errors.js.map +1 -1
  34. package/build/ts/common/index.d.ts +2 -0
  35. package/build/ts/common/index.d.ts.map +1 -1
  36. package/build/ts/common/index.js +2 -0
  37. package/build/ts/common/index.js.map +1 -1
  38. package/build/ts/common/types.d.ts +2 -3
  39. package/build/ts/common/types.d.ts.map +1 -1
  40. package/build/ts/deployer/__tests__/deployer.service.test.js +30 -289
  41. package/build/ts/deployer/__tests__/deployer.service.test.js.map +1 -1
  42. package/build/ts/deployer/__tests__/utils.d.ts +30 -1
  43. package/build/ts/deployer/__tests__/utils.d.ts.map +1 -1
  44. package/build/ts/deployer/__tests__/utils.js +46 -11
  45. package/build/ts/deployer/__tests__/utils.js.map +1 -1
  46. package/build/ts/deployer/deployer.service.d.ts +17 -53
  47. package/build/ts/deployer/deployer.service.d.ts.map +1 -1
  48. package/build/ts/deployer/deployer.service.js +174 -447
  49. package/build/ts/deployer/deployer.service.js.map +1 -1
  50. package/build/ts/deployer/dto.d.ts +4 -4
  51. package/build/ts/deployer/dto.d.ts.map +1 -1
  52. package/build/ts/deployer/dto.js +9 -1
  53. package/build/ts/deployer/dto.js.map +1 -1
  54. package/build/ts/deployer/types.d.ts +75 -24
  55. package/build/ts/deployer/types.d.ts.map +1 -1
  56. package/build/ts/file/__tests__/file.service.test.js +12 -11
  57. package/build/ts/file/__tests__/file.service.test.js.map +1 -1
  58. package/build/ts/file/file.service.d.ts +4 -3
  59. package/build/ts/file/file.service.d.ts.map +1 -1
  60. package/build/ts/file/file.service.js +14 -9
  61. package/build/ts/file/file.service.js.map +1 -1
  62. package/build/ts/file/types.d.ts +2 -2
  63. package/build/ts/file/types.d.ts.map +1 -1
  64. package/build/ts/proof/__tests__/proof.controller.test.js +5 -2
  65. package/build/ts/proof/__tests__/proof.controller.test.js.map +1 -1
  66. package/build/ts/proof/__tests__/proof.gateway.test.js +6 -2
  67. package/build/ts/proof/__tests__/proof.gateway.test.js.map +1 -1
  68. package/build/ts/proof/__tests__/proof.service.test.js +12 -10
  69. package/build/ts/proof/__tests__/proof.service.test.js.map +1 -1
  70. package/build/ts/proof/dto.d.ts +13 -11
  71. package/build/ts/proof/dto.d.ts.map +1 -1
  72. package/build/ts/proof/dto.js +51 -29
  73. package/build/ts/proof/dto.js.map +1 -1
  74. package/build/ts/proof/proof.controller.d.ts +3 -2
  75. package/build/ts/proof/proof.controller.d.ts.map +1 -1
  76. package/build/ts/proof/proof.controller.js.map +1 -1
  77. package/build/ts/proof/proof.service.d.ts +3 -3
  78. package/build/ts/proof/proof.service.d.ts.map +1 -1
  79. package/build/ts/proof/proof.service.js +40 -120
  80. package/build/ts/proof/proof.service.js.map +1 -1
  81. package/build/ts/proof/types.d.ts +18 -10
  82. package/build/ts/proof/types.d.ts.map +1 -1
  83. package/build/ts/sessionKeys/provider/KernelEIP1193Provider.d.ts +53 -0
  84. package/build/ts/sessionKeys/provider/KernelEIP1193Provider.d.ts.map +1 -0
  85. package/build/ts/sessionKeys/provider/KernelEIP1193Provider.js +105 -0
  86. package/build/ts/sessionKeys/provider/KernelEIP1193Provider.js.map +1 -0
  87. package/build/ts/sessionKeys/sessionKeys.service.d.ts +13 -2
  88. package/build/ts/sessionKeys/sessionKeys.service.d.ts.map +1 -1
  89. package/build/ts/sessionKeys/sessionKeys.service.js +22 -4
  90. package/build/ts/sessionKeys/sessionKeys.service.js.map +1 -1
  91. package/build/tsconfig.build.tsbuildinfo +1 -1
  92. package/package.json +30 -30
  93. package/build/ts/deployer/utils.d.ts +0 -8
  94. package/build/ts/deployer/utils.d.ts.map +0 -1
  95. package/build/ts/deployer/utils.js +0 -9
  96. package/build/ts/deployer/utils.js.map +0 -1
@@ -7,29 +7,21 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
7
7
  var __metadata = (this && this.__metadata) || function (k, v) {
8
8
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
9
  };
10
- var DeployerService_1;
11
- import { PubKey, VerifyingKey } from "@maci-protocol/domainobjs";
12
- import { ConstantInitialVoiceCreditProxy__factory as ConstantInitialVoiceCreditProxyFactory, ContractStorage, EPolicies, FreeForAllPolicy__factory as FreeForAllPolicyFactory, EASPolicy__factory as EASPolicyFactory, ZupassPolicy__factory as ZupassPolicyFactory, HatsPolicy__factory as HatsPolicyFactory, SemaphorePolicy__factory as SemaphorePolicyFactory, GitcoinPassportPolicy__factory as GitcoinPassportPolicyFactory, Verifier__factory as VerifierFactory, PoseidonT3__factory as PoseidonT3Factory, PoseidonT4__factory as PoseidonT4Factory, PoseidonT5__factory as PoseidonT5Factory, PoseidonT6__factory as PoseidonT6Factory, VkRegistry__factory as VkRegistryFactory, TallyFactory__factory as TallyFactoryFactory, PollFactory__factory as PollFactoryFactory, MessageProcessorFactory__factory as MessageProcessorFactoryFactory, MessageProcessor__factory as MessageProcessorFactory, ERC20VotesPolicy__factory as ERC20VotesPolicyFactory, Tally__factory as TallyFactory, Poll__factory as PollFactory, MACI__factory as MACIFactory, EContracts, EInitialVoiceCreditProxies, EMode, deployPoll, extractAllVks, extractVk, genEmptyBallotRoots, } from "@maci-protocol/sdk";
13
- import { Injectable, Logger } from "@nestjs/common";
10
+ import { deployVerifier } from "@maci-protocol/contracts";
11
+ import { PublicKey } from "@maci-protocol/domainobjs";
12
+ import { ContractStorage, EPolicies, VerifyingKeysRegistry__factory as VerifyingKeysRegistryFactory, MessageProcessor__factory as MessageProcessorFactory, Tally__factory as TallyFactory, Poll__factory as PollFactory, MACI__factory as MACIFactory, EContracts, EInitialVoiceCreditProxies, EMode, deployPoll, extractAllVerifyingKeys, deployConstantInitialVoiceCreditProxy, deployFreeForAllSignUpPolicy, deployERC20VotesPolicy, deployAnonAadhaarPolicy, deploySignupTokenPolicy, deployMerkleProofPolicy, deploySemaphoreSignupPolicy, deployZupassSignUpPolicy, deployGitcoinPassportPolicy, deployEASSignUpPolicy, deployHatsSignupPolicy, deployMaci, setVerifyingKeys, deployVerifyingKeysRegistryContract, generateEmptyBallotRoots, } from "@maci-protocol/sdk";
13
+ import { Injectable } from "@nestjs/common";
14
14
  import { BaseContract } from "ethers";
15
- import { encodeFunctionData } from "viem";
16
15
  import path from "path";
17
16
  import { ErrorCodes } from "../common";
18
- import { getBundlerClient, getDeployedContractAddress, getPublicClient } from "../common/accountAbstraction";
19
17
  import { FileService } from "../file/file.service";
20
18
  import { SessionKeysService } from "../sessionKeys/sessionKeys.service";
21
- import { MAX_GAS_LIMIT } from "./constants";
22
- import { estimateExtraGasLimit } from "./utils";
23
19
  /**
24
20
  * DeployerService is responsible for deploying contracts.
25
21
  */
26
- let DeployerService = DeployerService_1 = class DeployerService {
22
+ let DeployerService = class DeployerService {
27
23
  sessionKeysService;
28
24
  fileService;
29
- /**
30
- * Logger
31
- */
32
- logger = new Logger(DeployerService_1.name);
33
25
  /**
34
26
  * Contract storage instance
35
27
  */
@@ -42,299 +34,166 @@ let DeployerService = DeployerService_1 = class DeployerService {
42
34
  constructor(sessionKeysService, fileService) {
43
35
  this.sessionKeysService = sessionKeysService;
44
36
  this.fileService = fileService;
45
- this.logger = new Logger(DeployerService_1.name);
46
37
  this.storage = ContractStorage.getInstance(path.join(process.cwd(), "deployed-contracts.json"));
47
38
  }
48
39
  /**
49
- * Get the policy abi and bytecode based on the policy type
50
- * and also check if there is already an instance deployed
40
+ * Get the policy contract object
41
+ * always deploy and save it
51
42
  *
43
+ * @param signer - the signer
52
44
  * @param policyType - the policy type
53
45
  * @param network - the network
54
46
  * @param args - the policy args
55
- * @returns - the policy abi and bytecode
47
+ * @returns - the policy contract
56
48
  */
57
- getPolicyData(policyType, network, args) {
58
- const address = this.storage.getAddress(policyType, network);
59
- let storedArgs;
60
- let isAlreadyDeployed;
49
+ async deployAndSavePolicy(signer, policyType, network, args) {
50
+ let contract;
61
51
  // based on the policy type, we need to deploy the correct policy
62
52
  switch (policyType) {
63
53
  case EPolicies.FreeForAll: {
64
- return {
65
- address,
66
- abi: FreeForAllPolicyFactory.abi,
67
- bytecode: FreeForAllPolicyFactory.bytecode,
68
- alreadyDeployed: !!address,
69
- };
54
+ [contract] = await deployFreeForAllSignUpPolicy({}, signer, true);
55
+ break;
70
56
  }
71
57
  case EPolicies.EAS: {
72
- storedArgs = this.storage.getContractArgs(policyType, network);
73
- isAlreadyDeployed =
74
- !!storedArgs &&
75
- storedArgs.length === 3 &&
76
- storedArgs[0] === args.easAddress &&
77
- storedArgs[1] === args.schema &&
78
- storedArgs[2] === args.attester;
79
- return {
80
- address: isAlreadyDeployed ? address : undefined,
81
- abi: EASPolicyFactory.abi,
82
- bytecode: EASPolicyFactory.bytecode,
83
- alreadyDeployed: isAlreadyDeployed,
84
- };
58
+ [contract] = await deployEASSignUpPolicy({
59
+ eas: args.easAddress,
60
+ attester: args.attester,
61
+ schema: args.schema,
62
+ }, {}, signer, true);
63
+ break;
85
64
  }
86
- case EPolicies.Zupass: {
87
- storedArgs = this.storage.getContractArgs(policyType, network);
88
- isAlreadyDeployed =
89
- !!storedArgs &&
90
- storedArgs.length === 4 &&
91
- storedArgs[0] === args.signer1 &&
92
- storedArgs[1] === args.signer2 &&
93
- storedArgs[2] === args.eventId &&
94
- storedArgs[3] === args.zupassVerifier;
95
- return {
96
- address: isAlreadyDeployed ? address : undefined,
97
- abi: ZupassPolicyFactory.abi,
98
- bytecode: ZupassPolicyFactory.bytecode,
99
- alreadyDeployed: isAlreadyDeployed,
100
- };
65
+ case EPolicies.GitcoinPassport: {
66
+ [contract] = await deployGitcoinPassportPolicy({
67
+ decoderAddress: args.decoderAddress,
68
+ minimumScore: Number(args.passingScore),
69
+ }, {}, signer, true);
70
+ break;
101
71
  }
102
72
  case EPolicies.Hats: {
103
- storedArgs = this.storage.getContractArgs(policyType, network);
104
- isAlreadyDeployed =
105
- !!storedArgs &&
106
- storedArgs.length === 2 &&
107
- storedArgs[0] === args.hatsProtocolAddress &&
108
- JSON.stringify(storedArgs[1]) === JSON.stringify(args.critrionHats);
109
- return {
110
- address: isAlreadyDeployed ? address : undefined,
111
- abi: HatsPolicyFactory.abi,
112
- bytecode: HatsPolicyFactory.bytecode,
113
- alreadyDeployed: isAlreadyDeployed,
114
- };
73
+ [contract] = await deployHatsSignupPolicy({
74
+ hats: args.hatsProtocolAddress,
75
+ criterionHats: args.critrionHats.map((c) => BigInt(c)),
76
+ }, {}, signer, true);
77
+ break;
78
+ }
79
+ case EPolicies.Zupass: {
80
+ [contract] = await deployZupassSignUpPolicy({
81
+ eventId: args.eventId,
82
+ signer1: args.signer1,
83
+ signer2: args.signer2,
84
+ verifier: args.zupassVerifier,
85
+ }, {}, signer, true);
86
+ break;
115
87
  }
116
88
  case EPolicies.Semaphore: {
117
- storedArgs = this.storage.getContractArgs(policyType, network);
118
- isAlreadyDeployed =
119
- !!storedArgs &&
120
- storedArgs.length === 2 &&
121
- storedArgs[0] === args.semaphoreContract &&
122
- storedArgs[1] === args.groupId;
123
- return {
124
- address: isAlreadyDeployed ? address : undefined,
125
- abi: SemaphorePolicyFactory.abi,
126
- bytecode: SemaphorePolicyFactory.bytecode,
127
- alreadyDeployed: isAlreadyDeployed,
128
- };
89
+ [contract] = await deploySemaphoreSignupPolicy({
90
+ semaphore: args.semaphoreContract,
91
+ groupId: BigInt(args.groupId),
92
+ }, {}, signer, true);
93
+ break;
129
94
  }
130
- case EPolicies.GitcoinPassport: {
131
- storedArgs = this.storage.getContractArgs(policyType, network);
132
- isAlreadyDeployed =
133
- !!storedArgs &&
134
- storedArgs.length === 2 &&
135
- storedArgs[0] === args.decoderAddress &&
136
- storedArgs[1] === args.passingScore;
137
- return {
138
- address: isAlreadyDeployed ? address : undefined,
139
- abi: GitcoinPassportPolicyFactory.abi,
140
- bytecode: GitcoinPassportPolicyFactory.bytecode,
141
- alreadyDeployed: isAlreadyDeployed,
142
- };
95
+ case EPolicies.MerkleProof: {
96
+ [contract] = await deployMerkleProofPolicy({
97
+ root: args.root,
98
+ }, {}, signer, true);
99
+ break;
100
+ }
101
+ case EPolicies.Token: {
102
+ [contract] = await deploySignupTokenPolicy({
103
+ token: args.token,
104
+ }, {}, signer, true);
105
+ break;
106
+ }
107
+ case EPolicies.AnonAadhaar: {
108
+ [contract] = await deployAnonAadhaarPolicy({
109
+ verifierAddress: args.verifier,
110
+ nullifierSeed: args.nullifierSeed,
111
+ }, {}, signer, true);
112
+ break;
143
113
  }
144
114
  case EPolicies.ERC20Votes: {
145
- storedArgs = this.storage.getContractArgs(policyType, network);
146
- isAlreadyDeployed =
147
- !!storedArgs &&
148
- storedArgs.length === 3 &&
149
- storedArgs[0] === args.token &&
150
- storedArgs[1] === args.factor &&
151
- storedArgs[2] === args.snapshotBlock;
152
- return {
153
- address: isAlreadyDeployed ? address : undefined,
154
- abi: ERC20VotesPolicyFactory.abi,
155
- bytecode: ERC20VotesPolicyFactory.bytecode,
156
- alreadyDeployed: isAlreadyDeployed,
157
- };
115
+ [contract] = await deployERC20VotesPolicy({
116
+ snapshotBlock: BigInt(args.snapshotBlock),
117
+ threshold: BigInt(args.threshold),
118
+ token: args.token,
119
+ }, {}, signer, true);
120
+ break;
158
121
  }
159
122
  default:
160
123
  throw new Error(ErrorCodes.UNSUPPORTED_POLICY.toString());
161
124
  }
125
+ await this.storage.register({
126
+ id: policyType,
127
+ contract,
128
+ args: args ? Object.values(args).map((arg) => String(arg)) : [],
129
+ network,
130
+ });
131
+ return contract;
162
132
  }
163
133
  /**
164
- * Get the voice credit proxy abi and bytecode based on the voice credit proxy type
165
- * and also check if there is already an instance deployed
134
+ * Get the voice credit proxy contract object
135
+ * always deploy and save it
166
136
  *
137
+ * @param signer - the signer
167
138
  * @param voiceCreditProxyType - the voice credit proxy type
168
139
  * @param network - the network
169
- * @param args - the voice credit proxy args
170
- * @returns - the voice credit proxy abi and bytecode
140
+ * @param args - the args
141
+ * @returns - the voice credit proxy contract
171
142
  */
172
- getVoiceCreditProxyData(voiceCreditProxyType, network, args) {
173
- let storedArgs;
174
- let isAlreadyDeployed;
175
- const address = this.storage.getAddress(voiceCreditProxyType, network);
143
+ async deployAndSaveVoiceCreditProxy(signer, voiceCreditProxyType, network, args) {
144
+ let contract;
176
145
  switch (voiceCreditProxyType) {
177
146
  case EInitialVoiceCreditProxies.Constant: {
178
- storedArgs = this.storage.getContractArgs(voiceCreditProxyType, network);
179
- isAlreadyDeployed = !!storedArgs && storedArgs[0] === args.amount;
180
- return {
181
- address: isAlreadyDeployed ? address : undefined,
182
- abi: ConstantInitialVoiceCreditProxyFactory.abi,
183
- bytecode: ConstantInitialVoiceCreditProxyFactory.bytecode,
184
- alreadyDeployed: isAlreadyDeployed,
185
- };
147
+ [contract] = await deployConstantInitialVoiceCreditProxy({
148
+ amount: args.amount,
149
+ }, signer, undefined, true);
150
+ break;
186
151
  }
187
152
  default:
188
153
  throw new Error(ErrorCodes.UNSUPPORTED_VOICE_CREDIT_PROXY.toString());
189
154
  }
190
- }
191
- /**
192
- * @param abi - the abi
193
- * @param bytecode - the bytecode
194
- * @param args - the args
195
- * @param publicClient - the public client
196
- * @returns - the address
197
- */
198
- async deployAndGetAddress(kernelClient, abi, bytecode, args, bundlerClient, publicClient) {
199
- const deployCallData = await kernelClient.account.encodeDeployCallData({
200
- abi,
201
- args,
202
- bytecode,
203
- });
204
- const gasPrice = await kernelClient.getUserOperationGasPrice();
205
- const opEstimate = await kernelClient.prepareUserOperation({
206
- callData: deployCallData,
207
- sender: kernelClient.account.address,
208
- maxFeePerGas: gasPrice.maxFeePerGas,
209
- maxPriorityFeePerGas: gasPrice.maxPriorityFeePerGas,
210
- });
211
- const callGasLimitMultiplier = estimateExtraGasLimit(opEstimate.callGasLimit);
212
- const tx = await kernelClient.sendUserOperation({
213
- callData: deployCallData,
214
- sender: kernelClient.account.address,
215
- maxFeePerGas: gasPrice.maxFeePerGas,
216
- maxPriorityFeePerGas: gasPrice.maxPriorityFeePerGas,
217
- callGasLimit: opEstimate.callGasLimit + callGasLimitMultiplier < MAX_GAS_LIMIT
218
- ? opEstimate.callGasLimit + callGasLimitMultiplier
219
- : MAX_GAS_LIMIT,
220
- });
221
- const receipt = await bundlerClient.waitForUserOperationReceipt({
222
- hash: tx,
155
+ await this.storage.register({
156
+ id: voiceCreditProxyType,
157
+ contract,
158
+ args: args ? Object.values(args).map((arg) => String(arg)) : [],
159
+ network,
223
160
  });
224
- const txReceipt = await publicClient.getTransactionReceipt({
225
- hash: receipt.receipt.transactionHash,
226
- });
227
- return getDeployedContractAddress(txReceipt);
228
- }
229
- /**
230
- * Deploy a contract and store the address
231
- *
232
- * @param contract - the contract to deploy
233
- * @param args - the args
234
- * @param abi - the abi
235
- * @param bytecode - the bytecode
236
- * @param kernelClient - the kernel client
237
- * @param publicClient - the public client
238
- * @param chain - the chain
239
- * @returns - the address of the deployed contract
240
- */
241
- async deployAndStore(contract, args, abi, bytecode, kernelClient, bundlerClient, publicClient, chain) {
242
- let address = this.storage.getAddress(contract, chain);
243
- if (!address) {
244
- address = await this.deployAndGetAddress(kernelClient, abi, bytecode, args, bundlerClient, publicClient);
245
- if (!address) {
246
- this.logger.error(`Failed to deploy contract: ${contract}`);
247
- throw new Error(`${ErrorCodes.FAILED_TO_DEPLOY_CONTRACT} ${contract}`);
248
- }
249
- await this.storage.register({
250
- id: contract,
251
- contract: new BaseContract(address, abi),
252
- args: args.map((arg) => {
253
- if (Array.isArray(arg)) {
254
- return arg.map((a) => String(a));
255
- }
256
- return String(arg);
257
- }),
258
- network: chain,
259
- });
260
- }
261
- return address;
262
- }
263
- /**
264
- * Estimate gas, add a bit extra and send the user operation (aka. transaction)
265
- * @param to - the to address of the user operation
266
- * @param value - the value of the user operation
267
- * @param abi - the abi
268
- * @param functionName - the function name
269
- * @param args - the args
270
- * @param errorMessage - the error message
271
- * @param kernelClient - the kernel client
272
- * @param bundlerClient - the bundler client
273
- */
274
- async estimateGasAndSend(to, value, abi, functionName, args, errorMessage, kernelClient, bundlerClient) {
275
- const gasEstimates = await kernelClient.getUserOperationGasPrice();
276
- const userOperation = {
277
- sender: kernelClient.account.address,
278
- maxFeePerGas: gasEstimates.maxFeePerGas,
279
- maxPriorityFeePerGas: gasEstimates.maxPriorityFeePerGas,
280
- callData: await kernelClient.account.encodeCalls([
281
- {
282
- to,
283
- value,
284
- data: encodeFunctionData({
285
- abi,
286
- functionName,
287
- args,
288
- }),
289
- },
290
- ]),
291
- };
292
- const opEstimate = await kernelClient.prepareUserOperation(userOperation);
293
- const callGasLimitMultiplier = estimateExtraGasLimit(opEstimate.callGasLimit);
294
- const userOperationHash = await kernelClient.sendUserOperation({
295
- ...userOperation,
296
- callGasLimit: opEstimate.callGasLimit + callGasLimitMultiplier < MAX_GAS_LIMIT
297
- ? opEstimate.callGasLimit + callGasLimitMultiplier
298
- : MAX_GAS_LIMIT,
299
- });
300
- const receipt = await bundlerClient.waitForUserOperationReceipt({ hash: userOperationHash });
301
- if (!receipt.success) {
302
- throw new Error(errorMessage);
303
- }
304
- return receipt;
161
+ return contract;
305
162
  }
306
163
  /**
307
164
  * Get verifying keys arguments (specially zkey paths)
308
165
  * @param signer - the signer
309
- * @param vkRegistryContract - the deployed vk registry contract
310
- * @param vkRegistryArgs - the arguments send to the endpoint
166
+ * @param verifyingKeysRegistryContract - the deployed verifyingKey registry contract
167
+ * @param verifyingKeysRegistryArgs - the arguments send to the endpoint
311
168
  * @param mode - use QV or NON_QV
312
169
  * @returns SetVerifyingKeysArgs
313
170
  */
314
- async getVerifyingKeysArgs(signer, vkRegistryContract, vkRegistryArgs, mode) {
315
- const pollJoiningZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINING_ZKEY_NAME, true).zkey;
316
- const pollJoinedZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINED_ZKEY_NAME, true).zkey;
317
- const processMessagesZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_MESSAGE_PROCESS_ZKEY_NAME, mode === EMode.QV).zkey;
318
- const tallyVotesZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_TALLY_ZKEY_NAME, mode === EMode.QV).zkey;
319
- const { pollJoiningVk, pollJoinedVk, processVk, tallyVk } = await extractAllVks({
171
+ async getVerifyingKeysArgs(signer, verifyingKeysRegistryAddress, verifyingKeysRegistryArgs, mode) {
172
+ const { zkey: pollJoiningZkeyPath } = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINING_ZKEY_NAME, EMode.QV);
173
+ const { zkey: pollJoinedZkeyPath } = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINED_ZKEY_NAME, EMode.QV);
174
+ const { zkey: messageProcessorZkeyPath } = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_MESSAGE_PROCESS_ZKEY_NAME, mode);
175
+ // There are only QV and Non-QV modes available for tally circuit
176
+ const { zkey: voteTallyZkeyPath } = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_TALLY_ZKEY_NAME, mode === EMode.QV ? mode : EMode.NON_QV);
177
+ const { pollJoiningVerifyingKey, pollJoinedVerifyingKey, processVerifyingKey, tallyVerifyingKey } = await extractAllVerifyingKeys({
320
178
  pollJoiningZkeyPath,
321
179
  pollJoinedZkeyPath,
322
- processMessagesZkeyPath,
323
- tallyVotesZkeyPath,
180
+ messageProcessorZkeyPath,
181
+ voteTallyZkeyPath,
324
182
  });
325
- const { stateTreeDepth, intStateTreeDepth, voteOptionTreeDepth, messageBatchSize } = vkRegistryArgs;
183
+ const { stateTreeDepth, pollStateTreeDepth, tallyProcessingStateTreeDepth, voteOptionTreeDepth, messageBatchSize } = verifyingKeysRegistryArgs;
326
184
  return {
327
- pollJoiningVk: pollJoiningVk,
328
- pollJoinedVk: pollJoinedVk,
329
- processMessagesVk: processVk,
330
- tallyVotesVk: tallyVk,
185
+ pollJoiningVerifyingKey: pollJoiningVerifyingKey,
186
+ pollJoinedVerifyingKey: pollJoinedVerifyingKey,
187
+ processMessagesVerifyingKey: processVerifyingKey,
188
+ tallyVotesVerifyingKey: tallyVerifyingKey,
331
189
  stateTreeDepth: Number(stateTreeDepth),
332
- intStateTreeDepth: Number(intStateTreeDepth),
190
+ tallyProcessingStateTreeDepth: Number(tallyProcessingStateTreeDepth),
333
191
  voteOptionTreeDepth: Number(voteOptionTreeDepth),
334
192
  messageBatchSize: Number(messageBatchSize),
193
+ pollStateTreeDepth: Number(pollStateTreeDepth),
335
194
  signer,
336
195
  mode,
337
- vkRegistryAddress: await vkRegistryContract.getAddress(),
196
+ verifyingKeysRegistryAddress,
338
197
  };
339
198
  }
340
199
  /**
@@ -346,161 +205,46 @@ let DeployerService = DeployerService_1 = class DeployerService {
346
205
  * @returns the address of the deployed maci contract
347
206
  */
348
207
  async deployMaci({ approval, sessionKeyAddress, chain, config }) {
349
- const publicClient = getPublicClient(chain);
350
- const bundlerClient = getBundlerClient(chain);
351
- const kernelClient = await this.sessionKeysService.generateClientFromSessionKey(sessionKeyAddress, approval, chain);
352
- let policyAddress = this.storage.getAddress(config.policy.type, chain);
353
- const policyData = this.getPolicyData(config.policy.type, chain, config.policy.args);
354
- // if the policy is not already deployed, we need to deploy it
355
- if (!policyData.alreadyDeployed) {
356
- policyAddress = await this.deployAndStore(config.policy.type, config.policy.args ? Object.values(config.policy.args) : [], policyData.abi, policyData.bytecode, kernelClient, bundlerClient, publicClient, chain);
357
- }
358
- // deploy all maci contracts
359
- // (we are not using Promise.all because the write tx nonce should be sequential)
360
- // 1. verifier
361
- await this.deployAndStore(EContracts.Verifier, [], VerifierFactory.abi, VerifierFactory.bytecode, kernelClient, bundlerClient, publicClient, chain);
362
- // 2. poseidon
363
- let poseidonT3Address;
364
- let poseidonT4Address;
365
- let poseidonT5Address;
366
- let poseidonT6Address;
367
- if (config.Poseidon) {
368
- // Some times the poseidon contracts are already deployed so we don't need to deploy them again
369
- poseidonT3Address = config.Poseidon.poseidonT3;
370
- poseidonT4Address = config.Poseidon.poseidonT4;
371
- poseidonT5Address = config.Poseidon.poseidonT5;
372
- poseidonT6Address = config.Poseidon.poseidonT6;
373
- }
374
- else {
375
- poseidonT3Address = await this.deployAndStore(EContracts.PoseidonT3, [], PoseidonT3Factory.abi, PoseidonT3Factory.bytecode, kernelClient, bundlerClient, publicClient, chain);
376
- poseidonT4Address = await this.deployAndStore(EContracts.PoseidonT4, [], PoseidonT4Factory.abi, PoseidonT4Factory.bytecode, kernelClient, bundlerClient, publicClient, chain);
377
- poseidonT5Address = await this.deployAndStore(EContracts.PoseidonT5, [], PoseidonT5Factory.abi, PoseidonT5Factory.bytecode, kernelClient, bundlerClient, publicClient, chain);
378
- poseidonT6Address = await this.deployAndStore(EContracts.PoseidonT6, [], PoseidonT6Factory.abi, PoseidonT6Factory.bytecode, kernelClient, bundlerClient, publicClient, chain);
379
- }
380
- // 3. factories
381
- const pollFactoryAddress = await this.deployAndStore(EContracts.PollFactory, [], PollFactoryFactory.abi, PollFactoryFactory.linkBytecode({
382
- "contracts/crypto/PoseidonT3.sol:PoseidonT3": poseidonT3Address,
383
- "contracts/crypto/PoseidonT4.sol:PoseidonT4": poseidonT4Address,
384
- "contracts/crypto/PoseidonT5.sol:PoseidonT5": poseidonT5Address,
385
- "contracts/crypto/PoseidonT6.sol:PoseidonT6": poseidonT6Address,
386
- }), kernelClient, bundlerClient, publicClient, chain);
387
- const tallyFactoryAddress = await this.deployAndStore(EContracts.TallyFactory, [], TallyFactoryFactory.abi, TallyFactoryFactory.linkBytecode({
388
- "contracts/crypto/PoseidonT3.sol:PoseidonT3": poseidonT3Address,
389
- "contracts/crypto/PoseidonT4.sol:PoseidonT4": poseidonT4Address,
390
- "contracts/crypto/PoseidonT5.sol:PoseidonT5": poseidonT5Address,
391
- "contracts/crypto/PoseidonT6.sol:PoseidonT6": poseidonT6Address,
392
- }), kernelClient, bundlerClient, publicClient, chain);
393
- const messageProcessorFactoryAddress = await this.deployAndStore(EContracts.MessageProcessorFactory, [], MessageProcessorFactoryFactory.abi, MessageProcessorFactoryFactory.linkBytecode({
394
- "contracts/crypto/PoseidonT3.sol:PoseidonT3": poseidonT3Address,
395
- "contracts/crypto/PoseidonT4.sol:PoseidonT4": poseidonT4Address,
396
- "contracts/crypto/PoseidonT5.sol:PoseidonT5": poseidonT5Address,
397
- "contracts/crypto/PoseidonT6.sol:PoseidonT6": poseidonT6Address,
398
- }), kernelClient, bundlerClient, publicClient, chain);
399
- // 4. VkRegistry
400
- const vkRegistryAddress = await this.deployAndStore(EContracts.VkRegistry, [], VkRegistryFactory.abi, VkRegistryFactory.bytecode, kernelClient, bundlerClient, publicClient, chain);
401
- try {
402
- const processMessagesZkeyPathQv = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_MESSAGE_PROCESS_ZKEY_NAME, true);
403
- const tallyVotesZkeyPathQv = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_TALLY_ZKEY_NAME, true);
404
- const processMessagesZkeyPathNonQv = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_MESSAGE_PROCESS_ZKEY_NAME, false);
405
- const tallyVotesZkeyPathNonQv = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_TALLY_ZKEY_NAME, false);
406
- const pollJoiningZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINING_ZKEY_NAME, true);
407
- const pollJoinedZkeyPath = this.fileService.getZkeyFilePaths(process.env.COORDINATOR_POLL_JOINED_ZKEY_NAME, true);
408
- const [qvProcessVk, qvTallyVk, nonQvProcessVk, nonQvTallyVk, pollJoiningVk, pollJoinedVk] = await Promise.all([
409
- extractVk(processMessagesZkeyPathQv.zkey),
410
- extractVk(tallyVotesZkeyPathQv.zkey),
411
- extractVk(processMessagesZkeyPathNonQv.zkey),
412
- extractVk(tallyVotesZkeyPathNonQv.zkey),
413
- extractVk(pollJoiningZkeyPath.zkey),
414
- extractVk(pollJoinedZkeyPath.zkey),
415
- ]).then((vks) => vks.map((vk) => vk && VerifyingKey.fromObj(vk).asContractParam()));
416
- const processZkeys = [qvProcessVk, nonQvProcessVk].filter(Boolean);
417
- const tallyZkeys = [qvTallyVk, nonQvTallyVk].filter(Boolean);
418
- // check if the keys are already set
419
- const [isProcessVkSet, isProcessNonQvVkSet, isTallyVkSet, isTallyNonQvVkSet] = await Promise.all([
420
- publicClient.readContract({
421
- address: vkRegistryAddress,
422
- abi: VkRegistryFactory.abi,
423
- functionName: "hasProcessVk",
424
- args: [
425
- config.VkRegistry.args.stateTreeDepth,
426
- config.VkRegistry.args.voteOptionTreeDepth,
427
- config.VkRegistry.args.messageBatchSize,
428
- EMode.QV,
429
- ],
430
- }),
431
- publicClient.readContract({
432
- address: vkRegistryAddress,
433
- abi: VkRegistryFactory.abi,
434
- functionName: "hasProcessVk",
435
- args: [
436
- config.VkRegistry.args.stateTreeDepth,
437
- config.VkRegistry.args.voteOptionTreeDepth,
438
- config.VkRegistry.args.messageBatchSize,
439
- EMode.NON_QV,
440
- ],
441
- }),
442
- publicClient.readContract({
443
- address: vkRegistryAddress,
444
- abi: VkRegistryFactory.abi,
445
- functionName: "hasTallyVk",
446
- args: [
447
- config.VkRegistry.args.stateTreeDepth,
448
- config.VkRegistry.args.intStateTreeDepth,
449
- config.VkRegistry.args.voteOptionTreeDepth,
450
- EMode.QV,
451
- ],
452
- }),
453
- publicClient.readContract({
454
- address: vkRegistryAddress,
455
- abi: VkRegistryFactory.abi,
456
- functionName: "hasTallyVk",
457
- args: [
458
- config.VkRegistry.args.stateTreeDepth,
459
- config.VkRegistry.args.intStateTreeDepth,
460
- config.VkRegistry.args.voteOptionTreeDepth,
461
- EMode.NON_QV,
462
- ],
463
- }),
464
- ]);
465
- if (isProcessVkSet && isProcessNonQvVkSet && isTallyVkSet && isTallyNonQvVkSet) {
466
- this.logger.debug("Verifying keys are already set on the vk registry");
467
- }
468
- else {
469
- await this.estimateGasAndSend(vkRegistryAddress, 0n, VkRegistryFactory.abi, "setVerifyingKeysBatch", [
470
- config.VkRegistry.args.stateTreeDepth,
471
- config.VkRegistry.args.intStateTreeDepth,
472
- config.VkRegistry.args.voteOptionTreeDepth,
473
- config.VkRegistry.args.messageBatchSize,
474
- [EMode.QV, EMode.NON_QV],
475
- pollJoiningVk,
476
- pollJoinedVk,
477
- processZkeys,
478
- tallyZkeys,
479
- ], ErrorCodes.FAILED_TO_SET_VERIFYING_KEYS_ON_VK_REGISTRY.toString(), kernelClient, bundlerClient);
480
- }
481
- }
482
- catch (error) {
483
- this.logger.error("Failed to set verifying keys on vk registry: ", error);
484
- throw error;
485
- }
486
- // 5. maci (here we don't check whether one is already deployed, we just deploy it)
487
- const emptyBallotRoots = genEmptyBallotRoots(config.MACI.stateTreeDepth);
488
- const maciAddress = await this.deployAndStore(EContracts.MACI, [
489
- pollFactoryAddress,
490
- messageProcessorFactoryAddress,
491
- tallyFactoryAddress,
492
- policyAddress,
493
- config.MACI.stateTreeDepth,
494
- emptyBallotRoots,
495
- ], MACIFactory.abi, MACIFactory.linkBytecode({
496
- "contracts/crypto/PoseidonT3.sol:PoseidonT3": "0x07490eba00dc4ACA6721D052Fa4C5002Aa077233",
497
- "contracts/crypto/PoseidonT4.sol:PoseidonT4": "0xbb0e724CE02e5E7eDd31e632dc6e59F229a1126d",
498
- "contracts/crypto/PoseidonT5.sol:PoseidonT5": "0xE0398F7DFAC494c530F6404AfEaC8669ABeD2679",
499
- "contracts/crypto/PoseidonT6.sol:PoseidonT6": "0xfD77833F10a29c76A6a0ede235Eb651D744d0E2F",
500
- }), kernelClient, bundlerClient, publicClient, chain);
501
- // set the gate on the policy
502
- await this.estimateGasAndSend(policyAddress, 0n, policyData.abi, "setTarget", [maciAddress], ErrorCodes.FAILED_TO_SET_MACI_INSTANCE_ON_POLICY.toString(), kernelClient, bundlerClient);
503
- return { address: maciAddress };
208
+ const signer = await this.sessionKeysService.getCoordinatorSigner(chain, sessionKeyAddress, approval);
209
+ const policyContract = await this.deployAndSavePolicy(signer, config.policy.type, chain, config.policy.args);
210
+ const policyAddress = await policyContract.getAddress();
211
+ const verifierContract = await deployVerifier(signer, true);
212
+ const verifyingKeysRegistryAddress = await deployVerifyingKeysRegistryContract({ signer });
213
+ const verifyingKeysArgs = await this.getVerifyingKeysArgs(signer, verifyingKeysRegistryAddress, config.VerifyingKeysRegistry.args, EMode.QV);
214
+ await setVerifyingKeys(verifyingKeysArgs);
215
+ // deploy the smart contracts
216
+ const maciAddresses = await deployMaci({
217
+ stateTreeDepth: config.MACI.stateTreeDepth,
218
+ signer,
219
+ signupPolicyAddress: policyAddress,
220
+ });
221
+ // store the contracts
222
+ await Promise.all([
223
+ this.storage.register({
224
+ id: EContracts.Verifier,
225
+ contract: verifierContract,
226
+ network: chain,
227
+ }),
228
+ this.storage.register({
229
+ id: EContracts.VerifyingKeysRegistry,
230
+ contract: new BaseContract(verifyingKeysRegistryAddress, VerifyingKeysRegistryFactory.abi),
231
+ network: chain,
232
+ }),
233
+ this.storage.register({
234
+ id: EContracts.MACI,
235
+ contract: new BaseContract(maciAddresses.maciContractAddress, MACIFactory.abi),
236
+ args: [
237
+ maciAddresses.pollFactoryContractAddress,
238
+ maciAddresses.messageProcessorFactoryContractAddress,
239
+ maciAddresses.tallyFactoryContractAddress,
240
+ policyAddress,
241
+ config.MACI.stateTreeDepth,
242
+ generateEmptyBallotRoots(config.MACI.stateTreeDepth).map((root) => root.toString()),
243
+ ],
244
+ network: chain,
245
+ }),
246
+ ]);
247
+ return { address: maciAddresses.maciContractAddress };
504
248
  }
505
249
  /**
506
250
  * Deploy a poll
@@ -509,10 +253,7 @@ let DeployerService = DeployerService_1 = class DeployerService {
509
253
  * @returns poll id
510
254
  */
511
255
  async deployPoll({ approval, sessionKeyAddress, chain, config }) {
512
- const publicClient = getPublicClient(chain);
513
- const bundlerClient = getBundlerClient(chain);
514
- const kernelClient = await this.sessionKeysService.generateClientFromSessionKey(sessionKeyAddress, approval, chain);
515
- const signer = await this.sessionKeysService.getKernelClientSigner(kernelClient);
256
+ const signer = await this.sessionKeysService.getCoordinatorSigner(chain, sessionKeyAddress, approval);
516
257
  // check if there is a maci contract deployed on this chain
517
258
  const maciAddress = this.storage.getAddress(EContracts.MACI, chain);
518
259
  if (!maciAddress) {
@@ -523,43 +264,35 @@ let DeployerService = DeployerService_1 = class DeployerService {
523
264
  if (!verifierAddress) {
524
265
  throw new Error(ErrorCodes.VERIFIER_NOT_DEPLOYED.toString());
525
266
  }
526
- // check if there is a vk registry deployed on this chain
527
- const vkRegistryAddress = this.storage.getAddress(EContracts.VkRegistry, chain);
528
- if (!vkRegistryAddress) {
529
- throw new Error(ErrorCodes.VK_REGISTRY_NOT_DEPLOYED.toString());
267
+ // check if there is a verifyingKey registry deployed on this chain
268
+ const verifyingKeysRegistryAddress = this.storage.getAddress(EContracts.VerifyingKeysRegistry, chain);
269
+ if (!verifyingKeysRegistryAddress) {
270
+ throw new Error(ErrorCodes.VERIFYING_KEYS_REGISTRY_NOT_DEPLOYED.toString());
530
271
  }
531
272
  // check if policy address was given
532
273
  let policyAddress = config.policy.address;
533
274
  if (!policyAddress) {
534
- const policyData = this.getPolicyData(config.policy.type, chain, config.policy.args);
535
- policyAddress = policyData.address;
536
- // if the policy is not already deployed, we need to deploy it
537
- if (!policyData.alreadyDeployed) {
538
- policyAddress = await this.deployAndStore(config.policy.type, config.policy.args ? Object.values(config.policy.args) : [], policyData.abi, policyData.bytecode, kernelClient, bundlerClient, publicClient, chain);
539
- }
275
+ const policyContract = await this.deployAndSavePolicy(signer, config.policy.type, chain, config.policy.args);
276
+ policyAddress = (await policyContract.getAddress());
540
277
  }
541
278
  // check if initial voice credit proxy address was given
542
279
  let initialVoiceCreditProxyAddress = config.initialVoiceCreditsProxy.address;
543
280
  if (!initialVoiceCreditProxyAddress) {
544
- const voiceCreditProxyData = this.getVoiceCreditProxyData(config.initialVoiceCreditsProxy.type, chain, config.initialVoiceCreditsProxy.args);
545
- initialVoiceCreditProxyAddress = voiceCreditProxyData.address;
546
- // if the voice credit proxy is not already deployed, we need to deploy it
547
- if (!voiceCreditProxyData.alreadyDeployed) {
548
- initialVoiceCreditProxyAddress = await this.deployAndStore(config.initialVoiceCreditsProxy.type, Object.values(config.initialVoiceCreditsProxy.args), voiceCreditProxyData.abi, voiceCreditProxyData.bytecode, kernelClient, bundlerClient, publicClient, chain);
549
- }
281
+ const initialVoiceCreditProxyContract = await this.deployAndSaveVoiceCreditProxy(signer, config.initialVoiceCreditsProxy.type, chain, config.initialVoiceCreditsProxy.args);
282
+ initialVoiceCreditProxyAddress = (await initialVoiceCreditProxyContract.getAddress());
550
283
  }
551
- const mode = config.useQuadraticVoting ? EMode.QV : EMode.NON_QV;
552
284
  const deployPollArgs = {
553
285
  maciAddress,
554
286
  pollStartTimestamp: config.startDate,
555
287
  pollEndTimestamp: config.endDate,
556
- intStateTreeDepth: config.intStateTreeDepth,
288
+ tallyProcessingStateTreeDepth: config.tallyProcessingStateTreeDepth,
557
289
  voteOptionTreeDepth: config.voteOptionTreeDepth,
558
290
  messageBatchSize: config.messageBatchSize,
559
- coordinatorPubKey: PubKey.deserialize(config.coordinatorPubkey),
291
+ stateTreeDepth: config.pollStateTreeDepth,
292
+ coordinatorPublicKey: PublicKey.deserialize(config.coordinatorPublicKey),
560
293
  verifierContractAddress: verifierAddress,
561
- vkRegistryContractAddress: vkRegistryAddress,
562
- mode,
294
+ verifyingKeysRegistryContractAddress: verifyingKeysRegistryAddress,
295
+ mode: config.mode,
563
296
  policyContractAddress: policyAddress,
564
297
  initialVoiceCreditProxyContractAddress: initialVoiceCreditProxyAddress,
565
298
  relayers: config.relayers ? config.relayers.map((address) => address) : [],
@@ -569,43 +302,37 @@ let DeployerService = DeployerService_1 = class DeployerService {
569
302
  };
570
303
  const { pollContractAddress, messageProcessorContractAddress, tallyContractAddress, pollId } = await deployPoll(deployPollArgs);
571
304
  const poll = PollFactory.connect(pollContractAddress, signer);
572
- // read the emptyBallotRoot and extContracts
573
- const emptyBallotRoot = await poll.emptyBallotRoot();
574
- const extContracts = await poll.extContracts();
575
305
  // store to storage
576
306
  await Promise.all([
577
307
  this.storage.register({
578
308
  id: EContracts.Poll,
579
309
  key: `poll-${pollId}`,
580
310
  contract: poll,
581
- args: [
582
- {
583
- ...deployPollArgs,
584
- extContracts,
585
- emptyBallotRoot: emptyBallotRoot.toString(),
586
- },
587
- ],
311
+ // clones do not have args for verification
312
+ args: [],
588
313
  network: chain,
589
314
  }),
590
315
  this.storage.register({
591
316
  id: EContracts.MessageProcessor,
592
317
  key: `poll-${pollId}`,
593
- contract: new BaseContract(messageProcessorContractAddress, MessageProcessorFactory.abi),
594
- args: [verifierAddress, vkRegistryAddress, pollContractAddress, mode],
318
+ contract: MessageProcessorFactory.connect(messageProcessorContractAddress, signer),
319
+ // clones do not have args for verification
320
+ args: [],
595
321
  network: chain,
596
322
  }),
597
323
  this.storage.register({
598
324
  id: EContracts.Tally,
599
325
  key: `poll-${pollId}`,
600
- contract: new BaseContract(tallyContractAddress, TallyFactory.abi),
601
- args: [verifierAddress, vkRegistryAddress, pollContractAddress, messageProcessorContractAddress, mode],
326
+ contract: TallyFactory.connect(tallyContractAddress, signer),
327
+ // clones do not have args for verification
328
+ args: [],
602
329
  network: chain,
603
330
  }),
604
331
  ]);
605
332
  return { pollId: pollId.toString() };
606
333
  }
607
334
  };
608
- DeployerService = DeployerService_1 = __decorate([
335
+ DeployerService = __decorate([
609
336
  Injectable(),
610
337
  __metadata("design:paramtypes", [SessionKeysService,
611
338
  FileService])