@bitgo-beta/sdk-core 8.2.1-beta.11 → 8.2.1-beta.111

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