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