@bitgo-beta/sdk-core 8.2.1-beta.7 → 8.2.1-beta.70

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 (99) hide show
  1. package/CHANGELOG.md +98 -0
  2. package/dist/src/account-lib/baseCoin/enum.d.ts +3 -1
  3. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/enum.js +5 -1
  5. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +38 -12
  6. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
  7. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +555 -178
  8. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
  9. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
  10. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
  11. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +92 -155
  12. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  13. package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
  14. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
  15. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
  16. package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
  17. package/dist/src/account-lib/util/crypto.d.ts +5 -25
  18. package/dist/src/account-lib/util/crypto.d.ts.map +1 -1
  19. package/dist/src/account-lib/util/crypto.js +10 -55
  20. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +16 -0
  21. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  22. package/dist/src/bitgo/baseCoin/baseCoin.js +15 -1
  23. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +13 -1
  24. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  25. package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
  26. package/dist/src/bitgo/enterprise/enterprise.d.ts +3 -3
  27. package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
  28. package/dist/src/bitgo/enterprise/enterprise.js +7 -6
  29. package/dist/src/bitgo/enterprise/iEnterprise.d.ts +3 -3
  30. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  31. package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
  32. package/dist/src/bitgo/environments.d.ts +6 -0
  33. package/dist/src/bitgo/environments.d.ts.map +1 -1
  34. package/dist/src/bitgo/environments.js +15 -3
  35. package/dist/src/bitgo/keychain/iKeychains.d.ts +1 -0
  36. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  37. package/dist/src/bitgo/keychain/iKeychains.js +1 -1
  38. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  39. package/dist/src/bitgo/keychain/keychains.js +30 -24
  40. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
  41. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
  42. package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
  43. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
  44. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
  45. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
  46. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
  47. package/dist/src/bitgo/pendingApproval/pendingApproval.js +12 -1
  48. package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
  49. package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
  50. package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
  51. package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
  52. package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
  53. package/dist/src/bitgo/staking/stakingWallet.js +9 -1
  54. package/dist/src/bitgo/tss/common.d.ts +16 -6
  55. package/dist/src/bitgo/tss/common.d.ts.map +1 -1
  56. package/dist/src/bitgo/tss/common.js +26 -11
  57. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +11 -8
  58. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  59. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +36 -33
  60. package/dist/src/bitgo/tss/ecdsa/types.d.ts +2 -2
  61. package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
  62. package/dist/src/bitgo/tss/ecdsa/types.js +1 -1
  63. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +4 -3
  64. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  65. package/dist/src/bitgo/tss/eddsa/eddsa.js +16 -5
  66. package/dist/src/bitgo/tss/types.d.ts +4 -0
  67. package/dist/src/bitgo/tss/types.d.ts.map +1 -1
  68. package/dist/src/bitgo/tss/types.js +1 -1
  69. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +38 -12
  70. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
  71. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +28 -9
  72. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +48 -8
  73. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  74. package/dist/src/bitgo/utils/tss/baseTypes.js +11 -2
  75. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +10 -8
  76. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  77. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +65 -62
  78. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +4 -3
  79. package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
  80. package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
  81. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
  82. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
  83. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +76 -22
  84. package/dist/src/bitgo/wallet/iWallet.d.ts +2 -1
  85. package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
  86. package/dist/src/bitgo/wallet/iWallet.js +1 -1
  87. package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
  88. package/dist/src/bitgo/wallet/wallet.js +22 -8
  89. package/dist/src/openssl/index.d.ts +4 -1
  90. package/dist/src/openssl/index.d.ts.map +1 -1
  91. package/dist/src/openssl/index.js +7 -12
  92. package/dist/tsconfig.tsbuildinfo +1 -8264
  93. package/package.json +6 -7
  94. package/dist/src/openssl/openssl.d.ts +0 -12
  95. package/dist/src/openssl/openssl.d.ts.map +0 -1
  96. package/dist/src/openssl/openssl.js +0 -48
  97. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  98. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  99. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -28,15 +28,11 @@ const secp = __importStar(require("@noble/secp256k1"));
28
28
  const hdTree_1 = require("../../hdTree");
29
29
  const crypto_1 = require("crypto");
30
30
  const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
31
- const crypto_2 = require("../../../util/crypto");
32
31
  const util_1 = require("../../util");
33
32
  const curves_1 = require("../../curves");
34
33
  const shamir_1 = __importDefault(require("../../shamir"));
35
34
  const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
36
35
  const _5n = BigInt(5);
37
- function hasNtilde(share) {
38
- return 'ntilde' in share;
39
- }
40
36
  /**
41
37
  * ECDSA TSS implementation supporting 2:n Threshold
42
38
  */
@@ -67,10 +63,10 @@ class Ecdsa {
67
63
  // Generate additively homomorphic encryption key.
68
64
  let paillierKeyPair;
69
65
  if (!sync) {
70
- paillierKeyPair = await paillierBigint.generateRandomKeys(3072, true);
66
+ paillierKeyPair = await paillierBigint.generateRandomKeys(sdk_lib_mpc_1.minModulusBitLength, true);
71
67
  }
72
68
  else {
73
- paillierKeyPair = paillierBigint.generateRandomKeysSync(3072, true);
69
+ paillierKeyPair = paillierBigint.generateRandomKeysSync(sdk_lib_mpc_1.minModulusBitLength, true);
74
70
  }
75
71
  const { publicKey, privateKey } = paillierKeyPair;
76
72
  // Accept a 64 byte seed and create an extended private key from that seed
@@ -122,14 +118,14 @@ class Ecdsa {
122
118
  keyCombine(pShare, nShares) {
123
119
  const allShares = [pShare, ...nShares];
124
120
  // Compute the public key.
125
- const y = allShares.map((participant) => crypto_2.hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);
121
+ const y = allShares.map((participant) => sdk_lib_mpc_1.hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);
126
122
  // Add secret shares
127
- const x = allShares.map((participant) => crypto_2.hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);
123
+ const x = allShares.map((participant) => sdk_lib_mpc_1.hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);
128
124
  // Verify shares.
129
125
  for (const share of nShares) {
130
126
  if (share.v) {
131
127
  try {
132
- Ecdsa.shamir.verify(crypto_2.hexToBigInt(share.u), [crypto_2.hexToBigInt(share.y), crypto_2.hexToBigInt(share.v)], pShare.i);
128
+ Ecdsa.shamir.verify(sdk_lib_mpc_1.hexToBigInt(share.u), [sdk_lib_mpc_1.hexToBigInt(share.y), sdk_lib_mpc_1.hexToBigInt(share.v)], pShare.i);
133
129
  }
134
130
  catch (err) {
135
131
  throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);
@@ -171,17 +167,17 @@ class Ecdsa {
171
167
  * be distributed to participants at their corresponding index.
172
168
  */
173
169
  keyDerive(pShare, nShares, path) {
174
- const yValues = [pShare, ...nShares].map((share) => crypto_2.hexToBigInt(share.y));
170
+ const yValues = [pShare, ...nShares].map((share) => sdk_lib_mpc_1.hexToBigInt(share.y));
175
171
  const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));
176
172
  const u = BigInt(pShare.uu);
177
- let contribChaincode = crypto_2.hexToBigInt(pShare.chaincode);
178
- const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => crypto_2.hexToBigInt(chaincode))];
173
+ let contribChaincode = sdk_lib_mpc_1.hexToBigInt(pShare.chaincode);
174
+ const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => sdk_lib_mpc_1.hexToBigInt(chaincode))];
179
175
  const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % hdTree_1.chaincodeBase);
180
176
  // Verify shares.
181
177
  for (const share of nShares) {
182
178
  if (share.v) {
183
179
  try {
184
- Ecdsa.shamir.verify(crypto_2.hexToBigInt(share.u), [crypto_2.hexToBigInt(share.y), crypto_2.hexToBigInt(share.v)], pShare.i);
180
+ Ecdsa.shamir.verify(sdk_lib_mpc_1.hexToBigInt(share.u), [sdk_lib_mpc_1.hexToBigInt(share.y), sdk_lib_mpc_1.hexToBigInt(share.v)], pShare.i);
185
181
  }
186
182
  catch (err) {
187
183
  throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);
@@ -198,7 +194,7 @@ class Ecdsa {
198
194
  // Calculate new u values.
199
195
  const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);
200
196
  // Calculate new signing key.
201
- const x = [split_u[pShare.i], ...nShares.map(({ u }) => crypto_2.hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);
197
+ const x = [split_u[pShare.i], ...nShares.map(({ u }) => sdk_lib_mpc_1.hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);
202
198
  const P_i = {
203
199
  i: pShare.i,
204
200
  l: pShare.l,
@@ -217,7 +213,7 @@ class Ecdsa {
217
213
  shares.nShares[P_j.j] = {
218
214
  i: P_j.j,
219
215
  j: P_i.i,
220
- n: P_j.n,
216
+ n: P_i.n,
221
217
  u: util_1.bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),
222
218
  y: util_1.bigIntToBufferBE(contribY, 32).toString('hex'),
223
219
  v: util_1.bigIntToBufferBE(v[0], 32).toString('hex'),
@@ -249,30 +245,19 @@ class Ecdsa {
249
245
  /**
250
246
  * Appends a given range proof challenge to the shares previously created
251
247
  * by #keyCombine. Generates a new challenge if not provided.
252
- * @param {XShare} xShare Private xShare of signer
253
- * @param {YShare} yShare YShare of the other participant involved in
254
- * this signing operation
255
- * @param {SerializedNtilde} challenge
256
- * @returns {KeyCombined} The new XShare and YShares with the amended
257
- * challenge values
248
+ * @param {XShare | YShare} share Private xShare or yShare of the signing operation
249
+ * @param rangeProofChallenge - challenge generated via generateNtilde
250
+ * @param paillierProofChallenge
251
+ * @returns {KeyCombined} The share with amended challenge values
258
252
  */
259
- async appendChallenge(xShare, yShare, challenge) {
260
- if (!challenge) {
261
- challenge = Ecdsa.serializeNtilde(await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde(3072));
262
- }
263
- const { ntilde, h1, h2 } = challenge;
253
+ appendChallenge(share, rangeProofChallenge, paillierProofChallenge) {
254
+ const { ntilde, h1, h2 } = rangeProofChallenge;
264
255
  return {
265
- xShare: { ...xShare, ntilde, h1, h2 },
266
- yShares: {
267
- [yShare.j]: {
268
- i: yShare.j,
269
- j: yShare.i,
270
- n: xShare.n,
271
- ntilde,
272
- h1,
273
- h2,
274
- },
275
- },
256
+ ...share,
257
+ ntilde,
258
+ h1,
259
+ h2,
260
+ p: paillierProofChallenge.p,
276
261
  };
277
262
  }
278
263
  /**
@@ -283,45 +268,42 @@ class Ecdsa {
283
268
  * and k-share to be distributed to other participant signer
284
269
  */
285
270
  async signShare(xShare, yShare) {
286
- const pk = util_1.getPaillierPublicKey(crypto_2.hexToBigInt(xShare.n));
287
- // Generate a challenge if ntilde is not present in the xShare.
288
- if (!hasNtilde(xShare)) {
289
- xShare = (await this.appendChallenge(xShare, yShare)).xShare;
290
- }
271
+ const pk = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(xShare.n));
291
272
  const k = Ecdsa.curve.scalarRandom();
292
- const rk = await sdk_lib_mpc_1.randomCoPrimeTo(pk.n);
273
+ const rk = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pk.n);
293
274
  const ck = pk.encrypt(k, rk);
294
275
  const gamma = Ecdsa.curve.scalarRandom();
295
276
  const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));
296
277
  const w = [
297
278
  Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),
298
- crypto_2.hexToBigInt(xShare['x']),
279
+ sdk_lib_mpc_1.hexToBigInt(xShare['x']),
299
280
  Ecdsa.curve.scalarInvert(d),
300
281
  ].reduce(Ecdsa.curve.scalarMult);
301
282
  const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare;
302
- const signers = {
303
- wShare: {
304
- i: xShare.i,
305
- l: xShare.l,
306
- m: xShare.m,
307
- n: xShare.n,
308
- y: xShare.y,
309
- ntilde: ntildea,
310
- h1: h1a,
311
- h2: h2a,
312
- k: util_1.bigIntToBufferBE(k, 32).toString('hex'),
313
- ck: util_1.bigIntToBufferBE(ck, 768).toString('hex'),
314
- w: util_1.bigIntToBufferBE(w, 32).toString('hex'),
315
- gamma: util_1.bigIntToBufferBE(gamma, 32).toString('hex'),
316
- },
317
- kShare: {},
283
+ const wShare = {
284
+ i: xShare.i,
285
+ l: xShare.l,
286
+ m: xShare.m,
287
+ n: xShare.n,
288
+ y: xShare.y,
289
+ ntilde: ntildea,
290
+ h1: h1a,
291
+ h2: h2a,
292
+ p: xShare.p,
293
+ k: util_1.bigIntToBufferBE(k, 32).toString('hex'),
294
+ ck: util_1.bigIntToBufferBE(ck, 768).toString('hex'),
295
+ w: util_1.bigIntToBufferBE(w, 32).toString('hex'),
296
+ gamma: util_1.bigIntToBufferBE(gamma, 32).toString('hex'),
318
297
  };
319
298
  const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;
320
- const proof = await sdk_lib_mpc_1.EcdsaRangeProof.prove(Ecdsa.curve, 3072, pk, {
321
- ntilde: crypto_2.hexToBigInt(ntildeb),
322
- h1: crypto_2.hexToBigInt(h1b),
323
- h2: crypto_2.hexToBigInt(h2b),
299
+ const proof = await sdk_lib_mpc_1.EcdsaRangeProof.prove(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pk, {
300
+ ntilde: sdk_lib_mpc_1.hexToBigInt(ntildeb),
301
+ h1: sdk_lib_mpc_1.hexToBigInt(h1b),
302
+ h2: sdk_lib_mpc_1.hexToBigInt(h2b),
324
303
  }, ck, k, rk);
304
+ // create paillier challenge proof based on the other signers challenge
305
+ // only send sigma if we also send challenge p
306
+ const sigma = sdk_lib_mpc_1.EcdsaPaillierProof.prove(sdk_lib_mpc_1.hexToBigInt(xShare.n), sdk_lib_mpc_1.hexToBigInt(xShare.l), sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: yShare.p }).p);
325
307
  const proofShare = {
326
308
  z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
327
309
  u: util_1.bigIntToBufferBE(proof.u, 768).toString('hex'),
@@ -330,22 +312,443 @@ class Ecdsa {
330
312
  s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
331
313
  s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
332
314
  };
333
- signers.kShare = {
315
+ const kShare = {
316
+ // this share will be sent to the other participant,
317
+ // so we need to swap the i and j values here
318
+ // so that they know it's their kShare, produced by us
334
319
  i: yShare.j,
335
320
  j: xShare.i,
336
321
  n: pk.n.toString(16),
337
322
  ntilde: ntildea,
338
323
  h1: h1a,
339
324
  h2: h2a,
325
+ p: xShare.p,
340
326
  k: util_1.bigIntToBufferBE(ck, 768).toString('hex'),
327
+ sigma: sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallengeProofs({ sigma: sigma }).sigma,
341
328
  proof: proofShare,
342
329
  };
343
- return signers;
330
+ return {
331
+ wShare,
332
+ kShare,
333
+ };
334
+ }
335
+ /**
336
+ * Perform multiplicitive-to-additive (MtA) share conversion with another signer.
337
+ * Connection 1.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
338
+ * If signer A completed signShare initially (input to this fn), then this step is completed by signer B.
339
+ * @param {SignConvert} shares
340
+ * @returns {SignConvertRT}
341
+ */
342
+ async signConvertStep1(shares) {
343
+ const receivedKShare = shares.kShare;
344
+ const xShare = shares.xShare; // currentParticipant secret xShare
345
+ const yShare = {
346
+ ...shares.yShare,
347
+ ntilde: receivedKShare.ntilde,
348
+ h1: receivedKShare.h1,
349
+ h2: receivedKShare.h2,
350
+ p: receivedKShare.p,
351
+ };
352
+ const signShare = await this.signShare(xShare, yShare);
353
+ const shareParticipant = signShare.wShare;
354
+ if (shareParticipant.i !== receivedKShare.i) {
355
+ throw new Error('Shares from same participant');
356
+ }
357
+ if (!receivedKShare.proof) {
358
+ throw new Error('Unexpected missing proof on aShareToBeSent');
359
+ }
360
+ // the other participants paillier public key
361
+ const n = sdk_lib_mpc_1.hexToBigInt(receivedKShare.n);
362
+ const pka = util_1.getPaillierPublicKey(n);
363
+ // the other participant's range proof challenge
364
+ const ntildea = sdk_lib_mpc_1.hexToBigInt(receivedKShare.ntilde);
365
+ const h1a = sdk_lib_mpc_1.hexToBigInt(receivedKShare.h1);
366
+ const h2a = sdk_lib_mpc_1.hexToBigInt(receivedKShare.h2);
367
+ // the current participant's range proof challenge
368
+ const ntildeb = sdk_lib_mpc_1.hexToBigInt(shareParticipant.ntilde);
369
+ const h1b = sdk_lib_mpc_1.hexToBigInt(shareParticipant.h1);
370
+ const h2b = sdk_lib_mpc_1.hexToBigInt(shareParticipant.h2);
371
+ const k = sdk_lib_mpc_1.hexToBigInt(receivedKShare.k);
372
+ // the current participants paillier proof challenge
373
+ const shareParticipantPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: shareParticipant.p });
374
+ // the other signing parties proof to the current participants paillier proof challenge
375
+ const receivedPaillierChallengeProof = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallengeProofs({
376
+ sigma: receivedKShare.sigma,
377
+ });
378
+ if (!(await sdk_lib_mpc_1.EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma))) {
379
+ throw new Error('Could not verify signing A share paillier proof');
380
+ }
381
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
382
+ ntilde: ntildeb,
383
+ h1: h1b,
384
+ h2: h2b,
385
+ }, {
386
+ z: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.z),
387
+ u: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.u),
388
+ w: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.w),
389
+ s: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s),
390
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s1),
391
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s2),
392
+ }, k)) {
393
+ throw new Error('Could not verify signing A share proof');
394
+ }
395
+ // MtA $k_j, \gamma_i$.
396
+ const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
397
+ const beta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
398
+ const g = sdk_lib_mpc_1.hexToBigInt(shareParticipant.gamma);
399
+ const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
400
+ const cb = pka.encrypt(beta0, rb);
401
+ const alpha = pka.addition(pka.multiply(k, g), cb);
402
+ const alphaToBeSent = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
403
+ // Prove $\gamma_i \in Z_{N^2}$.
404
+ const gx = Ecdsa.curve.basePointMult(g);
405
+ let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
406
+ ntilde: ntildea,
407
+ h1: h1a,
408
+ h2: h2a,
409
+ }, k, alpha, g, beta0, rb, gx);
410
+ const gammaProofToBeSent = {
411
+ z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
412
+ zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
413
+ t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
414
+ v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
415
+ w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
416
+ s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
417
+ s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
418
+ s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
419
+ t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
420
+ t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
421
+ u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
422
+ x: util_1.bigIntToBufferBE(gx, 33).toString('hex'),
423
+ };
424
+ // MtA $k_j, w_i$.
425
+ const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
426
+ const nu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
427
+ const w = sdk_lib_mpc_1.hexToBigInt(shareParticipant.w);
428
+ const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
429
+ const cn = pka.encrypt(nu0, rn);
430
+ const mu = pka.addition(pka.multiply(k, w), cn);
431
+ const muToBeSent = util_1.bigIntToBufferBE(mu, 32).toString('hex');
432
+ // Prove $\w_i \in Z_{N^2}$.
433
+ const wx = Ecdsa.curve.basePointMult(w);
434
+ proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
435
+ ntilde: ntildea,
436
+ h1: h1a,
437
+ h2: h2a,
438
+ }, k, sdk_lib_mpc_1.hexToBigInt(muToBeSent), w, nu0, rn, wx);
439
+ const wProofToBeSent = {
440
+ z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
441
+ zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
442
+ t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
443
+ v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
444
+ w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
445
+ s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
446
+ s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
447
+ s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
448
+ t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
449
+ t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
450
+ u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
451
+ x: util_1.bigIntToBufferBE(wx, 33).toString('hex'),
452
+ };
453
+ const nToBeSent = signShare.kShare.n;
454
+ const ntildeToBeSent = util_1.bigIntToBufferBE(ntildeb, 384).toString('hex');
455
+ const h1ToBeSent = util_1.bigIntToBufferBE(h1b, 384).toString('hex');
456
+ const h2ToBeSent = util_1.bigIntToBufferBE(h2b, 384).toString('hex');
457
+ const kToBeSent = signShare.kShare.k;
458
+ const proofToBeSent = signShare.kShare.proof;
459
+ const [iToBeSent, jToBeSent] = [receivedKShare.j, receivedKShare.i];
460
+ return {
461
+ aShare: {
462
+ i: iToBeSent,
463
+ j: jToBeSent,
464
+ ntilde: ntildeToBeSent,
465
+ h1: h1ToBeSent,
466
+ h2: h2ToBeSent,
467
+ n: nToBeSent,
468
+ k: kToBeSent,
469
+ alpha: alphaToBeSent,
470
+ mu: muToBeSent,
471
+ proof: proofToBeSent,
472
+ gammaProof: gammaProofToBeSent,
473
+ wProof: wProofToBeSent,
474
+ // provide the share participants proof
475
+ // to the paillier challenge in the receivedKShare from the other signer
476
+ sigma: signShare.kShare.sigma,
477
+ },
478
+ bShare: {
479
+ ...shareParticipant,
480
+ beta,
481
+ nu,
482
+ },
483
+ };
344
484
  }
