@bitgo-beta/sdk-core 8.2.1-beta.11 → 8.2.1-beta.111
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +302 -0
- package/dist/src/account-lib/baseCoin/enum.d.ts +4 -1
- package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
- package/dist/src/account-lib/baseCoin/enum.js +7 -1
- package/dist/src/account-lib/mpc/curves/ed25519.d.ts +4 -18
- package/dist/src/account-lib/mpc/curves/ed25519.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/curves/ed25519.js +6 -60
- package/dist/src/account-lib/mpc/index.d.ts +4 -4
- package/dist/src/account-lib/mpc/index.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/index.js +6 -6
- package/dist/src/account-lib/mpc/shamir.d.ts +5 -37
- package/dist/src/account-lib/mpc/shamir.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/shamir.js +6 -130
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +34 -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 -146
- 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 +70 -55
- 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/eddsa.d.ts +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/eddsa.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/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 +20 -4
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
- package/dist/src/bitgo/bitgoBase.d.ts +2 -1
- package/dist/src/bitgo/bitgoBase.d.ts.map +1 -1
- package/dist/src/bitgo/bitgoBase.js +1 -1
- package/dist/src/bitgo/enterprise/enterprise.d.ts +13 -1
- package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/enterprise.js +29 -1
- package/dist/src/bitgo/enterprise/enterprises.d.ts +6 -0
- package/dist/src/bitgo/enterprise/enterprises.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/enterprises.js +26 -1
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts +4 -1
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
- package/dist/src/bitgo/enterprise/iEnterprises.d.ts +2 -0
- package/dist/src/bitgo/enterprise/iEnterprises.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprises.js +1 -1
- package/dist/src/bitgo/environments.d.ts +7 -0
- package/dist/src/bitgo/environments.d.ts.map +1 -1
- package/dist/src/bitgo/environments.js +17 -3
- package/dist/src/bitgo/keychain/iKeychains.d.ts +6 -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 +2 -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 +13 -1
- package/dist/src/bitgo/recovery/initiate.d.ts +7 -1
- package/dist/src/bitgo/recovery/initiate.d.ts.map +1 -1
- package/dist/src/bitgo/recovery/initiate.js +1 -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 +15 -4
- 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 +6 -5
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.js +20 -9
- package/dist/src/bitgo/tss/types.d.ts +19 -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/codecProps.d.ts +7 -0
- package/dist/src/bitgo/utils/codecProps.d.ts.map +1 -0
- package/dist/src/bitgo/utils/codecProps.js +41 -0
- package/dist/src/bitgo/utils/opengpgUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/opengpgUtils.js +7 -10
- package/dist/src/bitgo/utils/postWithCodec.d.ts +18 -0
- package/dist/src/bitgo/utils/postWithCodec.d.ts.map +1 -0
- package/dist/src/bitgo/utils/postWithCodec.js +59 -0
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +54 -12
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +66 -9
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts +99 -8
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTypes.js +26 -2
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +47 -7
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +242 -128
- package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +9 -0
- 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 +79 -25
- package/dist/src/bitgo/wallet/BuildParams.d.ts +110 -0
- package/dist/src/bitgo/wallet/BuildParams.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/BuildParams.js +119 -0
- package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts +92 -0
- package/dist/src/bitgo/wallet/SendTransactionRequest.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/SendTransactionRequest.js +41 -0
- package/dist/src/bitgo/wallet/iWallet.d.ts +13 -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 +11 -2
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +136 -80
- package/dist/src/index.d.ts +5 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -2
- 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/test/node.utils.d.ts +2 -0
- package/dist/test/node.utils.d.ts.map +1 -0
- package/dist/test/node.utils.js +5 -0
- package/dist/test/unit/bitgo/utils/postWithCodec.d.ts +2 -0
- package/dist/test/unit/bitgo/utils/postWithCodec.d.ts.map +1 -0
- package/dist/test/unit/bitgo/utils/postWithCodec.js +79 -0
- package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts +2 -0
- package/dist/test/unit/bitgo/wallet/SendTransactionRequest.d.ts.map +1 -0
- package/dist/test/unit/bitgo/wallet/SendTransactionRequest.js +49 -0
- package/dist/test/unit/openssl.d.ts +2 -0
- package/dist/test/unit/openssl.d.ts.map +1 -0
- package/dist/test/unit/openssl.js +39 -0
- package/dist/test/unit/units.d.ts +2 -0
- package/dist/test/unit/units.d.ts.map +1 -0
- package/dist/test/unit/units.js +98 -0
- package/dist/tsconfig.tsbuildinfo +1 -8272
- package/package.json +11 -10
- package/dist/src/account-lib/mpc/hdTree.d.ts +0 -31
- package/dist/src/account-lib/mpc/hdTree.d.ts.map +0 -1
- package/dist/src/account-lib/mpc/hdTree.js +0 -141
- package/dist/src/account-lib/mpc/types.d.ts +0 -5
- package/dist/src/account-lib/mpc/types.d.ts.map +0 -1
- package/dist/src/account-lib/mpc/types.js +0 -3
- 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
|
@@ -25,18 +25,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
25
25
|
const paillierBigint = __importStar(require("paillier-bigint"));
|
|
26
26
|
const bigintCryptoUtils = __importStar(require("bigint-crypto-utils"));
|
|
27
27
|
const secp = __importStar(require("@noble/secp256k1"));
|
|
28
|
-
const hdTree_1 = require("../../hdTree");
|
|
29
28
|
const crypto_1 = require("crypto");
|
|
30
29
|
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
31
|
-
const crypto_2 = require("../../../util/crypto");
|
|
32
30
|
const util_1 = require("../../util");
|
|
33
31
|
const curves_1 = require("../../curves");
|
|
34
32
|
const shamir_1 = __importDefault(require("../../shamir"));
|
|
35
33
|
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
36
34
|
const _5n = BigInt(5);
|
|
37
|
-
function hasNtilde(share) {
|
|
38
|
-
return 'ntilde' in share;
|
|
39
|
-
}
|
|
40
35
|
/**
|
|
41
36
|
* ECDSA TSS implementation supporting 2:n Threshold
|
|
42
37
|
*/
|
|
@@ -67,10 +62,10 @@ class Ecdsa {
|
|
|
67
62
|
// Generate additively homomorphic encryption key.
|
|
68
63
|
let paillierKeyPair;
|
|
69
64
|
if (!sync) {
|
|
70
|
-
paillierKeyPair = await paillierBigint.generateRandomKeys(
|
|
65
|
+
paillierKeyPair = await paillierBigint.generateRandomKeys(sdk_lib_mpc_1.minModulusBitLength, true);
|
|
71
66
|
}
|
|
72
67
|
else {
|
|
73
|
-
paillierKeyPair = paillierBigint.generateRandomKeysSync(
|
|
68
|
+
paillierKeyPair = paillierBigint.generateRandomKeysSync(sdk_lib_mpc_1.minModulusBitLength, true);
|
|
74
69
|
}
|
|
75
70
|
const { publicKey, privateKey } = paillierKeyPair;
|
|
76
71
|
// Accept a 64 byte seed and create an extended private key from that seed
|
|
@@ -122,14 +117,14 @@ class Ecdsa {
|
|
|
122
117
|
keyCombine(pShare, nShares) {
|
|
123
118
|
const allShares = [pShare, ...nShares];
|
|
124
119
|
// Compute the public key.
|
|
125
|
-
const y = allShares.map((participant) =>
|
|
120
|
+
const y = allShares.map((participant) => sdk_lib_mpc_1.hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);
|
|
126
121
|
// Add secret shares
|
|
127
|
-
const x = allShares.map((participant) =>
|
|
122
|
+
const x = allShares.map((participant) => sdk_lib_mpc_1.hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);
|
|
128
123
|
// Verify shares.
|
|
129
124
|
for (const share of nShares) {
|
|
130
125
|
if (share.v) {
|
|
131
126
|
try {
|
|
132
|
-
Ecdsa.shamir.verify(
|
|
127
|
+
Ecdsa.shamir.verify(sdk_lib_mpc_1.hexToBigInt(share.u), [sdk_lib_mpc_1.hexToBigInt(share.y), sdk_lib_mpc_1.hexToBigInt(share.v)], pShare.i);
|
|
133
128
|
}
|
|
134
129
|
catch (err) {
|
|
135
130
|
throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);
|
|
@@ -171,17 +166,17 @@ class Ecdsa {
|
|
|
171
166
|
* be distributed to participants at their corresponding index.
|
|
172
167
|
*/
|
|
173
168
|
keyDerive(pShare, nShares, path) {
|
|
174
|
-
const yValues = [pShare, ...nShares].map((share) =>
|
|
169
|
+
const yValues = [pShare, ...nShares].map((share) => sdk_lib_mpc_1.hexToBigInt(share.y));
|
|
175
170
|
const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));
|
|
176
171
|
const u = BigInt(pShare.uu);
|
|
177
|
-
let contribChaincode =
|
|
178
|
-
const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) =>
|
|
179
|
-
const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) %
|
|
172
|
+
let contribChaincode = sdk_lib_mpc_1.hexToBigInt(pShare.chaincode);
|
|
173
|
+
const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => sdk_lib_mpc_1.hexToBigInt(chaincode))];
|
|
174
|
+
const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % sdk_lib_mpc_1.chaincodeBase);
|
|
180
175
|
// Verify shares.
|
|
181
176
|
for (const share of nShares) {
|
|
182
177
|
if (share.v) {
|
|
183
178
|
try {
|
|
184
|
-
Ecdsa.shamir.verify(
|
|
179
|
+
Ecdsa.shamir.verify(sdk_lib_mpc_1.hexToBigInt(share.u), [sdk_lib_mpc_1.hexToBigInt(share.y), sdk_lib_mpc_1.hexToBigInt(share.v)], pShare.i);
|
|
185
180
|
}
|
|
186
181
|
catch (err) {
|
|
187
182
|
throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);
|
|
@@ -193,12 +188,12 @@ class Ecdsa {
|
|
|
193
188
|
// Calculate new public key contribution.
|
|
194
189
|
const contribY = Ecdsa.curve.basePointMult(subkey.sk);
|
|
195
190
|
// Calculate new chaincode contribution.
|
|
196
|
-
const chaincodeDelta = (
|
|
197
|
-
contribChaincode = (contribChaincode + chaincodeDelta) %
|
|
191
|
+
const chaincodeDelta = (sdk_lib_mpc_1.chaincodeBase + subkey.chaincode - chaincode) % sdk_lib_mpc_1.chaincodeBase;
|
|
192
|
+
contribChaincode = (contribChaincode + chaincodeDelta) % sdk_lib_mpc_1.chaincodeBase;
|
|
198
193
|
// Calculate new u values.
|
|
199
194
|
const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);
|
|
200
195
|
// Calculate new signing key.
|
|
201
|
-
const x = [split_u[pShare.i], ...nShares.map(({ u }) =>
|
|
196
|
+
const x = [split_u[pShare.i], ...nShares.map(({ u }) => sdk_lib_mpc_1.hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);
|
|
202
197
|
const P_i = {
|
|
203
198
|
i: pShare.i,
|
|
204
199
|
l: pShare.l,
|
|
@@ -217,7 +212,7 @@ class Ecdsa {
|
|
|
217
212
|
shares.nShares[P_j.j] = {
|
|
218
213
|
i: P_j.j,
|
|
219
214
|
j: P_i.i,
|
|
220
|
-
n:
|
|
215
|
+
n: P_i.n,
|
|
221
216
|
u: util_1.bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),
|
|
222
217
|
y: util_1.bigIntToBufferBE(contribY, 32).toString('hex'),
|
|
223
218
|
v: util_1.bigIntToBufferBE(v[0], 32).toString('hex'),
|
|
@@ -249,30 +244,19 @@ class Ecdsa {
|
|
|
249
244
|
/**
|
|
250
245
|
* Appends a given range proof challenge to the shares previously created
|
|
251
246
|
* by #keyCombine. Generates a new challenge if not provided.
|
|
252
|
-
* @param {XShare}
|
|
253
|
-
* @param
|
|
254
|
-
*
|
|
255
|
-
* @
|
|
256
|
-
* @returns {KeyCombined} The new XShare and YShares with the amended
|
|
257
|
-
* challenge values
|
|
247
|
+
* @param {XShare | YShare} share Private xShare or yShare of the signing operation
|
|
248
|
+
* @param rangeProofChallenge - challenge generated via generateNtilde
|
|
249
|
+
* @param paillierProofChallenge
|
|
250
|
+
* @returns {KeyCombined} The share with amended challenge values
|
|
258
251
|
*/
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
challenge = sdk_lib_mpc_1.EcdsaTypes.serializeNtilde(await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde(3072));
|
|
262
|
-
}
|
|
263
|
-
const { ntilde, h1, h2 } = challenge;
|
|
252
|
+
appendChallenge(share, rangeProofChallenge, paillierProofChallenge) {
|
|
253
|
+
const { ntilde, h1, h2 } = rangeProofChallenge;
|
|
264
254
|
return {
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
n: xShare.n,
|
|
271
|
-
ntilde,
|
|
272
|
-
h1,
|
|
273
|
-
h2,
|
|
274
|
-
},
|
|
275
|
-
},
|
|
255
|
+
...share,
|
|
256
|
+
ntilde,
|
|
257
|
+
h1,
|
|
258
|
+
h2,
|
|
259
|
+
p: paillierProofChallenge.p,
|
|
276
260
|
};
|
|
277
261
|
}
|
|
278
262
|
/**
|
|
@@ -283,45 +267,42 @@ class Ecdsa {
|
|
|
283
267
|
* and k-share to be distributed to other participant signer
|
|
284
268
|
*/
|
|
285
269
|
async signShare(xShare, yShare) {
|
|
286
|
-
const pk = util_1.getPaillierPublicKey(
|
|
287
|
-
// Generate a challenge if ntilde is not present in the xShare.
|
|
288
|
-
if (!hasNtilde(xShare)) {
|
|
289
|
-
xShare = (await this.appendChallenge(xShare, yShare)).xShare;
|
|
290
|
-
}
|
|
270
|
+
const pk = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(xShare.n));
|
|
291
271
|
const k = Ecdsa.curve.scalarRandom();
|
|
292
|
-
const rk = await sdk_lib_mpc_1.
|
|
272
|
+
const rk = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pk.n);
|
|
293
273
|
const ck = pk.encrypt(k, rk);
|
|
294
274
|
const gamma = Ecdsa.curve.scalarRandom();
|
|
295
275
|
const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));
|
|
296
276
|
const w = [
|
|
297
277
|
Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),
|
|
298
|
-
|
|
278
|
+
sdk_lib_mpc_1.hexToBigInt(xShare['x']),
|
|
299
279
|
Ecdsa.curve.scalarInvert(d),
|
|
300
280
|
].reduce(Ecdsa.curve.scalarMult);
|
|
301
281
|
const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare;
|
|
302
|
-
const
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
},
|
|
317
|
-
kShare: {},
|
|
282
|
+
const wShare = {
|
|
283
|
+
i: xShare.i,
|
|
284
|
+
l: xShare.l,
|
|
285
|
+
m: xShare.m,
|
|
286
|
+
n: xShare.n,
|
|
287
|
+
y: xShare.y,
|
|
288
|
+
ntilde: ntildea,
|
|
289
|
+
h1: h1a,
|
|
290
|
+
h2: h2a,
|
|
291
|
+
p: xShare.p,
|
|
292
|
+
k: util_1.bigIntToBufferBE(k, 32).toString('hex'),
|
|
293
|
+
ck: util_1.bigIntToBufferBE(ck, 768).toString('hex'),
|
|
294
|
+
w: util_1.bigIntToBufferBE(w, 32).toString('hex'),
|
|
295
|
+
gamma: util_1.bigIntToBufferBE(gamma, 32).toString('hex'),
|
|
318
296
|
};
|
|
319
297
|
const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;
|
|
320
|
-
const proof = await sdk_lib_mpc_1.EcdsaRangeProof.prove(Ecdsa.curve,
|
|
321
|
-
ntilde:
|
|
322
|
-
h1:
|
|
323
|
-
h2:
|
|
298
|
+
const proof = await sdk_lib_mpc_1.EcdsaRangeProof.prove(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pk, {
|
|
299
|
+
ntilde: sdk_lib_mpc_1.hexToBigInt(ntildeb),
|
|
300
|
+
h1: sdk_lib_mpc_1.hexToBigInt(h1b),
|
|
301
|
+
h2: sdk_lib_mpc_1.hexToBigInt(h2b),
|
|
324
302
|
}, ck, k, rk);
|
|
303
|
+
// create paillier challenge proof based on the other signers challenge
|
|
304
|
+
// only send sigma if we also send challenge p
|
|
305
|
+
const sigma = sdk_lib_mpc_1.EcdsaPaillierProof.prove(sdk_lib_mpc_1.hexToBigInt(xShare.n), sdk_lib_mpc_1.hexToBigInt(xShare.l), sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: yShare.p }).p);
|
|
325
306
|
const proofShare = {
|
|
326
307
|
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
327
308
|
u: util_1.bigIntToBufferBE(proof.u, 768).toString('hex'),
|
|
@@ -330,22 +311,443 @@ class Ecdsa {
|
|
|
330
311
|
s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
|
|
331
312
|
s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
|
|
332
313
|
};
|
|
333
|
-
|
|
314
|
+
const kShare = {
|
|
315
|
+
// this share will be sent to the other participant,
|
|
316
|
+
// so we need to swap the i and j values here
|
|
317
|
+
// so that they know it's their kShare, produced by us
|
|
334
318
|
i: yShare.j,
|
|
335
319
|
j: xShare.i,
|
|
336
320
|
n: pk.n.toString(16),
|
|
337
321
|
ntilde: ntildea,
|
|
338
322
|
h1: h1a,
|
|
339
323
|
h2: h2a,
|
|
324
|
+
p: xShare.p,
|
|
340
325
|
k: util_1.bigIntToBufferBE(ck, 768).toString('hex'),
|
|
326
|
+
sigma: sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallengeProofs({ sigma: sigma }).sigma,
|
|
341
327
|
proof: proofShare,
|
|
342
328
|
};
|
|
343
|
-
return
|
|
329
|
+
return {
|
|
330
|
+
wShare,
|
|
331
|
+
kShare,
|
|
332
|
+
};
|
|
333
|
+
}
|
|
334
|
+
/**
|
|
335
|
+
* Perform multiplicitive-to-additive (MtA) share conversion with another signer.
|
|
336
|
+
* Connection 1.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
|
|
337
|
+
* If signer A completed signShare initially (input to this fn), then this step is completed by signer B.
|
|
338
|
+
* @param {SignConvert} shares
|
|
339
|
+
* @returns {SignConvertRT}
|
|
340
|
+
*/
|
|
341
|
+
async signConvertStep1(shares) {
|
|
342
|
+
const receivedKShare = shares.kShare;
|
|
343
|
+
const xShare = shares.xShare; // currentParticipant secret xShare
|
|
344
|
+
const yShare = {
|
|
345
|
+
...shares.yShare,
|
|
346
|
+
ntilde: receivedKShare.ntilde,
|
|
347
|
+
h1: receivedKShare.h1,
|
|
348
|
+
h2: receivedKShare.h2,
|
|
349
|
+
p: receivedKShare.p,
|
|
350
|
+
};
|
|
351
|
+
const signShare = await this.signShare(xShare, yShare);
|
|
352
|
+
const shareParticipant = signShare.wShare;
|
|
353
|
+
if (shareParticipant.i !== receivedKShare.i) {
|
|
354
|
+
throw new Error('Shares from same participant');
|
|
355
|
+
}
|
|
356
|
+
if (!receivedKShare.proof) {
|
|
357
|
+
throw new Error('Unexpected missing proof on aShareToBeSent');
|
|
358
|
+
}
|
|
359
|
+
// the other participants paillier public key
|
|
360
|
+
const n = sdk_lib_mpc_1.hexToBigInt(receivedKShare.n);
|
|
361
|
+
const pka = util_1.getPaillierPublicKey(n);
|
|
362
|
+
// the other participant's range proof challenge
|
|
363
|
+
const ntildea = sdk_lib_mpc_1.hexToBigInt(receivedKShare.ntilde);
|
|
364
|
+
const h1a = sdk_lib_mpc_1.hexToBigInt(receivedKShare.h1);
|
|
365
|
+
const h2a = sdk_lib_mpc_1.hexToBigInt(receivedKShare.h2);
|
|
366
|
+
// the current participant's range proof challenge
|
|
367
|
+
const ntildeb = sdk_lib_mpc_1.hexToBigInt(shareParticipant.ntilde);
|
|
368
|
+
const h1b = sdk_lib_mpc_1.hexToBigInt(shareParticipant.h1);
|
|
369
|
+
const h2b = sdk_lib_mpc_1.hexToBigInt(shareParticipant.h2);
|
|
370
|
+
const k = sdk_lib_mpc_1.hexToBigInt(receivedKShare.k);
|
|
371
|
+
// the current participants paillier proof challenge
|
|
372
|
+
const shareParticipantPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: shareParticipant.p });
|
|
373
|
+
// the other signing parties proof to the current participants paillier proof challenge
|
|
374
|
+
const receivedPaillierChallengeProof = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallengeProofs({
|
|
375
|
+
sigma: receivedKShare.sigma,
|
|
376
|
+
});
|
|
377
|
+
if (!(await sdk_lib_mpc_1.EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma))) {
|
|
378
|
+
throw new Error('Could not verify signing A share paillier proof');
|
|
379
|
+
}
|
|
380
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
381
|
+
ntilde: ntildeb,
|
|
382
|
+
h1: h1b,
|
|
383
|
+
h2: h2b,
|
|
384
|
+
}, {
|
|
385
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.z),
|
|
386
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.u),
|
|
387
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.w),
|
|
388
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s),
|
|
389
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s1),
|
|
390
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedKShare.proof.s2),
|
|
391
|
+
}, k)) {
|
|
392
|
+
throw new Error('Could not verify signing A share proof');
|
|
393
|
+
}
|
|
394
|
+
// MtA $k_j, \gamma_i$.
|
|
395
|
+
const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
396
|
+
const beta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
|
|
397
|
+
const g = sdk_lib_mpc_1.hexToBigInt(shareParticipant.gamma);
|
|
398
|
+
const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
|
|
399
|
+
const cb = pka.encrypt(beta0, rb);
|
|
400
|
+
const alpha = pka.addition(pka.multiply(k, g), cb);
|
|
401
|
+
const alphaToBeSent = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
|
|
402
|
+
// Prove $\gamma_i \in Z_{N^2}$.
|
|
403
|
+
const gx = Ecdsa.curve.basePointMult(g);
|
|
404
|
+
let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
405
|
+
ntilde: ntildea,
|
|
406
|
+
h1: h1a,
|
|
407
|
+
h2: h2a,
|
|
408
|
+
}, k, alpha, g, beta0, rb, gx);
|
|
409
|
+
const gammaProofToBeSent = {
|
|
410
|
+
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
411
|
+
zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
|
|
412
|
+
t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
|
|
413
|
+
v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
|
|
414
|
+
w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
|
|
415
|
+
s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
|
|
416
|
+
s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
|
|
417
|
+
s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
|
|
418
|
+
t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
|
|
419
|
+
t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
|
|
420
|
+
u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
|
|
421
|
+
x: util_1.bigIntToBufferBE(gx, 33).toString('hex'),
|
|
422
|
+
};
|
|
423
|
+
// MtA $k_j, w_i$.
|
|
424
|
+
const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
425
|
+
const nu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
|
|
426
|
+
const w = sdk_lib_mpc_1.hexToBigInt(shareParticipant.w);
|
|
427
|
+
const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
|
|
428
|
+
const cn = pka.encrypt(nu0, rn);
|
|
429
|
+
const mu = pka.addition(pka.multiply(k, w), cn);
|
|
430
|
+
const muToBeSent = util_1.bigIntToBufferBE(mu, 32).toString('hex');
|
|
431
|
+
// Prove $\w_i \in Z_{N^2}$.
|
|
432
|
+
const wx = Ecdsa.curve.basePointMult(w);
|
|
433
|
+
proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
434
|
+
ntilde: ntildea,
|
|
435
|
+
h1: h1a,
|
|
436
|
+
h2: h2a,
|
|
437
|
+
}, k, sdk_lib_mpc_1.hexToBigInt(muToBeSent), w, nu0, rn, wx);
|
|
438
|
+
const wProofToBeSent = {
|
|
439
|
+
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
440
|
+
zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
|
|
441
|
+
t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
|
|
442
|
+
v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
|
|
443
|
+
w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
|
|
444
|
+
s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
|
|
445
|
+
s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
|
|
446
|
+
s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
|
|
447
|
+
t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
|
|
448
|
+
t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
|
|
449
|
+
u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
|
|
450
|
+
x: util_1.bigIntToBufferBE(wx, 33).toString('hex'),
|
|
451
|
+
};
|
|
452
|
+
const nToBeSent = signShare.kShare.n;
|
|
453
|
+
const ntildeToBeSent = util_1.bigIntToBufferBE(ntildeb, 384).toString('hex');
|
|
454
|
+
const h1ToBeSent = util_1.bigIntToBufferBE(h1b, 384).toString('hex');
|
|
455
|
+
const h2ToBeSent = util_1.bigIntToBufferBE(h2b, 384).toString('hex');
|
|
456
|
+
const kToBeSent = signShare.kShare.k;
|
|
457
|
+
const proofToBeSent = signShare.kShare.proof;
|
|
458
|
+
const [iToBeSent, jToBeSent] = [receivedKShare.j, receivedKShare.i];
|
|
459
|
+
return {
|
|
460
|
+
aShare: {
|
|
461
|
+
i: iToBeSent,
|
|
462
|
+
j: jToBeSent,
|
|
463
|
+
ntilde: ntildeToBeSent,
|
|
464
|
+
h1: h1ToBeSent,
|
|
465
|
+
h2: h2ToBeSent,
|
|
466
|
+
n: nToBeSent,
|
|
467
|
+
k: kToBeSent,
|
|
468
|
+
alpha: alphaToBeSent,
|
|
469
|
+
mu: muToBeSent,
|
|
470
|
+
proof: proofToBeSent,
|
|
471
|
+
gammaProof: gammaProofToBeSent,
|
|
472
|
+
wProof: wProofToBeSent,
|
|
473
|
+
// provide the share participants proof
|
|
474
|
+
// to the paillier challenge in the receivedKShare from the other signer
|
|
475
|
+
sigma: signShare.kShare.sigma,
|
|
476
|
+
},
|
|
477
|
+
bShare: {
|
|
478
|
+
...shareParticipant,
|
|
479
|
+
beta,
|
|
480
|
+
nu,
|
|
481
|
+
},
|
|
482
|
+
};
|
|
344
483
|
}
|
|
345
484
|
/**
|
|
346
485
|
* Perform multiplicitive-to-additive (MtA) share conversion with another
|
|
347
486
|
* signer.
|
|
348
|
-
*
|
|
487
|
+
* Connection 2.1 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
|
|
488
|
+
* If signer B completed signConvertStep1, then this step is completed by signer A.
|
|
489
|
+
* @param {SignConvert} shares
|
|
490
|
+
* @returns {SignConvertRT}
|
|
491
|
+
*/
|
|
492
|
+
async signConvertStep2(shares) {
|
|
493
|
+
const receivedAShare = shares.aShare;
|
|
494
|
+
if (!receivedAShare.gammaProof) {
|
|
495
|
+
throw new Error('Unexpected missing gammaProof on aShareToBeSent');
|
|
496
|
+
}
|
|
497
|
+
if (!receivedAShare.wProof) {
|
|
498
|
+
throw new Error('Unexpected missing wProof on aShareToBeSent');
|
|
499
|
+
}
|
|
500
|
+
const n = sdk_lib_mpc_1.hexToBigInt(receivedAShare.n); // Paillier pub from other signer
|
|
501
|
+
// current participant public key
|
|
502
|
+
const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(shares.wShare.n));
|
|
503
|
+
const ntildea = sdk_lib_mpc_1.hexToBigInt(shares.wShare.ntilde);
|
|
504
|
+
const h1a = sdk_lib_mpc_1.hexToBigInt(shares.wShare.h1);
|
|
505
|
+
const h2a = sdk_lib_mpc_1.hexToBigInt(shares.wShare.h2);
|
|
506
|
+
const ck = sdk_lib_mpc_1.hexToBigInt(shares.wShare.ck);
|
|
507
|
+
const shareParticipantPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallenge({ p: shares.wShare.p });
|
|
508
|
+
const receivedPaillierChallengeProof = sdk_lib_mpc_1.EcdsaTypes.deserializePaillierChallengeProofs({
|
|
509
|
+
sigma: shares.aShare.sigma,
|
|
510
|
+
});
|
|
511
|
+
if (!sdk_lib_mpc_1.EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma)) {
|
|
512
|
+
throw new Error('could not verify signing share for paillier proof');
|
|
513
|
+
}
|
|
514
|
+
// Verify $\gamma_i \in Z_{N^2}$.
|
|
515
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
516
|
+
ntilde: ntildea,
|
|
517
|
+
h1: h1a,
|
|
518
|
+
h2: h2a,
|
|
519
|
+
}, {
|
|
520
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.z),
|
|
521
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.zprm),
|
|
522
|
+
t: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t),
|
|
523
|
+
v: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.v),
|
|
524
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.w),
|
|
525
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s),
|
|
526
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s1),
|
|
527
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.s2),
|
|
528
|
+
t1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t1),
|
|
529
|
+
t2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.t2),
|
|
530
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.u),
|
|
531
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(receivedAShare.alpha), sdk_lib_mpc_1.hexToBigInt(receivedAShare.gammaProof.x))) {
|
|
532
|
+
throw new Error('could not verify signing share for gamma proof');
|
|
533
|
+
}
|
|
534
|
+
// Verify $\w_i \in Z_{N^2}$.
|
|
535
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
536
|
+
ntilde: ntildea,
|
|
537
|
+
h1: h1a,
|
|
538
|
+
h2: h2a,
|
|
539
|
+
}, {
|
|
540
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.z),
|
|
541
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.zprm),
|
|
542
|
+
t: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t),
|
|
543
|
+
v: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.v),
|
|
544
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.w),
|
|
545
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s),
|
|
546
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s1),
|
|
547
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.s2),
|
|
548
|
+
t1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t1),
|
|
549
|
+
t2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.t2),
|
|
550
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.u),
|
|
551
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(receivedAShare.mu), sdk_lib_mpc_1.hexToBigInt(receivedAShare.wProof.x))) {
|
|
552
|
+
throw new Error('could not verify share for wProof');
|
|
553
|
+
}
|
|
554
|
+
const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(shares.wShare.l), sdk_lib_mpc_1.hexToBigInt(shares.wShare.m), pka);
|
|
555
|
+
const gShareAlpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedAShare.alpha))), 32).toString('hex');
|
|
556
|
+
const gShareMu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedAShare.mu))), // recheck encrypted number
|
|
557
|
+
32).toString('hex');
|
|
558
|
+
if (!receivedAShare.proof) {
|
|
559
|
+
throw new Error('Unexpected missing proof on aShareToBeSent');
|
|
560
|
+
}
|
|
561
|
+
const pkb = util_1.getPaillierPublicKey(n);
|
|
562
|
+
const ntildeb = sdk_lib_mpc_1.hexToBigInt(receivedAShare.ntilde);
|
|
563
|
+
const h1b = sdk_lib_mpc_1.hexToBigInt(receivedAShare.h1);
|
|
564
|
+
const h2b = sdk_lib_mpc_1.hexToBigInt(receivedAShare.h2);
|
|
565
|
+
const k = sdk_lib_mpc_1.hexToBigInt(receivedAShare.k);
|
|
566
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
|
|
567
|
+
ntilde: ntildea,
|
|
568
|
+
h1: h1a,
|
|
569
|
+
h2: h2a,
|
|
570
|
+
}, {
|
|
571
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.z),
|
|
572
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.u),
|
|
573
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.w),
|
|
574
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s),
|
|
575
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s1),
|
|
576
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedAShare.proof.s2),
|
|
577
|
+
}, k)) {
|
|
578
|
+
throw new Error('Could not verify signing A share proof');
|
|
579
|
+
}
|
|
580
|
+
// MtA $k_j, \gamma_i$.
|
|
581
|
+
const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
582
|
+
const gShareBeta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
|
|
583
|
+
const g = sdk_lib_mpc_1.hexToBigInt(shares.wShare.gamma);
|
|
584
|
+
const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pkb.n);
|
|
585
|
+
const cb = pkb.encrypt(beta0, rb);
|
|
586
|
+
const alpha = pkb.addition(pkb.multiply(k, g), cb);
|
|
587
|
+
const alphaToBeSent = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
|
|
588
|
+
// Prove $\gamma_i \in Z_{N^2}$.
|
|
589
|
+
const gx = Ecdsa.curve.basePointMult(g);
|
|
590
|
+
let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
|
|
591
|
+
ntilde: ntildeb,
|
|
592
|
+
h1: h1b,
|
|
593
|
+
h2: h2b,
|
|
594
|
+
}, k, alpha, g, beta0, rb, gx);
|
|
595
|
+
const gammaProofToBeSent = {
|
|
596
|
+
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
597
|
+
zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
|
|
598
|
+
t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
|
|
599
|
+
v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
|
|
600
|
+
w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
|
|
601
|
+
s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
|
|
602
|
+
s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
|
|
603
|
+
s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
|
|
604
|
+
t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
|
|
605
|
+
t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
|
|
606
|
+
u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
|
|
607
|
+
x: util_1.bigIntToBufferBE(gx, 33).toString('hex'),
|
|
608
|
+
};
|
|
609
|
+
// MtA $k_j, w_i$.
|
|
610
|
+
const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
611
|
+
const gShareNu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
|
|
612
|
+
const w = sdk_lib_mpc_1.hexToBigInt(shares.wShare.w);
|
|
613
|
+
const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pkb.n);
|
|
614
|
+
const cn = pkb.encrypt(nu0, rn);
|
|
615
|
+
const mu = pkb.addition(pkb.multiply(k, w), cn);
|
|
616
|
+
const muToBeSent = util_1.bigIntToBufferBE(mu, 32).toString('hex');
|
|
617
|
+
// Prove $\w_i \in Z_{N^2}$.
|
|
618
|
+
const wx = Ecdsa.curve.basePointMult(w);
|
|
619
|
+
proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pkb, {
|
|
620
|
+
ntilde: ntildeb,
|
|
621
|
+
h1: h1b,
|
|
622
|
+
h2: h2b,
|
|
623
|
+
}, k, sdk_lib_mpc_1.hexToBigInt(muToBeSent), w, nu0, rn, wx);
|
|
624
|
+
const wProofToBeSent = {
|
|
625
|
+
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
626
|
+
zprm: util_1.bigIntToBufferBE(proof.zprm, 384).toString('hex'),
|
|
627
|
+
t: util_1.bigIntToBufferBE(proof.t, 384).toString('hex'),
|
|
628
|
+
v: util_1.bigIntToBufferBE(proof.v, 768).toString('hex'),
|
|
629
|
+
w: util_1.bigIntToBufferBE(proof.w, 384).toString('hex'),
|
|
630
|
+
s: util_1.bigIntToBufferBE(proof.s, 384).toString('hex'),
|
|
631
|
+
s1: util_1.bigIntToBufferBE(proof.s1, 96).toString('hex'),
|
|
632
|
+
s2: util_1.bigIntToBufferBE(proof.s2, 480).toString('hex'),
|
|
633
|
+
t1: util_1.bigIntToBufferBE(proof.t1, 224).toString('hex'),
|
|
634
|
+
t2: util_1.bigIntToBufferBE(proof.t2, 480).toString('hex'),
|
|
635
|
+
u: util_1.bigIntToBufferBE(proof.u, 33).toString('hex'),
|
|
636
|
+
x: util_1.bigIntToBufferBE(wx, 33).toString('hex'),
|
|
637
|
+
};
|
|
638
|
+
const [iToBeSent, jToBeSent] = [receivedAShare.j, receivedAShare.i];
|
|
639
|
+
return {
|
|
640
|
+
muShare: {
|
|
641
|
+
i: iToBeSent,
|
|
642
|
+
j: jToBeSent,
|
|
643
|
+
alpha: alphaToBeSent,
|
|
644
|
+
mu: muToBeSent,
|
|
645
|
+
gammaProof: gammaProofToBeSent,
|
|
646
|
+
wProof: wProofToBeSent,
|
|
647
|
+
},
|
|
648
|
+
gShare: {
|
|
649
|
+
i: shares.wShare.i,
|
|
650
|
+
n: shares.wShare.n,
|
|
651
|
+
y: shares.wShare.y,
|
|
652
|
+
k: shares.wShare.k,
|
|
653
|
+
w: shares.wShare.w,
|
|
654
|
+
gamma: shares.wShare.gamma,
|
|
655
|
+
alpha: gShareAlpha,
|
|
656
|
+
mu: gShareMu,
|
|
657
|
+
beta: gShareBeta,
|
|
658
|
+
nu: gShareNu,
|
|
659
|
+
},
|
|
660
|
+
};
|
|
661
|
+
}
|
|
662
|
+
/**
|
|
663
|
+
* Perform multiplicitive-to-additive (MtA) share conversion with another signer.
|
|
664
|
+
* Connection 2.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#
|
|
665
|
+
* If signer A completed signConvertStep2, then this step is completed by signer B.
|
|
666
|
+
* @param {SignConvert} shares
|
|
667
|
+
* @returns {SignConvertRT}
|
|
668
|
+
*/
|
|
669
|
+
async signConvertStep3(shares) {
|
|
670
|
+
const receivedMuShare = shares.muShare;
|
|
671
|
+
if (!receivedMuShare.gammaProof) {
|
|
672
|
+
throw new Error('Unexpected missing gammaProof on aShareToBeSent');
|
|
673
|
+
}
|
|
674
|
+
if (!receivedMuShare.wProof) {
|
|
675
|
+
throw new Error('Unexpected missing wProof on aShareToBeSent');
|
|
676
|
+
}
|
|
677
|
+
const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(shares.bShare.n));
|
|
678
|
+
const ntildea = sdk_lib_mpc_1.hexToBigInt(shares.bShare.ntilde);
|
|
679
|
+
const h1a = sdk_lib_mpc_1.hexToBigInt(shares.bShare.h1);
|
|
680
|
+
const h2a = sdk_lib_mpc_1.hexToBigInt(shares.bShare.h2);
|
|
681
|
+
const ck = sdk_lib_mpc_1.hexToBigInt(shares.bShare.ck);
|
|
682
|
+
// Verify $\gamma_i \in Z_{N^2}$.
|
|
683
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
684
|
+
ntilde: ntildea,
|
|
685
|
+
h1: h1a,
|
|
686
|
+
h2: h2a,
|
|
687
|
+
}, {
|
|
688
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.z),
|
|
689
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.zprm),
|
|
690
|
+
t: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t),
|
|
691
|
+
v: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.v),
|
|
692
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.w),
|
|
693
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s),
|
|
694
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s1),
|
|
695
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.s2),
|
|
696
|
+
t1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t1),
|
|
697
|
+
t2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.t2),
|
|
698
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.u),
|
|
699
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(receivedMuShare.alpha), sdk_lib_mpc_1.hexToBigInt(receivedMuShare.gammaProof.x))) {
|
|
700
|
+
throw new Error('could not verify signing share for gamma proof');
|
|
701
|
+
}
|
|
702
|
+
// Verify $\w_i \in Z_{N^2}$.
|
|
703
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
704
|
+
ntilde: ntildea,
|
|
705
|
+
h1: h1a,
|
|
706
|
+
h2: h2a,
|
|
707
|
+
}, {
|
|
708
|
+
z: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.z),
|
|
709
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.zprm),
|
|
710
|
+
t: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t),
|
|
711
|
+
v: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.v),
|
|
712
|
+
w: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.w),
|
|
713
|
+
s: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s),
|
|
714
|
+
s1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s1),
|
|
715
|
+
s2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.s2),
|
|
716
|
+
t1: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t1),
|
|
717
|
+
t2: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.t2),
|
|
718
|
+
u: sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.u),
|
|
719
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(receivedMuShare.mu), sdk_lib_mpc_1.hexToBigInt(receivedMuShare.wProof.x))) {
|
|
720
|
+
throw new Error('could not verify share for wProof');
|
|
721
|
+
}
|
|
722
|
+
const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(shares.bShare.l), sdk_lib_mpc_1.hexToBigInt(shares.bShare.m), pka);
|
|
723
|
+
const alpha = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedMuShare.alpha));
|
|
724
|
+
const gShareAlpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');
|
|
725
|
+
const mu = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(receivedMuShare.mu)); // recheck encrypted number
|
|
726
|
+
const gShareMu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');
|
|
727
|
+
const [iToBeSent, jToBeSent] = [receivedMuShare.j, receivedMuShare.i];
|
|
728
|
+
return {
|
|
729
|
+
gShare: {
|
|
730
|
+
i: shares.bShare.i,
|
|
731
|
+
n: shares.bShare.n,
|
|
732
|
+
y: shares.bShare.y,
|
|
733
|
+
k: shares.bShare.k,
|
|
734
|
+
w: shares.bShare.w,
|
|
735
|
+
gamma: shares.bShare.gamma,
|
|
736
|
+
alpha: gShareAlpha,
|
|
737
|
+
mu: gShareMu,
|
|
738
|
+
beta: shares.bShare.beta,
|
|
739
|
+
nu: shares.bShare.nu,
|
|
740
|
+
},
|
|
741
|
+
signIndex: {
|
|
742
|
+
i: iToBeSent,
|
|
743
|
+
j: jToBeSent,
|
|
744
|
+
},
|
|
745
|
+
};
|
|
746
|
+
}
|
|
747
|
+
/**
|
|
748
|
+
* Perform multiplicitive-to-additive (MtA) share conversion with another signer.
|
|
749
|
+
* @deprecated - use one of [signConvertStep1, signConvertStep2, signConvertStep3] instead
|
|
750
|
+
* @param {SignConvert} shares
|
|
349
751
|
* @returns {SignConvertRT}
|
|
350
752
|
*/
|
|
351
753
|
async signConvert(shares) {
|
|
@@ -359,6 +761,7 @@ class Ecdsa {
|
|
|
359
761
|
ntilde: shares.kShare.ntilde,
|
|
360
762
|
h1: shares.kShare.h1,
|
|
361
763
|
h2: shares.kShare.h2,
|
|
764
|
+
p: shares.kShare.p,
|
|
362
765
|
};
|
|
363
766
|
const signShare = await this.signShare(xShare, yShare);
|
|
364
767
|
kShare = signShare.kShare;
|
|
@@ -379,60 +782,66 @@ class Ecdsa {
|
|
|
379
782
|
if (shareToBeSent.alpha) {
|
|
380
783
|
const bShareParticipant = shareParticipant;
|
|
381
784
|
const aShareToBeSent = shareToBeSent;
|
|
382
|
-
|
|
785
|
+
if (!aShareToBeSent.gammaProof) {
|
|
786
|
+
throw new Error('Unexpected missing gammaProof on aShareToBeSent');
|
|
787
|
+
}
|
|
788
|
+
if (!aShareToBeSent.wProof) {
|
|
789
|
+
throw new Error('Unexpected missing wProof on aShareToBeSent');
|
|
790
|
+
}
|
|
791
|
+
const pka = util_1.getPaillierPublicKey(sdk_lib_mpc_1.hexToBigInt(bShareParticipant.n));
|
|
383
792
|
let ntildea, h1a, h2a, ck;
|
|
384
793
|
if (bShareParticipant.ntilde) {
|
|
385
|
-
ntildea =
|
|
386
|
-
h1a =
|
|
387
|
-
h2a =
|
|
388
|
-
ck =
|
|
794
|
+
ntildea = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ntilde);
|
|
795
|
+
h1a = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h1);
|
|
796
|
+
h2a = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h2);
|
|
797
|
+
ck = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ck);
|
|
389
798
|
}
|
|
390
799
|
// Verify $\gamma_i \in Z_{N^2}$.
|
|
391
|
-
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve,
|
|
800
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
392
801
|
ntilde: ntildea,
|
|
393
802
|
h1: h1a,
|
|
394
803
|
h2: h2a,
|
|
395
804
|
}, {
|
|
396
|
-
z:
|
|
397
|
-
zprm:
|
|
398
|
-
t:
|
|
399
|
-
v:
|
|
400
|
-
w:
|
|
401
|
-
s:
|
|
402
|
-
s1:
|
|
403
|
-
s2:
|
|
404
|
-
t1:
|
|
405
|
-
t2:
|
|
406
|
-
u:
|
|
407
|
-
}, ck,
|
|
805
|
+
z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.z),
|
|
806
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.zprm),
|
|
807
|
+
t: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t),
|
|
808
|
+
v: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.v),
|
|
809
|
+
w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.w),
|
|
810
|
+
s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s),
|
|
811
|
+
s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s1),
|
|
812
|
+
s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.s2),
|
|
813
|
+
t1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t1),
|
|
814
|
+
t2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.t2),
|
|
815
|
+
u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.u),
|
|
816
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.alpha), sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.gammaProof.x))) {
|
|
408
817
|
throw new Error('could not verify signing share for gamma proof');
|
|
409
818
|
}
|
|
410
819
|
// Verify $\w_i \in Z_{N^2}$.
|
|
411
|
-
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve,
|
|
820
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verifyWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
412
821
|
ntilde: ntildea,
|
|
413
822
|
h1: h1a,
|
|
414
823
|
h2: h2a,
|
|
415
824
|
}, {
|
|
416
|
-
z:
|
|
417
|
-
zprm:
|
|
418
|
-
t:
|
|
419
|
-
v:
|
|
420
|
-
w:
|
|
421
|
-
s:
|
|
422
|
-
s1:
|
|
423
|
-
s2:
|
|
424
|
-
t1:
|
|
425
|
-
t2:
|
|
426
|
-
u:
|
|
427
|
-
}, ck,
|
|
825
|
+
z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.z),
|
|
826
|
+
zprm: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.zprm),
|
|
827
|
+
t: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t),
|
|
828
|
+
v: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.v),
|
|
829
|
+
w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.w),
|
|
830
|
+
s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s),
|
|
831
|
+
s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s1),
|
|
832
|
+
s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.s2),
|
|
833
|
+
t1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t1),
|
|
834
|
+
t2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.t2),
|
|
835
|
+
u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.u),
|
|
836
|
+
}, ck, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu), sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.wProof.x))) {
|
|
428
837
|
throw new Error('could not verify share for wProof');
|
|
429
838
|
}
|
|
430
|
-
const sk = new paillierBigint.PrivateKey(
|
|
839
|
+
const sk = new paillierBigint.PrivateKey(sdk_lib_mpc_1.hexToBigInt(bShareParticipant.l), sdk_lib_mpc_1.hexToBigInt(bShareParticipant.m), pka);
|
|
431
840
|
const gShareParticipant = shareParticipant;
|
|
432
841
|
const muShareToBeSent = shareToBeSent;
|
|
433
|
-
const alpha = sk.decrypt(
|
|
842
|
+
const alpha = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.alpha));
|
|
434
843
|
gShareParticipant.alpha = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');
|
|
435
|
-
const mu = sk.decrypt(
|
|
844
|
+
const mu = sk.decrypt(sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu)); // recheck encrypted number
|
|
436
845
|
gShareParticipant.mu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');
|
|
437
846
|
const partialShareParticipant = shareParticipant;
|
|
438
847
|
const partialShareToBeSent = muShareToBeSent;
|
|
@@ -444,43 +853,43 @@ class Ecdsa {
|
|
|
444
853
|
if (shareToBeSent.k) {
|
|
445
854
|
const bShareParticipant = shareParticipant;
|
|
446
855
|
const aShareToBeSent = shareToBeSent;
|
|
447
|
-
|
|
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);
|
|
856
|
+
if (!aShareToBeSent.proof) {
|
|
857
|
+
throw new Error('Unexpected missing proof on aShareToBeSent');
|
|
457
858
|
}
|
|
458
|
-
const
|
|
459
|
-
|
|
859
|
+
const n = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer
|
|
860
|
+
const pka = util_1.getPaillierPublicKey(n);
|
|
861
|
+
const ntildea = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.ntilde);
|
|
862
|
+
const h1a = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.h1);
|
|
863
|
+
const h2a = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.h2);
|
|
864
|
+
const ntildeb = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.ntilde);
|
|
865
|
+
const h1b = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h1);
|
|
866
|
+
const h2b = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.h2);
|
|
867
|
+
const k = sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.k);
|
|
868
|
+
if (!sdk_lib_mpc_1.EcdsaRangeProof.verify(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
460
869
|
ntilde: ntildeb,
|
|
461
870
|
h1: h1b,
|
|
462
871
|
h2: h2b,
|
|
463
872
|
}, {
|
|
464
|
-
z:
|
|
465
|
-
u:
|
|
466
|
-
w:
|
|
467
|
-
s:
|
|
468
|
-
s1:
|
|
469
|
-
s2:
|
|
873
|
+
z: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.z),
|
|
874
|
+
u: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.u),
|
|
875
|
+
w: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.w),
|
|
876
|
+
s: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s),
|
|
877
|
+
s1: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s1),
|
|
878
|
+
s2: sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.proof.s2),
|
|
470
879
|
}, k)) {
|
|
471
880
|
throw new Error('Could not verify signing A share proof');
|
|
472
881
|
}
|
|
473
882
|
// MtA $k_j, \gamma_i$.
|
|
474
883
|
const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
475
884
|
bShareParticipant.beta = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');
|
|
476
|
-
const g =
|
|
477
|
-
const rb = await sdk_lib_mpc_1.
|
|
885
|
+
const g = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.gamma);
|
|
886
|
+
const rb = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
|
|
478
887
|
const cb = pka.encrypt(beta0, rb);
|
|
479
888
|
const alpha = pka.addition(pka.multiply(k, g), cb);
|
|
480
889
|
aShareToBeSent.alpha = util_1.bigIntToBufferBE(alpha, 32).toString('hex');
|
|
481
890
|
// Prove $\gamma_i \in Z_{N^2}$.
|
|
482
891
|
const gx = Ecdsa.curve.basePointMult(g);
|
|
483
|
-
let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve,
|
|
892
|
+
let proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
484
893
|
ntilde: ntildea,
|
|
485
894
|
h1: h1a,
|
|
486
895
|
h2: h2a,
|
|
@@ -504,18 +913,18 @@ class Ecdsa {
|
|
|
504
913
|
// MtA $k_j, w_i$.
|
|
505
914
|
const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);
|
|
506
915
|
shareParticipant.nu = util_1.bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');
|
|
507
|
-
const w =
|
|
508
|
-
const rn = await sdk_lib_mpc_1.
|
|
916
|
+
const w = sdk_lib_mpc_1.hexToBigInt(bShareParticipant.w);
|
|
917
|
+
const rn = await sdk_lib_mpc_1.randomPositiveCoPrimeTo(pka.n);
|
|
509
918
|
const cn = pka.encrypt(nu0, rn);
|
|
510
919
|
const mu = pka.addition(pka.multiply(k, w), cn);
|
|
511
920
|
shareToBeSent.mu = util_1.bigIntToBufferBE(mu, 32).toString('hex');
|
|
512
921
|
// Prove $\w_i \in Z_{N^2}$.
|
|
513
922
|
const wx = Ecdsa.curve.basePointMult(w);
|
|
514
|
-
proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve,
|
|
923
|
+
proof = await sdk_lib_mpc_1.EcdsaRangeProof.proveWithCheck(Ecdsa.curve, sdk_lib_mpc_1.minModulusBitLength, pka, {
|
|
515
924
|
ntilde: ntildea,
|
|
516
925
|
h1: h1a,
|
|
517
926
|
h2: h2a,
|
|
518
|
-
}, k,
|
|
927
|
+
}, k, sdk_lib_mpc_1.hexToBigInt(aShareToBeSent.mu), w, nu0, rn, wx);
|
|
519
928
|
Object.assign(shareToBeSent, {
|
|
520
929
|
wProof: {
|
|
521
930
|
z: util_1.bigIntToBufferBE(proof.z, 384).toString('hex'),
|
|
@@ -589,13 +998,13 @@ class Ecdsa {
|
|
|
589
998
|
signCombine(shares) {
|
|
590
999
|
const gShare = shares.gShare;
|
|
591
1000
|
const S = shares.signIndex;
|
|
592
|
-
const gamma =
|
|
593
|
-
const alpha =
|
|
594
|
-
const beta =
|
|
595
|
-
const mu =
|
|
596
|
-
const nu =
|
|
597
|
-
const k =
|
|
598
|
-
const w =
|
|
1001
|
+
const gamma = sdk_lib_mpc_1.hexToBigInt(gShare.gamma);
|
|
1002
|
+
const alpha = sdk_lib_mpc_1.hexToBigInt(gShare.alpha);
|
|
1003
|
+
const beta = sdk_lib_mpc_1.hexToBigInt(gShare.beta);
|
|
1004
|
+
const mu = sdk_lib_mpc_1.hexToBigInt(gShare.mu);
|
|
1005
|
+
const nu = sdk_lib_mpc_1.hexToBigInt(gShare.nu);
|
|
1006
|
+
const k = sdk_lib_mpc_1.hexToBigInt(gShare.k);
|
|
1007
|
+
const w = sdk_lib_mpc_1.hexToBigInt(gShare.w);
|
|
599
1008
|
const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));
|
|
600
1009
|
const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));
|
|
601
1010
|
const Gamma = Ecdsa.curve.basePointMult(gamma);
|
|
@@ -627,11 +1036,11 @@ class Ecdsa {
|
|
|
627
1036
|
*/
|
|
628
1037
|
sign(M, oShare, dShare, hash, shouldHash = true) {
|
|
629
1038
|
const m = shouldHash ? (hash || crypto_1.createHash('sha256')).update(M).digest() : M;
|
|
630
|
-
const delta = Ecdsa.curve.scalarAdd(
|
|
631
|
-
const R = Ecdsa.curve.pointMultiply(Ecdsa.curve.pointAdd(
|
|
1039
|
+
const delta = Ecdsa.curve.scalarAdd(sdk_lib_mpc_1.hexToBigInt(oShare.delta), sdk_lib_mpc_1.hexToBigInt(dShare.delta));
|
|
1040
|
+
const R = Ecdsa.curve.pointMultiply(Ecdsa.curve.pointAdd(sdk_lib_mpc_1.hexToBigInt(oShare.Gamma), sdk_lib_mpc_1.hexToBigInt(dShare.Gamma)), Ecdsa.curve.scalarInvert(delta));
|
|
632
1041
|
const pointR = secp.Point.fromHex(util_1.bigIntToBufferBE(R, 32));
|
|
633
1042
|
const r = pointR.x;
|
|
634
|
-
const s = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(util_1.bigIntFromU8ABE(m),
|
|
1043
|
+
const s = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(util_1.bigIntFromU8ABE(m), sdk_lib_mpc_1.hexToBigInt(oShare.k)), Ecdsa.curve.scalarMult(r, sdk_lib_mpc_1.hexToBigInt(oShare.omicron)));
|
|
635
1044
|
return {
|
|
636
1045
|
i: oShare.i,
|
|
637
1046
|
y: oShare.y,
|
|
@@ -651,7 +1060,7 @@ class Ecdsa {
|
|
|
651
1060
|
if (!isRMatching) {
|
|
652
1061
|
throw new Error('R value should be consistent across all shares');
|
|
653
1062
|
}
|
|
654
|
-
let s = shares.map((share) =>
|
|
1063
|
+
let s = shares.map((share) => sdk_lib_mpc_1.hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);
|
|
655
1064
|
const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);
|
|
656
1065
|
// Normalize s.
|
|
657
1066
|
s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;
|
|
@@ -674,9 +1083,9 @@ class Ecdsa {
|
|
|
674
1083
|
const messageToVerify = shouldHash ? (hash || crypto_1.createHash('sha256')).update(message).digest() : message;
|
|
675
1084
|
return Ecdsa.curve.verify(messageToVerify, Buffer.concat([
|
|
676
1085
|
Buffer.from([signature['recid']]),
|
|
677
|
-
util_1.bigIntToBufferBE(
|
|
678
|
-
util_1.bigIntToBufferBE(
|
|
679
|
-
]),
|
|
1086
|
+
util_1.bigIntToBufferBE(sdk_lib_mpc_1.hexToBigInt(signature['r']), 32),
|
|
1087
|
+
util_1.bigIntToBufferBE(sdk_lib_mpc_1.hexToBigInt(signature['s']), 32),
|
|
1088
|
+
]), sdk_lib_mpc_1.hexToBigInt(signature['y']));
|
|
680
1089
|
}
|
|
681
1090
|
/**
|
|
682
1091
|
* Deserializes a challenge and it's proofs from hex strings to bigint
|
|
@@ -696,6 +1105,6 @@ class Ecdsa {
|
|
|
696
1105
|
}
|
|
697
1106
|
exports.default = Ecdsa;
|
|
698
1107
|
Ecdsa.curve = new curves_1.Secp256k1Curve();
|
|
699
|
-
Ecdsa.hdTree = new
|
|
1108
|
+
Ecdsa.hdTree = new sdk_lib_mpc_1.Secp256k1Bip32HdTree();
|
|
700
1109
|
Ecdsa.shamir = new shamir_1.default(Ecdsa.curve);
|
|
701
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/account-lib/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,gEAAkD;AAClD,uEAAyD;AACzD,uDAAyC;AACzC,yCAA4D;AAC5D,mCAAuD;AACvD,mDAA6C;AAC7C,iDAAmD;AACnD,qCAAyG;AACzG,yCAA8C;AAC9C,0DAAkC;AAClC,yDAAuF;AA4BvF,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAEtB,SAAS,SAAS,CAAC,KAAsB;IACvC,OAAO,QAAQ,IAAI,KAAK,CAAC;AAC3B,CAAC;AAED;;GAEG;AACH,MAAqB,KAAK;IAIxB;;;;;;;;;OASG;IACH,KAAK,CAAC,QAAQ,CAAC,KAAa,EAAE,SAAiB,EAAE,SAAiB,EAAE,IAAa,EAAE,IAAI,GAAG,KAAK;;QAC7F,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,IAAI,KAAK,IAAI,SAAS,IAAI,SAAS,IAAI,SAAS,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACnF,MAAM,yBAAyB,CAAC;SACjC;QAED,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,EAAE,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QAED,IAAI,mBAAmB,GAAG,IAAI,CAAC;QAC/B,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,EAAE,EAAE;YAC5B,kEAAkE;YAClE,mBAAmB,GAAG,mBAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAClE;QAED,kDAAkD;QAClD,IAAI,eAAuC,CAAC;QAC5C,IAAI,CAAC,IAAI,EAAE;YACT,eAAe,GAAG,MAAM,cAAc,CAAC,kBAAkB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SACvE;aAAM;YACL,eAAe,GAAG,cAAc,CAAC,sBAAsB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SACrE;QACD,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,eAAe,CAAC;QAClD,0EAA0E;QAC1E,MAAM,SAAS,GAAG,mBAAmB,IAAI,gBAAK,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;QAC7E,MAAM,CAAC,GACL,MAAA,CAAC,SAAS,IAAI,SAAS,CAAC,UAAU,IAAI,sBAAe,CAAC,IAAI,UAAU,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,mCAC5F,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC7B,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,SAAS,GAAG,MAAA,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,CAAC,mCAAI,oBAAW,CAAC,EAAE,CAAC,CAAC;QACxE,2CAA2C;QAC3C,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;QAC3E,MAAM,kBAAkB,GAAW;YACjC,CAAC,EAAE,KAAK;YACR,CAAC,EAAE,SAAS;YACZ,CAAC,EAAE,SAAS;YACZ,CAAC,EAAE,uBAAgB,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC3D,CAAC,EAAE,uBAAgB,CAAC,UAAU,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACvD,CAAC,EAAE,uBAAgB,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACrD,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC1C,CAAC,EAAE,uBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACvD,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE;YAChB,SAAS,EAAE,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC;SACrC,CAAC;QACF,MAAM,QAAQ,GAAa;YACzB,MAAM,EAAE,kBAAkB;YAC1B,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,MAAM,gBAAgB,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAC7C,IAAI,gBAAgB,KAAK,KAAK,EAAE;gBAC9B,QAAQ,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG;oBACnC,CAAC,EAAE,gBAAgB;oBACnB,CAAC,EAAE,kBAAkB,CAAC,GAAG,CAAC;oBAC1B,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC3B,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAC1C,CAAC,EAAE,uBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAC7C,CAAC,EAAE,uBAAgB,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAClE,SAAS,EAAE,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC;iBAC3B,CAAC;aACb;SACF;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;;;OAMG;IACH,UAAU,CAAC,MAAc,EAAE,OAAiB;QAC1C,MAAM,SAAS,GAAG,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC;QACvC,0BAA0B;QAC1B,MAAM,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,oBAAW,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACrG,oBAAoB;QACpB,MAAM,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,oBAAW,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAEtG,iBAAiB;QACjB,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,IAAI,KAAK,CAAC,CAAC,EAAE;gBACX,IAAI;oBACF,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,oBAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,oBAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,oBAAW,CAAC,KAAK,CAAC,CAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;iBACpG;gBAAC,OAAO,GAAG,EAAE;oBACZ,MAAM,IAAI,KAAK,CAAC,2CAA2C,KAAK,CAAC,CAAC,yBAAyB,GAAG,EAAE,CAAC,CAAC;iBACnG;aACF;SACF;QAED,oFAAoF;QACpF,MAAM,UAAU,GAAG,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,yBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QAClH,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,CACjC,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,CACjB,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,MAAM,CAAC,sEAAsE,CAAC,CAAC,QAAQ;SAC9G,CAAC;QAEF,MAAM,YAAY,GAAgB;YAChC,MAAM,EAAE;gBACN,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC1C,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC1C,SAAS,EAAE,uBAAgB,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;aAC3D;YACD,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,MAAM,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;YAC7C,YAAY,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG;gBACvC,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;gBACtB,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;aACvB,CAAC;SACH;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;;;;;;OAOG;IACH,SAAS,CAAC,MAAc,EAAE,OAAiB,EAAE,IAAY;QACvD,MAAM,OAAO,GAAG,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,oBAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;QACnF,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5B,IAAI,gBAAgB,GAAG,oBAAW,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACrD,MAAM,UAAU,GAAG,CAAC,gBAAgB,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,oBAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjG,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,sBAAa,CAAC,CAAC;QAE3F,iBAAiB;QACjB,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;YAC3B,IAAI,KAAK,CAAC,CAAC,EAAE;gBACX,IAAI;oBACF,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,oBAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,oBAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,oBAAW,CAAC,KAAK,CAAC,CAAE,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;iBACpG;gBAAC,OAAO,GAAG,EAAE;oBACZ,MAAM,IAAI,KAAK,CAAC,2CAA2C,KAAK,CAAC,CAAC,yBAAyB,GAAG,EAAE,CAAC,CAAC;iBACnG;aACF;SACF;QAED,iBAAiB;QACjB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,IAAI,CAAC,CAAC;QAE7E,yCAAyC;QACzC,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAEtD,wCAAwC;QACxC,MAAM,cAAc,GAAG,CAAC,sBAAa,GAAG,MAAM,CAAC,SAAS,GAAG,SAAS,CAAC,GAAG,sBAAa,CAAC;QACtF,gBAAgB,GAAG,CAAC,gBAAgB,GAAG,cAAc,CAAC,GAAG,sBAAa,CAAC;QAEvE,0BAA0B;QAC1B,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAE3F,6BAA6B;QAC7B,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,oBAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAEvG,MAAM,GAAG,GAAW;YAClB,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,uBAAgB,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAClD,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC1C,SAAS,EAAE,uBAAgB,CAAC,MAAM,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SAClE,CAAC;QAEF,MAAM,MAAM,GAAgB;YAC1B,MAAM,EAAE,GAAG;YACX,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;YAC7C,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;YACzB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;gBACtB,CAAC,EAAE,GAAG,CAAC,CAAC;gBACR,CAAC,EAAE,GAAG,CAAC,CAAC;gBACR,CAAC,EAAE,GAAG,CAAC,CAAC;gBACR,CAAC,EAAE,uBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACvD,CAAC,EAAE,uBAAgB,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACjD,CAAC,EAAE,uBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC7C,SAAS,EAAE,uBAAgB,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;aAClE,CAAC;SACH;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IACH,gBAAgB,CAAC,cAAsB,EAAE,IAAY;QACnD,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QAED,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAEpD,MAAM,qBAAqB,GAAG,KAAK,CAAC,MAAM,CAAC,YAAY,CACrD;YACE,EAAE,EAAE,yBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC7C,SAAS,EAAE,yBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;SAClD,EACD,IAAI,CACL,CAAC;QAEF,MAAM,SAAS,GAAG,uBAAgB,CAAC,qBAAqB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACjF,MAAM,gBAAgB,GAAG,uBAAgB,CAAC,qBAAqB,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAE/F,OAAO,SAAS,GAAG,gBAAgB,CAAC;IACtC,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,eAAe,CACnB,MAAc,EACd,MAAc,EACd,SAAuC;QAEvC,IAAI,CAAC,SAAS,EAAE;YACd,SAAS,GAAG,wBAAU,CAAC,eAAe,CAAC,MAAM,6BAAe,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;SACpF;QACD,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,SAAS,CAAC;QACrC,OAAO;YACL,MAAM,EAAE,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE;YACrC,OAAO,EAAE;gBACP,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;oBACV,CAAC,EAAE,MAAM,CAAC,CAAC;oBACX,CAAC,EAAE,MAAM,CAAC,CAAC;oBACX,CAAC,EAAE,MAAM,CAAC,CAAC;oBACX,MAAM;oBACN,EAAE;oBACF,EAAE;iBACH;aACF;SACF,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,SAAS,CAAC,MAAiC,EAAE,MAAwB;QACzE,MAAM,EAAE,GAAG,2BAAoB,CAAC,oBAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAEvD,+DAA+D;QAC/D,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACtB,MAAM,GAAG,CAAC,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;SAC9D;QAED,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QACrC,MAAM,EAAE,GAAG,MAAM,6BAAe,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAEzC,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9G,MAAM,CAAC,GAAG;YACR,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC1D,oBAAW,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACxB,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;SAC5B,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAEjC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,MAA0B,CAAC;QAEzE,MAAM,OAAO,GAAgB;YAC3B,MAAM,EAAE;gBACN,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;gBACP,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC1C,EAAE,EAAE,uBAAgB,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC7C,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC1C,KAAK,EAAE,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;aACnD;YACD,MAAM,EAAE,EAAY;SACrB,CAAC;QAEF,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,MAAM,CAAC;QACrD,MAAM,KAAK,GAAG,MAAM,6BAAe,CAAC,KAAK,CACvC,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,EAAE,EACF;YACE,MAAM,EAAE,oBAAW,CAAC,OAAO,CAAC;YAC5B,EAAE,EAAE,oBAAW,CAAC,GAAG,CAAC;YACpB,EAAE,EAAE,oBAAW,CAAC,GAAG,CAAC;SACrB,EACD,EAAE,EACF,CAAC,EACD,EAAE,CACH,CAAC;QACF,MAAM,UAAU,GAAG;YACjB,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YACjD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAClD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SACpD,CAAC;QAEF,OAAO,CAAC,MAAM,GAAG;YACf,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;YACpB,MAAM,EAAE,OAAO;YACf,EAAE,EAAE,GAAG;YACP,EAAE,EAAE,GAAG;YACP,CAAC,EAAE,uBAAgB,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC5C,KAAK,EAAE,UAAU;SAClB,CAAC;QAEF,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,MAAmB;QACnC,IAAI,gBAAmD,EAAE,aAAwC,CAAC;QAClG,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,MAAM,GAAoB,EAAE,CAAC;QACjC,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE;YACnD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,mCAAmC;YACjE,MAAM,MAAM,GAAG;gBACb,GAAG,MAAM,CAAC,MAAM;gBAChB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM;gBAC5B,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE;gBACpB,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE;aACrB,CAAC;YACF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YACvD,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;YAC1B,aAAa,GAAG,EAAE,GAAG,MAAM,CAAC,MAAM,EAAqB,CAAC;YACxD,gBAAgB,GAAG,EAAE,GAAG,SAAS,CAAC,MAAM,EAAqB,CAAC;SAC/D;aAAM,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,EAAE;YAChF,YAAY,GAAG,IAAI,CAAC;YACpB,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAE,EAAE,GAAG,MAAM,CAAC,MAAM,EAAc,CAAC,CAAC,CAAE,EAAE,GAAG,MAAM,CAAC,OAAO,EAAc,CAAC;YACvG,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAE,EAAE,GAAG,MAAM,CAAC,MAAM,EAAsB,CAAC,CAAC,CAAE,EAAE,GAAG,MAAM,CAAC,MAAM,EAAa,CAAC;SACjH;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;SACpD;QACD,IAAI,gBAAgB,CAAC,CAAC,KAAK,aAAa,CAAC,CAAC,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;SACjD;QACD,IAAK,aAAwB,CAAC,KAAK,EAAE;YACnC,MAAM,iBAAiB,GAAG,gBAA0B,CAAC;YACrD,MAAM,cAAc,GAAG,aAAuB,CAAC;YAC/C,MAAM,GAAG,GAAG,2BAAoB,CAAC,oBAAW,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;YACnE,IAAI,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC;YAC1B,IAAI,iBAAiB,CAAC,MAAM,EAAE;gBAC5B,OAAO,GAAG,oBAAW,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBAChD,GAAG,GAAG,oBAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;gBACxC,GAAG,GAAG,oBAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;gBACxC,EAAE,GAAG,oBAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;aACxC;YACD,iCAAiC;YACjC,IACE,CAAC,6BAAe,CAAC,eAAe,CAC9B,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,GAAG,EACH;gBACE,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;aACR,EACD;gBACE,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC3C,IAAI,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC;gBACjD,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC3C,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC3C,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC3C,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC3C,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7C,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7C,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7C,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC7C,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;aAC5C,EACD,EAAE,EACF,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,EACjC,oBAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CACzC,EACD;gBACA,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;aACnE;YACD,6BAA6B;YAC7B,IACE,CAAC,6BAAe,CAAC,eAAe,CAC9B,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,GAAG,EACH;gBACE,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;aACR,EACD;gBACE,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;gBACvC,IAAI,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC;gBAC7C,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;gBACvC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;gBACvC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;gBACvC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;gBACvC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;aACxC,EACD,EAAE,EACF,oBAAW,CAAC,cAAc,CAAC,EAAE,CAAC,EAC9B,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CACrC,EACD;gBACA,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;aACtD;YACD,MAAM,EAAE,GAAG,IAAI,cAAc,CAAC,UAAU,CACtC,oBAAW,CAAC,iBAAiB,CAAC,CAAW,CAAC,EAC1C,oBAAW,CAAC,iBAAiB,CAAC,CAAW,CAAC,EAC1C,GAAG,CACJ,CAAC;YACF,MAAM,iBAAiB,GAAG,gBAA0B,CAAC;YACrD,MAAM,eAAe,GAAG,aAAwB,CAAC;YACjD,MAAM,KAAK,GAAG,EAAE,CAAC,OAAO,CAAC,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;YAC5D,iBAAiB,CAAC,KAAK,GAAG,uBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAChG,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,oBAAW,CAAC,cAAc,CAAC,EAAY,CAAC,CAAC,CAAC,CAAC,2BAA2B;YAC5F,iBAAiB,CAAC,EAAE,GAAG,uBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC1F,MAAM,uBAAuB,GAAG,gBAAmC,CAAC;YACpE,MAAM,oBAAoB,GAAG,eAAmC,CAAC;YACjE,OAAO,uBAAuB,CAAC,CAAC,CAAC;YACjC,OAAO,uBAAuB,CAAC,CAAC,CAAC;YACjC,OAAO,oBAAoB,CAAC,KAAK,CAAC;YAClC,OAAO,oBAAoB,CAAC,EAAE,CAAC;SAChC;QACD,IAAK,aAAwB,CAAC,CAAC,EAAE;YAC/B,MAAM,iBAAiB,GAAG,gBAA0B,CAAC;YACrD,MAAM,cAAc,GAAG,aAAuB,CAAC;YAC/C,MAAM,CAAC,GAAG,oBAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,iCAAiC;YAC1E,MAAM,GAAG,GAAG,2BAAoB,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,CAAC;YACzC,IAAI,cAAc,CAAC,MAAM,EAAE;gBACzB,OAAO,GAAG,oBAAW,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;gBAC7C,GAAG,GAAG,oBAAW,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;gBACrC,GAAG,GAAG,oBAAW,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;gBACrC,OAAO,GAAG,oBAAW,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBAChD,GAAG,GAAG,oBAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;gBACxC,GAAG,GAAG,oBAAW,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;aACzC;YACD,MAAM,CAAC,GAAG,oBAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;YACxC,IACE,CAAC,6BAAe,CAAC,MAAM,CACrB,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,GAAG,EACH;gBACE,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;aACR,EACD;gBACE,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtC,CAAC,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxC,EAAE,EAAE,oBAAW,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;aACzC,EACD,CAAC,CACF,EACD;gBACA,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;aAC3D;YACD,uBAAuB;YACvB,MAAM,KAAK,GAAG,iBAAiB,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,CAAC;YACxE,iBAAiB,CAAC,IAAI,GAAG,uBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAC/G,KAAK,CACN,CAAC;YACF,MAAM,CAAC,GAAG,oBAAW,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAC/C,MAAM,EAAE,GAAG,MAAM,6BAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACxC,MAAM,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAClC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACnD,cAAc,CAAC,KAAK,GAAG,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACnE,gCAAgC;YAChC,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YACxC,IAAI,KAAK,GAAG,MAAM,6BAAe,CAAC,cAAc,CAC9C,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,GAAG,EACH;gBACE,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;aACR,EACD,CAAC,EACD,KAAK,EACL,CAAC,EACD,KAAK,EACL,EAAE,EACF,EAAE,CACH,CAAC;YACF,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE;gBAC5B,UAAU,EAAE;oBACV,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,IAAI,EAAE,uBAAgB,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACvD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAClD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAChD,CAAC,EAAE,uBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;iBAC5C;aACF,CAAC,CAAC;YACH,kBAAkB;YAClB,MAAM,GAAG,GAAG,iBAAiB,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,CAAC;YACtE,gBAAgB,CAAC,EAAE,GAAG,uBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAC1G,KAAK,CACN,CAAC;YACF,MAAM,CAAC,GAAG,oBAAW,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC3C,MAAM,EAAE,GAAG,MAAM,6BAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACxC,MAAM,EAAE,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YAChC,MAAM,EAAE,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAChD,aAAa,CAAC,EAAE,GAAG,uBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC5D,4BAA4B;YAC5B,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YACxC,KAAK,GAAG,MAAM,6BAAe,CAAC,cAAc,CAC1C,KAAK,CAAC,KAAK,EACX,IAAI,EACJ,GAAG,EACH;gBACE,MAAM,EAAE,OAAO;gBACf,EAAE,EAAE,GAAG;gBACP,EAAE,EAAE,GAAG;aACR,EACD,CAAC,EACD,oBAAW,CAAC,cAAc,CAAC,EAAE,CAAC,EAC9B,CAAC,EACD,GAAG,EACH,EAAE,EACF,EAAE,CACH,CAAC;YACF,MAAM,CAAC,MAAM,CAAC,aAAa,EAAE;gBAC3B,MAAM,EAAE;oBACN,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,IAAI,EAAE,uBAAgB,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACvD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACjD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAClD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,EAAE,EAAE,uBAAgB,CAAC,KAAK,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACnD,CAAC,EAAE,uBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAChD,CAAC,EAAE,uBAAgB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;iBAC5C;aACF,CAAC,CAAC;YACH,IAAK,gBAA2B,CAAC,KAAK,EAAE;gBACtC,MAAM,uBAAuB,GAAG,gBAAmC,CAAC;gBACpE,MAAM,oBAAoB,GAAG,aAAgC,CAAC;gBAC9D,OAAO,uBAAuB,CAAC,MAAM,CAAC;gBACtC,OAAO,uBAAuB,CAAC,EAAE,CAAC;gBAClC,OAAO,uBAAuB,CAAC,EAAE,CAAC;gBAClC,OAAO,uBAAuB,CAAC,EAAE,CAAC;gBAClC,OAAO,oBAAoB,CAAC,CAAC,CAAC;gBAC9B,OAAO,oBAAoB,CAAC,MAAM,CAAC;gBACnC,OAAO,oBAAoB,CAAC,EAAE,CAAC;gBAC/B,OAAO,oBAAoB,CAAC,EAAE,CAAC;gBAC/B,OAAO,oBAAoB,CAAC,CAAC,CAAC;gBAC9B,OAAO,oBAAoB,CAAC,KAAK,CAAC;aACnC;iBAAM;gBACL,MAAM,CAAC,MAAM,CAAC,aAAa,EAAE;oBAC3B,CAAC,EAAE,MAAM,CAAC,CAAC;oBACX,MAAM,EAAE,uBAAgB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACtD,EAAE,EAAE,uBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAC9C,EAAE,EAAE,uBAAgB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAC9C,CAAC,EAAE,MAAM,CAAC,CAAC;oBACX,KAAK,EAAE,MAAM,CAAC,KAAK;iBACpB,CAAC,CAAC;aACJ;SACF;QACD,IAAI,CAAC,CAAC,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,aAAa,CAAC,EAAE;YAC1D,MAAM,uBAAuB,GAAG,gBAAmC,CAAC;YACpE,OAAO,uBAAuB,CAAC,MAAM,CAAC;YACtC,OAAO,uBAAuB,CAAC,EAAE,CAAC;YAClC,OAAO,uBAAuB,CAAC,EAAE,CAAC;YAClC,OAAO,uBAAuB,CAAC,EAAE,CAAC;YAClC,MAAM,eAAe,GAAG,aAAwB,CAAC;YACjD,aAAa,GAAG;gBACd,CAAC,EAAE,eAAe,CAAC,CAAC;gBACpB,CAAC,EAAE,eAAe,CAAC,CAAC;aACV,CAAC;SACd;QACD,CAAC,aAAa,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;QACxE,IAAI,YAAY,EAAE;YAChB,OAAO;gBACL,OAAO,EAAE,aAAwB;gBACjC,MAAM,EAAE,gBAA0B;aACnC,CAAC;SACH;QACD,OAAO;YACL,MAAM,EAAE,aAAuB;YAC/B,MAAM,EAAE,gBAA0B;SACnC,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,MAAmB;QAC7B,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC7B,MAAM,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC;QAC3B,MAAM,KAAK,GAAG,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,IAAI,GAAG,oBAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACtC,MAAM,EAAE,GAAG,oBAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAClC,MAAM,EAAE,GAAG,oBAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,oBAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,oBAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAEhC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;QAC1G,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACnG,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE/C,OAAO;YACL,MAAM,EAAE;gBACN,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAC1C,OAAO,EAAE,uBAAgB,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACtD,KAAK,EAAE,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAClD,KAAK,EAAE,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;aACnD;YACD,MAAM,EAAE;gBACN,CAAC,EAAE,CAAC,CAAC,CAAC;gBACN,CAAC,EAAE,MAAM,CAAC,CAAC;gBACX,KAAK,EAAE,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAClD,KAAK,EAAE,uBAAgB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;aACnD;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,IAAI,CAAC,CAAS,EAAE,MAAc,EAAE,MAAc,EAAE,IAAW,EAAE,UAAU,GAAG,IAAI;QAC5E,MAAM,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,mBAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAE7E,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QAE1F,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CACjC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,oBAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAC1E,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAChC,CAAC;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;QAEnB,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAC7B,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,sBAAe,CAAC,CAAC,CAAC,EAAE,oBAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EACjE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,EAAE,oBAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CACvD,CAAC;QACF,OAAO;YACL,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,CAAC;YACX,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;YACrB,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;SAC3C,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,kBAAkB,CAAC,MAAgB;QACjC,sBAAsB;QACtB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACzB,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACrF,IAAI,CAAC,WAAW,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QAED,IAAI,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,oBAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACrF,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE/F,eAAe;QACf,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtE,OAAO;YACL,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YACjB,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;YACb,CAAC,EAAE,uBAAgB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC1C,KAAK,EAAE,KAAK;SACb,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,OAAe,EAAE,SAAoB,EAAE,IAAW,EAAE,UAAU,GAAG,IAAI;QAC1E,MAAM,eAAe,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,mBAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;QACvG,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CACvB,eAAe,EACf,MAAM,CAAC,MAAM,CAAC;YACZ,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;YACjC,uBAAgB,CAAC,oBAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC;YACjD,uBAAgB,CAAC,oBAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC;SAClD,CAAC,EACF,oBAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAC5B,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,iBAAiB,CAAC,SAAsC;QAC7D,OAAO,wBAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;IACjD,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,eAAe,CAAC,SAAwC;QAC7D,OAAO,wBAAU,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;;AApxBH,wBAqxBC;AApxBQ,WAAK,GAAmB,IAAI,uBAAc,EAAE,CAAC;AAC7C,YAAM,GAAW,IAAI,cAAK,EAAE,CAAC;AAC7B,YAAM,GAAW,IAAI,gBAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC","sourcesContent":["import * as paillierBigint from 'paillier-bigint';\nimport * as bigintCryptoUtils from 'bigint-crypto-utils';\nimport * as secp from '@noble/secp256k1';\nimport HDTree, { BIP32, chaincodeBase } from '../../hdTree';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { hexToBigInt } from '../../../util/crypto';\nimport { bigIntFromBufferBE, bigIntFromU8ABE, bigIntToBufferBE, getPaillierPublicKey } from '../../util';\nimport { Secp256k1Curve } from '../../curves';\nimport Shamir from '../../shamir';\nimport { EcdsaRangeProof, EcdsaTypes, randomCoPrimeTo } from '@bitgo-beta/sdk-lib-mpc';\nimport {\n  AShare,\n  BShare,\n  DShare,\n  GShare,\n  KeyCombined,\n  KeyCombinedWithNtilde,\n  KeyShare,\n  KShare,\n  MUShare,\n  NShare,\n  OShare,\n  PShare,\n  Signature,\n  SignCombine,\n  SignCombineRT,\n  SignConvert,\n  SignConvertRT,\n  SignShareRT,\n  SShare,\n  SubkeyShare,\n  XShare,\n  XShareWithNtilde,\n  YShare,\n  YShareWithNtilde,\n} from './types';\n\nconst _5n = BigInt(5);\n\nfunction hasNtilde(share: XShare | YShare): share is XShareWithNtilde | YShareWithNtilde {\n  return 'ntilde' in share;\n}\n\n/**\n * ECDSA TSS implementation supporting 2:n Threshold\n */\nexport default class Ecdsa {\n  static curve: Secp256k1Curve = new Secp256k1Curve();\n  static hdTree: HDTree = new BIP32();\n  static shamir: Shamir = new Shamir(Ecdsa.curve);\n  /**\n   * Generate shares for participant at index and split keys `(threshold,numShares)` ways.\n   * @param {number} index participant index\n   * @param {number} threshold Signing threshold\n   * @param {number} numShares  Number of shares\n   * @param {Buffer} seed optional 64 byte seed to use for key generation\n   * @param {Boolean} sync optional sync flag, if true then a synchronous version of Paillier key generation is used that does not spawn Worker threads.\n   * @returns {Promise<KeyShare>} Returns the private p-share\n   * and n-shares to be distributed to participants at their corresponding index.\n   */\n  async keyShare(index: number, threshold: number, numShares: number, seed?: Buffer, sync = false): Promise<KeyShare> {\n    if (!(index > 0 && index <= numShares && threshold <= numShares && threshold === 2)) {\n      throw 'Invalid KeyShare Config';\n    }\n\n    if (seed && seed.length < 64) {\n      throw new Error('Seed must have a length of at least 64 bytes');\n    }\n\n    let seedWithValidLength = seed;\n    if (seed && seed.length > 64) {\n      // if seed length is greater than 64 bytes, hash seed to 64 bytes.\n      seedWithValidLength = createHash('sha512').update(seed).digest();\n    }\n\n    // Generate additively homomorphic encryption key.\n    let paillierKeyPair: paillierBigint.KeyPair;\n    if (!sync) {\n      paillierKeyPair = await paillierBigint.generateRandomKeys(3072, true);\n    } else {\n      paillierKeyPair = paillierBigint.generateRandomKeysSync(3072, true);\n    }\n    const { publicKey, privateKey } = paillierKeyPair;\n    // Accept a 64 byte seed and create an extended private key from that seed\n    const secretKey = seedWithValidLength && bip32.fromSeed(seedWithValidLength);\n    const u =\n      (secretKey && secretKey.privateKey && bigIntFromU8ABE(new Uint8Array(secretKey.privateKey))) ??\n      Ecdsa.curve.scalarRandom();\n    const y = Ecdsa.curve.basePointMult(u);\n    const chaincode = (secretKey && secretKey.chainCode) ?? randomBytes(32);\n    // Compute secret shares of the private key\n    const { shares: uShares, v } = Ecdsa.shamir.split(u, threshold, numShares);\n    const currentParticipant: PShare = {\n      i: index,\n      t: threshold,\n      c: numShares,\n      l: bigIntToBufferBE(privateKey.lambda, 192).toString('hex'),\n      m: bigIntToBufferBE(privateKey.mu, 192).toString('hex'),\n      n: bigIntToBufferBE(publicKey.n, 384).toString('hex'),\n      y: bigIntToBufferBE(y, 33).toString('hex'),\n      u: bigIntToBufferBE(uShares[index], 32).toString('hex'),\n      uu: u.toString(),\n      chaincode: chaincode.toString('hex'),\n    };\n    const keyShare: KeyShare = {\n      pShare: currentParticipant,\n      nShares: {},\n    };\n\n    for (const share in uShares) {\n      const participantIndex = parseInt(share, 10);\n      if (participantIndex !== index) {\n        keyShare.nShares[participantIndex] = {\n          i: participantIndex,\n          j: currentParticipant['i'],\n          n: publicKey.n.toString(16),\n          y: bigIntToBufferBE(y, 33).toString('hex'),\n          v: bigIntToBufferBE(v[0], 33).toString('hex'),\n          u: bigIntToBufferBE(uShares[participantIndex], 32).toString('hex'),\n          chaincode: chaincode.toString('hex'),\n        } as NShare;\n      }\n    }\n    return keyShare;\n  }\n\n  /**\n   * Combine data shared during the key generation protocol.\n   * @param {KeyShare} participantShares private p-share and\n   * n-shares received from all other participants.\n   * @returns {KeyCombined} Returns the participant private x-share\n   * and y-shares to be used when generating signing shares.\n   */\n  keyCombine(pShare: PShare, nShares: NShare[]): KeyCombined {\n    const allShares = [pShare, ...nShares];\n    // Compute the public key.\n    const y = allShares.map((participant) => hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);\n    // Add secret shares\n    const x = allShares.map((participant) => hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Chaincode will be used in future when we add support for key derivation for ecdsa\n    const chaincodes = [pShare, ...nShares].map(({ chaincode }) => bigIntFromBufferBE(Buffer.from(chaincode, 'hex')));\n    const chaincode = chaincodes.reduce(\n      (acc, chaincode) =>\n        (acc + chaincode) % BigInt('0x010000000000000000000000000000000000000000000000000000000000000000') // 2^256\n    );\n\n    const participants: KeyCombined = {\n      xShare: {\n        i: pShare.i,\n        l: pShare.l,\n        m: pShare.m,\n        n: pShare.n,\n        y: bigIntToBufferBE(y, 33).toString('hex'),\n        x: bigIntToBufferBE(x, 32).toString('hex'),\n        chaincode: bigIntToBufferBE(chaincode, 32).toString('hex'),\n      },\n      yShares: {},\n    };\n\n    for (const share in nShares) {\n      const participantIndex = nShares[share]['j'];\n      participants.yShares[participantIndex] = {\n        i: pShare.i,\n        j: nShares[share]['j'],\n        n: nShares[share]['n'],\n      };\n    }\n    return participants;\n  }\n\n  /**\n   * Derive shares for a BIP-32 subkey.\n   * @param {PShare} The user's p-share.\n   * @param {NShare[]} The n-shares received from the other participants.\n   * @param {string} The BIP-32 path to derive.\n   * @returns {SubkeyShare} Returns the private x-share and n-shares to\n   * be distributed to participants at their corresponding index.\n   */\n  keyDerive(pShare: PShare, nShares: NShare[], path: string): SubkeyShare {\n    const yValues = [pShare, ...nShares].map((share) => hexToBigInt(share.y));\n    const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));\n    const u = BigInt(pShare.uu);\n    let contribChaincode = hexToBigInt(pShare.chaincode);\n    const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => hexToBigInt(chaincode))];\n    const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % chaincodeBase);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Derive subkey.\n    const subkey = Ecdsa.hdTree.privateDerive({ pk: y, sk: u, chaincode }, path);\n\n    // Calculate new public key contribution.\n    const contribY = Ecdsa.curve.basePointMult(subkey.sk);\n\n    // Calculate new chaincode contribution.\n    const chaincodeDelta = (chaincodeBase + subkey.chaincode - chaincode) % chaincodeBase;\n    contribChaincode = (contribChaincode + chaincodeDelta) % chaincodeBase;\n\n    // Calculate new u values.\n    const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);\n\n    // Calculate new signing key.\n    const x = [split_u[pShare.i], ...nShares.map(({ u }) => hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);\n\n    const P_i: XShare = {\n      i: pShare.i,\n      l: pShare.l,\n      m: pShare.m,\n      n: pShare.n,\n      y: bigIntToBufferBE(subkey.pk, 33).toString('hex'),\n      x: bigIntToBufferBE(x, 32).toString('hex'),\n      chaincode: bigIntToBufferBE(subkey.chaincode, 32).toString('hex'),\n    };\n\n    const shares: SubkeyShare = {\n      xShare: P_i,\n      nShares: {},\n    };\n\n    for (let ind = 0; ind < nShares.length; ind++) {\n      const P_j = nShares[ind];\n      shares.nShares[P_j.j] = {\n        i: P_j.j,\n        j: P_i.i,\n        n: P_j.n,\n        u: bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),\n        y: bigIntToBufferBE(contribY, 32).toString('hex'),\n        v: bigIntToBufferBE(v[0], 32).toString('hex'),\n        chaincode: bigIntToBufferBE(contribChaincode, 32).toString('hex'),\n      };\n    }\n\n    return shares;\n  }\n\n  /**\n   * Derives a child common keychain from common keychain\n   *\n   * @param {commonKeychain} The common keychain as a hex string.\n   * @param {path} The BIP-32 path to derive.\n   * @return {string} The derived common keychain as a hex string.\n   */\n  deriveUnhardened(commonKeychain: string, path: string): string {\n    if (Ecdsa.hdTree === undefined) {\n      throw new Error(\"Can't derive key without HDTree implementation\");\n    }\n\n    const keychain = Buffer.from(commonKeychain, 'hex');\n\n    const derivedPublicKeychain = Ecdsa.hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferBE(keychain.slice(0, 33)),\n        chaincode: bigIntFromBufferBE(keychain.slice(33)),\n      },\n      path\n    );\n\n    const derivedPk = bigIntToBufferBE(derivedPublicKeychain.pk, 33).toString('hex');\n    const derivedChaincode = bigIntToBufferBE(derivedPublicKeychain.chaincode, 32).toString('hex');\n\n    return derivedPk + derivedChaincode;\n  }\n\n  /**\n   * Appends a given range proof challenge to the shares previously created\n   * by #keyCombine. Generates a new challenge if not provided.\n   * @param {XShare} xShare Private xShare of signer\n   * @param {YShare} yShare YShare of the other participant involved in\n   * this signing operation\n   * @param {EcdsaTypes.SerializedNtilde} challenge\n   * @returns {KeyCombined} The new XShare and YShares with the amended\n   * challenge values\n   */\n  async appendChallenge(\n    xShare: XShare,\n    yShare: YShare,\n    challenge?: EcdsaTypes.SerializedNtilde\n  ): Promise<KeyCombinedWithNtilde> {\n    if (!challenge) {\n      challenge = EcdsaTypes.serializeNtilde(await EcdsaRangeProof.generateNtilde(3072));\n    }\n    const { ntilde, h1, h2 } = challenge;\n    return {\n      xShare: { ...xShare, ntilde, h1, h2 },\n      yShares: {\n        [yShare.j]: {\n          i: yShare.j,\n          j: yShare.i,\n          n: xShare.n,\n          ntilde,\n          h1,\n          h2,\n        },\n      },\n    };\n  }\n\n  /**\n   * Create signing shares.\n   * @param {xShare} xShare Private xShare of current participant signer\n   * @param {YShare} yShare yShare corresponding to the other participant signer\n   * @returns {SignShareRT} Returns the participant private w-share\n   * and k-share to be distributed to other participant signer\n   */\n  async signShare(xShare: XShare | XShareWithNtilde, yShare: YShareWithNtilde): Promise<SignShareRT> {\n    const pk = getPaillierPublicKey(hexToBigInt(xShare.n));\n\n    // Generate a challenge if ntilde is not present in the xShare.\n    if (!hasNtilde(xShare)) {\n      xShare = (await this.appendChallenge(xShare, yShare)).xShare;\n    }\n\n    const k = Ecdsa.curve.scalarRandom();\n    const rk = await randomCoPrimeTo(pk.n);\n    const ck = pk.encrypt(k, rk);\n    const gamma = Ecdsa.curve.scalarRandom();\n\n    const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));\n\n    const w = [\n      Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),\n      hexToBigInt(xShare['x']),\n      Ecdsa.curve.scalarInvert(d),\n    ].reduce(Ecdsa.curve.scalarMult);\n\n    const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare as XShareWithNtilde;\n\n    const signers: SignShareRT = {\n      wShare: {\n        i: xShare.i,\n        l: xShare.l,\n        m: xShare.m,\n        n: xShare.n,\n        y: xShare.y,\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        ck: bigIntToBufferBE(ck, 768).toString('hex'),\n        w: bigIntToBufferBE(w, 32).toString('hex'),\n        gamma: bigIntToBufferBE(gamma, 32).toString('hex'),\n      },\n      kShare: {} as KShare,\n    };\n\n    const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;\n    const proof = await EcdsaRangeProof.prove(\n      Ecdsa.curve,\n      3072,\n      pk,\n      {\n        ntilde: hexToBigInt(ntildeb),\n        h1: hexToBigInt(h1b),\n        h2: hexToBigInt(h2b),\n      },\n      ck,\n      k,\n      rk\n    );\n    const proofShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n    };\n\n    signers.kShare = {\n      i: yShare.j,\n      j: xShare.i,\n      n: pk.n.toString(16),\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      k: bigIntToBufferBE(ck, 768).toString('hex'),\n      proof: proofShare,\n    };\n\n    return signers;\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another\n   * signer.\n   * @param {SignConvert}\n   * @returns {SignConvertRT}\n   */\n  async signConvert(shares: SignConvert): Promise<SignConvertRT> {\n    let shareParticipant: Partial<BShare> | Partial<GShare>, shareToBeSent: Partial<AShare> | MUShare;\n    let isGammaShare = false;\n    let kShare: Partial<KShare> = {};\n    if (shares.xShare && shares.yShare && shares.kShare) {\n      const xShare = shares.xShare; // currentParticipant secret xShare\n      const yShare = {\n        ...shares.yShare,\n        ntilde: shares.kShare.ntilde,\n        h1: shares.kShare.h1,\n        h2: shares.kShare.h2,\n      };\n      const signShare = await this.signShare(xShare, yShare);\n      kShare = signShare.kShare;\n      shareToBeSent = { ...shares.kShare } as Partial<AShare>;\n      shareParticipant = { ...signShare.wShare } as Partial<BShare>;\n    } else if ((shares.bShare && shares.muShare) || (shares.aShare && shares.wShare)) {\n      isGammaShare = true;\n      shareToBeSent = shares.aShare ? ({ ...shares.aShare } as MUShare) : ({ ...shares.muShare } as MUShare);\n      shareParticipant = shares.wShare ? ({ ...shares.wShare } as Partial<GShare>) : ({ ...shares.bShare } as GShare);\n    } else {\n      throw new Error('Invalid config for Sign Convert');\n    }\n    if (shareParticipant.i !== shareToBeSent.i) {\n      throw new Error('Shares from same participant');\n    }\n    if ((shareToBeSent as AShare).alpha) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      const pka = getPaillierPublicKey(hexToBigInt(bShareParticipant.n));\n      let ntildea, h1a, h2a, ck;\n      if (bShareParticipant.ntilde) {\n        ntildea = hexToBigInt(bShareParticipant.ntilde);\n        h1a = hexToBigInt(bShareParticipant.h1);\n        h2a = hexToBigInt(bShareParticipant.h2);\n        ck = hexToBigInt(bShareParticipant.ck);\n      }\n      // Verify $\\gamma_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.gammaProof.z),\n            zprm: hexToBigInt(aShareToBeSent.gammaProof.zprm),\n            t: hexToBigInt(aShareToBeSent.gammaProof.t),\n            v: hexToBigInt(aShareToBeSent.gammaProof.v),\n            w: hexToBigInt(aShareToBeSent.gammaProof.w),\n            s: hexToBigInt(aShareToBeSent.gammaProof.s),\n            s1: hexToBigInt(aShareToBeSent.gammaProof.s1),\n            s2: hexToBigInt(aShareToBeSent.gammaProof.s2),\n            t1: hexToBigInt(aShareToBeSent.gammaProof.t1),\n            t2: hexToBigInt(aShareToBeSent.gammaProof.t2),\n            u: hexToBigInt(aShareToBeSent.gammaProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.alpha),\n          hexToBigInt(aShareToBeSent.gammaProof.x)\n        )\n      ) {\n        throw new Error('could not verify signing share for gamma proof');\n      }\n      // Verify $\\w_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.wProof.z),\n            zprm: hexToBigInt(aShareToBeSent.wProof.zprm),\n            t: hexToBigInt(aShareToBeSent.wProof.t),\n            v: hexToBigInt(aShareToBeSent.wProof.v),\n            w: hexToBigInt(aShareToBeSent.wProof.w),\n            s: hexToBigInt(aShareToBeSent.wProof.s),\n            s1: hexToBigInt(aShareToBeSent.wProof.s1),\n            s2: hexToBigInt(aShareToBeSent.wProof.s2),\n            t1: hexToBigInt(aShareToBeSent.wProof.t1),\n            t2: hexToBigInt(aShareToBeSent.wProof.t2),\n            u: hexToBigInt(aShareToBeSent.wProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.mu),\n          hexToBigInt(aShareToBeSent.wProof.x)\n        )\n      ) {\n        throw new Error('could not verify share for wProof');\n      }\n      const sk = new paillierBigint.PrivateKey(\n        hexToBigInt(bShareParticipant.l as string),\n        hexToBigInt(bShareParticipant.m as string),\n        pka\n      );\n      const gShareParticipant = shareParticipant as GShare;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      const alpha = sk.decrypt(hexToBigInt(aShareToBeSent.alpha));\n      gShareParticipant.alpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n      const mu = sk.decrypt(hexToBigInt(aShareToBeSent.mu as string)); // recheck encrypted number\n      gShareParticipant.mu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n      const partialShareParticipant = shareParticipant as Partial<GShare>;\n      const partialShareToBeSent = muShareToBeSent as Partial<MUShare>;\n      delete partialShareParticipant.l;\n      delete partialShareParticipant.m;\n      delete partialShareToBeSent.alpha;\n      delete partialShareToBeSent.mu;\n    }\n    if ((shareToBeSent as AShare).k) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      const n = hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer\n      const pka = getPaillierPublicKey(n);\n      let ntildea, h1a, h2a, ntildeb, h1b, h2b;\n      if (aShareToBeSent.ntilde) {\n        ntildea = hexToBigInt(aShareToBeSent.ntilde);\n        h1a = hexToBigInt(aShareToBeSent.h1);\n        h2a = hexToBigInt(aShareToBeSent.h2);\n        ntildeb = hexToBigInt(bShareParticipant.ntilde);\n        h1b = hexToBigInt(bShareParticipant.h1);\n        h2b = hexToBigInt(bShareParticipant.h2);\n      }\n      const k = hexToBigInt(aShareToBeSent.k);\n      if (\n        !EcdsaRangeProof.verify(\n          Ecdsa.curve,\n          3072,\n          pka,\n          {\n            ntilde: ntildeb,\n            h1: h1b,\n            h2: h2b,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.proof.z),\n            u: hexToBigInt(aShareToBeSent.proof.u),\n            w: hexToBigInt(aShareToBeSent.proof.w),\n            s: hexToBigInt(aShareToBeSent.proof.s),\n            s1: hexToBigInt(aShareToBeSent.proof.s1),\n            s2: hexToBigInt(aShareToBeSent.proof.s2),\n          },\n          k\n        )\n      ) {\n        throw new Error('Could not verify signing A share proof');\n      }\n      // MtA $k_j, \\gamma_i$.\n      const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      bShareParticipant.beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString(\n        'hex'\n      );\n      const g = hexToBigInt(bShareParticipant.gamma);\n      const rb = await randomCoPrimeTo(pka.n);\n      const cb = pka.encrypt(beta0, rb);\n      const alpha = pka.addition(pka.multiply(k, g), cb);\n      aShareToBeSent.alpha = bigIntToBufferBE(alpha, 32).toString('hex');\n      // Prove $\\gamma_i \\in Z_{N^2}$.\n      const gx = Ecdsa.curve.basePointMult(g);\n      let proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        3072,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        alpha,\n        g,\n        beta0,\n        rb,\n        gx\n      );\n      Object.assign(aShareToBeSent, {\n        gammaProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(gx, 33).toString('hex'),\n        },\n      });\n      // MtA $k_j, w_i$.\n      const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      shareParticipant.nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString(\n        'hex'\n      );\n      const w = hexToBigInt(bShareParticipant.w);\n      const rn = await randomCoPrimeTo(pka.n);\n      const cn = pka.encrypt(nu0, rn);\n      const mu = pka.addition(pka.multiply(k, w), cn);\n      shareToBeSent.mu = bigIntToBufferBE(mu, 32).toString('hex');\n      // Prove $\\w_i \\in Z_{N^2}$.\n      const wx = Ecdsa.curve.basePointMult(w);\n      proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        3072,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        hexToBigInt(aShareToBeSent.mu),\n        w,\n        nu0,\n        rn,\n        wx\n      );\n      Object.assign(shareToBeSent, {\n        wProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(wx, 33).toString('hex'),\n        },\n      });\n      if ((shareParticipant as GShare).alpha) {\n        const partialShareParticipant = shareParticipant as Partial<BShare>;\n        const partialShareToBeSent = shareToBeSent as Partial<AShare>;\n        delete partialShareParticipant.ntilde;\n        delete partialShareParticipant.h1;\n        delete partialShareParticipant.h2;\n        delete partialShareParticipant.ck;\n        delete partialShareToBeSent.n;\n        delete partialShareToBeSent.ntilde;\n        delete partialShareToBeSent.h1;\n        delete partialShareToBeSent.h2;\n        delete partialShareToBeSent.k;\n        delete partialShareToBeSent.proof;\n      } else {\n        Object.assign(shareToBeSent, {\n          n: kShare.n,\n          ntilde: bigIntToBufferBE(ntildeb, 384).toString('hex'),\n          h1: bigIntToBufferBE(h1b, 384).toString('hex'),\n          h2: bigIntToBufferBE(h2b, 384).toString('hex'),\n          k: kShare.k,\n          proof: kShare.proof,\n        });\n      }\n    }\n    if (!('alpha' in shareToBeSent) && !('k' in shareToBeSent)) {\n      const partialShareParticipant = shareParticipant as Partial<BShare>;\n      delete partialShareParticipant.ntilde;\n      delete partialShareParticipant.h1;\n      delete partialShareParticipant.h2;\n      delete partialShareParticipant.ck;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      shareToBeSent = {\n        i: muShareToBeSent.i,\n        j: muShareToBeSent.j,\n      } as MUShare;\n    }\n    [shareToBeSent.i, shareToBeSent.j] = [shareToBeSent.j, shareToBeSent.i];\n    if (isGammaShare) {\n      return {\n        muShare: shareToBeSent as MUShare,\n        gShare: shareParticipant as GShare,\n      };\n    }\n    return {\n      aShare: shareToBeSent as AShare,\n      bShare: shareParticipant as BShare,\n    };\n  }\n\n  /**\n   * Combine gamma shares to get the private omicron / delta shares\n   * @param {SignCombine} shares\n   * @returns {SignCombineRT}\n   */\n  signCombine(shares: SignCombine): SignCombineRT {\n    const gShare = shares.gShare;\n    const S = shares.signIndex;\n    const gamma = hexToBigInt(gShare.gamma);\n    const alpha = hexToBigInt(gShare.alpha);\n    const beta = hexToBigInt(gShare.beta);\n    const mu = hexToBigInt(gShare.mu);\n    const nu = hexToBigInt(gShare.nu);\n    const k = hexToBigInt(gShare.k);\n    const w = hexToBigInt(gShare.w);\n\n    const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));\n    const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));\n    const Gamma = Ecdsa.curve.basePointMult(gamma);\n\n    return {\n      oShare: {\n        i: gShare.i,\n        y: gShare.y,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        omicron: bigIntToBufferBE(omicron, 32).toString('hex'),\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n      dShare: {\n        i: S.i,\n        j: gShare.i,\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n    };\n  }\n\n  /**\n   * Sign a message.\n   * @param {Buffer} M Message to be signed\n   * @param {OShare} oShare private omicron share of current participant\n   * @param {DShare} dShare delta share received from the other participant\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before signing\n   * @returns {SShare}\n   */\n  sign(M: Buffer, oShare: OShare, dShare: DShare, hash?: Hash, shouldHash = true): SShare {\n    const m = shouldHash ? (hash || createHash('sha256')).update(M).digest() : M;\n\n    const delta = Ecdsa.curve.scalarAdd(hexToBigInt(oShare.delta), hexToBigInt(dShare.delta));\n\n    const R = Ecdsa.curve.pointMultiply(\n      Ecdsa.curve.pointAdd(hexToBigInt(oShare.Gamma), hexToBigInt(dShare.Gamma)),\n      Ecdsa.curve.scalarInvert(delta)\n    );\n    const pointR = secp.Point.fromHex(bigIntToBufferBE(R, 32));\n    const r = pointR.x;\n\n    const s = Ecdsa.curve.scalarAdd(\n      Ecdsa.curve.scalarMult(bigIntFromU8ABE(m), hexToBigInt(oShare.k)),\n      Ecdsa.curve.scalarMult(r, hexToBigInt(oShare.omicron))\n    );\n    return {\n      i: oShare.i,\n      y: oShare.y,\n      R: pointR.toHex(true),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n    };\n  }\n\n  /**\n   * Construct full signature by combining Sign Shares\n   * @param {SShare[]} shares\n   * @returns {Signature}\n   */\n  constructSignature(shares: SShare[]): Signature {\n    // Every R must match.\n    const R = shares[0]['R'];\n    const isRMatching = shares.map((share) => share['R'] === R).reduce((a, b) => a && b);\n    if (!isRMatching) {\n      throw new Error('R value should be consistent across all shares');\n    }\n\n    let s = shares.map((share) => hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);\n    const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);\n\n    // Normalize s.\n    s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;\n    return {\n      y: shares[0]['y'],\n      r: R.slice(2),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n      recid: recid,\n    };\n  }\n\n  /**\n   * Verify ecdsa signatures\n   * @param {Buffer} message\n   * @param {Signature } signature\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before verifying\n   * @returns {boolean} True if signature is valid; False otherwise\n   */\n  verify(message: Buffer, signature: Signature, hash?: Hash, shouldHash = true): boolean {\n    const messageToVerify = shouldHash ? (hash || createHash('sha256')).update(message).digest() : message;\n    return Ecdsa.curve.verify(\n      messageToVerify,\n      Buffer.concat([\n        Buffer.from([signature['recid']]),\n        bigIntToBufferBE(hexToBigInt(signature['r']), 32),\n        bigIntToBufferBE(hexToBigInt(signature['s']), 32),\n      ]),\n      hexToBigInt(signature['y'])\n    );\n  }\n\n  /**\n   * Deserializes a challenge and it's proofs from hex strings to bigint\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   */\n  static deserializeNtilde(challenge: EcdsaTypes.SerializedNtilde): EcdsaTypes.DeserializedNtilde {\n    return EcdsaTypes.deserializeNtilde(challenge);\n  }\n\n  /**\n   * Serializes a challenge and it's proofs from big int to hex strings.\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   * @param challenge\n   */\n  static serializeNtilde(challenge: EcdsaTypes.DeserializedNtilde): EcdsaTypes.SerializedNtilde {\n    return EcdsaTypes.serializeNtilde(challenge);\n  }\n}\n"]}
|
|
1110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/account-lib/mpc/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import * as paillierBigint from 'paillier-bigint';\nimport * as bigintCryptoUtils from 'bigint-crypto-utils';\nimport * as secp from '@noble/secp256k1';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { bigIntFromBufferBE, bigIntFromU8ABE, bigIntToBufferBE, getPaillierPublicKey } from '../../util';\nimport { Secp256k1Curve } from '../../curves';\nimport Shamir from '../../shamir';\nimport {\n  EcdsaPaillierProof,\n  EcdsaRangeProof,\n  EcdsaTypes,\n  randomPositiveCoPrimeTo,\n  hexToBigInt,\n  minModulusBitLength,\n  HDTree,\n  Secp256k1Bip32HdTree,\n  chaincodeBase,\n} from '@bitgo-beta/sdk-lib-mpc';\nimport {\n  AShare,\n  BShare,\n  DShare,\n  GShare,\n  KeyCombined,\n  KeyShare,\n  KShare,\n  MUShare,\n  NShare,\n  OShare,\n  PShare,\n  RangeProofWithCheckShare,\n  Signature,\n  SignCombine,\n  SignCombineRT,\n  SignConvert,\n  SignConvertRT,\n  SignConvertStep1,\n  SignConvertStep1Response,\n  SignConvertStep2,\n  SignConvertStep2Response,\n  SignConvertStep3,\n  SignConvertStep3Response,\n  SignShareRT,\n  SShare,\n  SubkeyShare,\n  WShare,\n  XShare,\n  XShareWithChallenges,\n  YShareWithChallenges,\n} from './types';\n\nconst _5n = BigInt(5);\n\n/**\n * ECDSA TSS implementation supporting 2:n Threshold\n */\nexport default class Ecdsa {\n  static curve: Secp256k1Curve = new Secp256k1Curve();\n  static hdTree: HDTree = new Secp256k1Bip32HdTree();\n  static shamir: Shamir = new Shamir(Ecdsa.curve);\n  /**\n   * Generate shares for participant at index and split keys `(threshold,numShares)` ways.\n   * @param {number} index participant index\n   * @param {number} threshold Signing threshold\n   * @param {number} numShares  Number of shares\n   * @param {Buffer} seed optional 64 byte seed to use for key generation\n   * @param {Boolean} sync optional sync flag, if true then a synchronous version of Paillier key generation is used that does not spawn Worker threads.\n   * @returns {Promise<KeyShare>} Returns the private p-share\n   * and n-shares to be distributed to participants at their corresponding index.\n   */\n  async keyShare(index: number, threshold: number, numShares: number, seed?: Buffer, sync = false): Promise<KeyShare> {\n    if (!(index > 0 && index <= numShares && threshold <= numShares && threshold === 2)) {\n      throw 'Invalid KeyShare Config';\n    }\n\n    if (seed && seed.length < 64) {\n      throw new Error('Seed must have a length of at least 64 bytes');\n    }\n\n    let seedWithValidLength = seed;\n    if (seed && seed.length > 64) {\n      // if seed length is greater than 64 bytes, hash seed to 64 bytes.\n      seedWithValidLength = createHash('sha512').update(seed).digest();\n    }\n\n    // Generate additively homomorphic encryption key.\n    let paillierKeyPair: paillierBigint.KeyPair;\n    if (!sync) {\n      paillierKeyPair = await paillierBigint.generateRandomKeys(minModulusBitLength, true);\n    } else {\n      paillierKeyPair = paillierBigint.generateRandomKeysSync(minModulusBitLength, true);\n    }\n    const { publicKey, privateKey } = paillierKeyPair;\n    // Accept a 64 byte seed and create an extended private key from that seed\n    const secretKey = seedWithValidLength && bip32.fromSeed(seedWithValidLength);\n    const u =\n      (secretKey && secretKey.privateKey && bigIntFromU8ABE(new Uint8Array(secretKey.privateKey))) ??\n      Ecdsa.curve.scalarRandom();\n    const y = Ecdsa.curve.basePointMult(u);\n    const chaincode = (secretKey && secretKey.chainCode) ?? randomBytes(32);\n    // Compute secret shares of the private key\n    const { shares: uShares, v } = Ecdsa.shamir.split(u, threshold, numShares);\n    const currentParticipant: PShare = {\n      i: index,\n      t: threshold,\n      c: numShares,\n      l: bigIntToBufferBE(privateKey.lambda, 192).toString('hex'),\n      m: bigIntToBufferBE(privateKey.mu, 192).toString('hex'),\n      n: bigIntToBufferBE(publicKey.n, 384).toString('hex'),\n      y: bigIntToBufferBE(y, 33).toString('hex'),\n      u: bigIntToBufferBE(uShares[index], 32).toString('hex'),\n      uu: u.toString(),\n      chaincode: chaincode.toString('hex'),\n    };\n    const keyShare: KeyShare = {\n      pShare: currentParticipant,\n      nShares: {},\n    };\n\n    for (const share in uShares) {\n      const participantIndex = parseInt(share, 10);\n      if (participantIndex !== index) {\n        keyShare.nShares[participantIndex] = {\n          i: participantIndex,\n          j: currentParticipant['i'],\n          n: publicKey.n.toString(16),\n          y: bigIntToBufferBE(y, 33).toString('hex'),\n          v: bigIntToBufferBE(v[0], 33).toString('hex'),\n          u: bigIntToBufferBE(uShares[participantIndex], 32).toString('hex'),\n          chaincode: chaincode.toString('hex'),\n        } as NShare;\n      }\n    }\n    return keyShare;\n  }\n\n  /**\n   * Combine data shared during the key generation protocol.\n   * @param {KeyShare} participantShares private p-share and\n   * n-shares received from all other participants.\n   * @returns {KeyCombined} Returns the participant private x-share\n   * and y-shares to be used when generating signing shares.\n   */\n  keyCombine(pShare: PShare, nShares: NShare[]): KeyCombined {\n    const allShares = [pShare, ...nShares];\n    // Compute the public key.\n    const y = allShares.map((participant) => hexToBigInt(participant['y'])).reduce(Ecdsa.curve.pointAdd);\n    // Add secret shares\n    const x = allShares.map((participant) => hexToBigInt(participant['u'])).reduce(Ecdsa.curve.scalarAdd);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Chaincode will be used in future when we add support for key derivation for ecdsa\n    const chaincodes = [pShare, ...nShares].map(({ chaincode }) => bigIntFromBufferBE(Buffer.from(chaincode, 'hex')));\n    const chaincode = chaincodes.reduce(\n      (acc, chaincode) =>\n        (acc + chaincode) % BigInt('0x010000000000000000000000000000000000000000000000000000000000000000') // 2^256\n    );\n\n    const participants: KeyCombined = {\n      xShare: {\n        i: pShare.i,\n        l: pShare.l,\n        m: pShare.m,\n        n: pShare.n,\n        y: bigIntToBufferBE(y, 33).toString('hex'),\n        x: bigIntToBufferBE(x, 32).toString('hex'),\n        chaincode: bigIntToBufferBE(chaincode, 32).toString('hex'),\n      },\n      yShares: {},\n    };\n\n    for (const share in nShares) {\n      const participantIndex = nShares[share]['j'];\n      participants.yShares[participantIndex] = {\n        i: pShare.i,\n        j: nShares[share]['j'],\n        n: nShares[share]['n'],\n      };\n    }\n    return participants;\n  }\n\n  /**\n   * Derive shares for a BIP-32 subkey.\n   * @param {PShare} The user's p-share.\n   * @param {NShare[]} The n-shares received from the other participants.\n   * @param {string} The BIP-32 path to derive.\n   * @returns {SubkeyShare} Returns the private x-share and n-shares to\n   * be distributed to participants at their corresponding index.\n   */\n  keyDerive(pShare: PShare, nShares: NShare[], path: string): SubkeyShare {\n    const yValues = [pShare, ...nShares].map((share) => hexToBigInt(share.y));\n    const y = yValues.reduce((partial, share) => Ecdsa.curve.pointAdd(partial, share));\n    const u = BigInt(pShare.uu);\n    let contribChaincode = hexToBigInt(pShare.chaincode);\n    const chaincodes = [contribChaincode, ...nShares.map(({ chaincode }) => hexToBigInt(chaincode))];\n    const chaincode = chaincodes.reduce((acc, chaincode) => (acc + chaincode) % chaincodeBase);\n\n    // Verify shares.\n    for (const share of nShares) {\n      if (share.v) {\n        try {\n          Ecdsa.shamir.verify(hexToBigInt(share.u), [hexToBigInt(share.y), hexToBigInt(share.v!)], pShare.i);\n        } catch (err) {\n          throw new Error(`Could not verify share from participant ${share.j}. Verification error: ${err}`);\n        }\n      }\n    }\n\n    // Derive subkey.\n    const subkey = Ecdsa.hdTree.privateDerive({ pk: y, sk: u, chaincode }, path);\n\n    // Calculate new public key contribution.\n    const contribY = Ecdsa.curve.basePointMult(subkey.sk);\n\n    // Calculate new chaincode contribution.\n    const chaincodeDelta = (chaincodeBase + subkey.chaincode - chaincode) % chaincodeBase;\n    contribChaincode = (contribChaincode + chaincodeDelta) % chaincodeBase;\n\n    // Calculate new u values.\n    const { shares: split_u, v } = Ecdsa.shamir.split(subkey.sk, pShare.t || 2, pShare.c || 3);\n\n    // Calculate new signing key.\n    const x = [split_u[pShare.i], ...nShares.map(({ u }) => hexToBigInt(u))].reduce(Ecdsa.curve.scalarAdd);\n\n    const P_i: XShare = {\n      i: pShare.i,\n      l: pShare.l,\n      m: pShare.m,\n      n: pShare.n,\n      y: bigIntToBufferBE(subkey.pk, 33).toString('hex'),\n      x: bigIntToBufferBE(x, 32).toString('hex'),\n      chaincode: bigIntToBufferBE(subkey.chaincode, 32).toString('hex'),\n    };\n\n    const shares: SubkeyShare = {\n      xShare: P_i,\n      nShares: {},\n    };\n\n    for (let ind = 0; ind < nShares.length; ind++) {\n      const P_j = nShares[ind];\n      shares.nShares[P_j.j] = {\n        i: P_j.j,\n        j: P_i.i,\n        n: P_i.n,\n        u: bigIntToBufferBE(split_u[P_j.j], 32).toString('hex'),\n        y: bigIntToBufferBE(contribY, 32).toString('hex'),\n        v: bigIntToBufferBE(v[0], 32).toString('hex'),\n        chaincode: bigIntToBufferBE(contribChaincode, 32).toString('hex'),\n      };\n    }\n\n    return shares;\n  }\n\n  /**\n   * Derives a child common keychain from common keychain\n   *\n   * @param {commonKeychain} The common keychain as a hex string.\n   * @param {path} The BIP-32 path to derive.\n   * @return {string} The derived common keychain as a hex string.\n   */\n  deriveUnhardened(commonKeychain: string, path: string): string {\n    if (Ecdsa.hdTree === undefined) {\n      throw new Error(\"Can't derive key without HDTree implementation\");\n    }\n\n    const keychain = Buffer.from(commonKeychain, 'hex');\n\n    const derivedPublicKeychain = Ecdsa.hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferBE(keychain.slice(0, 33)),\n        chaincode: bigIntFromBufferBE(keychain.slice(33)),\n      },\n      path\n    );\n\n    const derivedPk = bigIntToBufferBE(derivedPublicKeychain.pk, 33).toString('hex');\n    const derivedChaincode = bigIntToBufferBE(derivedPublicKeychain.chaincode, 32).toString('hex');\n\n    return derivedPk + derivedChaincode;\n  }\n\n  /**\n   * Appends a given range proof challenge to the shares previously created\n   * by #keyCombine. Generates a new challenge if not provided.\n   * @param {XShare | YShare} share Private xShare or yShare of the signing operation\n   * @param rangeProofChallenge - challenge generated via generateNtilde\n   * @param paillierProofChallenge\n   * @returns {KeyCombined} The share with amended challenge values\n   */\n  appendChallenge<T>(\n    share: T,\n    rangeProofChallenge: EcdsaTypes.SerializedNtilde,\n    paillierProofChallenge: EcdsaTypes.SerializedPaillierChallenge\n  ): T & EcdsaTypes.SerializedEcdsaChallenges {\n    const { ntilde, h1, h2 } = rangeProofChallenge;\n    return {\n      ...share,\n      ntilde,\n      h1,\n      h2,\n      p: paillierProofChallenge.p,\n    };\n  }\n\n  /**\n   * Create signing shares.\n   * @param {xShare} xShare Private xShare of current participant signer\n   * @param {YShare} yShare yShare corresponding to the other participant signer\n   * @returns {SignShareRT} Returns the participant private w-share\n   * and k-share to be distributed to other participant signer\n   */\n  async signShare(xShare: XShareWithChallenges, yShare: YShareWithChallenges): Promise<SignShareRT> {\n    const pk = getPaillierPublicKey(hexToBigInt(xShare.n));\n\n    const k = Ecdsa.curve.scalarRandom();\n    const rk = await randomPositiveCoPrimeTo(pk.n);\n    const ck = pk.encrypt(k, rk);\n    const gamma = Ecdsa.curve.scalarRandom();\n\n    const d = Ecdsa.curve.scalarMult(Ecdsa.curve.scalarSub(BigInt(yShare.j), BigInt(xShare.i)), BigInt(xShare.i));\n\n    const w = [\n      Ecdsa.curve.scalarMult(BigInt(yShare.j), BigInt(xShare.i)),\n      hexToBigInt(xShare['x']),\n      Ecdsa.curve.scalarInvert(d),\n    ].reduce(Ecdsa.curve.scalarMult);\n\n    const { ntilde: ntildea, h1: h1a, h2: h2a } = xShare;\n\n    const wShare: WShare = {\n      i: xShare.i,\n      l: xShare.l,\n      m: xShare.m,\n      n: xShare.n,\n      y: xShare.y,\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      p: xShare.p,\n      k: bigIntToBufferBE(k, 32).toString('hex'),\n      ck: bigIntToBufferBE(ck, 768).toString('hex'),\n      w: bigIntToBufferBE(w, 32).toString('hex'),\n      gamma: bigIntToBufferBE(gamma, 32).toString('hex'),\n    };\n\n    const { ntilde: ntildeb, h1: h1b, h2: h2b } = yShare;\n    const proof = await EcdsaRangeProof.prove(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pk,\n      {\n        ntilde: hexToBigInt(ntildeb),\n        h1: hexToBigInt(h1b),\n        h2: hexToBigInt(h2b),\n      },\n      ck,\n      k,\n      rk\n    );\n\n    // create paillier challenge proof based on the other signers challenge\n    // only send sigma if we also send challenge p\n    const sigma = EcdsaPaillierProof.prove(\n      hexToBigInt(xShare.n),\n      hexToBigInt(xShare.l),\n      EcdsaTypes.deserializePaillierChallenge({ p: yShare.p! }).p\n    );\n\n    const proofShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n    };\n\n    const kShare: KShare = {\n      // this share will be sent to the other participant,\n      // so we need to swap the i and j values here\n      // so that they know it's their kShare, produced by us\n      i: yShare.j,\n      j: xShare.i,\n      n: pk.n.toString(16),\n      ntilde: ntildea,\n      h1: h1a,\n      h2: h2a,\n      p: xShare.p,\n      k: bigIntToBufferBE(ck, 768).toString('hex'),\n      sigma: EcdsaTypes.serializePaillierChallengeProofs({ sigma: sigma }).sigma,\n      proof: proofShare,\n    };\n\n    return {\n      wShare,\n      kShare,\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * Connection 1.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer A completed signShare initially (input to this fn), then this step is completed by signer B.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep1(shares: SignConvertStep1): Promise<SignConvertStep1Response> {\n    const receivedKShare = shares.kShare;\n    const xShare = shares.xShare; // currentParticipant secret xShare\n    const yShare: YShareWithChallenges = {\n      ...shares.yShare,\n      ntilde: receivedKShare.ntilde,\n      h1: receivedKShare.h1,\n      h2: receivedKShare.h2,\n      p: receivedKShare.p,\n    };\n    const signShare = await this.signShare(xShare, yShare);\n    const shareParticipant = signShare.wShare;\n\n    if (shareParticipant.i !== receivedKShare.i) {\n      throw new Error('Shares from same participant');\n    }\n    if (!receivedKShare.proof) {\n      throw new Error('Unexpected missing proof on aShareToBeSent');\n    }\n\n    // the other participants paillier public key\n    const n = hexToBigInt(receivedKShare.n);\n    const pka = getPaillierPublicKey(n);\n    // the other participant's range proof challenge\n    const ntildea = hexToBigInt(receivedKShare.ntilde);\n    const h1a = hexToBigInt(receivedKShare.h1);\n    const h2a = hexToBigInt(receivedKShare.h2);\n\n    // the current participant's range proof challenge\n    const ntildeb = hexToBigInt(shareParticipant.ntilde);\n    const h1b = hexToBigInt(shareParticipant.h1);\n    const h2b = hexToBigInt(shareParticipant.h2);\n\n    const k = hexToBigInt(receivedKShare.k);\n\n    // the current participants paillier proof challenge\n    const shareParticipantPaillierChallenge = EcdsaTypes.deserializePaillierChallenge({ p: shareParticipant.p });\n    // the other signing parties proof to the current participants paillier proof challenge\n    const receivedPaillierChallengeProof = EcdsaTypes.deserializePaillierChallengeProofs({\n      sigma: receivedKShare.sigma,\n    });\n    if (\n      !(await EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma))\n    ) {\n      throw new Error('Could not verify signing A share paillier proof');\n    }\n\n    if (\n      !EcdsaRangeProof.verify(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildeb,\n          h1: h1b,\n          h2: h2b,\n        },\n        {\n          z: hexToBigInt(receivedKShare.proof.z),\n          u: hexToBigInt(receivedKShare.proof.u),\n          w: hexToBigInt(receivedKShare.proof.w),\n          s: hexToBigInt(receivedKShare.proof.s),\n          s1: hexToBigInt(receivedKShare.proof.s1),\n          s2: hexToBigInt(receivedKShare.proof.s2),\n        },\n        k\n      )\n    ) {\n      throw new Error('Could not verify signing A share proof');\n    }\n    // MtA $k_j, \\gamma_i$.\n    const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');\n    const g = hexToBigInt(shareParticipant.gamma);\n    const rb = await randomPositiveCoPrimeTo(pka.n);\n    const cb = pka.encrypt(beta0, rb);\n    const alpha = pka.addition(pka.multiply(k, g), cb);\n    const alphaToBeSent = bigIntToBufferBE(alpha, 32).toString('hex');\n    // Prove $\\gamma_i \\in Z_{N^2}$.\n    const gx = Ecdsa.curve.basePointMult(g);\n    let proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pka,\n      {\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n      },\n      k,\n      alpha,\n      g,\n      beta0,\n      rb,\n      gx\n    );\n    const gammaProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(gx, 33).toString('hex'),\n    };\n    // MtA $k_j, w_i$.\n    const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');\n    const w = hexToBigInt(shareParticipant.w);\n    const rn = await randomPositiveCoPrimeTo(pka.n);\n    const cn = pka.encrypt(nu0, rn);\n    const mu = pka.addition(pka.multiply(k, w), cn);\n    const muToBeSent = bigIntToBufferBE(mu, 32).toString('hex');\n    // Prove $\\w_i \\in Z_{N^2}$.\n    const wx = Ecdsa.curve.basePointMult(w);\n    proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pka,\n      {\n        ntilde: ntildea,\n        h1: h1a,\n        h2: h2a,\n      },\n      k,\n      hexToBigInt(muToBeSent),\n      w,\n      nu0,\n      rn,\n      wx\n    );\n    const wProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(wx, 33).toString('hex'),\n    };\n\n    const nToBeSent = signShare.kShare.n;\n    const ntildeToBeSent = bigIntToBufferBE(ntildeb, 384).toString('hex');\n    const h1ToBeSent = bigIntToBufferBE(h1b, 384).toString('hex');\n    const h2ToBeSent = bigIntToBufferBE(h2b, 384).toString('hex');\n    const kToBeSent = signShare.kShare.k;\n    const proofToBeSent = signShare.kShare.proof;\n    const [iToBeSent, jToBeSent] = [receivedKShare.j, receivedKShare.i];\n    return {\n      aShare: {\n        i: iToBeSent,\n        j: jToBeSent,\n        ntilde: ntildeToBeSent,\n        h1: h1ToBeSent,\n        h2: h2ToBeSent,\n        n: nToBeSent,\n        k: kToBeSent,\n        alpha: alphaToBeSent,\n        mu: muToBeSent,\n        proof: proofToBeSent,\n        gammaProof: gammaProofToBeSent,\n        wProof: wProofToBeSent,\n        // provide the share participants proof\n        // to the paillier challenge in the receivedKShare from the other signer\n        sigma: signShare.kShare.sigma,\n      },\n      bShare: {\n        ...shareParticipant,\n        beta,\n        nu,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another\n   * signer.\n   * Connection 2.1 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer B completed signConvertStep1, then this step is completed by signer A.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep2(shares: SignConvertStep2): Promise<SignConvertStep2Response> {\n    const receivedAShare = shares.aShare;\n    if (!receivedAShare.gammaProof) {\n      throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n    }\n    if (!receivedAShare.wProof) {\n      throw new Error('Unexpected missing wProof on aShareToBeSent');\n    }\n    const n = hexToBigInt(receivedAShare.n); // Paillier pub from other signer\n    // current participant public key\n    const pka = getPaillierPublicKey(hexToBigInt(shares.wShare.n));\n    const ntildea = hexToBigInt(shares.wShare.ntilde);\n    const h1a = hexToBigInt(shares.wShare.h1);\n    const h2a = hexToBigInt(shares.wShare.h2);\n    const ck = hexToBigInt(shares.wShare.ck);\n\n    const shareParticipantPaillierChallenge = EcdsaTypes.deserializePaillierChallenge({ p: shares.wShare.p });\n    const receivedPaillierChallengeProof = EcdsaTypes.deserializePaillierChallengeProofs({\n      sigma: shares.aShare.sigma,\n    });\n    if (!EcdsaPaillierProof.verify(n, shareParticipantPaillierChallenge.p, receivedPaillierChallengeProof.sigma)) {\n      throw new Error('could not verify signing share for paillier proof');\n    }\n\n    // Verify $\\gamma_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.gammaProof.z),\n          zprm: hexToBigInt(receivedAShare.gammaProof.zprm),\n          t: hexToBigInt(receivedAShare.gammaProof.t),\n          v: hexToBigInt(receivedAShare.gammaProof.v),\n          w: hexToBigInt(receivedAShare.gammaProof.w),\n          s: hexToBigInt(receivedAShare.gammaProof.s),\n          s1: hexToBigInt(receivedAShare.gammaProof.s1),\n          s2: hexToBigInt(receivedAShare.gammaProof.s2),\n          t1: hexToBigInt(receivedAShare.gammaProof.t1),\n          t2: hexToBigInt(receivedAShare.gammaProof.t2),\n          u: hexToBigInt(receivedAShare.gammaProof.u),\n        },\n        ck,\n        hexToBigInt(receivedAShare.alpha),\n        hexToBigInt(receivedAShare.gammaProof.x)\n      )\n    ) {\n      throw new Error('could not verify signing share for gamma proof');\n    }\n    // Verify $\\w_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.wProof.z),\n          zprm: hexToBigInt(receivedAShare.wProof.zprm),\n          t: hexToBigInt(receivedAShare.wProof.t),\n          v: hexToBigInt(receivedAShare.wProof.v),\n          w: hexToBigInt(receivedAShare.wProof.w),\n          s: hexToBigInt(receivedAShare.wProof.s),\n          s1: hexToBigInt(receivedAShare.wProof.s1),\n          s2: hexToBigInt(receivedAShare.wProof.s2),\n          t1: hexToBigInt(receivedAShare.wProof.t1),\n          t2: hexToBigInt(receivedAShare.wProof.t2),\n          u: hexToBigInt(receivedAShare.wProof.u),\n        },\n        ck,\n        hexToBigInt(receivedAShare.mu),\n        hexToBigInt(receivedAShare.wProof.x)\n      )\n    ) {\n      throw new Error('could not verify share for wProof');\n    }\n    const sk = new paillierBigint.PrivateKey(hexToBigInt(shares.wShare.l), hexToBigInt(shares.wShare.m), pka);\n\n    const gShareAlpha = bigIntToBufferBE(\n      Ecdsa.curve.scalarReduce(sk.decrypt(hexToBigInt(receivedAShare.alpha))),\n      32\n    ).toString('hex');\n\n    const gShareMu = bigIntToBufferBE(\n      Ecdsa.curve.scalarReduce(sk.decrypt(hexToBigInt(receivedAShare.mu))), // recheck encrypted number\n      32\n    ).toString('hex');\n\n    if (!receivedAShare.proof) {\n      throw new Error('Unexpected missing proof on aShareToBeSent');\n    }\n    const pkb = getPaillierPublicKey(n);\n    const ntildeb = hexToBigInt(receivedAShare.ntilde);\n    const h1b = hexToBigInt(receivedAShare.h1);\n    const h2b = hexToBigInt(receivedAShare.h2);\n    const k = hexToBigInt(receivedAShare.k);\n    if (\n      !EcdsaRangeProof.verify(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pkb,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedAShare.proof.z),\n          u: hexToBigInt(receivedAShare.proof.u),\n          w: hexToBigInt(receivedAShare.proof.w),\n          s: hexToBigInt(receivedAShare.proof.s),\n          s1: hexToBigInt(receivedAShare.proof.s1),\n          s2: hexToBigInt(receivedAShare.proof.s2),\n        },\n        k\n      )\n    ) {\n      throw new Error('Could not verify signing A share proof');\n    }\n    // MtA $k_j, \\gamma_i$.\n    const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const gShareBeta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString('hex');\n\n    const g = hexToBigInt(shares.wShare.gamma);\n    const rb = await randomPositiveCoPrimeTo(pkb.n);\n    const cb = pkb.encrypt(beta0, rb);\n    const alpha = pkb.addition(pkb.multiply(k, g), cb);\n    const alphaToBeSent = bigIntToBufferBE(alpha, 32).toString('hex');\n    // Prove $\\gamma_i \\in Z_{N^2}$.\n    const gx = Ecdsa.curve.basePointMult(g);\n    let proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pkb,\n      {\n        ntilde: ntildeb,\n        h1: h1b,\n        h2: h2b,\n      },\n      k,\n      alpha,\n      g,\n      beta0,\n      rb,\n      gx\n    );\n    const gammaProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(gx, 33).toString('hex'),\n    };\n    // MtA $k_j, w_i$.\n    const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n    const gShareNu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString('hex');\n    const w = hexToBigInt(shares.wShare.w);\n    const rn = await randomPositiveCoPrimeTo(pkb.n);\n    const cn = pkb.encrypt(nu0, rn);\n    const mu = pkb.addition(pkb.multiply(k, w), cn);\n    const muToBeSent = bigIntToBufferBE(mu, 32).toString('hex');\n    // Prove $\\w_i \\in Z_{N^2}$.\n    const wx = Ecdsa.curve.basePointMult(w);\n    proof = await EcdsaRangeProof.proveWithCheck(\n      Ecdsa.curve,\n      minModulusBitLength,\n      pkb,\n      {\n        ntilde: ntildeb,\n        h1: h1b,\n        h2: h2b,\n      },\n      k,\n      hexToBigInt(muToBeSent),\n      w,\n      nu0,\n      rn,\n      wx\n    );\n    const wProofToBeSent: RangeProofWithCheckShare = {\n      z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n      zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n      t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n      v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n      w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n      s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n      s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n      s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n      t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n      t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n      u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n      x: bigIntToBufferBE(wx, 33).toString('hex'),\n    };\n\n    const [iToBeSent, jToBeSent] = [receivedAShare.j, receivedAShare.i];\n    return {\n      muShare: {\n        i: iToBeSent,\n        j: jToBeSent,\n        alpha: alphaToBeSent,\n        mu: muToBeSent,\n        gammaProof: gammaProofToBeSent,\n        wProof: wProofToBeSent,\n      },\n      gShare: {\n        i: shares.wShare.i,\n        n: shares.wShare.n,\n        y: shares.wShare.y,\n        k: shares.wShare.k,\n        w: shares.wShare.w,\n        gamma: shares.wShare.gamma,\n        alpha: gShareAlpha,\n        mu: gShareMu,\n        beta: gShareBeta,\n        nu: gShareNu,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * Connection 2.2 in https://lucid.app/lucidchart/7061785b-bc5c-4002-b546-3f4a3612fc62/edit?page=IAVmvYO4FvKc#\n   * If signer A completed signConvertStep2, then this step is completed by signer B.\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvertStep3(shares: SignConvertStep3): Promise<SignConvertStep3Response> {\n    const receivedMuShare = shares.muShare;\n    if (!receivedMuShare.gammaProof) {\n      throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n    }\n    if (!receivedMuShare.wProof) {\n      throw new Error('Unexpected missing wProof on aShareToBeSent');\n    }\n    const pka = getPaillierPublicKey(hexToBigInt(shares.bShare.n));\n    const ntildea = hexToBigInt(shares.bShare.ntilde);\n    const h1a = hexToBigInt(shares.bShare.h1);\n    const h2a = hexToBigInt(shares.bShare.h2);\n    const ck = hexToBigInt(shares.bShare.ck);\n    // Verify $\\gamma_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedMuShare.gammaProof.z),\n          zprm: hexToBigInt(receivedMuShare.gammaProof.zprm),\n          t: hexToBigInt(receivedMuShare.gammaProof.t),\n          v: hexToBigInt(receivedMuShare.gammaProof.v),\n          w: hexToBigInt(receivedMuShare.gammaProof.w),\n          s: hexToBigInt(receivedMuShare.gammaProof.s),\n          s1: hexToBigInt(receivedMuShare.gammaProof.s1),\n          s2: hexToBigInt(receivedMuShare.gammaProof.s2),\n          t1: hexToBigInt(receivedMuShare.gammaProof.t1),\n          t2: hexToBigInt(receivedMuShare.gammaProof.t2),\n          u: hexToBigInt(receivedMuShare.gammaProof.u),\n        },\n        ck,\n        hexToBigInt(receivedMuShare.alpha),\n        hexToBigInt(receivedMuShare.gammaProof.x)\n      )\n    ) {\n      throw new Error('could not verify signing share for gamma proof');\n    }\n    // Verify $\\w_i \\in Z_{N^2}$.\n    if (\n      !EcdsaRangeProof.verifyWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        {\n          z: hexToBigInt(receivedMuShare.wProof.z),\n          zprm: hexToBigInt(receivedMuShare.wProof.zprm),\n          t: hexToBigInt(receivedMuShare.wProof.t),\n          v: hexToBigInt(receivedMuShare.wProof.v),\n          w: hexToBigInt(receivedMuShare.wProof.w),\n          s: hexToBigInt(receivedMuShare.wProof.s),\n          s1: hexToBigInt(receivedMuShare.wProof.s1),\n          s2: hexToBigInt(receivedMuShare.wProof.s2),\n          t1: hexToBigInt(receivedMuShare.wProof.t1),\n          t2: hexToBigInt(receivedMuShare.wProof.t2),\n          u: hexToBigInt(receivedMuShare.wProof.u),\n        },\n        ck,\n        hexToBigInt(receivedMuShare.mu),\n        hexToBigInt(receivedMuShare.wProof.x)\n      )\n    ) {\n      throw new Error('could not verify share for wProof');\n    }\n    const sk = new paillierBigint.PrivateKey(hexToBigInt(shares.bShare.l), hexToBigInt(shares.bShare.m), pka);\n    const alpha = sk.decrypt(hexToBigInt(receivedMuShare.alpha));\n    const gShareAlpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n    const mu = sk.decrypt(hexToBigInt(receivedMuShare.mu as string)); // recheck encrypted number\n    const gShareMu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n\n    const [iToBeSent, jToBeSent] = [receivedMuShare.j, receivedMuShare.i];\n    return {\n      gShare: {\n        i: shares.bShare.i,\n        n: shares.bShare.n,\n        y: shares.bShare.y,\n        k: shares.bShare.k,\n        w: shares.bShare.w,\n        gamma: shares.bShare.gamma,\n        alpha: gShareAlpha,\n        mu: gShareMu,\n        beta: shares.bShare.beta,\n        nu: shares.bShare.nu,\n      },\n      signIndex: {\n        i: iToBeSent,\n        j: jToBeSent,\n      },\n    };\n  }\n\n  /**\n   * Perform multiplicitive-to-additive (MtA) share conversion with another signer.\n   * @deprecated - use one of [signConvertStep1, signConvertStep2, signConvertStep3] instead\n   * @param {SignConvert} shares\n   * @returns {SignConvertRT}\n   */\n  async signConvert(shares: SignConvert): Promise<SignConvertRT> {\n    let shareParticipant: Partial<BShare> | Partial<GShare>, shareToBeSent: Partial<AShare> | MUShare;\n    let isGammaShare = false;\n    let kShare: Partial<KShare> = {};\n    if (shares.xShare && shares.yShare && shares.kShare) {\n      const xShare = shares.xShare; // currentParticipant secret xShare\n      const yShare: YShareWithChallenges = {\n        ...shares.yShare,\n        ntilde: shares.kShare.ntilde,\n        h1: shares.kShare.h1,\n        h2: shares.kShare.h2,\n        p: shares.kShare.p,\n      };\n      const signShare = await this.signShare(xShare, yShare);\n      kShare = signShare.kShare;\n      shareToBeSent = { ...shares.kShare } as Partial<AShare>;\n      shareParticipant = { ...signShare.wShare } as Partial<BShare>;\n    } else if ((shares.bShare && shares.muShare) || (shares.aShare && shares.wShare)) {\n      isGammaShare = true;\n      shareToBeSent = shares.aShare ? ({ ...shares.aShare } as MUShare) : ({ ...shares.muShare } as MUShare);\n      shareParticipant = shares.wShare ? ({ ...shares.wShare } as Partial<GShare>) : ({ ...shares.bShare } as GShare);\n    } else {\n      throw new Error('Invalid config for Sign Convert');\n    }\n    if (shareParticipant.i !== shareToBeSent.i) {\n      throw new Error('Shares from same participant');\n    }\n    if ((shareToBeSent as AShare).alpha) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      if (!aShareToBeSent.gammaProof) {\n        throw new Error('Unexpected missing gammaProof on aShareToBeSent');\n      }\n      if (!aShareToBeSent.wProof) {\n        throw new Error('Unexpected missing wProof on aShareToBeSent');\n      }\n      const pka = getPaillierPublicKey(hexToBigInt(bShareParticipant.n));\n      let ntildea, h1a, h2a, ck;\n      if (bShareParticipant.ntilde) {\n        ntildea = hexToBigInt(bShareParticipant.ntilde);\n        h1a = hexToBigInt(bShareParticipant.h1);\n        h2a = hexToBigInt(bShareParticipant.h2);\n        ck = hexToBigInt(bShareParticipant.ck);\n      }\n      // Verify $\\gamma_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.gammaProof.z),\n            zprm: hexToBigInt(aShareToBeSent.gammaProof.zprm),\n            t: hexToBigInt(aShareToBeSent.gammaProof.t),\n            v: hexToBigInt(aShareToBeSent.gammaProof.v),\n            w: hexToBigInt(aShareToBeSent.gammaProof.w),\n            s: hexToBigInt(aShareToBeSent.gammaProof.s),\n            s1: hexToBigInt(aShareToBeSent.gammaProof.s1),\n            s2: hexToBigInt(aShareToBeSent.gammaProof.s2),\n            t1: hexToBigInt(aShareToBeSent.gammaProof.t1),\n            t2: hexToBigInt(aShareToBeSent.gammaProof.t2),\n            u: hexToBigInt(aShareToBeSent.gammaProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.alpha),\n          hexToBigInt(aShareToBeSent.gammaProof.x)\n        )\n      ) {\n        throw new Error('could not verify signing share for gamma proof');\n      }\n      // Verify $\\w_i \\in Z_{N^2}$.\n      if (\n        !EcdsaRangeProof.verifyWithCheck(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildea,\n            h1: h1a,\n            h2: h2a,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.wProof.z),\n            zprm: hexToBigInt(aShareToBeSent.wProof.zprm),\n            t: hexToBigInt(aShareToBeSent.wProof.t),\n            v: hexToBigInt(aShareToBeSent.wProof.v),\n            w: hexToBigInt(aShareToBeSent.wProof.w),\n            s: hexToBigInt(aShareToBeSent.wProof.s),\n            s1: hexToBigInt(aShareToBeSent.wProof.s1),\n            s2: hexToBigInt(aShareToBeSent.wProof.s2),\n            t1: hexToBigInt(aShareToBeSent.wProof.t1),\n            t2: hexToBigInt(aShareToBeSent.wProof.t2),\n            u: hexToBigInt(aShareToBeSent.wProof.u),\n          },\n          ck,\n          hexToBigInt(aShareToBeSent.mu),\n          hexToBigInt(aShareToBeSent.wProof.x)\n        )\n      ) {\n        throw new Error('could not verify share for wProof');\n      }\n      const sk = new paillierBigint.PrivateKey(\n        hexToBigInt(bShareParticipant.l as string),\n        hexToBigInt(bShareParticipant.m as string),\n        pka\n      );\n      const gShareParticipant = shareParticipant as GShare;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      const alpha = sk.decrypt(hexToBigInt(aShareToBeSent.alpha));\n      gShareParticipant.alpha = bigIntToBufferBE(Ecdsa.curve.scalarReduce(alpha), 32).toString('hex');\n      const mu = sk.decrypt(hexToBigInt(aShareToBeSent.mu as string)); // recheck encrypted number\n      gShareParticipant.mu = bigIntToBufferBE(Ecdsa.curve.scalarReduce(mu), 32).toString('hex');\n      const partialShareParticipant = shareParticipant as Partial<GShare>;\n      const partialShareToBeSent = muShareToBeSent as Partial<MUShare>;\n      delete partialShareParticipant.l;\n      delete partialShareParticipant.m;\n      delete partialShareToBeSent.alpha;\n      delete partialShareToBeSent.mu;\n    }\n    if ((shareToBeSent as AShare).k) {\n      const bShareParticipant = shareParticipant as BShare;\n      const aShareToBeSent = shareToBeSent as AShare;\n      if (!aShareToBeSent.proof) {\n        throw new Error('Unexpected missing proof on aShareToBeSent');\n      }\n      const n = hexToBigInt(aShareToBeSent.n); // Paillier pub from other signer\n      const pka = getPaillierPublicKey(n);\n      const ntildea = hexToBigInt(aShareToBeSent.ntilde);\n      const h1a = hexToBigInt(aShareToBeSent.h1);\n      const h2a = hexToBigInt(aShareToBeSent.h2);\n      const ntildeb = hexToBigInt(bShareParticipant.ntilde);\n      const h1b = hexToBigInt(bShareParticipant.h1);\n      const h2b = hexToBigInt(bShareParticipant.h2);\n      const k = hexToBigInt(aShareToBeSent.k);\n      if (\n        !EcdsaRangeProof.verify(\n          Ecdsa.curve,\n          minModulusBitLength,\n          pka,\n          {\n            ntilde: ntildeb,\n            h1: h1b,\n            h2: h2b,\n          },\n          {\n            z: hexToBigInt(aShareToBeSent.proof.z),\n            u: hexToBigInt(aShareToBeSent.proof.u),\n            w: hexToBigInt(aShareToBeSent.proof.w),\n            s: hexToBigInt(aShareToBeSent.proof.s),\n            s1: hexToBigInt(aShareToBeSent.proof.s1),\n            s2: hexToBigInt(aShareToBeSent.proof.s2),\n          },\n          k\n        )\n      ) {\n        throw new Error('Could not verify signing A share proof');\n      }\n      // MtA $k_j, \\gamma_i$.\n      const beta0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      bShareParticipant.beta = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(beta0)), 32).toString(\n        'hex'\n      );\n      const g = hexToBigInt(bShareParticipant.gamma);\n      const rb = await randomPositiveCoPrimeTo(pka.n);\n      const cb = pka.encrypt(beta0, rb);\n      const alpha = pka.addition(pka.multiply(k, g), cb);\n      aShareToBeSent.alpha = bigIntToBufferBE(alpha, 32).toString('hex');\n      // Prove $\\gamma_i \\in Z_{N^2}$.\n      const gx = Ecdsa.curve.basePointMult(g);\n      let proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        alpha,\n        g,\n        beta0,\n        rb,\n        gx\n      );\n      Object.assign(aShareToBeSent, {\n        gammaProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(gx, 33).toString('hex'),\n        },\n      });\n      // MtA $k_j, w_i$.\n      const nu0 = bigintCryptoUtils.randBetween(Ecdsa.curve.order() ** _5n);\n      shareParticipant.nu = bigIntToBufferBE(Ecdsa.curve.scalarNegate(Ecdsa.curve.scalarReduce(nu0)), 32).toString(\n        'hex'\n      );\n      const w = hexToBigInt(bShareParticipant.w);\n      const rn = await randomPositiveCoPrimeTo(pka.n);\n      const cn = pka.encrypt(nu0, rn);\n      const mu = pka.addition(pka.multiply(k, w), cn);\n      shareToBeSent.mu = bigIntToBufferBE(mu, 32).toString('hex');\n      // Prove $\\w_i \\in Z_{N^2}$.\n      const wx = Ecdsa.curve.basePointMult(w);\n      proof = await EcdsaRangeProof.proveWithCheck(\n        Ecdsa.curve,\n        minModulusBitLength,\n        pka,\n        {\n          ntilde: ntildea,\n          h1: h1a,\n          h2: h2a,\n        },\n        k,\n        hexToBigInt(aShareToBeSent.mu),\n        w,\n        nu0,\n        rn,\n        wx\n      );\n      Object.assign(shareToBeSent, {\n        wProof: {\n          z: bigIntToBufferBE(proof.z, 384).toString('hex'),\n          zprm: bigIntToBufferBE(proof.zprm, 384).toString('hex'),\n          t: bigIntToBufferBE(proof.t, 384).toString('hex'),\n          v: bigIntToBufferBE(proof.v, 768).toString('hex'),\n          w: bigIntToBufferBE(proof.w, 384).toString('hex'),\n          s: bigIntToBufferBE(proof.s, 384).toString('hex'),\n          s1: bigIntToBufferBE(proof.s1, 96).toString('hex'),\n          s2: bigIntToBufferBE(proof.s2, 480).toString('hex'),\n          t1: bigIntToBufferBE(proof.t1, 224).toString('hex'),\n          t2: bigIntToBufferBE(proof.t2, 480).toString('hex'),\n          u: bigIntToBufferBE(proof.u, 33).toString('hex'),\n          x: bigIntToBufferBE(wx, 33).toString('hex'),\n        },\n      });\n      if ((shareParticipant as GShare).alpha) {\n        const partialShareParticipant = shareParticipant as Partial<BShare>;\n        const partialShareToBeSent = shareToBeSent as Partial<AShare>;\n        delete partialShareParticipant.ntilde;\n        delete partialShareParticipant.h1;\n        delete partialShareParticipant.h2;\n        delete partialShareParticipant.ck;\n        delete partialShareToBeSent.n;\n        delete partialShareToBeSent.ntilde;\n        delete partialShareToBeSent.h1;\n        delete partialShareToBeSent.h2;\n        delete partialShareToBeSent.k;\n        delete partialShareToBeSent.proof;\n      } else {\n        Object.assign(shareToBeSent, {\n          n: kShare.n,\n          ntilde: bigIntToBufferBE(ntildeb, 384).toString('hex'),\n          h1: bigIntToBufferBE(h1b, 384).toString('hex'),\n          h2: bigIntToBufferBE(h2b, 384).toString('hex'),\n          k: kShare.k,\n          proof: kShare.proof,\n        });\n      }\n    }\n    if (!('alpha' in shareToBeSent) && !('k' in shareToBeSent)) {\n      const partialShareParticipant = shareParticipant as Partial<BShare>;\n      delete partialShareParticipant.ntilde;\n      delete partialShareParticipant.h1;\n      delete partialShareParticipant.h2;\n      delete partialShareParticipant.ck;\n      const muShareToBeSent = shareToBeSent as MUShare;\n      shareToBeSent = {\n        i: muShareToBeSent.i,\n        j: muShareToBeSent.j,\n      } as MUShare;\n    }\n    [shareToBeSent.i, shareToBeSent.j] = [shareToBeSent.j, shareToBeSent.i];\n    if (isGammaShare) {\n      return {\n        muShare: shareToBeSent as MUShare,\n        gShare: shareParticipant as GShare,\n      };\n    }\n    return {\n      aShare: shareToBeSent as AShare,\n      bShare: shareParticipant as BShare,\n    };\n  }\n\n  /**\n   * Combine gamma shares to get the private omicron / delta shares\n   * @param {SignCombine} shares\n   * @returns {SignCombineRT}\n   */\n  signCombine(shares: SignCombine): SignCombineRT {\n    const gShare = shares.gShare;\n    const S = shares.signIndex;\n    const gamma = hexToBigInt(gShare.gamma);\n    const alpha = hexToBigInt(gShare.alpha);\n    const beta = hexToBigInt(gShare.beta);\n    const mu = hexToBigInt(gShare.mu);\n    const nu = hexToBigInt(gShare.nu);\n    const k = hexToBigInt(gShare.k);\n    const w = hexToBigInt(gShare.w);\n\n    const delta = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, gamma), Ecdsa.curve.scalarAdd(alpha, beta));\n    const omicron = Ecdsa.curve.scalarAdd(Ecdsa.curve.scalarMult(k, w), Ecdsa.curve.scalarAdd(mu, nu));\n    const Gamma = Ecdsa.curve.basePointMult(gamma);\n\n    return {\n      oShare: {\n        i: gShare.i,\n        y: gShare.y,\n        k: bigIntToBufferBE(k, 32).toString('hex'),\n        omicron: bigIntToBufferBE(omicron, 32).toString('hex'),\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n      dShare: {\n        i: S.i,\n        j: gShare.i,\n        delta: bigIntToBufferBE(delta, 32).toString('hex'),\n        Gamma: bigIntToBufferBE(Gamma, 33).toString('hex'),\n      },\n    };\n  }\n\n  /**\n   * Sign a message.\n   * @param {Buffer} M Message to be signed\n   * @param {OShare} oShare private omicron share of current participant\n   * @param {DShare} dShare delta share received from the other participant\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before signing\n   * @returns {SShare}\n   */\n  sign(M: Buffer, oShare: OShare, dShare: DShare, hash?: Hash, shouldHash = true): SShare {\n    const m = shouldHash ? (hash || createHash('sha256')).update(M).digest() : M;\n\n    const delta = Ecdsa.curve.scalarAdd(hexToBigInt(oShare.delta), hexToBigInt(dShare.delta));\n\n    const R = Ecdsa.curve.pointMultiply(\n      Ecdsa.curve.pointAdd(hexToBigInt(oShare.Gamma), hexToBigInt(dShare.Gamma)),\n      Ecdsa.curve.scalarInvert(delta)\n    );\n    const pointR = secp.Point.fromHex(bigIntToBufferBE(R, 32));\n    const r = pointR.x;\n\n    const s = Ecdsa.curve.scalarAdd(\n      Ecdsa.curve.scalarMult(bigIntFromU8ABE(m), hexToBigInt(oShare.k)),\n      Ecdsa.curve.scalarMult(r, hexToBigInt(oShare.omicron))\n    );\n    return {\n      i: oShare.i,\n      y: oShare.y,\n      R: pointR.toHex(true),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n    };\n  }\n\n  /**\n   * Construct full signature by combining Sign Shares\n   * @param {SShare[]} shares\n   * @returns {Signature}\n   */\n  constructSignature(shares: SShare[]): Signature {\n    // Every R must match.\n    const R = shares[0]['R'];\n    const isRMatching = shares.map((share) => share['R'] === R).reduce((a, b) => a && b);\n    if (!isRMatching) {\n      throw new Error('R value should be consistent across all shares');\n    }\n\n    let s = shares.map((share) => hexToBigInt(share['s'])).reduce(Ecdsa.curve.scalarAdd);\n    const recid = (R.slice(0, 2) === '03' ? 1 : 0) ^ (s > Ecdsa.curve.order() / BigInt(2) ? 1 : 0);\n\n    // Normalize s.\n    s = s > Ecdsa.curve.order() / BigInt(2) ? Ecdsa.curve.order() - s : s;\n    return {\n      y: shares[0]['y'],\n      r: R.slice(2),\n      s: bigIntToBufferBE(s, 32).toString('hex'),\n      recid: recid,\n    };\n  }\n\n  /**\n   * Verify ecdsa signatures\n   * @param {Buffer} message\n   * @param {Signature } signature\n   * @param {Hash} hash hashing algorithm implementing Node`s standard crypto hash interface\n   * @param {boolean} shouldHash if true, we hash the provided buffer before verifying\n   * @returns {boolean} True if signature is valid; False otherwise\n   */\n  verify(message: Buffer, signature: Signature, hash?: Hash, shouldHash = true): boolean {\n    const messageToVerify = shouldHash ? (hash || createHash('sha256')).update(message).digest() : message;\n    return Ecdsa.curve.verify(\n      messageToVerify,\n      Buffer.concat([\n        Buffer.from([signature['recid']]),\n        bigIntToBufferBE(hexToBigInt(signature['r']), 32),\n        bigIntToBufferBE(hexToBigInt(signature['s']), 32),\n      ]),\n      hexToBigInt(signature['y'])\n    );\n  }\n\n  /**\n   * Deserializes a challenge and it's proofs from hex strings to bigint\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   */\n  static deserializeNtilde(challenge: EcdsaTypes.SerializedNtilde): EcdsaTypes.DeserializedNtilde {\n    return EcdsaTypes.deserializeNtilde(challenge);\n  }\n\n  /**\n   * Serializes a challenge and it's proofs from big int to hex strings.\n   * @deprecated use sdk-lib-mpc EcdsaTypes.deserializeNtilde instead\n   * @param challenge\n   */\n  static serializeNtilde(challenge: EcdsaTypes.DeserializedNtilde): EcdsaTypes.SerializedNtilde {\n    return EcdsaTypes.serializeNtilde(challenge);\n  }\n}\n"]}
|