345
485
  /**
346
486
  * Perform multiplicitive-to-additive (MtA) share conversion with another
347
487
  * signer.
348
- * @param {SignConvert}
488
+ * Connection 2.1 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
489
+ * If signer B completed signConvertStep1, then this step is completed by signer A.
490
+ * @param {SignConvert} shares
491
+ * @returns {SignConvertRT}
492
+ */
493
+ async signConvertStep2(shares) {
494
+ const receivedAShare = shares.aShare;
495
+ if (!receivedAShare.gammaProof) {
496
+ throw new Error('Unexpected missing gammaProof on aShareToBeSent');
497
+ }
498
+ if (!receivedAShare.wProof) {
499
+ throw new Error('Unexpected missing wProof on aShareToBeSent');
500
+ }
501
+ const n = sdk_lib_mpc_1.hexToBigInt(receivedAShare.n); // Paillier pub from other signer
502
+ // current participant public key
503
+ const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(shares.wShare.n));
504
+ const ntildea = sdk_lib_mpc_1.hexToBigInt(shares.wShare.ntilde);
505
+ const h1a = sdk_lib_mpc_1.hexToBigInt(shares.wShare.h1);
506
+ const h2a = sdk_lib_mpc_1.hexToBigInt(shares.wShare.h2);
507
+ const ck = sdk_lib_mpc_1.hexToBigInt(shares.wShare.ck);
508
+ const shareParticipantPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: shares.wShare.p });
509
+ const receivedPaillierChallengeProof = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallengeProofs({
510
+ sigma: shares.aShare.sigma,
511
+ });
512
+ if (!sdk_lib_mpc_1.EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma)) {
513
+ throw new Error('could not verify signing share for paillier proof');
514
+ }
515
+ // Verify $\gamma_i \in Z_{N^2}$.
516
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
517
+ ntilde: ntildea,
518
+ h1: h1a,
519
+ h2: h2a,
520
+ }, {
521
+ z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.z),
522
+ zprm: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.zprm),
523
+ t: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t),
524
+ v: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.v),
525
+ w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.w),
526
+ s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s),
527
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s1),
528
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s2),
529
+ t1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t1),
530
+ t2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t2),
531
+ u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.u),
532
+ }, ck, sdk_lib_mpc_1.hexToBigInt(receivedAShare.alpha), sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.x))) {
533
+ throw new Error('could not verify signing share for gamma proof');
534
+ }
535
+ // Verify $\w_i \in Z_{N^2}$.
536
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
537
+ ntilde: ntildea,
538
+ h1: h1a,
539
+ h2: h2a,
540
+ }, {
541
+ z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.z),
542
+ zprm: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.zprm),
543
+ t: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t),
544
+ v: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.v),
545
+ w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.w),
546
+ s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s),
547
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s1),
548
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s2),
549
+ t1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t1),
550
+ t2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t2),
551
+ u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.u),
552
+ }, ck, sdk_lib_mpc_1.hexToBigInt(receivedAShare.mu), sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.x))) {
553
+ throw new Error('could not verify share for wProof');
554
+ }
555
+ const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(shares.wShare.l), sdk_lib_mpc_1.hexToBigInt(shares.wShare.m), pka);
556
+ const gShareAlpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedAShare.alpha))), 32).toString('hex');
557
+ const gShareMu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedAShare.mu))), // recheck encrypted number
558
+ 32).toString('hex');
559
+ if (!receivedAShare.proof) {
560
+ throw new Error('Unexpected missing proof on aShareToBeSent');
561
+ }
562
+ const pkb = util_1.getPaillierPublicKey(n);
563
+ const ntildeb = sdk_lib_mpc_1.hexToBigInt(receivedAShare.ntilde);
564
+ const h1b = sdk_lib_mpc_1.hexToBigInt(receivedAShare.h1);
565
+ const h2b = sdk_lib_mpc_1.hexToBigInt(receivedAShare.h2);
566
+ const k = sdk_lib_mpc_1.hexToBigInt(receivedAShare.k);
567
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
568
+ ntilde: ntildea,
569
+ h1: h1a,
570
+ h2: h2a,
571
+ }, {
572
+ z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.z),
573
+ u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.u),
574
+ w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.w),
575
+ s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s),
576
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s1),
577
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s2),
578
+ }, k)) {
579
+ throw new Error('Could not verify signing A share proof');
580
+ }
581
+ // MtA $k_j, \gamma_i$.
582
+ const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
583
+ const gShareBeta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
584
+ const g = sdk_lib_mpc_1.hexToBigInt(shares.wShare.gamma);
585
+ const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pkb.n);
586
+ const cb = pkb.encrypt(beta0, rb);
587
+ const alpha = pkb.addition(pkb.multiply(k, g), cb);
588
+ const alphaToBeSent = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
589
+ // Prove $\gamma_i \in Z_{N^2}$.
590
+ const gx = Ecdsa.curve.basePointMult(g);
591
+ let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
592
+ ntilde: ntildeb,
593
+ h1: h1b,
594
+ h2: h2b,
595
+ }, k, alpha, g, beta0, rb, gx);
596
+ const gammaProofToBeSent = {
597
+ z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
598
+ zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
599
+ t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
600
+ v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
601
+ w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
602
+ s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
603
+ s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
604
+ s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
605
+ t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
606
+ t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
607
+ u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
608
+ x: util_1.bigIntToBufferBE(gx, 33).toString('hex'),
609
+ };
610
+ // MtA $k_j, w_i$.
611
+ const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
612
+ const gShareNu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
613
+ const w = sdk_lib_mpc_1.hexToBigInt(shares.wShare.w);
614
+ const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pkb.n);
615
+ const cn = pkb.encrypt(nu0, rn);
616
+ const mu = pkb.addition(pkb.multiply(k, w), cn);
617
+ const muToBeSent = util_1.bigIntToBufferBE(mu, 32).toString('hex');
618
+ // Prove $\w_i \in Z_{N^2}$.
619
+ const wx = Ecdsa.curve.basePointMult(w);
620
+ proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
621
+ ntilde: ntildeb,
622
+ h1: h1b,
623
+ h2: h2b,
624
+ }, k, sdk_lib_mpc_1.hexToBigInt(muToBeSent), w, nu0, rn, wx);
625
+ const wProofToBeSent = {
626
+ z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
627
+ zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
628
+ t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
629
+ v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
630
+ w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
631
+ s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
632
+ s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
633
+ s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
634
+ t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
635
+ t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
636
+ u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
637
+ x: util_1.bigIntToBufferBE(wx, 33).toString('hex'),
638
+ };
639
+ const [iToBeSent, jToBeSent] = [receivedAShare.j, receivedAShare.i];
640
+ return {
641
+ muShare: {
642
+ i: iToBeSent,
643
+ j: jToBeSent,
644
+ alpha: alphaToBeSent,
645
+ mu: muToBeSent,
646
+ gammaProof: gammaProofToBeSent,
647
+ wProof: wProofToBeSent,
648
+ },
649
+ gShare: {
650
+ i: shares.wShare.i,
651
+ n: shares.wShare.n,
652
+ y: shares.wShare.y,
653
+ k: shares.wShare.k,
654
+ w: shares.wShare.w,
655
+ gamma: shares.wShare.gamma,
656
+ alpha: gShareAlpha,
657
+ mu: gShareMu,
658
+ beta: gShareBeta,
659
+ nu: gShareNu,
660
+ },
661
+ };
662
+ }
663
+ /**
664
+ * Perform multiplicitive-to-additive (MtA) share conversion with another signer.
665
+ * Connection 2.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
666
+ * If signer A completed signConvertStep2, then this step is completed by signer B.
667
+ * @param {SignConvert} shares
668
+ * @returns {SignConvertRT}
669
+ */
670
+ async signConvertStep3(shares) {
671
+ const receivedMuShare = shares.muShare;
672
+ if (!receivedMuShare.gammaProof) {
673
+ throw new Error('Unexpected missing gammaProof on aShareToBeSent');
674
+ }
675
+ if (!receivedMuShare.wProof) {
676
+ throw new Error('Unexpected missing wProof on aShareToBeSent');
677
+ }
678
+ const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(shares.bShare.n));
679
+ const ntildea = sdk_lib_mpc_1.hexToBigInt(shares.bShare.ntilde);
680
+ const h1a = sdk_lib_mpc_1.hexToBigInt(shares.bShare.h1);
681
+ const h2a = sdk_lib_mpc_1.hexToBigInt(shares.bShare.h2);
682
+ const ck = sdk_lib_mpc_1.hexToBigInt(shares.bShare.ck);
683
+ // Verify $\gamma_i \in Z_{N^2}$.
684
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
685
+ ntilde: ntildea,
686
+ h1: h1a,
687
+ h2: h2a,
688
+ }, {
689
+ z: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.z),
690
+ zprm: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.zprm),
691
+ t: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t),
692
+ v: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.v),
693
+ w: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.w),
694
+ s: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s),
695
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s1),
696
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s2),
697
+ t1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t1),
698
+ t2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t2),
699
+ u: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.u),
700
+ }, ck, sdk_lib_mpc_1.hexToBigInt(receivedMuShare.alpha), sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.x))) {
701
+ throw new Error('could not verify signing share for gamma proof');
702
+ }
703
+ // Verify $\w_i \in Z_{N^2}$.
704
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
705
+ ntilde: ntildea,
706
+ h1: h1a,
707
+ h2: h2a,
708
+ }, {
709
+ z: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.z),
710
+ zprm: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.zprm),
711
+ t: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t),
712
+ v: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.v),
713
+ w: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.w),
714
+ s: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s),
715
+ s1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s1),
716
+ s2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s2),
717
+ t1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t1),
718
+ t2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t2),
719
+ u: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.u),
720
+ }, ck, sdk_lib_mpc_1.hexToBigInt(receivedMuShare.mu), sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.x))) {
721
+ throw new Error('could not verify share for wProof');
722
+ }
723
+ const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(shares.bShare.l), sdk_lib_mpc_1.hexToBigInt(shares.bShare.m), pka);
724
+ const alpha = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedMuShare.alpha));
725
+ const gShareAlpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');
726
+ const mu = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedMuShare.mu)); // recheck encrypted number
727
+ const gShareMu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');
728
+ const [iToBeSent, jToBeSent] = [receivedMuShare.j, receivedMuShare.i];
729
+ return {
730
+ gShare: {
731
+ i: shares.bShare.i,
732
+ n: shares.bShare.n,
733
+ y: shares.bShare.y,
734
+ k: shares.bShare.k,
735
+ w: shares.bShare.w,
736
+ gamma: shares.bShare.gamma,
737
+ alpha: gShareAlpha,
738
+ mu: gShareMu,
739
+ beta: shares.bShare.beta,
740
+ nu: shares.bShare.nu,
741
+ },
742
+ signIndex: {
743
+ i: iToBeSent,
744
+ j: jToBeSent,
745
+ },
746
+ };
747
+ }
748
+ /**
749
+ * Perform multiplicitive-to-additive (MtA) share conversion with another signer.
750
+ * @deprecated - use one of [signConvertStep1, signConvertStep2, signConvertStep3] instead
751
+ * @param {SignConvert} shares
349
752
  * @returns {SignConvertRT}
350
753
  */
351
754
  async signConvert(shares) {
@@ -359,6 +762,7 @@ class Ecdsa {
359
762
  ntilde: shares.kShare.ntilde,
360
763
  h1: shares.kShare.h1,
361
764
  h2: shares.kShare.h2,
765
+ p: shares.kShare.p,
362
766
  };
363
767
  const signShare = await this.signShare(xShare, yShare);
364
768
  kShare = signShare.kShare;
@@ -379,60 +783,66 @@ class Ecdsa {
379
783
  if (shareToBeSent.alpha) {
380
784
  const bShareParticipant = shareParticipant;
381
785
  const aShareToBeSent = shareToBeSent;
382
- const pka = util_1.getPaillierPublicKey(crypto_2.hexToBigInt(bShareParticipant.n));
786
+ if (!aShareToBeSent.gammaProof) {
787
+ throw new Error('Unexpected missing gammaProof on aShareToBeSent');
788
+ }
789
+ if (!aShareToBeSent.wProof) {
790
+ throw new Error('Unexpected missing wProof on aShareToBeSent');
791
+ }
792
+ const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(bShareParticipant.n));
383
793
  let ntildea, h1a, h2a, ck;
384
794
  if (bShareParticipant.ntilde) {
385
- ntildea = crypto_2.hexToBigInt(bShareParticipant.ntilde);
386
- h1a = crypto_2.hexToBigInt(bShareParticipant.h1);
387
- h2a = crypto_2.hexToBigInt(bShareParticipant.h2);
388
- ck = crypto_2.hexToBigInt(bShareParticipant.ck);
795
+ ntildea = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ntilde);
796
+ h1a = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h1);
797
+ h2a = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h2);
798
+ ck = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ck);
389
799
  }
390
800
  // Verify $\gamma_i \in Z_{N^2}$.
391
- if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, 3072, pka, {
801
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
392
802
  ntilde: ntildea,
393
803
  h1: h1a,
394
804
  h2: h2a,
395
805
  }, {
396
- z: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.z),
397
- zprm: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.zprm),
398
- t: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.t),
399
- v: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.v),
400
- w: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.w),
401
- s: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.s),
402
- s1: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.s1),
403
- s2: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.s2),
404
- t1: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.t1),
405
- t2: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.t2),
406
- u: crypto_2.hexToBigInt(aShareToBeSent.gammaProof.u),
407
- }, ck, crypto_2.hexToBigInt(aShareToBeSent.alpha), crypto_2.hexToBigInt(aShareToBeSent.gammaProof.x))) {
806
+ z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.z),
807
+ zprm: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.zprm),
808
+ t: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t),
809
+ v: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.v),
810
+ w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.w),
811
+ s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s),
812
+ s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s1),
813
+ s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s2),
814
+ t1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t1),
815
+ t2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t2),
816
+ u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.u),
817
+ }, ck, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.alpha), sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.x))) {
408
818
  throw new Error('could not verify signing share for gamma proof');
409
819
  }
410
820
  // Verify $\w_i \in Z_{N^2}$.
411
- if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, 3072, pka, {
821
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
412
822
  ntilde: ntildea,
413
823
  h1: h1a,
414
824
  h2: h2a,
415
825
  }, {
416
- z: crypto_2.hexToBigInt(aShareToBeSent.wProof.z),
417
- zprm: crypto_2.hexToBigInt(aShareToBeSent.wProof.zprm),
418
- t: crypto_2.hexToBigInt(aShareToBeSent.wProof.t),
419
- v: crypto_2.hexToBigInt(aShareToBeSent.wProof.v),
420
- w: crypto_2.hexToBigInt(aShareToBeSent.wProof.w),
421
- s: crypto_2.hexToBigInt(aShareToBeSent.wProof.s),
422
- s1: crypto_2.hexToBigInt(aShareToBeSent.wProof.s1),
423
- s2: crypto_2.hexToBigInt(aShareToBeSent.wProof.s2),
424
- t1: crypto_2.hexToBigInt(aShareToBeSent.wProof.t1),
425
- t2: crypto_2.hexToBigInt(aShareToBeSent.wProof.t2),
426
- u: crypto_2.hexToBigInt(aShareToBeSent.wProof.u),
427
- }, ck, crypto_2.hexToBigInt(aShareToBeSent.mu), crypto_2.hexToBigInt(aShareToBeSent.wProof.x))) {
826
+ z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.z),
827
+ zprm: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.zprm),
828
+ t: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t),
829
+ v: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.v),
830
+ w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.w),
831
+ s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s),
832
+ s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s1),
833
+ s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s2),
834
+ t1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t1),
835
+ t2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t2),
836
+ u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.u),
837
+ }, ck, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu), sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.x))) {
428
838
  throw new Error('could not verify share for wProof');
429
839
  }
430
- const sk = new paillierBigint.PrivateKey(crypto_2.hexToBigInt(bShareParticipant.l), crypto_2.hexToBigInt(bShareParticipant.m), pka);
840
+ const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(bShareParticipant.l), sdk_lib_mpc_1.hexToBigInt(bShareParticipant.m), pka);
431
841
  const gShareParticipant = shareParticipant;
432
842
  const muShareToBeSent = shareToBeSent;
433
- const alpha = sk.decrypt(crypto_2.hexToBigInt(aShareToBeSent.alpha));
843
+ const alpha = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.alpha));
434
844
  gShareParticipant.alpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');
435
- const mu = sk.decrypt(crypto_2.hexToBigInt(aShareToBeSent.mu)); // recheck encrypted number
845
+ const mu = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu)); // recheck encrypted number
436
846
  gShareParticipant.mu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');
437
847
  const partialShareParticipant = shareParticipant;
438
848
  const partialShareToBeSent = muShareToBeSent;
@@ -444,44 +854,43 @@ class Ecdsa {
444
854
  if (shareToBeSent.k) {
445
855
  const bShareParticipant = shareParticipant;
446
856
  const aShareToBeSent = shareToBeSent;
447
- const n = crypto_2.hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer
448
- const pka = util_1.getPaillierPublicKey(n);
449
- let ntildea, h1a, h2a, ntildeb, h1b, h2b;
450
- if (aShareToBeSent.ntilde) {
451
- ntildea = crypto_2.hexToBigInt(aShareToBeSent.ntilde);
452
- h1a = crypto_2.hexToBigInt(aShareToBeSent.h1);
453
- h2a = crypto_2.hexToBigInt(aShareToBeSent.h2);
454
- ntildeb = crypto_2.hexToBigInt(bShareParticipant.ntilde);
455
- h1b = crypto_2.hexToBigInt(bShareParticipant.h1);
456
- h2b = crypto_2.hexToBigInt(bShareParticipant.h2);
857
+ if (!aShareToBeSent.proof) {
858
+ throw new Error('Unexpected missing proof on aShareToBeSent');
457
859
  }
458
- const k = crypto_2.hexToBigInt(aShareToBeSent.k);
459
- if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, 3072, pka, {
860
+ const n = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer
861
+ const pka = util_1.getPaillierPublicKey(n);
862
+ const ntildea = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.ntilde);
863
+ const h1a = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.h1);
864
+ const h2a = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.h2);
865
+ const ntildeb = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ntilde);
866
+ const h1b = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h1);
867
+ const h2b = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h2);
868
+ const k = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.k);
869
+ if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
460
870
  ntilde: ntildeb,
461
871
  h1: h1b,
462
872
  h2: h2b,
463
873
  }, {
464
- z: crypto_2.hexToBigInt(aShareToBeSent.proof.z),
465
- u: crypto_2.hexToBigInt(aShareToBeSent.proof.u),
466
- w: crypto_2.hexToBigInt(aShareToBeSent.proof.w),
467
- s: crypto_2.hexToBigInt(aShareToBeSent.proof.s),
468
- s1: crypto_2.hexToBigInt(aShareToBeSent.proof.s1),
469
- s2: crypto_2.hexToBigInt(aShareToBeSent.proof.s2),
874
+ z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.z),
875
+ u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.u),
876
+ w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.w),
877
+ s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s),
878
+ s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s1),
879
+ s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s2),
470
880
  }, k)) {
471
881
  throw new Error('Could not verify signing A share proof');
472
882
  }
473
883
  // MtA $k_j, \gamma_i$.
474
884
  const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
475
885
  bShareParticipant.beta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
476
- const g = crypto_2.hexToBigInt(bShareParticipant.gamma);
477
- const rb = await sdk_lib_mpc_1.randomCoPrimeTo(pka.n);
886
+ const g = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.gamma);
887
+ const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
478
888
  const cb = pka.encrypt(beta0, rb);
479
889
  const alpha = pka.addition(pka.multiply(k, g), cb);
480
890
  aShareToBeSent.alpha = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
481
891
  // Prove $\gamma_i \in Z_{N^2}$.
482
892
  const gx = Ecdsa.curve.basePointMult(g);
483
- let proof;
484
- proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, 3072, pka, {
893
+ let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
485
894
  ntilde: ntildea,
486
895
  h1: h1a,
487
896
  h2: h2a,
@@ -505,18 +914,18 @@ class Ecdsa {
505
914
  // MtA $k_j, w_i$.
506
915
  const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
507
916
  shareParticipant.nu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
508
- const w = crypto_2.hexToBigInt(bShareParticipant.w);
509
- const rn = await sdk_lib_mpc_1.randomCoPrimeTo(pka.n);
917
+ const w = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.w);
918
+ const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
510
919
  const cn = pka.encrypt(nu0, rn);
511
920
  const mu = pka.addition(pka.multiply(k, w), cn);
512
921
  shareToBeSent.mu = util_1.bigIntToBufferBE(mu, 32).toString('hex');
513
922
  // Prove $\w_i \in Z_{N^2}$.
514
923
  const wx = Ecdsa.curve.basePointMult(w);
515
- proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, 3072, pka, {
924
+ proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
516
925
  ntilde: ntildea,
517
926
  h1: h1a,
518
927
  h2: h2a,
519
- }, k, crypto_2.hexToBigInt(aShareToBeSent.mu), w, nu0, rn, wx);
928
+ }, k, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu), w, nu0, rn, wx);
520
929
  Object.assign(shareToBeSent, {
521
930
  wProof: {
522
931
  z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
@@ -590,13 +999,13 @@ class Ecdsa {
590
999
  signCombine(shares) {
591
1000
  const gShare = shares.gShare;
592
1001
  const S = shares.signIndex;
593
- const gamma = crypto_2.hexToBigInt(gShare.gamma);
594
- const alpha = crypto_2.hexToBigInt(gShare.alpha);
595
- const beta = crypto_2.hexToBigInt(gShare.beta);
596
- const mu = crypto_2.hexToBigInt(gShare.mu);
597
- const nu = crypto_2.hexToBigInt(gShare.nu);
598
- const k = crypto_2.hexToBigInt(gShare.k);
599
- const w = crypto_2.hexToBigInt(gShare.w);
1002
+ const gamma = sdk_lib_mpc_1.hexToBigInt(gShare.gamma);
1003
+ const alpha = sdk_lib_mpc_1.hexToBigInt(gShare.alpha);
1004
+ const beta = sdk_lib_mpc_1.hexToBigInt(gShare.beta);
1005
+ const mu = sdk_lib_mpc_1.hexToBigInt(gShare.mu);
1006
+ const nu = sdk_lib_mpc_1.hexToBigInt(gShare.nu);
1007
+ const k = sdk_lib_mpc_1.hexToBigInt(gShare.k);
1008
+ const w = sdk_lib_mpc_1.hexToBigInt(gShare.w);
600
1009
  const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));
601
1010
  const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));
602
1011
  const Gamma = Ecdsa.curve.basePointMult(gamma);
@@ -628,11 +1037,11 @@ class Ecdsa {
628
1037
  */
629
1038
  sign(M, oShare, dShare, hash, shouldHash = true) {
630
1039
  const m = shouldHash ? (hash || crypto_1.createHash('sha256')).update(M).digest() : M;
631
- const delta = Ecdsa.curve.scalarAdd(crypto_2.hexToBigInt(oShare.delta), crypto_2.hexToBigInt(dShare.delta));
632
- const R = Ecdsa.curve.pointMultiply(Ecdsa.curve.pointAdd(crypto_2.hexToBigInt(oShare.Gamma), crypto_2.hexToBigInt(dShare.Gamma)), Ecdsa.curve.scalarInvert(delta));
1040
+ const delta = Ecdsa.curve.scalarAdd(sdk_lib_mpc_1.hexToBigInt(oShare.delta), sdk_lib_mpc_1.hexToBigInt(dShare.delta));
1041
+ const R = Ecdsa.curve.pointMultiply(Ecdsa.curve.pointAdd(sdk_lib_mpc_1.hexToBigInt(oShare.Gamma), sdk_lib_mpc_1.hexToBigInt(dShare.Gamma)), Ecdsa.curve.scalarInvert(delta));
633
1042
  const pointR = secp.Point.fromHex(util_1.bigIntToBufferBE(R, 32));
634
1043
  const r = pointR.x;
635
- const s = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(util_1.bigIntFromU8ABE(m), crypto_2.hexToBigInt(oShare.k)), Ecdsa.curve.scalarMult(r, crypto_2.hexToBigInt(oShare.omicron)));
1044
+ const s = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(util_1.bigIntFromU8ABE(m), sdk_lib_mpc_1.hexToBigInt(oShare.k)), Ecdsa.curve.scalarMult(r, sdk_lib_mpc_1.hexToBigInt(oShare.omicron)));
636
1045
  return {
637
1046
  i: oShare.i,
638
1047
  y: oShare.y,
@@ -652,7 +1061,7 @@ class Ecdsa {
652
1061
  if (!isRMatching) {
653
1062
  throw new Error('R value should be consistent across all shares');
654
1063
  }
655
- let s = shares.map((share) => crypto_2.hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);
1064
+ let s = shares.map((share) => sdk_lib_mpc_1.hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);
656
1065
  const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);
657
1066
  // Normalize s.
658
1067
  s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;
@@ -675,60 +1084,28 @@ class Ecdsa {
675
1084
  const messageToVerify = shouldHash ? (hash || crypto_1.createHash('sha256')).update(message).digest() : message;
676
1085
  return Ecdsa.curve.verify(messageToVerify, Buffer.concat([
677
1086
  Buffer.from([signature['recid']]),
678
- util_1.bigIntToBufferBE(crypto_2.hexToBigInt(signature['r']), 32),
679
- util_1.bigIntToBufferBE(crypto_2.hexToBigInt(signature['s']), 32),
680
- ]), crypto_2.hexToBigInt(signature['y']));
1087
+ util_1.bigIntToBufferBE(sdk_lib_mpc_1.hexToBigInt(signature['r']), 32),
1088
+ util_1.bigIntToBufferBE(sdk_lib_mpc_1.hexToBigInt(signature['s']), 32),
1089
+ ]), sdk_lib_mpc_1.hexToBigInt(signature['y']));
681
1090
  }
682
1091
  /**
683
1092
  * Deserializes a challenge and it's proofs from hex strings to bigint
1093
+ * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead
684
1094
  */
685
1095
  static deserializeNtilde(challenge) {
686
- const deserializedNtilde = {
687
- ntilde: crypto_2.hexToBigInt(challenge.ntilde),
688
- h1: crypto_2.hexToBigInt(challenge.h1),
689
- h2: crypto_2.hexToBigInt(challenge.h2),
690
- };
691
- if (challenge.ntildeProof) {
692
- deserializedNtilde.ntildeProof = {
693
- h1WrtH2: {
694
- alpha: crypto_2.convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.alpha),
695
- t: crypto_2.convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.t),
696
- },
697
- h2WrtH1: {
698
- alpha: crypto_2.convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.alpha),
699
- t: crypto_2.convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.t),
700
- },
701
- };
702
- }
703
- return deserializedNtilde;
1096
+ return sdk_lib_mpc_1.EcdsaTypes.deserializeNtilde(challenge);
704
1097
  }
705
1098
  /**
706
1099
  * Serializes a challenge and it's proofs from big int to hex strings.
1100
+ * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead
707
1101
  * @param challenge
708
1102
  */
709
1103
  static serializeNtilde(challenge) {
710
- const serializedNtilde = {
711
- ntilde: crypto_2.bigIntToHex(challenge.ntilde),
712
- h1: crypto_2.bigIntToHex(challenge.h1),
713
- h2: crypto_2.bigIntToHex(challenge.h2),
714
- };
715
- if (challenge.ntildeProof) {
716
- serializedNtilde.ntildeProof = {
717
- h1WrtH2: {
718
- alpha: crypto_2.convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.alpha),
719
- t: crypto_2.convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.t),
720
- },
721
- h2WrtH1: {
722
- alpha: crypto_2.convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.alpha),
723
- t: crypto_2.convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.t),
724
- },
725
- };
726
- }
727
- return serializedNtilde;
1104
+ return sdk_lib_mpc_1.EcdsaTypes.serializeNtilde(challenge);
728
1105
  }
729
1106
  }
730
1107
  exports.default = Ecdsa;
731
1108
  Ecdsa.curve = new curves_1.Secp256k1Curve();
732
1109
  Ecdsa.hdTree = new hdTree_1.BIP32();
733
1110
  Ecdsa.shamir = new shamir_1.default(Ecdsa.curve);
734
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/account-lib/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import * as paillierBigint from 'paillier-bigint';\nimport * as bigintCryptoUtils from 'bigint-crypto-utils';\nimport * as secp from '@noble/secp256k1';\nimport HDTree, { BIP32, chaincodeBase } from '../../hdTree';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { bigIntToHex, convertBigIntArrToHexArr, convertHexArrToBigIntArr, hexToBigInt } from '../../../util/crypto';\nimport { bigIntFromBufferBE, bigIntFromU8ABE, bigIntToBufferBE, getPaillierPublicKey } from '../../util';\nimport { Secp256k1Curve } from '../../curves';\nimport Shamir from '../../shamir';\nimport { EcdsaRangeProof, randomCoPrimeTo } from '@bitgo-beta/sdk-lib-mpc';\nimport {\n  AShare,\n  BShare,\n  DShare,\n  GShare,\n  KeyCombined,\n  KeyCombinedWithNtilde,\n  KeyShare,\n  KShare,\n  MUShare,\n  NShare,\n  OShare,\n  PShare,\n  RangeProofWithCheck,\n  Signature,\n  SignCombine,\n  SignCombineRT,\n  SignConvert,\n  SignConvertRT,\n  SignShareRT,\n  SShare,\n  SubkeyShare,\n  XShare,\n  XShareWithNtilde,\n  YShare,\n  YShareWithNtilde,\n  SerializedNtilde,\n  DeserializedNtilde,\n} from './types';\n\nconst _5n = BigInt(5);\n\nfunction hasNtilde(share: XShare | YShare): share is XShareWithNtilde | YShareWithNtilde {\n  return 'ntilde' in share;\n}\n\n/**\n * ECDSA TSS implementation supporting 2:n Threshold\n */\nexport default class Ecdsa {\n  static curve: Secp256k1Curve = new Secp256k1Curve();\n  static hdTree: HDTree = new BIP32();\n  static shamir: Shamir = new Shamir(Ecdsa.curve);\n  /**\n   * Generate shares for participant at index and split keys `(threshold,numShares)` ways.\n   * @param {number} index participant index\n   * @param {number} threshold Signing threshold\n   * @param {number} numShares  Number of shares\n   * @param {Buffer} seed optional 64 byte seed to use for key generation\n   * @param {Boolean} sync optional sync flag, if true then a synchronous version of Paillier key generation is used that does not spawn Worker threads.\n   * @returns {Promise<KeyShare>} Returns the private p-share\n   * and n-shares to be distributed to participants at their corresponding index.\n   */\n  async keyShare(index: number, threshold: number, numShares: number, seed?: Buffer, sync = false): Promise<KeyShare> {\n    if (!(index > 0 && index <= numShares && threshold <= numShares && threshold === 2)) {\n      throw 'Invalid KeyShare Config';\n    }\n\n    if (seed && seed.length < 64) {\n      throw new Error('Seed must have a length of at least 64 bytes');\n    }\n\n    let seedWithValidLength = seed;\n    if (seed && seed.length > 64) {\n      // if seed length is greater than 64 bytes, hash seed to 64 bytes.\n      seedWithValidLength = createHash('sha512').update(seed).digest();\n    }\n\n    // Generate additively homomorphic encryption key.\n    let paillierKeyPair: paillierBigint.KeyPair;\n    if (!sync) {\n      paillierKeyPair = await paillierBigint.generateRandomKeys(3072, true);\n    } else {\n      paillierKeyPair = paillierBigint.generateRandomKeysSync(3072, true);\n    }\n    const { publicKey, privateKey } = paillierKeyPair;\n    // Accept a 64 byte seed and create an extended private key from that seed\n    const secretKey = seedWithValidLength && bip32.fromSeed(seedWithValidLength);\n    const u =\n      (secretKey && secretKey.privateKey && bigIntFromU8ABE(new Uint8Array(secretKey.privateKey))) ??\n      Ecdsa.curve.scalarRandom();\n    const y = Ecdsa.curve.basePointMult(u);\n    const chaincode = (secretKey && secretKey.chainCode) ?? randomBytes(32);\n    // Compute secret shares of the private key\n    const { shares: uShares, v } = Ecdsa.shamir.split(u, threshold, numShares);\n    const currentParticipant: PShare = {\n      i: index,\n      t: threshold,\n      c: numShares,\n      l: bigIntToBufferBE(privateKey.lambda, 192).toString('hex'),\n      m: bigIntToBufferBE(privateKey.mu, 192).toString('hex'),\n      n: bigIntToBufferBE(publicKey.n, 384).toString('hex'),\n      y: bigIntToBufferBE(y, 33).toString('hex'),\n      u: bigIntToBufferBE(uShares[index], 32).toString('hex'),\n      uu: u.toString(),\n      chaincode: chaincode.toString('hex'),\n    };\n    const keyShare: KeyShare = {\n      pShare: currentParticipant,\n      nShares: {},\n    };\n\n    for (const share in uShares) {\n      const participantIndex = parseInt(share, 10);\n      if (participantIndex !== index) {\n        keyShare.nShares[participantIndex] = {\n          i: participantIndex,\n          j: currentParticipant['i'],\n          n: publicKey.n.toString(16),\n          y: bigIntToBufferBE(y, 33).toString('hex'),\n          v: bigIntToBufferBE(v[0], 33).toString('hex'),\n          u: bigIntToBufferBE(uShares[participantIndex], 32).toString('hex'),\n          chaincode: chaincode.toString('hex'),\n        } as NShare;\n      }\n    }\n    return keyShare;\n  }\n\n  /**\n   * Combine data shared during the key generation protocol.\n   * @param {KeyShare} participantShares private p-share and\n   * n-shares received from all other participants.\n   * @returns {KeyCombined} Returns the participant private x-share\n   * and y-shares to be used when generating signing shares.\n   */\n  keyCombine(pShare: PShare, nShares: NShare[]): KeyCombined {\n    const allShares = [pShare, ...nShares];\n    // Compute the public key.\n    const y = allShares.map((participant) => hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);\n    // Add secret shares\n    const x = allShares.map((participant) => hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Chaincode will be used in future when we add support for key derivation for ecdsa\n    const chaincodes = [pShare, ...nShares].map(({ chaincode }) => bigIntFromBufferBE(Buffer.from(chaincode, 'hex')));\n    const chaincode = chaincodes.reduce(\n      (acc, chaincode) =>\n        (acc + chaincode) % BigInt('0x010000000000000000000000000000000000000000000000000000000000000000') // 2^256\n    );\n\n    const participants: KeyCombined = {\n      xShare: {\n        i: pShare.i,\n        l: pShare.l,\n        m: pShare.m,\n        n: pShare.n,\n        y: bigIntToBufferBE(y, 33).toString('hex'),\n        x: bigIntToBufferBE(x, 32).toString('hex'),\n        chaincode: bigIntToBufferBE(chaincode, 32).toString('hex'),\n      },\n      yShares: {},\n    };\n\n    for (const share in nShares) {\n      const participantIndex = nShares[share]['j'];\n      participants.yShares[participantIndex] = {\n        i: pShare.i,\n        j: nShares[share]['j'],\n        n: nShares[share]['n'],\n      };\n    }\n    return participants;\n  }\n\n  /**\n   * Derive shares for a BIP-32 subkey.\n   * @param {PShare} The user's p-share.\n   * @param {NShare[]} The n-shares received from the other participants.\n   * @param {string} The BIP-32 path to derive.\n   * @returns {SubkeyShare} Returns the private x-share and n-shares to\n   * be distributed to participants at their corresponding index.\n   */\n  keyDerive(pShare: PShare, nShares: NShare[], path: string): SubkeyShare {\n    const yValues = [pShare, ...nShares].map((share) => hexToBigInt(share.y));\n    const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));\n    const u = BigInt(pShare.uu);\n    let contribChaincode = hexToBigInt(pShare.chaincode);\n    const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => hexToBigInt(chaincode))];\n    const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % chaincodeBase);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Derive subkey.\n    const subkey = Ecdsa.hdTree.privateDerive({ pk: y, sk: u, chaincode }, path);\n\n    // Calculate new public key contribution.\n    const contribY = Ecdsa.curve.basePointMult(subkey.sk);\n\n    // Calculate new chaincode contribution.\n    const chaincodeDelta = (chaincodeBase + subkey.chaincode - chaincode) % chaincodeBase;\n    contribChaincode = (contribChaincode + chaincodeDelta) % chaincodeBase;\n\n    // Calculate new u values.\n    const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);\n\n    // Calculate new signing key.\n    const x = [split_u[pShare.i], ...nShares.map(({ u }) => hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);\n\n    const P_i: XShare = {\n      i: pShare.i,\n      l: pShare.l,\n      m: pShare.m,\n      n: pShare.n,\n      y: bigIntToBufferBE(subkey.pk, 33).toString('hex'),\n      x: bigIntToBufferBE(x, 32).toString('hex'),\n      chaincode: bigIntToBufferBE(subkey.chaincode, 32).toString('hex'),\n    };\n\n    const shares: SubkeyShare = {\n      xShare: P_i,\n      nShares: {},\n    };\n\n    for (let ind = 0; ind < nShares.length; ind++) {\n      const P_j = nShares[ind];\n      shares.nShares[P_j.j] = {\n        i: P_j.j,\n        j: P_i.i,\n        n: P_j.n,\n        u: bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),\n        y: bigIntToBufferBE(contribY, 32).toString('hex'),\n        v: bigIntToBufferBE(v[0], 32).toString('hex'),\n        chaincode: bigIntToBufferBE(contribChaincode, 32).toString('hex'),\n      };\n    }\n\n    return shares;\n  }\n\n  /**\n   * Derives a child common keychain from common keychain\n   *\n   * @param {commonKeychain} The common keychain as a hex string.\n   * @param {path} The BIP-32 path to derive.\n   * @return {string} The derived common keychain as a hex string.\n   */\n  deriveUnhardened(commonKeychain: string, path: string): string {\n    if (Ecdsa.hdTree === undefined) {\n      throw new Error(\"Can't derive key without HDTree implementation\");\n    }\n\n    const keychain = Buffer.from(commonKeychain, 'hex');\n\n    const derivedPublicKeychain = Ecdsa.hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferBE(keychain.slice(0, 33)),\n        chaincode: bigIntFromBufferBE(keychain.slice(33)),\n      },\n      path\n    );\n\n    const derivedPk = bigIntToBufferBE(derivedPublicKeychain.pk, 33).toString('hex');\n    const derivedChaincode = bigIntToBufferBE(derivedPublicKeychain.chaincode, 32).toString('hex');\n\n    return derivedPk + derivedChaincode;\n  }\n\n  /**\n   * Appends a given range proof challenge to the shares previously created\n   * by #keyCombine. Generates a new challenge if not provided.\n   * @param {XShare} xShare Private xShare of signer\n   * @param {YShare} yShare YShare of the other participant involved in\n   * this signing operation\n   * @param {SerializedNtilde} challenge\n   * @returns {KeyCombined} The new XShare and YShares with the amended\n   * challenge values\n   */\n  async appendChallenge(xShare: XShare, yShare: YShare, challenge?: SerializedNtilde): Promise<KeyCombinedWithNtilde> {\n    if (!challenge) {\n      challenge = Ecdsa.serializeNtilde(await EcdsaRangeProof.generateNtilde(3072));\n    }\n    const { ntilde, h1, h2 } = challenge;\n    return {\n      xShare: { ...xShare, ntilde, h1, h2 },\n      yShares: {\n        [yShare.j]: {\n          i: yShare.j,\n          j: yShare.i,\n          n: xShare.n,\n          ntilde,\n          h1,\n          h2,\n        },\n      },\n    };\n  }\n\n  /**\n   * Create signing shares.\n   * @param {xShare} xShare Private xShare of current participant signer\n   * @param {YShare} yShare yShare corresponding to the other participant signer\n   * @returns {SignShareRT} Returns the participant private w-share\n   * and k-share to be distributed to other participant signer\n   */\n  async signShare(xShare: XShare | XShareWithNtilde, yShare: YShareWithNtilde): Promise<SignShareRT> {\n    const pk = getPaillierPublicKey(hexToBigInt(xShare.n));\n\n    // Generate a challenge if ntilde is not present in the xShare.\n    if (!hasNtilde(xShare)) {\n      xShare = (await this.appendChallenge(xShare, yShare)).xShare;\n    }\n\n    const k = Ecdsa.curve.scalarRandom();\n    const rk = await randomCoPrimeTo(pk.n);\n    const ck = pk.encrypt(k, rk);\n    const gamma = Ecdsa.curve.scalarRandom();\n\n    const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));\n\n    const w = [\n      Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),\n      hexToBigInt(xShare['x']),\n      Ecdsa.curve.scalarInvert(d),\n    ].reduce(Ecdsa.curve.scalarMult);\n\n    const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare as XShareWithNtilde;\n\n    const signers: SignShareRT = {\n      wShare: {\n        i: xShare.i,\n        l: xShare.l,\n        m: xShare.m,\n        n: xShare.n,\n        y: xShare.y,\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        ck: bigIntToBufferBE(ck, 768).toString('hex'),\n        w: bigIntToBufferBE(w, 32).toString('hex'),\n        gamma: bigIntToBufferBE(gamma, 32).toString('hex'),\n      },\n      kShare: {} as KShare,\n    };\n\n    const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;\n    const proof = await EcdsaRangeProof.prove(\n      Ecdsa.curve,\n      3072,\n      pk,\n      {\n        ntilde: hexToBigInt(ntildeb),\n        h1: hexToBigInt(h1b),\n        h2: hexToBigInt(h2b),\n      },\n      ck,\n      k,\n      rk\n    );\n    const proofShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n    };\n\n    signers.kShare = {\n      i: yShare.j,\n      j: xShare.i,\n      n: pk.n.toString(16),\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      k: bigIntToBufferBE(ck, 768).toString('hex'),\n      proof: proofShare,\n    };\n\n    return signers;\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another\n   * signer.\n   * @param {SignConvert}\n   * @returns {SignConvertRT}\n   */\n  async signConvert(shares: SignConvert): Promise<SignConvertRT> {\n    let shareParticipant: Partial<BShare> | Partial<GShare>, shareToBeSent: Partial<AShare> | MUShare;\n    let isGammaShare = false;\n    let kShare: Partial<KShare> = {};\n    if (shares.xShare && shares.yShare && shares.kShare) {\n      const xShare = shares.xShare; // currentParticipant secret xShare\n      const yShare = {\n        ...shares.yShare,\n        ntilde: shares.kShare.ntilde,\n        h1: shares.kShare.h1,\n        h2: shares.kShare.h2,\n      };\n      const signShare = await this.signShare(xShare, yShare);\n      kShare = signShare.kShare;\n      shareToBeSent = { ...shares.kShare } as Partial<AShare>;\n      shareParticipant = { ...signShare.wShare } as Partial<BShare>;\n    } else if ((shares.bShare && shares.muShare) || (shares.aShare && shares.wShare)) {\n      isGammaShare = true;\n      shareToBeSent = shares.aShare ? ({ ...shares.aShare } as MUShare) : ({ ...shares.muShare } as MUShare);\n      shareParticipant = shares.wShare ? ({ ...shares.wShare } as Partial<GShare>) : ({ ...shares.bShare } as GShare);\n    } else {\n      throw new Error('Invalid config for Sign Convert');\n    }\n    if (shareParticipant.i !== shareToBeSent.i) {\n      throw new Error('Shares from same participant');\n    }\n    if ((shareToBeSent as AShare).alpha) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      const pka = getPaillierPublicKey(hexToBigInt(bShareParticipant.n));\n      let ntildea, h1a, h2a, ck;\n      if (bShareParticipant.ntilde) {\n        ntildea = hexToBigInt(bShareParticipant.ntilde);\n        h1a = hexToBigInt(bShareParticipant.h1);\n        h2a = hexToBigInt(bShareParticipant.h2);\n        ck = hexToBigInt(bShareParticipant.ck);\n      }\n      // Verify $\\gamma_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.gammaProof.z),\n            zprm: hexToBigInt(aShareToBeSent.gammaProof.zprm),\n            t: hexToBigInt(aShareToBeSent.gammaProof.t),\n            v: hexToBigInt(aShareToBeSent.gammaProof.v),\n            w: hexToBigInt(aShareToBeSent.gammaProof.w),\n            s: hexToBigInt(aShareToBeSent.gammaProof.s),\n            s1: hexToBigInt(aShareToBeSent.gammaProof.s1),\n            s2: hexToBigInt(aShareToBeSent.gammaProof.s2),\n            t1: hexToBigInt(aShareToBeSent.gammaProof.t1),\n            t2: hexToBigInt(aShareToBeSent.gammaProof.t2),\n            u: hexToBigInt(aShareToBeSent.gammaProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.alpha),\n          hexToBigInt(aShareToBeSent.gammaProof.x)\n        )\n      ) {\n        throw new Error('could not verify signing share for gamma proof');\n      }\n      // Verify $\\w_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.wProof.z),\n            zprm: hexToBigInt(aShareToBeSent.wProof.zprm),\n            t: hexToBigInt(aShareToBeSent.wProof.t),\n            v: hexToBigInt(aShareToBeSent.wProof.v),\n            w: hexToBigInt(aShareToBeSent.wProof.w),\n            s: hexToBigInt(aShareToBeSent.wProof.s),\n            s1: hexToBigInt(aShareToBeSent.wProof.s1),\n            s2: hexToBigInt(aShareToBeSent.wProof.s2),\n            t1: hexToBigInt(aShareToBeSent.wProof.t1),\n            t2: hexToBigInt(aShareToBeSent.wProof.t2),\n            u: hexToBigInt(aShareToBeSent.wProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.mu),\n          hexToBigInt(aShareToBeSent.wProof.x)\n        )\n      ) {\n        throw new Error('could not verify share for wProof');\n      }\n      const sk = new paillierBigint.PrivateKey(\n        hexToBigInt(bShareParticipant.l as string),\n        hexToBigInt(bShareParticipant.m as string),\n        pka\n      );\n      const gShareParticipant = shareParticipant as GShare;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      const alpha = sk.decrypt(hexToBigInt(aShareToBeSent.alpha));\n      gShareParticipant.alpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n      const mu = sk.decrypt(hexToBigInt(aShareToBeSent.mu as string)); // recheck encrypted number\n      gShareParticipant.mu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n      const partialShareParticipant = shareParticipant as Partial<GShare>;\n      const partialShareToBeSent = muShareToBeSent as Partial<MUShare>;\n      delete partialShareParticipant.l;\n      delete partialShareParticipant.m;\n      delete partialShareToBeSent.alpha;\n      delete partialShareToBeSent.mu;\n    }\n    if ((shareToBeSent as AShare).k) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      const n = hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer\n      const pka = getPaillierPublicKey(n);\n      let ntildea, h1a, h2a, ntildeb, h1b, h2b;\n      if (aShareToBeSent.ntilde) {\n        ntildea = hexToBigInt(aShareToBeSent.ntilde);\n        h1a = hexToBigInt(aShareToBeSent.h1);\n        h2a = hexToBigInt(aShareToBeSent.h2);\n        ntildeb = hexToBigInt(bShareParticipant.ntilde);\n        h1b = hexToBigInt(bShareParticipant.h1);\n        h2b = hexToBigInt(bShareParticipant.h2);\n      }\n      const k = hexToBigInt(aShareToBeSent.k);\n      if (\n        !EcdsaRangeProof.verify(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildeb,\n            h1: h1b,\n            h2: h2b,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.proof.z),\n            u: hexToBigInt(aShareToBeSent.proof.u),\n            w: hexToBigInt(aShareToBeSent.proof.w),\n            s: hexToBigInt(aShareToBeSent.proof.s),\n            s1: hexToBigInt(aShareToBeSent.proof.s1),\n            s2: hexToBigInt(aShareToBeSent.proof.s2),\n          },\n          k\n        )\n      ) {\n        throw new Error('Could not verify signing A share proof');\n      }\n      // MtA $k_j, \\gamma_i$.\n      const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      bShareParticipant.beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString(\n        'hex'\n      );\n      const g = hexToBigInt(bShareParticipant.gamma);\n      const rb = await randomCoPrimeTo(pka.n);\n      const cb = pka.encrypt(beta0, rb);\n      const alpha = pka.addition(pka.multiply(k, g), cb);\n      aShareToBeSent.alpha = bigIntToBufferBE(alpha, 32).toString('hex');\n      // Prove $\\gamma_i \\in Z_{N^2}$.\n      const gx = Ecdsa.curve.basePointMult(g);\n      let proof: RangeProofWithCheck;\n      proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        3072,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        alpha,\n        g,\n        beta0,\n        rb,\n        gx\n      );\n      Object.assign(aShareToBeSent, {\n        gammaProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(gx, 33).toString('hex'),\n        },\n      });\n      // MtA $k_j, w_i$.\n      const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      shareParticipant.nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString(\n        'hex'\n      );\n      const w = hexToBigInt(bShareParticipant.w);\n      const rn = await randomCoPrimeTo(pka.n);\n      const cn = pka.encrypt(nu0, rn);\n      const mu = pka.addition(pka.multiply(k, w), cn);\n      shareToBeSent.mu = bigIntToBufferBE(mu, 32).toString('hex');\n      // Prove $\\w_i \\in Z_{N^2}$.\n      const wx = Ecdsa.curve.basePointMult(w);\n      proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        3072,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        hexToBigInt(aShareToBeSent.mu),\n        w,\n        nu0,\n        rn,\n        wx\n      );\n      Object.assign(shareToBeSent, {\n        wProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(wx, 33).toString('hex'),\n        },\n      });\n      if ((shareParticipant as GShare).alpha) {\n        const partialShareParticipant = shareParticipant as Partial<BShare>;\n        const partialShareToBeSent = shareToBeSent as Partial<AShare>;\n        delete partialShareParticipant.ntilde;\n        delete partialShareParticipant.h1;\n        delete partialShareParticipant.h2;\n        delete partialShareParticipant.ck;\n        delete partialShareToBeSent.n;\n        delete partialShareToBeSent.ntilde;\n        delete partialShareToBeSent.h1;\n        delete partialShareToBeSent.h2;\n        delete partialShareToBeSent.k;\n        delete partialShareToBeSent.proof;\n      } else {\n        Object.assign(shareToBeSent, {\n          n: kShare.n,\n          ntilde: bigIntToBufferBE(ntildeb, 384).toString('hex'),\n          h1: bigIntToBufferBE(h1b, 384).toString('hex'),\n          h2: bigIntToBufferBE(h2b, 384).toString('hex'),\n          k: kShare.k,\n          proof: kShare.proof,\n        });\n      }\n    }\n    if (!('alpha' in shareToBeSent) && !('k' in shareToBeSent)) {\n      const partialShareParticipant = shareParticipant as Partial<BShare>;\n      delete partialShareParticipant.ntilde;\n      delete partialShareParticipant.h1;\n      delete partialShareParticipant.h2;\n      delete partialShareParticipant.ck;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      shareToBeSent = {\n        i: muShareToBeSent.i,\n        j: muShareToBeSent.j,\n      } as MUShare;\n    }\n    [shareToBeSent.i, shareToBeSent.j] = [shareToBeSent.j, shareToBeSent.i];\n    if (isGammaShare) {\n      return {\n        muShare: shareToBeSent as MUShare,\n        gShare: shareParticipant as GShare,\n      };\n    }\n    return {\n      aShare: shareToBeSent as AShare,\n      bShare: shareParticipant as BShare,\n    };\n  }\n\n  /**\n   * Combine gamma shares to get the private omicron / delta shares\n   * @param {SignCombine} shares\n   * @returns {SignCombineRT}\n   */\n  signCombine(shares: SignCombine): SignCombineRT {\n    const gShare = shares.gShare;\n    const S = shares.signIndex;\n    const gamma = hexToBigInt(gShare.gamma);\n    const alpha = hexToBigInt(gShare.alpha);\n    const beta = hexToBigInt(gShare.beta);\n    const mu = hexToBigInt(gShare.mu);\n    const nu = hexToBigInt(gShare.nu);\n    const k = hexToBigInt(gShare.k);\n    const w = hexToBigInt(gShare.w);\n\n    const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));\n    const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));\n    const Gamma = Ecdsa.curve.basePointMult(gamma);\n\n    return {\n      oShare: {\n        i: gShare.i,\n        y: gShare.y,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        omicron: bigIntToBufferBE(omicron, 32).toString('hex'),\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n      dShare: {\n        i: S.i,\n        j: gShare.i,\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n    };\n  }\n\n  /**\n   * Sign a message.\n   * @param {Buffer} M Message to be signed\n   * @param {OShare} oShare private omicron share of current participant\n   * @param {DShare} dShare delta share received from the other participant\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before signing\n   * @returns {SShare}\n   */\n  sign(M: Buffer, oShare: OShare, dShare: DShare, hash?: Hash, shouldHash = true): SShare {\n    const m = shouldHash ? (hash || createHash('sha256')).update(M).digest() : M;\n\n    const delta = Ecdsa.curve.scalarAdd(hexToBigInt(oShare.delta), hexToBigInt(dShare.delta));\n\n    const R = Ecdsa.curve.pointMultiply(\n      Ecdsa.curve.pointAdd(hexToBigInt(oShare.Gamma), hexToBigInt(dShare.Gamma)),\n      Ecdsa.curve.scalarInvert(delta)\n    );\n    const pointR = secp.Point.fromHex(bigIntToBufferBE(R, 32));\n    const r = pointR.x;\n\n    const s = Ecdsa.curve.scalarAdd(\n      Ecdsa.curve.scalarMult(bigIntFromU8ABE(m), hexToBigInt(oShare.k)),\n      Ecdsa.curve.scalarMult(r, hexToBigInt(oShare.omicron))\n    );\n    return {\n      i: oShare.i,\n      y: oShare.y,\n      R: pointR.toHex(true),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n    };\n  }\n\n  /**\n   * Construct full signature by combining Sign Shares\n   * @param {SShare[]} shares\n   * @returns {Signature}\n   */\n  constructSignature(shares: SShare[]): Signature {\n    // Every R must match.\n    const R = shares[0]['R'];\n    const isRMatching = shares.map((share) => share['R'] === R).reduce((a, b) => a && b);\n    if (!isRMatching) {\n      throw new Error('R value should be consistent across all shares');\n    }\n\n    let s = shares.map((share) => hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);\n    const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);\n\n    // Normalize s.\n    s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;\n    return {\n      y: shares[0]['y'],\n      r: R.slice(2),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n      recid: recid,\n    };\n  }\n\n  /**\n   * Verify ecdsa signatures\n   * @param {Buffer} message\n   * @param {Signature } signature\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before verifying\n   * @returns {boolean} True if signature is valid; False otherwise\n   */\n  verify(message: Buffer, signature: Signature, hash?: Hash, shouldHash = true): boolean {\n    const messageToVerify = shouldHash ? (hash || createHash('sha256')).update(message).digest() : message;\n    return Ecdsa.curve.verify(\n      messageToVerify,\n      Buffer.concat([\n        Buffer.from([signature['recid']]),\n        bigIntToBufferBE(hexToBigInt(signature['r']), 32),\n        bigIntToBufferBE(hexToBigInt(signature['s']), 32),\n      ]),\n      hexToBigInt(signature['y'])\n    );\n  }\n\n  /**\n   * Deserializes a challenge and it's proofs from hex strings to bigint\n   */\n  static deserializeNtilde(challenge: SerializedNtilde): DeserializedNtilde {\n    const deserializedNtilde: DeserializedNtilde = {\n      ntilde: hexToBigInt(challenge.ntilde),\n      h1: hexToBigInt(challenge.h1),\n      h2: hexToBigInt(challenge.h2),\n    };\n    if (challenge.ntildeProof) {\n      deserializedNtilde.ntildeProof = {\n        h1WrtH2: {\n          alpha: convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.alpha),\n          t: convertHexArrToBigIntArr(challenge.ntildeProof.h1WrtH2.t),\n        },\n        h2WrtH1: {\n          alpha: convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.alpha),\n          t: convertHexArrToBigIntArr(challenge.ntildeProof.h2WrtH1.t),\n        },\n      };\n    }\n    return deserializedNtilde;\n  }\n\n  /**\n   * Serializes a challenge and it's proofs from big int to hex strings.\n   * @param challenge\n   */\n  static serializeNtilde(challenge: DeserializedNtilde): SerializedNtilde {\n    const serializedNtilde: SerializedNtilde = {\n      ntilde: bigIntToHex(challenge.ntilde),\n      h1: bigIntToHex(challenge.h1),\n      h2: bigIntToHex(challenge.h2),\n    };\n    if (challenge.ntildeProof) {\n      serializedNtilde.ntildeProof = {\n        h1WrtH2: {\n          alpha: convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.alpha),\n          t: convertBigIntArrToHexArr(challenge.ntildeProof.h1WrtH2.t),\n        },\n        h2WrtH1: {\n          alpha: convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.alpha),\n          t: convertBigIntArrToHexArr(challenge.ntildeProof.h2WrtH1.t),\n        },\n      };\n    }\n    return serializedNtilde;\n  }\n}\n"]}
1111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/account-lib/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import * as paillierBigint from 'paillier-bigint';\nimport * as bigintCryptoUtils from 'bigint-crypto-utils';\nimport * as secp from '@noble/secp256k1';\nimport HDTree, { BIP32, chaincodeBase } from '../../hdTree';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { bigIntFromBufferBE, bigIntFromU8ABE, bigIntToBufferBE, getPaillierPublicKey } from '../../util';\nimport { Secp256k1Curve } from '../../curves';\nimport Shamir from '../../shamir';\nimport {\n  EcdsaPaillierProof,\n  EcdsaRangeProof,\n  EcdsaTypes,\n  randomPositiveCoPrimeTo,\n  hexToBigInt,\n  minModulusBitLength,\n} from '@bitgo-beta/sdk-lib-mpc';\nimport {\n  AShare,\n  BShare,\n  DShare,\n  GShare,\n  KeyCombined,\n  KeyShare,\n  KShare,\n  MUShare,\n  NShare,\n  OShare,\n  PShare,\n  RangeProofWithCheckShare,\n  Signature,\n  SignCombine,\n  SignCombineRT,\n  SignConvert,\n  SignConvertRT,\n  SignConvertStep1,\n  SignConvertStep1Response,\n  SignConvertStep2,\n  SignConvertStep2Response,\n  SignConvertStep3,\n  SignConvertStep3Response,\n  SignShareRT,\n  SShare,\n  SubkeyShare,\n  WShare,\n  XShare,\n  XShareWithChallenges,\n  YShareWithChallenges,\n} from './types';\n\nconst _5n = BigInt(5);\n\n/**\n * ECDSA TSS implementation supporting 2:n Threshold\n */\nexport default class Ecdsa {\n  static curve: Secp256k1Curve = new Secp256k1Curve();\n  static hdTree: HDTree = new BIP32();\n  static shamir: Shamir = new Shamir(Ecdsa.curve);\n  /**\n   * Generate shares for participant at index and split keys `(threshold,numShares)` ways.\n   * @param {number} index participant index\n   * @param {number} threshold Signing threshold\n   * @param {number} numShares  Number of shares\n   * @param {Buffer} seed optional 64 byte seed to use for key generation\n   * @param {Boolean} sync optional sync flag, if true then a synchronous version of Paillier key generation is used that does not spawn Worker threads.\n   * @returns {Promise<KeyShare>} Returns the private p-share\n   * and n-shares to be distributed to participants at their corresponding index.\n   */\n  async keyShare(index: number, threshold: number, numShares: number, seed?: Buffer, sync = false): Promise<KeyShare> {\n    if (!(index > 0 && index <= numShares && threshold <= numShares && threshold === 2)) {\n      throw 'Invalid KeyShare Config';\n    }\n\n    if (seed && seed.length < 64) {\n      throw new Error('Seed must have a length of at least 64 bytes');\n    }\n\n    let seedWithValidLength = seed;\n    if (seed && seed.length > 64) {\n      // if seed length is greater than 64 bytes, hash seed to 64 bytes.\n      seedWithValidLength = createHash('sha512').update(seed).digest();\n    }\n\n    // Generate additively homomorphic encryption key.\n    let paillierKeyPair: paillierBigint.KeyPair;\n    if (!sync) {\n      paillierKeyPair = await paillierBigint.generateRandomKeys(minModulusBitLength, true);\n    } else {\n      paillierKeyPair = paillierBigint.generateRandomKeysSync(minModulusBitLength, true);\n    }\n    const { publicKey, privateKey } = paillierKeyPair;\n    // Accept a 64 byte seed and create an extended private key from that seed\n    const secretKey = seedWithValidLength && bip32.fromSeed(seedWithValidLength);\n    const u =\n      (secretKey && secretKey.privateKey && bigIntFromU8ABE(new Uint8Array(secretKey.privateKey))) ??\n      Ecdsa.curve.scalarRandom();\n    const y = Ecdsa.curve.basePointMult(u);\n    const chaincode = (secretKey && secretKey.chainCode) ?? randomBytes(32);\n    // Compute secret shares of the private key\n    const { shares: uShares, v } = Ecdsa.shamir.split(u, threshold, numShares);\n    const currentParticipant: PShare = {\n      i: index,\n      t: threshold,\n      c: numShares,\n      l: bigIntToBufferBE(privateKey.lambda, 192).toString('hex'),\n      m: bigIntToBufferBE(privateKey.mu, 192).toString('hex'),\n      n: bigIntToBufferBE(publicKey.n, 384).toString('hex'),\n      y: bigIntToBufferBE(y, 33).toString('hex'),\n      u: bigIntToBufferBE(uShares[index], 32).toString('hex'),\n      uu: u.toString(),\n      chaincode: chaincode.toString('hex'),\n    };\n    const keyShare: KeyShare = {\n      pShare: currentParticipant,\n      nShares: {},\n    };\n\n    for (const share in uShares) {\n      const participantIndex = parseInt(share, 10);\n      if (participantIndex !== index) {\n        keyShare.nShares[participantIndex] = {\n          i: participantIndex,\n          j: currentParticipant['i'],\n          n: publicKey.n.toString(16),\n          y: bigIntToBufferBE(y, 33).toString('hex'),\n          v: bigIntToBufferBE(v[0], 33).toString('hex'),\n          u: bigIntToBufferBE(uShares[participantIndex], 32).toString('hex'),\n          chaincode: chaincode.toString('hex'),\n        } as NShare;\n      }\n    }\n    return keyShare;\n  }\n\n  /**\n   * Combine data shared during the key generation protocol.\n   * @param {KeyShare} participantShares private p-share and\n   * n-shares received from all other participants.\n   * @returns {KeyCombined} Returns the participant private x-share\n   * and y-shares to be used when generating signing shares.\n   */\n  keyCombine(pShare: PShare, nShares: NShare[]): KeyCombined {\n    const allShares = [pShare, ...nShares];\n    // Compute the public key.\n    const y = allShares.map((participant) => hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);\n    // Add secret shares\n    const x = allShares.map((participant) => hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Chaincode will be used in future when we add support for key derivation for ecdsa\n    const chaincodes = [pShare, ...nShares].map(({ chaincode }) => bigIntFromBufferBE(Buffer.from(chaincode, 'hex')));\n    const chaincode = chaincodes.reduce(\n      (acc, chaincode) =>\n        (acc + chaincode) % BigInt('0x010000000000000000000000000000000000000000000000000000000000000000') // 2^256\n    );\n\n    const participants: KeyCombined = {\n      xShare: {\n        i: pShare.i,\n        l: pShare.l,\n        m: pShare.m,\n        n: pShare.n,\n        y: bigIntToBufferBE(y, 33).toString('hex'),\n        x: bigIntToBufferBE(x, 32).toString('hex'),\n        chaincode: bigIntToBufferBE(chaincode, 32).toString('hex'),\n      },\n      yShares: {},\n    };\n\n    for (const share in nShares) {\n      const participantIndex = nShares[share]['j'];\n      participants.yShares[participantIndex] = {\n        i: pShare.i,\n        j: nShares[share]['j'],\n        n: nShares[share]['n'],\n      };\n    }\n    return participants;\n  }\n\n  /**\n   * Derive shares for a BIP-32 subkey.\n   * @param {PShare} The user's p-share.\n   * @param {NShare[]} The n-shares received from the other participants.\n   * @param {string} The BIP-32 path to derive.\n   * @returns {SubkeyShare} Returns the private x-share and n-shares to\n   * be distributed to participants at their corresponding index.\n   */\n  keyDerive(pShare: PShare, nShares: NShare[], path: string): SubkeyShare {\n    const yValues = [pShare, ...nShares].map((share) => hexToBigInt(share.y));\n    const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));\n    const u = BigInt(pShare.uu);\n    let contribChaincode = hexToBigInt(pShare.chaincode);\n    const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => hexToBigInt(chaincode))];\n    const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % chaincodeBase);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Derive subkey.\n    const subkey = Ecdsa.hdTree.privateDerive({ pk: y, sk: u, chaincode }, path);\n\n    // Calculate new public key contribution.\n    const contribY = Ecdsa.curve.basePointMult(subkey.sk);\n\n    // Calculate new chaincode contribution.\n    const chaincodeDelta = (chaincodeBase + subkey.chaincode - chaincode) % chaincodeBase;\n    contribChaincode = (contribChaincode + chaincodeDelta) % chaincodeBase;\n\n    // Calculate new u values.\n    const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);\n\n    // Calculate new signing key.\n    const x = [split_u[pShare.i], ...nShares.map(({ u }) => hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);\n\n    const P_i: XShare = {\n      i: pShare.i,\n      l: pShare.l,\n      m: pShare.m,\n      n: pShare.n,\n      y: bigIntToBufferBE(subkey.pk, 33).toString('hex'),\n      x: bigIntToBufferBE(x, 32).toString('hex'),\n      chaincode: bigIntToBufferBE(subkey.chaincode, 32).toString('hex'),\n    };\n\n    const shares: SubkeyShare = {\n      xShare: P_i,\n      nShares: {},\n    };\n\n    for (let ind = 0; ind < nShares.length; ind++) {\n      const P_j = nShares[ind];\n      shares.nShares[P_j.j] = {\n        i: P_j.j,\n        j: P_i.i,\n        n: P_i.n,\n        u: bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),\n        y: bigIntToBufferBE(contribY, 32).toString('hex'),\n        v: bigIntToBufferBE(v[0], 32).toString('hex'),\n        chaincode: bigIntToBufferBE(contribChaincode, 32).toString('hex'),\n      };\n    }\n\n    return shares;\n  }\n\n  /**\n   * Derives a child common keychain from common keychain\n   *\n   * @param {commonKeychain} The common keychain as a hex string.\n   * @param {path} The BIP-32 path to derive.\n   * @return {string} The derived common keychain as a hex string.\n   */\n  deriveUnhardened(commonKeychain: string, path: string): string {\n    if (Ecdsa.hdTree === undefined) {\n      throw new Error(\"Can't derive key without HDTree implementation\");\n    }\n\n    const keychain = Buffer.from(commonKeychain, 'hex');\n\n    const derivedPublicKeychain = Ecdsa.hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferBE(keychain.slice(0, 33)),\n        chaincode: bigIntFromBufferBE(keychain.slice(33)),\n      },\n      path\n    );\n\n    const derivedPk = bigIntToBufferBE(derivedPublicKeychain.pk, 33).toString('hex');\n    const derivedChaincode = bigIntToBufferBE(derivedPublicKeychain.chaincode, 32).toString('hex');\n\n    return derivedPk + derivedChaincode;\n  }\n\n  /**\n   * Appends a given range proof challenge to the shares previously created\n   * by #keyCombine. Generates a new challenge if not provided.\n   * @param {XShare | YShare} share Private xShare or yShare of the signing operation\n   * @param rangeProofChallenge - challenge generated via generateNtilde\n   * @param paillierProofChallenge\n   * @returns {KeyCombined} The share with amended challenge values\n   */\n  appendChallenge<T>(\n    share: T,\n    rangeProofChallenge: EcdsaTypes.SerializedNtilde,\n    paillierProofChallenge: EcdsaTypes.SerializedPaillierChallenge\n  ): T & EcdsaTypes.SerializedEcdsaChallenges {\n    const { ntilde, h1, h2 } = rangeProofChallenge;\n    return {\n      ...share,\n      ntilde,\n      h1,\n      h2,\n      p: paillierProofChallenge.p,\n    };\n  }\n\n  /**\n   * Create signing shares.\n   * @param {xShare} xShare Private xShare of current participant signer\n   * @param {YShare} yShare yShare corresponding to the other participant signer\n   * @returns {SignShareRT} Returns the participant private w-share\n   * and k-share to be distributed to other participant signer\n   */\n  async signShare(xShare: XShareWithChallenges, yShare: YShareWithChallenges): Promise<SignShareRT> {\n    const pk = getPaillierPublicKey(hexToBigInt(xShare.n));\n\n    const k = Ecdsa.curve.scalarRandom();\n    const rk = await randomPositiveCoPrimeTo(pk.n);\n    const ck = pk.encrypt(k, rk);\n    const gamma = Ecdsa.curve.scalarRandom();\n\n    const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));\n\n    const w = [\n      Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),\n      hexToBigInt(xShare['x']),\n      Ecdsa.curve.scalarInvert(d),\n    ].reduce(Ecdsa.curve.scalarMult);\n\n    const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare;\n\n    const wShare: WShare = {\n      i: xShare.i,\n      l: xShare.l,\n      m: xShare.m,\n      n: xShare.n,\n      y: xShare.y,\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      p: xShare.p,\n      k: bigIntToBufferBE(k, 32).toString('hex'),\n      ck: bigIntToBufferBE(ck, 768).toString('hex'),\n      w: bigIntToBufferBE(w, 32).toString('hex'),\n      gamma: bigIntToBufferBE(gamma, 32).toString('hex'),\n    };\n\n    const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;\n    const proof = await EcdsaRangeProof.prove(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pk,\n      {\n        ntilde: hexToBigInt(ntildeb),\n        h1: hexToBigInt(h1b),\n        h2: hexToBigInt(h2b),\n      },\n      ck,\n      k,\n      rk\n    );\n\n    // create paillier challenge proof based on the other signers challenge\n    // only send sigma if we also send challenge p\n    const sigma = EcdsaPaillierProof.prove(\n      hexToBigInt(xShare.n),\n      hexToBigInt(xShare.l),\n      EcdsaTypes.deserializePaillierChallenge({ p: yShare.p! }).p\n    );\n\n    const proofShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n    };\n\n    const kShare: KShare = {\n      // this share will be sent to the other participant,\n      // so we need to swap the i and j values here\n      // so that they know it's their kShare, produced by us\n      i: yShare.j,\n      j: xShare.i,\n      n: pk.n.toString(16),\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      p: xShare.p,\n      k: bigIntToBufferBE(ck, 768).toString('hex'),\n      sigma: EcdsaTypes.serializePaillierChallengeProofs({ sigma: sigma }).sigma,\n      proof: proofShare,\n    };\n\n    return {\n      wShare,\n      kShare,\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * Connection 1.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer A completed signShare initially (input to this fn), then this step is completed by signer B.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep1(shares: SignConvertStep1): Promise<SignConvertStep1Response> {\n    const receivedKShare = shares.kShare;\n    const xShare = shares.xShare; // currentParticipant secret xShare\n    const yShare: YShareWithChallenges = {\n      ...shares.yShare,\n      ntilde: receivedKShare.ntilde,\n      h1: receivedKShare.h1,\n      h2: receivedKShare.h2,\n      p: receivedKShare.p,\n    };\n    const signShare = await this.signShare(xShare, yShare);\n    const shareParticipant = signShare.wShare;\n\n    if (shareParticipant.i !== receivedKShare.i) {\n      throw new Error('Shares from same participant');\n    }\n    if (!receivedKShare.proof) {\n      throw new Error('Unexpected missing proof on aShareToBeSent');\n    }\n\n    // the other participants paillier public key\n    const n = hexToBigInt(receivedKShare.n);\n    const pka = getPaillierPublicKey(n);\n    // the other participant's range proof challenge\n    const ntildea = hexToBigInt(receivedKShare.ntilde);\n    const h1a = hexToBigInt(receivedKShare.h1);\n    const h2a = hexToBigInt(receivedKShare.h2);\n\n    // the current participant's range proof challenge\n    const ntildeb = hexToBigInt(shareParticipant.ntilde);\n    const h1b = hexToBigInt(shareParticipant.h1);\n    const h2b = hexToBigInt(shareParticipant.h2);\n\n    const k = hexToBigInt(receivedKShare.k);\n\n    // the current participants paillier proof challenge\n    const shareParticipantPaillierChallenge = EcdsaTypes.deserializePaillierChallenge({ p: shareParticipant.p });\n    // the other signing parties proof to the current participants paillier proof challenge\n    const receivedPaillierChallengeProof = EcdsaTypes.deserializePaillierChallengeProofs({\n      sigma: receivedKShare.sigma,\n    });\n    if (\n      !(await EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma))\n    ) {\n      throw new Error('Could not verify signing A share paillier proof');\n    }\n\n    if (\n      !EcdsaRangeProof.verify(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildeb,\n          h1: h1b,\n          h2: h2b,\n        },\n        {\n          z: hexToBigInt(receivedKShare.proof.z),\n          u: hexToBigInt(receivedKShare.proof.u),\n          w: hexToBigInt(receivedKShare.proof.w),\n          s: hexToBigInt(receivedKShare.proof.s),\n          s1: hexToBigInt(receivedKShare.proof.s1),\n          s2: hexToBigInt(receivedKShare.proof.s2),\n        },\n        k\n      )\n    ) {\n      throw new Error('Could not verify signing A share proof');\n    }\n    // MtA $k_j, \\gamma_i$.\n    const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');\n    const g = hexToBigInt(shareParticipant.gamma);\n    const rb = await randomPositiveCoPrimeTo(pka.n);\n    const cb = pka.encrypt(beta0, rb);\n    const alpha = pka.addition(pka.multiply(k, g), cb);\n    const alphaToBeSent = bigIntToBufferBE(alpha, 32).toString('hex');\n    // Prove $\\gamma_i \\in Z_{N^2}$.\n    const gx = Ecdsa.curve.basePointMult(g);\n    let proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pka,\n      {\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n      },\n      k,\n      alpha,\n      g,\n      beta0,\n      rb,\n      gx\n    );\n    const gammaProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(gx, 33).toString('hex'),\n    };\n    // MtA $k_j, w_i$.\n    const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');\n    const w = hexToBigInt(shareParticipant.w);\n    const rn = await randomPositiveCoPrimeTo(pka.n);\n    const cn = pka.encrypt(nu0, rn);\n    const mu = pka.addition(pka.multiply(k, w), cn);\n    const muToBeSent = bigIntToBufferBE(mu, 32).toString('hex');\n    // Prove $\\w_i \\in Z_{N^2}$.\n    const wx = Ecdsa.curve.basePointMult(w);\n    proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pka,\n      {\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n      },\n      k,\n      hexToBigInt(muToBeSent),\n      w,\n      nu0,\n      rn,\n      wx\n    );\n    const wProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(wx, 33).toString('hex'),\n    };\n\n    const nToBeSent = signShare.kShare.n;\n    const ntildeToBeSent = bigIntToBufferBE(ntildeb, 384).toString('hex');\n    const h1ToBeSent = bigIntToBufferBE(h1b, 384).toString('hex');\n    const h2ToBeSent = bigIntToBufferBE(h2b, 384).toString('hex');\n    const kToBeSent = signShare.kShare.k;\n    const proofToBeSent = signShare.kShare.proof;\n    const [iToBeSent, jToBeSent] = [receivedKShare.j, receivedKShare.i];\n    return {\n      aShare: {\n        i: iToBeSent,\n        j: jToBeSent,\n        ntilde: ntildeToBeSent,\n        h1: h1ToBeSent,\n        h2: h2ToBeSent,\n        n: nToBeSent,\n        k: kToBeSent,\n        alpha: alphaToBeSent,\n        mu: muToBeSent,\n        proof: proofToBeSent,\n        gammaProof: gammaProofToBeSent,\n        wProof: wProofToBeSent,\n        // provide the share participants proof\n        // to the paillier challenge in the receivedKShare from the other signer\n        sigma: signShare.kShare.sigma,\n      },\n      bShare: {\n        ...shareParticipant,\n        beta,\n        nu,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another\n   * signer.\n   * Connection 2.1 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer B completed signConvertStep1, then this step is completed by signer A.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep2(shares: SignConvertStep2): Promise<SignConvertStep2Response> {\n    const receivedAShare = shares.aShare;\n    if (!receivedAShare.gammaProof) {\n      throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n    }\n    if (!receivedAShare.wProof) {\n      throw new Error('Unexpected missing wProof on aShareToBeSent');\n    }\n    const n = hexToBigInt(receivedAShare.n); // Paillier pub from other signer\n    // current participant public key\n    const pka = getPaillierPublicKey(hexToBigInt(shares.wShare.n));\n    const ntildea = hexToBigInt(shares.wShare.ntilde);\n    const h1a = hexToBigInt(shares.wShare.h1);\n    const h2a = hexToBigInt(shares.wShare.h2);\n    const ck = hexToBigInt(shares.wShare.ck);\n\n    const shareParticipantPaillierChallenge = EcdsaTypes.deserializePaillierChallenge({ p: shares.wShare.p });\n    const receivedPaillierChallengeProof = EcdsaTypes.deserializePaillierChallengeProofs({\n      sigma: shares.aShare.sigma,\n    });\n    if (!EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma)) {\n      throw new Error('could not verify signing share for paillier proof');\n    }\n\n    // Verify $\\gamma_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.gammaProof.z),\n          zprm: hexToBigInt(receivedAShare.gammaProof.zprm),\n          t: hexToBigInt(receivedAShare.gammaProof.t),\n          v: hexToBigInt(receivedAShare.gammaProof.v),\n          w: hexToBigInt(receivedAShare.gammaProof.w),\n          s: hexToBigInt(receivedAShare.gammaProof.s),\n          s1: hexToBigInt(receivedAShare.gammaProof.s1),\n          s2: hexToBigInt(receivedAShare.gammaProof.s2),\n          t1: hexToBigInt(receivedAShare.gammaProof.t1),\n          t2: hexToBigInt(receivedAShare.gammaProof.t2),\n          u: hexToBigInt(receivedAShare.gammaProof.u),\n        },\n        ck,\n        hexToBigInt(receivedAShare.alpha),\n        hexToBigInt(receivedAShare.gammaProof.x)\n      )\n    ) {\n      throw new Error('could not verify signing share for gamma proof');\n    }\n    // Verify $\\w_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.wProof.z),\n          zprm: hexToBigInt(receivedAShare.wProof.zprm),\n          t: hexToBigInt(receivedAShare.wProof.t),\n          v: hexToBigInt(receivedAShare.wProof.v),\n          w: hexToBigInt(receivedAShare.wProof.w),\n          s: hexToBigInt(receivedAShare.wProof.s),\n          s1: hexToBigInt(receivedAShare.wProof.s1),\n          s2: hexToBigInt(receivedAShare.wProof.s2),\n          t1: hexToBigInt(receivedAShare.wProof.t1),\n          t2: hexToBigInt(receivedAShare.wProof.t2),\n          u: hexToBigInt(receivedAShare.wProof.u),\n        },\n        ck,\n        hexToBigInt(receivedAShare.mu),\n        hexToBigInt(receivedAShare.wProof.x)\n      )\n    ) {\n      throw new Error('could not verify share for wProof');\n    }\n    const sk = new paillierBigint.PrivateKey(hexToBigInt(shares.wShare.l), hexToBigInt(shares.wShare.m), pka);\n\n    const gShareAlpha = bigIntToBufferBE(\n      Ecdsa.curve.scalarReduce(sk.decrypt(hexToBigInt(receivedAShare.alpha))),\n      32\n    ).toString('hex');\n\n    const gShareMu = bigIntToBufferBE(\n      Ecdsa.curve.scalarReduce(sk.decrypt(hexToBigInt(receivedAShare.mu))), // recheck encrypted number\n      32\n    ).toString('hex');\n\n    if (!receivedAShare.proof) {\n      throw new Error('Unexpected missing proof on aShareToBeSent');\n    }\n    const pkb = getPaillierPublicKey(n);\n    const ntildeb = hexToBigInt(receivedAShare.ntilde);\n    const h1b = hexToBigInt(receivedAShare.h1);\n    const h2b = hexToBigInt(receivedAShare.h2);\n    const k = hexToBigInt(receivedAShare.k);\n    if (\n      !EcdsaRangeProof.verify(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pkb,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.proof.z),\n          u: hexToBigInt(receivedAShare.proof.u),\n          w: hexToBigInt(receivedAShare.proof.w),\n          s: hexToBigInt(receivedAShare.proof.s),\n          s1: hexToBigInt(receivedAShare.proof.s1),\n          s2: hexToBigInt(receivedAShare.proof.s2),\n        },\n        k\n      )\n    ) {\n      throw new Error('Could not verify signing A share proof');\n    }\n    // MtA $k_j, \\gamma_i$.\n    const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const gShareBeta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');\n\n    const g = hexToBigInt(shares.wShare.gamma);\n    const rb = await randomPositiveCoPrimeTo(pkb.n);\n    const cb = pkb.encrypt(beta0, rb);\n    const alpha = pkb.addition(pkb.multiply(k, g), cb);\n    const alphaToBeSent = bigIntToBufferBE(alpha, 32).toString('hex');\n    // Prove $\\gamma_i \\in Z_{N^2}$.\n    const gx = Ecdsa.curve.basePointMult(g);\n    let proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pkb,\n      {\n        ntilde: ntildeb,\n        h1: h1b,\n        h2: h2b,\n      },\n      k,\n      alpha,\n      g,\n      beta0,\n      rb,\n      gx\n    );\n    const gammaProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(gx, 33).toString('hex'),\n    };\n    // MtA $k_j, w_i$.\n    const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const gShareNu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');\n    const w = hexToBigInt(shares.wShare.w);\n    const rn = await randomPositiveCoPrimeTo(pkb.n);\n    const cn = pkb.encrypt(nu0, rn);\n    const mu = pkb.addition(pkb.multiply(k, w), cn);\n    const muToBeSent = bigIntToBufferBE(mu, 32).toString('hex');\n    // Prove $\\w_i \\in Z_{N^2}$.\n    const wx = Ecdsa.curve.basePointMult(w);\n    proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pkb,\n      {\n        ntilde: ntildeb,\n        h1: h1b,\n        h2: h2b,\n      },\n      k,\n      hexToBigInt(muToBeSent),\n      w,\n      nu0,\n      rn,\n      wx\n    );\n    const wProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(wx, 33).toString('hex'),\n    };\n\n    const [iToBeSent, jToBeSent] = [receivedAShare.j, receivedAShare.i];\n    return {\n      muShare: {\n        i: iToBeSent,\n        j: jToBeSent,\n        alpha: alphaToBeSent,\n        mu: muToBeSent,\n        gammaProof: gammaProofToBeSent,\n        wProof: wProofToBeSent,\n      },\n      gShare: {\n        i: shares.wShare.i,\n        n: shares.wShare.n,\n        y: shares.wShare.y,\n        k: shares.wShare.k,\n        w: shares.wShare.w,\n        gamma: shares.wShare.gamma,\n        alpha: gShareAlpha,\n        mu: gShareMu,\n        beta: gShareBeta,\n        nu: gShareNu,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * Connection 2.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer A completed signConvertStep2, then this step is completed by signer B.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep3(shares: SignConvertStep3): Promise<SignConvertStep3Response> {\n    const receivedMuShare = shares.muShare;\n    if (!receivedMuShare.gammaProof) {\n      throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n    }\n    if (!receivedMuShare.wProof) {\n      throw new Error('Unexpected missing wProof on aShareToBeSent');\n    }\n    const pka = getPaillierPublicKey(hexToBigInt(shares.bShare.n));\n    const ntildea = hexToBigInt(shares.bShare.ntilde);\n    const h1a = hexToBigInt(shares.bShare.h1);\n    const h2a = hexToBigInt(shares.bShare.h2);\n    const ck = hexToBigInt(shares.bShare.ck);\n    // Verify $\\gamma_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedMuShare.gammaProof.z),\n          zprm: hexToBigInt(receivedMuShare.gammaProof.zprm),\n          t: hexToBigInt(receivedMuShare.gammaProof.t),\n          v: hexToBigInt(receivedMuShare.gammaProof.v),\n          w: hexToBigInt(receivedMuShare.gammaProof.w),\n          s: hexToBigInt(receivedMuShare.gammaProof.s),\n          s1: hexToBigInt(receivedMuShare.gammaProof.s1),\n          s2: hexToBigInt(receivedMuShare.gammaProof.s2),\n          t1: hexToBigInt(receivedMuShare.gammaProof.t1),\n          t2: hexToBigInt(receivedMuShare.gammaProof.t2),\n          u: hexToBigInt(receivedMuShare.gammaProof.u),\n        },\n        ck,\n        hexToBigInt(receivedMuShare.alpha),\n        hexToBigInt(receivedMuShare.gammaProof.x)\n      )\n    ) {\n      throw new Error('could not verify signing share for gamma proof');\n    }\n    // Verify $\\w_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedMuShare.wProof.z),\n          zprm: hexToBigInt(receivedMuShare.wProof.zprm),\n          t: hexToBigInt(receivedMuShare.wProof.t),\n          v: hexToBigInt(receivedMuShare.wProof.v),\n          w: hexToBigInt(receivedMuShare.wProof.w),\n          s: hexToBigInt(receivedMuShare.wProof.s),\n          s1: hexToBigInt(receivedMuShare.wProof.s1),\n          s2: hexToBigInt(receivedMuShare.wProof.s2),\n          t1: hexToBigInt(receivedMuShare.wProof.t1),\n          t2: hexToBigInt(receivedMuShare.wProof.t2),\n          u: hexToBigInt(receivedMuShare.wProof.u),\n        },\n        ck,\n        hexToBigInt(receivedMuShare.mu),\n        hexToBigInt(receivedMuShare.wProof.x)\n      )\n    ) {\n      throw new Error('could not verify share for wProof');\n    }\n    const sk = new paillierBigint.PrivateKey(hexToBigInt(shares.bShare.l), hexToBigInt(shares.bShare.m), pka);\n    const alpha = sk.decrypt(hexToBigInt(receivedMuShare.alpha));\n    const gShareAlpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n    const mu = sk.decrypt(hexToBigInt(receivedMuShare.mu as string)); // recheck encrypted number\n    const gShareMu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n\n    const [iToBeSent, jToBeSent] = [receivedMuShare.j, receivedMuShare.i];\n    return {\n      gShare: {\n        i: shares.bShare.i,\n        n: shares.bShare.n,\n        y: shares.bShare.y,\n        k: shares.bShare.k,\n        w: shares.bShare.w,\n        gamma: shares.bShare.gamma,\n        alpha: gShareAlpha,\n        mu: gShareMu,\n        beta: shares.bShare.beta,\n        nu: shares.bShare.nu,\n      },\n      signIndex: {\n        i: iToBeSent,\n        j: jToBeSent,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * @deprecated - use one of [signConvertStep1, signConvertStep2, signConvertStep3] instead\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvert(shares: SignConvert): Promise<SignConvertRT> {\n    let shareParticipant: Partial<BShare> | Partial<GShare>, shareToBeSent: Partial<AShare> | MUShare;\n    let isGammaShare = false;\n    let kShare: Partial<KShare> = {};\n    if (shares.xShare && shares.yShare && shares.kShare) {\n      const xShare = shares.xShare; // currentParticipant secret xShare\n      const yShare: YShareWithChallenges = {\n        ...shares.yShare,\n        ntilde: shares.kShare.ntilde,\n        h1: shares.kShare.h1,\n        h2: shares.kShare.h2,\n        p: shares.kShare.p,\n      };\n      const signShare = await this.signShare(xShare, yShare);\n      kShare = signShare.kShare;\n      shareToBeSent = { ...shares.kShare } as Partial<AShare>;\n      shareParticipant = { ...signShare.wShare } as Partial<BShare>;\n    } else if ((shares.bShare && shares.muShare) || (shares.aShare && shares.wShare)) {\n      isGammaShare = true;\n      shareToBeSent = shares.aShare ? ({ ...shares.aShare } as MUShare) : ({ ...shares.muShare } as MUShare);\n      shareParticipant = shares.wShare ? ({ ...shares.wShare } as Partial<GShare>) : ({ ...shares.bShare } as GShare);\n    } else {\n      throw new Error('Invalid config for Sign Convert');\n    }\n    if (shareParticipant.i !== shareToBeSent.i) {\n      throw new Error('Shares from same participant');\n    }\n    if ((shareToBeSent as AShare).alpha) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      if (!aShareToBeSent.gammaProof) {\n        throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n      }\n      if (!aShareToBeSent.wProof) {\n        throw new Error('Unexpected missing wProof on aShareToBeSent');\n      }\n      const pka = getPaillierPublicKey(hexToBigInt(bShareParticipant.n));\n      let ntildea, h1a, h2a, ck;\n      if (bShareParticipant.ntilde) {\n        ntildea = hexToBigInt(bShareParticipant.ntilde);\n        h1a = hexToBigInt(bShareParticipant.h1);\n        h2a = hexToBigInt(bShareParticipant.h2);\n        ck = hexToBigInt(bShareParticipant.ck);\n      }\n      // Verify $\\gamma_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.gammaProof.z),\n            zprm: hexToBigInt(aShareToBeSent.gammaProof.zprm),\n            t: hexToBigInt(aShareToBeSent.gammaProof.t),\n            v: hexToBigInt(aShareToBeSent.gammaProof.v),\n            w: hexToBigInt(aShareToBeSent.gammaProof.w),\n            s: hexToBigInt(aShareToBeSent.gammaProof.s),\n            s1: hexToBigInt(aShareToBeSent.gammaProof.s1),\n            s2: hexToBigInt(aShareToBeSent.gammaProof.s2),\n            t1: hexToBigInt(aShareToBeSent.gammaProof.t1),\n            t2: hexToBigInt(aShareToBeSent.gammaProof.t2),\n            u: hexToBigInt(aShareToBeSent.gammaProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.alpha),\n          hexToBigInt(aShareToBeSent.gammaProof.x)\n        )\n      ) {\n        throw new Error('could not verify signing share for gamma proof');\n      }\n      // Verify $\\w_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.wProof.z),\n            zprm: hexToBigInt(aShareToBeSent.wProof.zprm),\n            t: hexToBigInt(aShareToBeSent.wProof.t),\n            v: hexToBigInt(aShareToBeSent.wProof.v),\n            w: hexToBigInt(aShareToBeSent.wProof.w),\n            s: hexToBigInt(aShareToBeSent.wProof.s),\n            s1: hexToBigInt(aShareToBeSent.wProof.s1),\n            s2: hexToBigInt(aShareToBeSent.wProof.s2),\n            t1: hexToBigInt(aShareToBeSent.wProof.t1),\n            t2: hexToBigInt(aShareToBeSent.wProof.t2),\n            u: hexToBigInt(aShareToBeSent.wProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.mu),\n          hexToBigInt(aShareToBeSent.wProof.x)\n        )\n      ) {\n        throw new Error('could not verify share for wProof');\n      }\n      const sk = new paillierBigint.PrivateKey(\n        hexToBigInt(bShareParticipant.l as string),\n        hexToBigInt(bShareParticipant.m as string),\n        pka\n      );\n      const gShareParticipant = shareParticipant as GShare;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      const alpha = sk.decrypt(hexToBigInt(aShareToBeSent.alpha));\n      gShareParticipant.alpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n      const mu = sk.decrypt(hexToBigInt(aShareToBeSent.mu as string)); // recheck encrypted number\n      gShareParticipant.mu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n      const partialShareParticipant = shareParticipant as Partial<GShare>;\n      const partialShareToBeSent = muShareToBeSent as Partial<MUShare>;\n      delete partialShareParticipant.l;\n      delete partialShareParticipant.m;\n      delete partialShareToBeSent.alpha;\n      delete partialShareToBeSent.mu;\n    }\n    if ((shareToBeSent as AShare).k) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      if (!aShareToBeSent.proof) {\n        throw new Error('Unexpected missing proof on aShareToBeSent');\n      }\n      const n = hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer\n      const pka = getPaillierPublicKey(n);\n      const ntildea = hexToBigInt(aShareToBeSent.ntilde);\n      const h1a = hexToBigInt(aShareToBeSent.h1);\n      const h2a = hexToBigInt(aShareToBeSent.h2);\n      const ntildeb = hexToBigInt(bShareParticipant.ntilde);\n      const h1b = hexToBigInt(bShareParticipant.h1);\n      const h2b = hexToBigInt(bShareParticipant.h2);\n      const k = hexToBigInt(aShareToBeSent.k);\n      if (\n        !EcdsaRangeProof.verify(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildeb,\n            h1: h1b,\n            h2: h2b,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.proof.z),\n            u: hexToBigInt(aShareToBeSent.proof.u),\n            w: hexToBigInt(aShareToBeSent.proof.w),\n            s: hexToBigInt(aShareToBeSent.proof.s),\n            s1: hexToBigInt(aShareToBeSent.proof.s1),\n            s2: hexToBigInt(aShareToBeSent.proof.s2),\n          },\n          k\n        )\n      ) {\n        throw new Error('Could not verify signing A share proof');\n      }\n      // MtA $k_j, \\gamma_i$.\n      const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      bShareParticipant.beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString(\n        'hex'\n      );\n      const g = hexToBigInt(bShareParticipant.gamma);\n      const rb = await randomPositiveCoPrimeTo(pka.n);\n      const cb = pka.encrypt(beta0, rb);\n      const alpha = pka.addition(pka.multiply(k, g), cb);\n      aShareToBeSent.alpha = bigIntToBufferBE(alpha, 32).toString('hex');\n      // Prove $\\gamma_i \\in Z_{N^2}$.\n      const gx = Ecdsa.curve.basePointMult(g);\n      let proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        alpha,\n        g,\n        beta0,\n        rb,\n        gx\n      );\n      Object.assign(aShareToBeSent, {\n        gammaProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(gx, 33).toString('hex'),\n        },\n      });\n      // MtA $k_j, w_i$.\n      const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      shareParticipant.nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString(\n        'hex'\n      );\n      const w = hexToBigInt(bShareParticipant.w);\n      const rn = await randomPositiveCoPrimeTo(pka.n);\n      const cn = pka.encrypt(nu0, rn);\n      const mu = pka.addition(pka.multiply(k, w), cn);\n      shareToBeSent.mu = bigIntToBufferBE(mu, 32).toString('hex');\n      // Prove $\\w_i \\in Z_{N^2}$.\n      const wx = Ecdsa.curve.basePointMult(w);\n      proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        hexToBigInt(aShareToBeSent.mu),\n        w,\n        nu0,\n        rn,\n        wx\n      );\n      Object.assign(shareToBeSent, {\n        wProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(wx, 33).toString('hex'),\n        },\n      });\n      if ((shareParticipant as GShare).alpha) {\n        const partialShareParticipant = shareParticipant as Partial<BShare>;\n        const partialShareToBeSent = shareToBeSent as Partial<AShare>;\n        delete partialShareParticipant.ntilde;\n        delete partialShareParticipant.h1;\n        delete partialShareParticipant.h2;\n        delete partialShareParticipant.ck;\n        delete partialShareToBeSent.n;\n        delete partialShareToBeSent.ntilde;\n        delete partialShareToBeSent.h1;\n        delete partialShareToBeSent.h2;\n        delete partialShareToBeSent.k;\n        delete partialShareToBeSent.proof;\n      } else {\n        Object.assign(shareToBeSent, {\n          n: kShare.n,\n          ntilde: bigIntToBufferBE(ntildeb, 384).toString('hex'),\n          h1: bigIntToBufferBE(h1b, 384).toString('hex'),\n          h2: bigIntToBufferBE(h2b, 384).toString('hex'),\n          k: kShare.k,\n          proof: kShare.proof,\n        });\n      }\n    }\n    if (!('alpha' in shareToBeSent) && !('k' in shareToBeSent)) {\n      const partialShareParticipant = shareParticipant as Partial<BShare>;\n      delete partialShareParticipant.ntilde;\n      delete partialShareParticipant.h1;\n      delete partialShareParticipant.h2;\n      delete partialShareParticipant.ck;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      shareToBeSent = {\n        i: muShareToBeSent.i,\n        j: muShareToBeSent.j,\n      } as MUShare;\n    }\n    [shareToBeSent.i, shareToBeSent.j] = [shareToBeSent.j, shareToBeSent.i];\n    if (isGammaShare) {\n      return {\n        muShare: shareToBeSent as MUShare,\n        gShare: shareParticipant as GShare,\n      };\n    }\n    return {\n      aShare: shareToBeSent as AShare,\n      bShare: shareParticipant as BShare,\n    };\n  }\n\n  /**\n   * Combine gamma shares to get the private omicron / delta shares\n   * @param {SignCombine} shares\n   * @returns {SignCombineRT}\n   */\n  signCombine(shares: SignCombine): SignCombineRT {\n    const gShare = shares.gShare;\n    const S = shares.signIndex;\n    const gamma = hexToBigInt(gShare.gamma);\n    const alpha = hexToBigInt(gShare.alpha);\n    const beta = hexToBigInt(gShare.beta);\n    const mu = hexToBigInt(gShare.mu);\n    const nu = hexToBigInt(gShare.nu);\n    const k = hexToBigInt(gShare.k);\n    const w = hexToBigInt(gShare.w);\n\n    const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));\n    const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));\n    const Gamma = Ecdsa.curve.basePointMult(gamma);\n\n    return {\n      oShare: {\n        i: gShare.i,\n        y: gShare.y,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        omicron: bigIntToBufferBE(omicron, 32).toString('hex'),\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n      dShare: {\n        i: S.i,\n        j: gShare.i,\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n    };\n  }\n\n  /**\n   * Sign a message.\n   * @param {Buffer} M Message to be signed\n   * @param {OShare} oShare private omicron share of current participant\n   * @param {DShare} dShare delta share received from the other participant\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before signing\n   * @returns {SShare}\n   */\n  sign(M: Buffer, oShare: OShare, dShare: DShare, hash?: Hash, shouldHash = true): SShare {\n    const m = shouldHash ? (hash || createHash('sha256')).update(M).digest() : M;\n\n    const delta = Ecdsa.curve.scalarAdd(hexToBigInt(oShare.delta), hexToBigInt(dShare.delta));\n\n    const R = Ecdsa.curve.pointMultiply(\n      Ecdsa.curve.pointAdd(hexToBigInt(oShare.Gamma), hexToBigInt(dShare.Gamma)),\n      Ecdsa.curve.scalarInvert(delta)\n    );\n    const pointR = secp.Point.fromHex(bigIntToBufferBE(R, 32));\n    const r = pointR.x;\n\n    const s = Ecdsa.curve.scalarAdd(\n      Ecdsa.curve.scalarMult(bigIntFromU8ABE(m), hexToBigInt(oShare.k)),\n      Ecdsa.curve.scalarMult(r, hexToBigInt(oShare.omicron))\n    );\n    return {\n      i: oShare.i,\n      y: oShare.y,\n      R: pointR.toHex(true),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n    };\n  }\n\n  /**\n   * Construct full signature by combining Sign Shares\n   * @param {SShare[]} shares\n   * @returns {Signature}\n   */\n  constructSignature(shares: SShare[]): Signature {\n    // Every R must match.\n    const R = shares[0]['R'];\n    const isRMatching = shares.map((share) => share['R'] === R).reduce((a, b) => a && b);\n    if (!isRMatching) {\n      throw new Error('R value should be consistent across all shares');\n    }\n\n    let s = shares.map((share) => hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);\n    const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);\n\n    // Normalize s.\n    s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;\n    return {\n      y: shares[0]['y'],\n      r: R.slice(2),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n      recid: recid,\n    };\n  }\n\n  /**\n   * Verify ecdsa signatures\n   * @param {Buffer} message\n   * @param {Signature } signature\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before verifying\n   * @returns {boolean} True if signature is valid; False otherwise\n   */\n  verify(message: Buffer, signature: Signature, hash?: Hash, shouldHash = true): boolean {\n    const messageToVerify = shouldHash ? (hash || createHash('sha256')).update(message).digest() : message;\n    return Ecdsa.curve.verify(\n      messageToVerify,\n      Buffer.concat([\n        Buffer.from([signature['recid']]),\n        bigIntToBufferBE(hexToBigInt(signature['r']), 32),\n        bigIntToBufferBE(hexToBigInt(signature['s']), 32),\n      ]),\n      hexToBigInt(signature['y'])\n    );\n  }\n\n  /**\n   * Deserializes a challenge and it's proofs from hex strings to bigint\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   */\n  static deserializeNtilde(challenge: EcdsaTypes.SerializedNtilde): EcdsaTypes.DeserializedNtilde {\n    return EcdsaTypes.deserializeNtilde(challenge);\n  }\n\n  /**\n   * Serializes a challenge and it's proofs from big int to hex strings.\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   * @param challenge\n   */\n  static serializeNtilde(challenge: EcdsaTypes.DeserializedNtilde): EcdsaTypes.SerializedNtilde {\n    return EcdsaTypes.serializeNtilde(challenge);\n  }\n}\n"]}