@bitgo-beta/sdk-core 8.2.1-beta.9 → 8.2.1-beta.91
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 +151 -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/tss/ecdsa/ecdsa.d.ts +33 -10
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +551 -141
- 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/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 +18 -2
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.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 +1 -0
- package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/iKeychains.js +1 -1
- package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/keychains.js +30 -24
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.js +12 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/stakingWallet.js +9 -1
- package/dist/src/bitgo/tss/common.d.ts +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 +4 -3
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.js +16 -5
- package/dist/src/bitgo/tss/types.d.ts +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/tss/baseTSSUtils.d.ts +53 -12
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +62 -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 +44 -5
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +229 -86
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +76 -22
- package/dist/src/bitgo/wallet/iWallet.d.ts +12 -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 +10 -2
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +108 -14
- package/dist/src/index.d.ts +4 -0
- 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/tsconfig.tsbuildinfo +1 -8272
- package/package.json +8 -7
- package/dist/src/openssl/openssl.d.ts +0 -12
- package/dist/src/openssl/openssl.d.ts.map +0 -1
- package/dist/src/openssl/openssl.js +0 -48
- package/dist/src/openssl/opensslbytes.d.ts +0 -4
- package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
- package/dist/src/openssl/opensslbytes.js +0 -20
|
@@ -26,6 +26,7 @@ exports.EcdsaUtils = void 0;
|
|
|
26
26
|
const assert_1 = __importDefault(require("assert"));
|
|
27
27
|
const buffer_1 = require("buffer");
|
|
28
28
|
const openpgp = __importStar(require("openpgp"));
|
|
29
|
+
const elliptic_1 = require("elliptic");
|
|
29
30
|
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
30
31
|
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
31
32
|
const tss_1 = require("../../../../account-lib/mpc/tss");
|
|
@@ -38,7 +39,7 @@ const opengpgUtils_1 = require("../../opengpgUtils");
|
|
|
38
39
|
const ecdsa_2 = require("../../../tss/ecdsa/ecdsa");
|
|
39
40
|
const ecdh_1 = require("../../../ecdh");
|
|
40
41
|
const common_1 = require("../../../tss/common");
|
|
41
|
-
const
|
|
42
|
+
const types_2 = require("../../../tss/types");
|
|
42
43
|
const encryptNShare = ecdsa_1.default.encryptNShare;
|
|
43
44
|
/** @inheritdoc */
|
|
44
45
|
class EcdsaUtils extends baseTSSUtils_1.default {
|
|
@@ -422,61 +423,28 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
422
423
|
? await keychains.add(recipientKeychainParams)
|
|
423
424
|
: await keychains.createBackup(recipientKeychainParams);
|
|
424
425
|
}
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
* @param {string} params.prv - decrypted private key
|
|
429
|
-
* @param { string} params.reqId - request id
|
|
430
|
-
* @returns {Promise<TxRequest>}
|
|
431
|
-
*/
|
|
432
|
-
async signRequestBase(params, requestType) {
|
|
433
|
-
var _a;
|
|
434
|
-
const pendingEcdsaTssInitialization = (_a = this.wallet.coinSpecific()) === null || _a === void 0 ? void 0 : _a.pendingEcdsaTssInitialization;
|
|
435
|
-
if (pendingEcdsaTssInitialization) {
|
|
436
|
-
throw new Error('Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.');
|
|
437
|
-
}
|
|
438
|
-
const userSigningMaterial = JSON.parse(params.prv);
|
|
426
|
+
async createTssEcdsaStep1SigningMaterial(params) {
|
|
427
|
+
const { challenges, derivationPath, prv } = params;
|
|
428
|
+
const userSigningMaterial = JSON.parse(prv);
|
|
439
429
|
if (userSigningMaterial.pShare.i !== 1) {
|
|
440
430
|
throw new Error('Invalid user key');
|
|
441
431
|
}
|
|
442
432
|
if (!userSigningMaterial.backupNShare) {
|
|
443
433
|
throw new Error('Invalid user key - missing backupNShare');
|
|
444
434
|
}
|
|
445
|
-
const txRequest = typeof params.txRequest === 'string'
|
|
446
|
-
? await tss_2.getTxRequest(this.bitgo, this.wallet.id(), params.txRequest)
|
|
447
|
-
: params.txRequest;
|
|
448
|
-
let signablePayload;
|
|
449
|
-
let derivationPath;
|
|
450
|
-
if (requestType === baseTypes_1.RequestType.tx) {
|
|
451
|
-
assert_1.default(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');
|
|
452
|
-
const unsignedTx = txRequest.apiVersion === 'full' ? txRequest.transactions[0].unsignedTx : txRequest.unsignedTxs[0];
|
|
453
|
-
signablePayload = buffer_1.Buffer.from(unsignedTx.signableHex, 'hex');
|
|
454
|
-
derivationPath = unsignedTx.derivationPath;
|
|
455
|
-
}
|
|
456
|
-
else if (requestType === baseTypes_1.RequestType.message) {
|
|
457
|
-
signablePayload = params.bufferToSign;
|
|
458
|
-
// TODO BG-67299 Message signing with derivation path
|
|
459
|
-
derivationPath = '';
|
|
460
|
-
}
|
|
461
435
|
const MPC = new tss_1.Ecdsa();
|
|
462
436
|
const signingKey = MPC.keyDerive(userSigningMaterial.pShare, [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare], derivationPath);
|
|
463
|
-
const bitgoIndex =
|
|
464
|
-
const userIndex =
|
|
465
|
-
const
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
};
|
|
470
|
-
const challenges = await this.getEcdsaSigningChallenges(txRequest.txRequestId, requestType, 0);
|
|
471
|
-
const signingKeyWithChallenge = await MPC.appendChallenge(signingKey.xShare, yShare, challenges.enterpriseChallenge);
|
|
472
|
-
const userSignShare = await ecdsa_1.default.createUserSignShare(signingKeyWithChallenge.xShare, {
|
|
437
|
+
const bitgoIndex = types_2.ShareKeyPosition.BITGO;
|
|
438
|
+
const userIndex = userSigningMaterial.pShare.i;
|
|
439
|
+
const { ntilde: ntildea, h1: h1a, h2: h2a, p: pa } = challenges.enterpriseChallenge;
|
|
440
|
+
const { ntilde: ntildeb, h1: h1b, h2: h2b, p: pb, n: nb } = challenges.bitgoChallenge;
|
|
441
|
+
const userXShare = MPC.appendChallenge(signingKey.xShare, { ntilde: ntildea, h1: h1a, h2: h2a }, { p: pa });
|
|
442
|
+
const bitgoYShare = MPC.appendChallenge({
|
|
473
443
|
i: userIndex,
|
|
474
444
|
j: bitgoIndex,
|
|
475
|
-
n:
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
h2: challenges.bitgoChallenge.h2,
|
|
479
|
-
});
|
|
445
|
+
n: nb,
|
|
446
|
+
}, { ntilde: ntildeb, h1: h1b, h2: h2b }, { p: pb });
|
|
447
|
+
const userSignShare = await ecdsa_1.default.createUserSignShare(userXShare, bitgoYShare);
|
|
480
448
|
const u = signingKey.nShares[bitgoIndex].u;
|
|
481
449
|
let chaincode = userSigningMaterial.bitgoNShare.chaincode;
|
|
482
450
|
while (chaincode.length < 64) {
|
|
@@ -498,20 +466,184 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
498
466
|
const vssProof = signingKey.nShares[bitgoIndex].v;
|
|
499
467
|
const userPublicGpgKey = userGpgKey.publicKey;
|
|
500
468
|
const publicShare = signingKey.nShares[bitgoIndex].y + signingKey.nShares[bitgoIndex].chaincode;
|
|
501
|
-
|
|
502
|
-
|
|
469
|
+
return {
|
|
470
|
+
privateShareProof: privateShareProof,
|
|
471
|
+
vssProof: vssProof,
|
|
472
|
+
publicShare: publicShare,
|
|
473
|
+
encryptedSignerOffsetShare: encryptedSignerShare,
|
|
474
|
+
userPublicGpgKey: userPublicGpgKey,
|
|
475
|
+
kShare: userSignShare.kShare,
|
|
476
|
+
wShare: params.walletPassphrase
|
|
477
|
+
? this.bitgo.encrypt({ input: JSON.stringify(userSignShare.wShare), password: params.walletPassphrase })
|
|
478
|
+
: userSignShare.wShare,
|
|
479
|
+
};
|
|
480
|
+
}
|
|
481
|
+
async createTssEcdsaStep2SigningMaterial(params) {
|
|
503
482
|
// Append the BitGo challenge to the Ashare to be used in subsequent proofs
|
|
504
483
|
const bitgoToUserAShareWithNtilde = {
|
|
505
|
-
...
|
|
506
|
-
...
|
|
484
|
+
...params.aShareFromBitgo,
|
|
485
|
+
...params.bitgoChallenge,
|
|
507
486
|
};
|
|
508
|
-
const userGammaAndMuShares = await ecdsa_1.default.createUserGammaAndMuShare(
|
|
487
|
+
const userGammaAndMuShares = await ecdsa_1.default.createUserGammaAndMuShare(params.wShare, bitgoToUserAShareWithNtilde);
|
|
509
488
|
const userOmicronAndDeltaShare = await ecdsa_1.default.createUserOmicronAndDeltaShare(userGammaAndMuShares.gShare);
|
|
510
|
-
|
|
511
|
-
|
|
489
|
+
return {
|
|
490
|
+
muDShare: {
|
|
491
|
+
muShare: userGammaAndMuShares.muShare,
|
|
492
|
+
dShare: userOmicronAndDeltaShare.dShare,
|
|
493
|
+
i: userGammaAndMuShares.muShare.i,
|
|
494
|
+
},
|
|
495
|
+
oShare: params.walletPassphrase
|
|
496
|
+
? this.bitgo.encrypt({
|
|
497
|
+
input: JSON.stringify(userOmicronAndDeltaShare.oShare),
|
|
498
|
+
password: params.walletPassphrase,
|
|
499
|
+
})
|
|
500
|
+
: userOmicronAndDeltaShare.oShare,
|
|
501
|
+
};
|
|
502
|
+
}
|
|
503
|
+
getOfflineSignerPaillierModulus(params) {
|
|
504
|
+
assert_1.default(params.prv, 'Params to get paillier modulus are missing prv.');
|
|
505
|
+
const userSigningMaterial = JSON.parse(params.prv);
|
|
506
|
+
return { userPaillierModulus: userSigningMaterial.pShare.n };
|
|
507
|
+
}
|
|
508
|
+
async createOfflineKShare(params) {
|
|
509
|
+
const { tssParams, prv, requestType, challenges } = params;
|
|
510
|
+
assert_1.default(typeof tssParams.txRequest !== 'string', 'Invalid txRequest type');
|
|
511
|
+
const txRequest = tssParams.txRequest;
|
|
512
|
+
let derivationPath;
|
|
513
|
+
if (requestType === baseTypes_1.RequestType.tx) {
|
|
514
|
+
assert_1.default(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');
|
|
515
|
+
const unsignedTx = txRequest.apiVersion === 'full' ? txRequest.transactions[0].unsignedTx : txRequest.unsignedTxs[0];
|
|
516
|
+
derivationPath = unsignedTx.derivationPath;
|
|
517
|
+
}
|
|
518
|
+
else if (requestType === baseTypes_1.RequestType.message) {
|
|
519
|
+
// TODO BG-67299 Message signing with derivation path
|
|
520
|
+
derivationPath = '';
|
|
521
|
+
}
|
|
522
|
+
return this.createTssEcdsaStep1SigningMaterial({
|
|
523
|
+
prv: prv,
|
|
524
|
+
challenges: challenges,
|
|
525
|
+
derivationPath: derivationPath,
|
|
526
|
+
walletPassphrase: params.walletPassphrase,
|
|
527
|
+
});
|
|
528
|
+
}
|
|
529
|
+
async createOfflineMuDeltaShare(params) {
|
|
530
|
+
const decryptedWShare = this.bitgo.decrypt({ input: params.encryptedWShare, password: params.walletPassphrase });
|
|
531
|
+
return await this.createTssEcdsaStep2SigningMaterial({
|
|
532
|
+
aShareFromBitgo: params.aShareFromBitgo,
|
|
533
|
+
bitgoChallenge: params.bitgoChallenge,
|
|
534
|
+
wShare: JSON.parse(decryptedWShare),
|
|
535
|
+
walletPassphrase: params.walletPassphrase,
|
|
536
|
+
});
|
|
537
|
+
}
|
|
538
|
+
async createOfflineSShare(params) {
|
|
539
|
+
const { tssParams, requestType, dShareFromBitgo, encryptedOShare, walletPassphrase } = params;
|
|
540
|
+
assert_1.default(typeof tssParams.txRequest !== 'string', 'Invalid txRequest type');
|
|
541
|
+
const txRequest = tssParams.txRequest;
|
|
542
|
+
let signablePayload;
|
|
543
|
+
if (requestType === baseTypes_1.RequestType.tx) {
|
|
544
|
+
assert_1.default(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');
|
|
545
|
+
const unsignedTx = txRequest.apiVersion === 'full' ? txRequest.transactions[0].unsignedTx : txRequest.unsignedTxs[0];
|
|
546
|
+
signablePayload = buffer_1.Buffer.from(unsignedTx.signableHex, 'hex');
|
|
547
|
+
}
|
|
548
|
+
else if (requestType === baseTypes_1.RequestType.message) {
|
|
549
|
+
signablePayload = params.tssParams.bufferToSign;
|
|
550
|
+
}
|
|
551
|
+
const decryptedOShare = this.bitgo.decrypt({ input: encryptedOShare, password: walletPassphrase });
|
|
552
|
+
return await ecdsa_1.default.createUserSignatureShare(JSON.parse(decryptedOShare), dShareFromBitgo, signablePayload);
|
|
553
|
+
}
|
|
554
|
+
async signEcdsaTssUsingExternalSigner(params, requestType, externalSignerPaillierModulusGetter, externalSignerKShareGenerator, externalSignerMuDeltaShareGenerator, externalSignerSShareGenerator) {
|
|
555
|
+
var _a;
|
|
556
|
+
const { txRequest } = params;
|
|
557
|
+
const pendingEcdsaTssInitialization = (_a = this.wallet.coinSpecific()) === null || _a === void 0 ? void 0 : _a.pendingEcdsaTssInitialization;
|
|
558
|
+
if (pendingEcdsaTssInitialization) {
|
|
559
|
+
throw new Error('Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.');
|
|
560
|
+
}
|
|
561
|
+
const txRequestObj = await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequest);
|
|
562
|
+
const { userPaillierModulus } = await externalSignerPaillierModulusGetter({ txRequest: txRequestObj });
|
|
563
|
+
const { enterpriseChallenge, bitgoChallenge } = await this.getEcdsaSigningChallenges(txRequest, requestType, userPaillierModulus, 0);
|
|
564
|
+
const step1SigningMaterial = await externalSignerKShareGenerator({
|
|
565
|
+
tssParams: {
|
|
566
|
+
...params,
|
|
567
|
+
txRequest: txRequestObj,
|
|
568
|
+
},
|
|
569
|
+
challenges: { enterpriseChallenge, bitgoChallenge },
|
|
570
|
+
requestType: requestType,
|
|
571
|
+
});
|
|
572
|
+
// signing stage one with K share send to bitgo and receives A share
|
|
573
|
+
const bitgoToUserAShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequestObj.txRequestId, requestType, types_1.SendShareType.KShare, step1SigningMaterial.kShare, step1SigningMaterial.encryptedSignerOffsetShare, step1SigningMaterial.vssProof, step1SigningMaterial.privateShareProof, step1SigningMaterial.publicShare, step1SigningMaterial.userPublicGpgKey)); // WP/HSM does not return the initial challenge
|
|
574
|
+
const step2Return = await externalSignerMuDeltaShareGenerator({
|
|
575
|
+
txRequest: txRequestObj,
|
|
576
|
+
aShareFromBitgo: bitgoToUserAShare,
|
|
577
|
+
bitgoChallenge: bitgoChallenge,
|
|
578
|
+
encryptedWShare: step1SigningMaterial.wShare,
|
|
579
|
+
});
|
|
580
|
+
// signing stage two with muShare and dShare send to bitgo and receives D share
|
|
581
|
+
const bitgoToUserDShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequestObj.txRequestId, requestType, types_1.SendShareType.MUShare, step2Return.muDShare));
|
|
582
|
+
const userSShare = await externalSignerSShareGenerator({
|
|
583
|
+
tssParams: {
|
|
584
|
+
...params,
|
|
585
|
+
txRequest: txRequestObj,
|
|
586
|
+
},
|
|
587
|
+
dShareFromBitgo: bitgoToUserDShare,
|
|
588
|
+
requestType: requestType,
|
|
589
|
+
encryptedOShare: step2Return.oShare,
|
|
590
|
+
});
|
|
591
|
+
// signing stage three with SShare send to bitgo and receives SShare
|
|
592
|
+
await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequestObj.txRequestId, requestType, types_1.SendShareType.SShare, userSShare);
|
|
593
|
+
return await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequestObj.txRequestId);
|
|
594
|
+
}
|
|
595
|
+
/**
|
|
596
|
+
* Gets signing key, txRequestResolved and txRequestId
|
|
597
|
+
* @param {string | TxRequest} params.txRequest - transaction request object or id
|
|
598
|
+
* @param {string} params.prv - decrypted private key
|
|
599
|
+
* @param { string} params.reqId - request id
|
|
600
|
+
* @returns {Promise<TxRequest>}
|
|
601
|
+
*/
|
|
602
|
+
async signRequestBase(params, requestType) {
|
|
603
|
+
var _a;
|
|
604
|
+
const pendingEcdsaTssInitialization = (_a = this.wallet.coinSpecific()) === null || _a === void 0 ? void 0 : _a.pendingEcdsaTssInitialization;
|
|
605
|
+
if (pendingEcdsaTssInitialization) {
|
|
606
|
+
throw new Error('Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.');
|
|
607
|
+
}
|
|
608
|
+
const userSigningMaterial = JSON.parse(params.prv);
|
|
609
|
+
if (userSigningMaterial.pShare.i !== 1) {
|
|
610
|
+
throw new Error('Invalid user key');
|
|
611
|
+
}
|
|
612
|
+
if (!userSigningMaterial.backupNShare) {
|
|
613
|
+
throw new Error('Invalid user key - missing backupNShare');
|
|
614
|
+
}
|
|
615
|
+
const txRequest = typeof params.txRequest === 'string'
|
|
616
|
+
? await tss_2.getTxRequest(this.bitgo, this.wallet.id(), params.txRequest)
|
|
617
|
+
: params.txRequest;
|
|
618
|
+
let signablePayload = new buffer_1.Buffer('');
|
|
619
|
+
let derivationPath = '';
|
|
620
|
+
if (requestType === baseTypes_1.RequestType.tx) {
|
|
621
|
+
assert_1.default(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');
|
|
622
|
+
const unsignedTx = txRequest.apiVersion === 'full' ? txRequest.transactions[0].unsignedTx : txRequest.unsignedTxs[0];
|
|
623
|
+
signablePayload = buffer_1.Buffer.from(unsignedTx.signableHex, 'hex');
|
|
624
|
+
derivationPath = unsignedTx.derivationPath;
|
|
625
|
+
}
|
|
626
|
+
else if (requestType === baseTypes_1.RequestType.message) {
|
|
627
|
+
signablePayload = params.bufferToSign;
|
|
628
|
+
// TODO BG-67299 Message signing with derivation path
|
|
629
|
+
}
|
|
630
|
+
const paillierModulus = this.getOfflineSignerPaillierModulus({ prv: params.prv });
|
|
631
|
+
const challenges = await this.getEcdsaSigningChallenges(txRequest.txRequestId, requestType, paillierModulus.userPaillierModulus, 0);
|
|
632
|
+
const step1Return = await this.createTssEcdsaStep1SigningMaterial({
|
|
633
|
+
prv: params.prv,
|
|
634
|
+
challenges: challenges,
|
|
635
|
+
derivationPath: derivationPath,
|
|
636
|
+
});
|
|
637
|
+
// signing stage one with K share send to bitgo and receives A share
|
|
638
|
+
const bitgoToUserAShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.KShare, step1Return.kShare, step1Return.encryptedSignerOffsetShare, step1Return.vssProof, step1Return.privateShareProof, step1Return.publicShare, step1Return.userPublicGpgKey)); // WP/HSM does not return the initial challenge
|
|
639
|
+
const step2Return = await this.createTssEcdsaStep2SigningMaterial({
|
|
640
|
+
aShareFromBitgo: bitgoToUserAShare,
|
|
641
|
+
bitgoChallenge: challenges.bitgoChallenge,
|
|
642
|
+
wShare: step1Return.wShare,
|
|
643
|
+
});
|
|
512
644
|
// signing stage two with muShare and dShare send to bitgo and receives D share
|
|
513
|
-
const bitgoToUserDShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.MUShare,
|
|
514
|
-
const userSShare = await ecdsa_1.default.createUserSignatureShare(
|
|
645
|
+
const bitgoToUserDShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.MUShare, step2Return.muDShare));
|
|
646
|
+
const userSShare = await ecdsa_1.default.createUserSignatureShare(step2Return.oShare, bitgoToUserDShare, signablePayload, params.hash);
|
|
515
647
|
// signing stage three with SShare send to bitgo and receives SShare
|
|
516
648
|
await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.SShare, userSShare);
|
|
517
649
|
return await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequest.txRequestId);
|
|
@@ -544,53 +676,53 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
544
676
|
* Only returns the challenges if they are verified by the user's enterprise admin's ecdh key
|
|
545
677
|
* @param {string} txRequestId - transaction request id
|
|
546
678
|
* @param {RequestType} requestType - (0 for tx, 1 for message)
|
|
679
|
+
* @param {string} walletPaillierModulus - paillier pubkey $n$
|
|
547
680
|
* @param {number} index - index of the requestType
|
|
548
681
|
*/
|
|
549
|
-
async getEcdsaSigningChallenges(txRequestId, requestType, index = 0) {
|
|
682
|
+
async getEcdsaSigningChallenges(txRequestId, requestType, walletPaillierModulus, index = 0) {
|
|
550
683
|
const enterpriseId = this.wallet.toJSON().enterprise;
|
|
551
684
|
if (!enterpriseId) {
|
|
552
685
|
throw new Error('Wallet must be an enterprise wallet.');
|
|
553
686
|
}
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
};
|
|
564
|
-
}
|
|
565
|
-
const result = await this.wallet.getChallengesForEcdsaSigning();
|
|
566
|
-
const enterpriseChallenge = result.enterpriseChallenge;
|
|
567
|
-
const bitgoChallenge = result.bitgoChallenge;
|
|
568
|
-
const challengeVerifierUserId = result.createdBy;
|
|
687
|
+
// create BitGo range proof and paillier proof challenge
|
|
688
|
+
const createBitgoChallengeResponse = await common_1.getTxRequestChallenge(this.bitgo, this.wallet.id(), txRequestId, index.toString(), requestType, walletPaillierModulus);
|
|
689
|
+
const bitgoToEnterprisePaillierChallenge = { p: createBitgoChallengeResponse.p };
|
|
690
|
+
const enterpriseToBitgoPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({
|
|
691
|
+
p: await sdk_lib_mpc_1.EcdsaPaillierProof.generateP(sdk_lib_mpc_1.hexToBigInt(createBitgoChallengeResponse.n)),
|
|
692
|
+
});
|
|
693
|
+
// TODO(BG-78764): once the paillier proofs are complete, reduce challenge creation to one API call
|
|
694
|
+
const walletChallenges = await this.wallet.getChallengesForEcdsaSigning();
|
|
695
|
+
const challengeVerifierUserId = walletChallenges.createdBy;
|
|
569
696
|
const adminSigningKeyResponse = await this.bitgo.getSigningKeyForUser(enterpriseId, challengeVerifierUserId);
|
|
570
697
|
const pubkeyOfAdminEcdhKeyHex = adminSigningKeyResponse.derivedPubkey;
|
|
571
|
-
// Verify enterprise's challenge is signed by the respective
|
|
698
|
+
// Verify enterprise's challenge is signed by the respective admins ecdh keychain
|
|
572
699
|
const enterpriseRawChallenge = {
|
|
573
|
-
ntilde: enterpriseChallenge.ntilde,
|
|
574
|
-
h1: enterpriseChallenge.h1,
|
|
575
|
-
h2: enterpriseChallenge.h2,
|
|
700
|
+
ntilde: walletChallenges.enterpriseChallenge.ntilde,
|
|
701
|
+
h1: walletChallenges.enterpriseChallenge.h1,
|
|
702
|
+
h2: walletChallenges.enterpriseChallenge.h2,
|
|
576
703
|
};
|
|
577
|
-
const adminSignatureOnEntChallenge = enterpriseChallenge.verifiers.adminSignature;
|
|
704
|
+
const adminSignatureOnEntChallenge = walletChallenges.enterpriseChallenge.verifiers.adminSignature;
|
|
578
705
|
if (!ecdh_1.verifyEcdhSignature(EcdsaUtils.getMessageToSignFromChallenge(enterpriseRawChallenge), adminSignatureOnEntChallenge, buffer_1.Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex'))) {
|
|
579
706
|
throw new Error(`Admin signature for enterprise challenge is not valid. Please contact your enterprise admin.`);
|
|
580
707
|
}
|
|
581
708
|
// Verify that the BitGo challenge's ZK proofs have been verified by the admin
|
|
582
|
-
const
|
|
583
|
-
ntilde: bitgoChallenge.ntilde,
|
|
584
|
-
h1: bitgoChallenge.h1,
|
|
585
|
-
h2: bitgoChallenge.h2,
|
|
709
|
+
const bitgoChallenge = {
|
|
710
|
+
ntilde: walletChallenges.bitgoChallenge.ntilde,
|
|
711
|
+
h1: walletChallenges.bitgoChallenge.h1,
|
|
712
|
+
h2: walletChallenges.bitgoChallenge.h2,
|
|
713
|
+
p: bitgoToEnterprisePaillierChallenge.p,
|
|
714
|
+
n: createBitgoChallengeResponse.n,
|
|
586
715
|
};
|
|
587
|
-
const adminVerificationSignatureForBitGoChallenge = bitgoChallenge.verifiers.adminSignature;
|
|
588
|
-
if (!ecdh_1.verifyEcdhSignature(EcdsaUtils.getMessageToSignFromChallenge(
|
|
716
|
+
const adminVerificationSignatureForBitGoChallenge = walletChallenges.bitgoChallenge.verifiers.adminSignature;
|
|
717
|
+
if (!ecdh_1.verifyEcdhSignature(EcdsaUtils.getMessageToSignFromChallenge(bitgoChallenge), adminVerificationSignatureForBitGoChallenge, buffer_1.Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex'))) {
|
|
589
718
|
throw new Error(`Admin signature for BitGo's challenge is not valid. Please contact your enterprise admin.`);
|
|
590
719
|
}
|
|
591
720
|
return {
|
|
592
|
-
enterpriseChallenge:
|
|
593
|
-
|
|
721
|
+
enterpriseChallenge: {
|
|
722
|
+
...enterpriseRawChallenge,
|
|
723
|
+
p: enterpriseToBitgoPaillierChallenge.p,
|
|
724
|
+
},
|
|
725
|
+
bitgoChallenge,
|
|
594
726
|
};
|
|
595
727
|
}
|
|
596
728
|
/**
|
|
@@ -792,7 +924,7 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
792
924
|
throw new Error('Incorrect password. Please try again.');
|
|
793
925
|
}
|
|
794
926
|
// Generate and sign enterprise challenge
|
|
795
|
-
const entChallengeWithProof = challenge !== null && challenge !== void 0 ? challenge : (await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde(
|
|
927
|
+
const entChallengeWithProof = challenge !== null && challenge !== void 0 ? challenge : (await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde(sdk_lib_mpc_1.minModulusBitLength));
|
|
796
928
|
const serializedEntChallengeWithProof = sdk_lib_mpc_1.EcdsaTypes.serializeNtildeWithProofs(entChallengeWithProof);
|
|
797
929
|
const signedEnterpriseChallenge = EcdsaUtils.signChallenge(serializedEntChallengeWithProof, xprv, userSigningKey.derivationPath);
|
|
798
930
|
await this.uploadChallengesToEnterprise(bitgo, entId, serializedEntChallengeWithProof, signedEnterpriseChallenge.toString('hex'), bitgoInstChallengeProofSignature.toString('hex'), bitgoNitroChallengeProofSignature.toString('hex'));
|
|
@@ -837,6 +969,17 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
837
969
|
.send(body)
|
|
838
970
|
.result();
|
|
839
971
|
}
|
|
972
|
+
/**
|
|
973
|
+
* util function that checks that a commonKeychain is valid and can ultimately resolve to a valid public key
|
|
974
|
+
* @param commonKeychain - a user uploaded commonKeychain string
|
|
975
|
+
* @throws if the commonKeychain is invalid length or invalid format
|
|
976
|
+
*/
|
|
977
|
+
static validateCommonKeychainPublicKey(commonKeychain) {
|
|
978
|
+
const pub = EcdsaUtils.getPublicKeyFromCommonKeychain(commonKeychain);
|
|
979
|
+
const secp256k1 = new elliptic_1.ec('secp256k1');
|
|
980
|
+
const key = secp256k1.keyFromPublic(pub, 'hex');
|
|
981
|
+
return key.getPublic().encode('hex', false).slice(2);
|
|
982
|
+
}
|
|
840
983
|
}
|
|
841
984
|
exports.EcdsaUtils = EcdsaUtils;
|
|
842
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { Buffer } from 'buffer';\nimport { Key, SerializedKeyPair } from 'openpgp';\nimport * as openpgp from 'openpgp';\n\nimport { EcdsaRangeProof, EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\n\nimport { ECDSA, Ecdsa } from '../../../../account-lib/mpc/tss';\nimport { AddKeychainOptions, ApiKeyShare, CreateBackupOptions, Keychain, KeyType } from '../../../keychain';\nimport ECDSAMethods, { ECDSAMethodTypes } from '../../../tss/ecdsa';\nimport { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';\nimport baseTSSUtils from '../baseTSSUtils';\nimport {\n  BitGoProofSignatures,\n  CreateEcdsaBitGoKeychainParams,\n  CreateEcdsaKeychainParams,\n  DecryptableNShare,\n  GetBitGoChallengesApi,\n  KeyShare,\n} from './types';\nimport {\n  BackupGpgKey,\n  BackupKeyShare,\n  BitgoHeldBackupKeyShare,\n  RequestType,\n  TSSParams,\n  TSSParamsForMessage,\n  TxRequest,\n} from '../baseTypes';\nimport { getTxRequest } from '../../../tss';\nimport { AShare, DShare, EncryptedNShare, SendShareType } from '../../../tss/ecdsa/types';\nimport { createShareProof, generateGPGKeyPair, getBitgoGpgPubKey, getTrustGpgPubKey } from '../../opengpgUtils';\nimport { BitGoBase } from '../../../bitgoBase';\nimport { BackupProvider, IWallet } from '../../../wallet';\nimport { buildNShareFromAPIKeyShare, getParticipantFromIndex, verifyWalletSignature } from '../../../tss/ecdsa/ecdsa';\nimport { signMessageWithDerivedEcdhKey, verifyEcdhSignature } from '../../../ecdh';\nimport { getTxRequestChallenge } from '../../../tss/common';\nimport { Enterprises } from '../../../enterprise';\n\nconst encryptNShare = ECDSAMethods.encryptNShare;\n\n/** @inheritdoc */\nexport class EcdsaUtils extends baseTSSUtils<KeyShare> {\n  // We do not have full support for 3-party verification (w/ external source) of key shares and signature shares. There is no 3rd party key service support with this release.\n  private bitgoPublicGpgKey: openpgp.Key | undefined = undefined;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin, wallet);\n    this.setBitgoGpgPubKey(bitgo);\n  }\n\n  private async setBitgoGpgPubKey(bitgo) {\n    this.bitgoPublicGpgKey = await getBitgoGpgPubKey(bitgo);\n  }\n\n  async getBitgoPublicGpgKey(): Promise<openpgp.Key> {\n    if (!this.bitgoPublicGpgKey) {\n      // retry getting bitgo's gpg key\n      await this.setBitgoGpgPubKey(this.bitgo);\n      if (!this.bitgoPublicGpgKey) {\n        throw new Error(\"Failed to get Bitgo's gpg key\");\n      }\n    }\n\n    return this.bitgoPublicGpgKey;\n  }\n\n  /**\n   * Gets the common public key from commonKeychain.\n   *\n   * @param {String} commonKeychain common key chain between n parties\n   * @returns {string} encoded public key\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 130) {\n      throw new Error(`Invalid commonKeychain length, expected 130, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 66);\n    return commonPubHexStr;\n  }\n\n  async finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    thirdPartyBackupPublicGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const encryptedUserToBackupShare = await encryptNShare(\n      userKeyShare,\n      2,\n      thirdPartyBackupPublicGpgKey.armor(),\n      userGpgKey\n    );\n    const bitgoToBackupKeyShare = bitgoKeychain.keyShares?.find(\n      (keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup'\n    );\n    const userPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.nShares[2].y, 'hex'),\n      Buffer.from(userKeyShare.nShares[2].chaincode, 'hex'),\n    ]).toString('hex');\n    assert(bitgoToBackupKeyShare);\n    const keyResponse = await this.bitgo\n      .put(this.baseCoin.url(`/krs/backupkeys/${keyId}`))\n      .send({\n        commonKeychain,\n        keyShares: [\n          {\n            from: 'user',\n            to: 'backup',\n            publicShare: userPublicShare,\n            privateShare: encryptedUserToBackupShare.encryptedPrivateShare,\n            privateShareProof: encryptedUserToBackupShare.privateShareProof,\n            vssProof: encryptedUserToBackupShare.vssProof,\n          },\n          bitgoToBackupKeyShare,\n        ],\n      })\n      .result();\n    if (!keyResponse || !keyResponse.commonKeychain) {\n      throw new Error('Failed backup key verification.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n      commonKeychain: keyResponse.commonKeychain,\n    };\n  }\n\n  /** @inheritdoc */\n  async createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    const MPC = new Ecdsa();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = await MPC.keyShare(1, m, n);\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const isThirdPartyBackup = this.isValidThirdPartyBackupProvider(params.backupProvider);\n    const backupKeyShare = await this.createBackupKeyShares(isThirdPartyBackup, userGpgKey, params.enterprise);\n    const backupGpgKey = await this.getBackupGpgPubKey(isThirdPartyBackup);\n\n    // Get the BitGo public key based on user/enterprise feature flags\n    // If it doesn't work, use the default public key from the constants\n    const bitgoPublicGpgKey =\n      (await this.getBitgoGpgPubkeyBasedOnFeatureFlags(params.enterprise)) ?? this.bitgoPublicGpgKey;\n\n    const bitgoKeychain = await this.createBitgoKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      enterprise: params.enterprise,\n      isThirdPartyBackup,\n    });\n    const userKeychainPromise = this.createUserKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n      isThirdPartyBackup,\n    });\n    const backupKeychainPromise = this.createBackupKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      backupProvider: params.backupProvider,\n    });\n\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    return {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n  }\n\n  /**\n   * If a third party backup is requested, it will create backup shares from\n   * a third party (BitGo as of now), otherwise the key shares will be client generated\n   */\n  async createBackupKeyShares(\n    isThirdPartyBackup = false,\n    userGpgPubKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BackupKeyShare> {\n    let backupKeyShare: BackupKeyShare;\n    if (isThirdPartyBackup) {\n      const bitgoHeldBackupKeyShares = await this.createBitgoHeldBackupKeyShare(userGpgPubKey, enterprise);\n      backupKeyShare = {\n        bitGoHeldKeyShares: bitgoHeldBackupKeyShares,\n      };\n    } else {\n      const MPC = new Ecdsa();\n      const m = 2;\n      const n = 3;\n      backupKeyShare = {\n        userHeldKeyShare: await MPC.keyShare(2, m, n),\n      };\n    }\n    return backupKeyShare;\n  }\n\n  /**\n   * Gets backup pub gpg key string\n   * if a third party provided then get from trust\n   * @param isThirdPartyBackup\n   */\n  async getBackupGpgPubKey(isThirdPartyBackup = false): Promise<BackupGpgKey> {\n    return isThirdPartyBackup ? getTrustGpgPubKey(this.bitgo) : generateGPGKeyPair('secp256k1');\n  }\n\n  createUserKeychain({\n    userGpgKey,\n    backupGpgKey,\n    bitgoPublicGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n    originalPasscodeEncryptionCode,\n    isThirdPartyBackup = false,\n  }: CreateEcdsaKeychainParams): Promise<Keychain> {\n    if (!passphrase) {\n      throw new Error('Please provide a wallet passphrase');\n    }\n    if (isThirdPartyBackup && backupKeyShare.bitGoHeldKeyShares?.keyShares) {\n      return this.createUserKeychainFromThirdPartyBackup(\n        userGpgKey,\n        bitgoPublicGpgKey,\n        backupGpgKey as Key,\n        userKeyShare,\n        backupKeyShare.bitGoHeldKeyShares.keyShares,\n        bitgoKeychain,\n        passphrase,\n        originalPasscodeEncryptionCode\n      );\n    }\n    assert(backupKeyShare.userHeldKeyShare);\n    return this.createParticipantKeychain(\n      userGpgKey,\n      backupGpgKey as SerializedKeyPair<string>,\n      bitgoPublicGpgKey,\n      1,\n      userKeyShare,\n      backupKeyShare.userHeldKeyShare,\n      bitgoKeychain,\n      passphrase,\n      originalPasscodeEncryptionCode\n    );\n  }\n\n  async createBackupKeychain({\n    userGpgKey,\n    userKeyShare,\n    backupGpgKey,\n    backupKeyShare,\n    bitgoKeychain,\n    bitgoPublicGpgKey,\n    passphrase,\n    backupProvider,\n  }: CreateEcdsaKeychainParams): Promise<Keychain> {\n    if (this.isValidThirdPartyBackupProvider(backupProvider) && backupKeyShare.bitGoHeldKeyShares?.keyShares) {\n      assert(bitgoKeychain.commonKeychain);\n      const finalizedBackupKeyShare = await this.finalizeBitgoHeldBackupKeyShare(\n        backupKeyShare.bitGoHeldKeyShares.id,\n        bitgoKeychain.commonKeychain,\n        userKeyShare,\n        bitgoKeychain,\n        userGpgKey,\n        backupGpgKey as Key\n      );\n      if (finalizedBackupKeyShare.commonKeychain !== bitgoKeychain.commonKeychain) {\n        throw new Error('Failed to create backup keychain - commonKeychains do not match');\n      }\n      const backupKeyParams: CreateBackupOptions = {\n        source: 'backup',\n        keyType: 'tss',\n        commonKeychain: finalizedBackupKeyShare.commonKeychain,\n        provider: backupProvider ?? 'BitGoTrustAsKrs',\n      };\n      const backupKeychain = await this.baseCoin.keychains().createBackup(backupKeyParams);\n      backupKeychain.keyShares = finalizedBackupKeyShare.keyShares;\n      return backupKeychain;\n    }\n    assert(backupKeyShare.userHeldKeyShare);\n    assert(passphrase);\n    return this.createParticipantKeychain(\n      userGpgKey,\n      backupGpgKey as SerializedKeyPair<string>,\n      bitgoPublicGpgKey,\n      2,\n      userKeyShare,\n      backupKeyShare.userHeldKeyShare,\n      bitgoKeychain,\n      passphrase\n    );\n  }\n\n  /** @inheritdoc */\n  async createBitgoKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    enterprise,\n    bitgoPublicGpgKey,\n    isThirdPartyBackup = false,\n  }: CreateEcdsaBitGoKeychainParams): Promise<Keychain> {\n    const recipientIndex = 3;\n    const userToBitgoShare = await encryptNShare(userKeyShare, recipientIndex, bitgoPublicGpgKey.armor(), userGpgKey);\n\n    const backupToBitgoShare = await this.getBackupEncryptedNShare(\n      backupKeyShare,\n      recipientIndex,\n      bitgoPublicGpgKey.armor(),\n      backupGpgKey as SerializedKeyPair<string>,\n      isThirdPartyBackup\n    );\n\n    const createBitGoMPCParams: AddKeychainOptions = {\n      keyType: 'tss' as KeyType,\n      source: 'bitgo',\n      keyShares: [\n        {\n          from: 'user',\n          to: 'bitgo',\n          publicShare: userToBitgoShare.publicShare,\n          privateShare: userToBitgoShare.encryptedPrivateShare,\n          n: userToBitgoShare.n,\n          vssProof: userToBitgoShare.vssProof,\n          privateShareProof: userToBitgoShare.privateShareProof,\n        },\n        {\n          from: 'backup',\n          to: 'bitgo',\n          publicShare: backupToBitgoShare.publicShare,\n          privateShare: backupToBitgoShare.encryptedPrivateShare,\n          n: backupToBitgoShare.n,\n          vssProof: backupToBitgoShare.vssProof,\n          privateShareProof: backupToBitgoShare.privateShareProof,\n        },\n      ],\n      userGPGPublicKey: userGpgKey.publicKey,\n      backupGPGPublicKey: isThirdPartyBackup\n        ? (backupGpgKey as Key).armor()\n        : (backupGpgKey as SerializedKeyPair<string>).publicKey,\n      enterprise: enterprise,\n      algoUsed: 'ecdsa',\n    };\n\n    return await this.baseCoin.keychains().add(createBitGoMPCParams);\n  }\n\n  /**\n   * This builds the relevant backup encryptedNShare based on whether the\n   * backup key is user or third party generated\n   * @param backupShare can either have key shares from the user or third party\n   * @param recipientIndex index of the party receiving the backup shares\n   * @param recipientGpgPublicArmor gpg armor of the party receiving the backup shares\n   * @param backupGpgKey backup gpg key\n   * @param isThirdPartyBackup whether the backup is generated by third party\n   */\n  async getBackupEncryptedNShare(\n    backupShare: BackupKeyShare,\n    recipientIndex: number,\n    recipientGpgPublicArmor: string,\n    backupGpgKey: SerializedKeyPair<string>,\n    isThirdPartyBackup = false\n  ): Promise<EncryptedNShare> {\n    let backupToRecipientShare: EncryptedNShare;\n    if (isThirdPartyBackup) {\n      if (!backupShare.bitGoHeldKeyShares) {\n        throw new Error(`Missing third party backup key shares`);\n      }\n      const backupToRecipientApiShare = backupShare.bitGoHeldKeyShares.keyShares.find(\n        (keyShare) => keyShare.from === 'backup' && keyShare.to === getParticipantFromIndex(recipientIndex)\n      );\n      if (!backupToRecipientApiShare) {\n        throw new Error(`Missing backup to ${getParticipantFromIndex(recipientIndex)} key share`);\n      }\n      // Since backup is from a third party, it is already encrypted\n      backupToRecipientShare = await buildNShareFromAPIKeyShare(backupToRecipientApiShare);\n    } else {\n      assert(backupShare.userHeldKeyShare);\n      backupToRecipientShare = await encryptNShare(\n        backupShare.userHeldKeyShare,\n        recipientIndex,\n        recipientGpgPublicArmor,\n        backupGpgKey\n      );\n    }\n    return backupToRecipientShare;\n  }\n\n  /**\n   * This uses the backup key from a third party (bitgo in this case)\n   * to create the user keychain via WP.\n   */\n  async createUserKeychainFromThirdPartyBackup(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    bitgoPublicGpgKey: Key,\n    thirdPartyBackupPublicGpgKey: Key,\n    userKeyShare: KeyShare,\n    thirdPartybackupKeyShares: ApiKeyShare[],\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n    if (!bitgoKeychain.commonKeychain) {\n      throw new Error(`Missing common key chain: ${bitgoKeychain.commonKeychain}`);\n    }\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (!bitGoToUserShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const backupToUserShare = thirdPartybackupKeyShares.find(\n      (keyShare) => keyShare.from === 'backup' && keyShare.to === 'user'\n    );\n    if (!backupToUserShare) {\n      throw new Error('Missing Backup to User key share');\n    }\n\n    const backupToUserNShare = await buildNShareFromAPIKeyShare(backupToUserShare);\n    const bitGoToUserNShare = await buildNShareFromAPIKeyShare(bitGoToUserShare);\n    const encryptedNShares: DecryptableNShare[] = [\n      {\n        nShare: backupToUserNShare,\n        recipientPrivateArmor: userGpgKey.privateKey,\n        senderPublicArmor: thirdPartyBackupPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n      {\n        nShare: bitGoToUserNShare,\n        recipientPrivateArmor: userGpgKey.privateKey,\n        senderPublicArmor: bitgoPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n    ];\n\n    const userCombinedKey = await ECDSAMethods.createCombinedKey(\n      userKeyShare,\n      encryptedNShares,\n      bitgoKeychain.commonKeychain\n    );\n    if (userCombinedKey.commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const prv = JSON.stringify(userCombinedKey.signingMaterial);\n    const userKeychainParams = {\n      source: 'user',\n      keyType: 'tss' as KeyType,\n      commonKeychain: userCombinedKey.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({\n        input: prv,\n        password: passphrase,\n      }),\n      originalPasscodeEncryptionCode,\n    };\n\n    const keychains = this.baseCoin.keychains();\n    return await keychains.add(userKeychainParams);\n  }\n\n  /** @inheritdoc */\n  async createParticipantKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userLocalBackupGpgKey: openpgp.SerializedKeyPair<string>,\n    bitgoPublicGpgKey: Key,\n    recipientIndex: number,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n    if (!bitgoKeychain.commonKeychain) {\n      throw new Error(`Missing common key chain: ${bitgoKeychain.commonKeychain}`);\n    }\n\n    let recipient: string;\n    let keyShare: KeyShare;\n    let otherShare: KeyShare;\n    let recipientGpgKey: openpgp.SerializedKeyPair<string>;\n    let senderGpgKey: openpgp.SerializedKeyPair<string>;\n    if (recipientIndex === 1) {\n      keyShare = userKeyShare;\n      otherShare = backupKeyShare;\n      recipient = 'user';\n      recipientGpgKey = userGpgKey;\n      senderGpgKey = userLocalBackupGpgKey;\n    } else if (recipientIndex === 2) {\n      keyShare = backupKeyShare;\n      otherShare = userKeyShare;\n      recipient = 'backup';\n      recipientGpgKey = userLocalBackupGpgKey;\n      senderGpgKey = userGpgKey;\n    } else {\n      throw new Error('Invalid user index');\n    }\n\n    const bitGoToRecipientShare = bitgoKeyShares.find(\n      (keyShare) => keyShare.from === 'bitgo' && keyShare.to === recipient\n    );\n    if (!bitGoToRecipientShare) {\n      throw new Error(`Missing BitGo to ${recipient} key share`);\n    }\n\n    const decryptedShare = await this.decryptPrivateShare(bitGoToRecipientShare.privateShare, recipientGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      userLocalBackupGpgKey.publicKey,\n      bitgoKeychain,\n      decryptedShare,\n      recipientIndex\n    );\n\n    const senderToRecipientShare = await encryptNShare(\n      otherShare,\n      recipientIndex,\n      recipientGpgKey.publicKey,\n      senderGpgKey\n    );\n    const encryptedNShares: DecryptableNShare[] = [\n      {\n        // userToBackup or backupToUser\n        nShare: senderToRecipientShare,\n        recipientPrivateArmor: recipientGpgKey.privateKey,\n        senderPublicArmor: senderGpgKey.publicKey,\n      },\n      {\n        // bitgoToRecipient\n        nShare: {\n          i: recipientIndex,\n          j: 3,\n          publicShare: bitGoToRecipientShare.publicShare,\n          encryptedPrivateShare: bitGoToRecipientShare.privateShare,\n          n: bitGoToRecipientShare.n!,\n          vssProof: bitGoToRecipientShare.vssProof,\n          privateShareProof: bitGoToRecipientShare.privateShareProof,\n        },\n        recipientPrivateArmor: recipientGpgKey.privateKey,\n        senderPublicArmor: bitgoPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n    ];\n\n    const recipientCombinedKey = await ECDSAMethods.createCombinedKey(\n      keyShare,\n      encryptedNShares,\n      bitgoKeychain.commonKeychain\n    );\n\n    const prv = JSON.stringify(recipientCombinedKey.signingMaterial);\n    const recipientKeychainParams = {\n      source: recipient,\n      keyType: 'tss' as KeyType,\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({\n        input: prv,\n        password: passphrase,\n      }),\n      originalPasscodeEncryptionCode,\n    };\n\n    const keychains = this.baseCoin.keychains();\n    return recipientIndex === 1\n      ? await keychains.add(recipientKeychainParams)\n      : await keychains.createBackup(recipientKeychainParams);\n  }\n\n  /**\n   * Gets signing key, txRequestResolved and txRequestId\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param { string} params.reqId - request id\n   * @returns {Promise<TxRequest>}\n   */\n  private async signRequestBase(params: TSSParams | TSSParamsForMessage, requestType: RequestType): Promise<TxRequest> {\n    const pendingEcdsaTssInitialization = this.wallet.coinSpecific()?.pendingEcdsaTssInitialization;\n    if (pendingEcdsaTssInitialization) {\n      throw new Error(\n        'Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.'\n      );\n    }\n\n    const userSigningMaterial: ECDSAMethodTypes.SigningMaterial = JSON.parse(params.prv);\n    if (userSigningMaterial.pShare.i !== 1) {\n      throw new Error('Invalid user key');\n    }\n    if (!userSigningMaterial.backupNShare) {\n      throw new Error('Invalid user key - missing backupNShare');\n    }\n\n    const txRequest: TxRequest =\n      typeof params.txRequest === 'string'\n        ? await getTxRequest(this.bitgo, this.wallet.id(), params.txRequest)\n        : params.txRequest;\n\n    let signablePayload;\n    let derivationPath;\n\n    if (requestType === RequestType.tx) {\n      assert(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');\n      const unsignedTx =\n        txRequest.apiVersion === 'full' ? txRequest.transactions![0].unsignedTx : txRequest.unsignedTxs[0];\n      signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n      derivationPath = unsignedTx.derivationPath;\n    } else if (requestType === RequestType.message) {\n      signablePayload = (params as TSSParamsForMessage).bufferToSign;\n      // TODO BG-67299 Message signing with derivation path\n      derivationPath = '';\n    }\n\n    const MPC = new Ecdsa();\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.pShare,\n      [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare],\n      derivationPath\n    );\n\n    const bitgoIndex = 3;\n    const userIndex = 1;\n    const yShare = {\n      i: userSigningMaterial.pShare.i,\n      j: bitgoIndex,\n      n: signingKey.nShares[bitgoIndex].n,\n    };\n\n    const challenges = await this.getEcdsaSigningChallenges(txRequest.txRequestId, requestType, 0);\n    const signingKeyWithChallenge = await MPC.appendChallenge(\n      signingKey.xShare,\n      yShare,\n      challenges.enterpriseChallenge\n    );\n\n    const userSignShare = await ECDSAMethods.createUserSignShare(signingKeyWithChallenge.xShare, {\n      i: userIndex,\n      j: bitgoIndex,\n      n: userSigningMaterial.bitgoNShare.n,\n      ntilde: challenges.bitgoChallenge.ntilde,\n      h1: challenges.bitgoChallenge.h1,\n      h2: challenges.bitgoChallenge.h2,\n    });\n    const u = signingKey.nShares[bitgoIndex].u;\n\n    let chaincode = userSigningMaterial.bitgoNShare.chaincode;\n    while (chaincode.length < 64) {\n      chaincode = '0' + chaincode;\n    }\n    const signerShare = bip32.fromPrivateKey(Buffer.from(u, 'hex'), Buffer.from(chaincode, 'hex')).toBase58();\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = (await openpgp.encrypt({\n      message: await openpgp.createMessage({\n        text: signerShare,\n      }),\n      config: {\n        rejectCurves: new Set(),\n      },\n      encryptionKeys: [bitgoGpgKey],\n    })) as string;\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const privateShareProof = await createShareProof(userGpgKey.privateKey, signingKey.nShares[bitgoIndex].u, 'ecdsa');\n    const vssProof = signingKey.nShares[bitgoIndex].v;\n    const userPublicGpgKey = userGpgKey.publicKey;\n    const publicShare = signingKey.nShares[bitgoIndex].y + signingKey.nShares[bitgoIndex].chaincode;\n\n    // signing stage one with K share send to bitgo and receives A share\n    const bitgoToUserAShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.KShare,\n      userSignShare.kShare,\n      encryptedSignerShare,\n      vssProof,\n      privateShareProof,\n      publicShare,\n      userPublicGpgKey\n    )) as Omit<AShare, 'ntilde' | 'h1' | 'h2'>; // WP/HSM does not return the initial challenge\n\n    // Append the BitGo challenge to the Ashare to be used in subsequent proofs\n    const bitgoToUserAShareWithNtilde: AShare = {\n      ...bitgoToUserAShare,\n      ...challenges.bitgoChallenge,\n    };\n\n    const userGammaAndMuShares = await ECDSAMethods.createUserGammaAndMuShare(\n      userSignShare.wShare,\n      bitgoToUserAShareWithNtilde\n    );\n    const userOmicronAndDeltaShare = await ECDSAMethods.createUserOmicronAndDeltaShare(\n      userGammaAndMuShares.gShare as ECDSA.GShare\n    );\n    const muShare = userGammaAndMuShares.muShare!;\n    const dShare = userOmicronAndDeltaShare.dShare;\n\n    // signing stage two with muShare and dShare send to bitgo and receives D share\n    const bitgoToUserDShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.MUShare,\n      { muShare, dShare, i: muShare.i }\n    )) as DShare;\n\n    const userSShare = await ECDSAMethods.createUserSignatureShare(\n      userOmicronAndDeltaShare.oShare,\n      bitgoToUserDShare,\n      signablePayload,\n      params.hash\n    );\n\n    // signing stage three with SShare send to bitgo and receives SShare\n    await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.SShare,\n      userSShare\n    );\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequest.txRequestId);\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param {string} params.reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: TSSParams): Promise<TxRequest> {\n    return this.signRequestBase(params, RequestType.tx);\n  }\n\n  /**\n   * Signs the message associated to the transaction request.\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param {string} params.reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequestForMessage(params: TSSParamsForMessage): Promise<TxRequest> {\n    if (!params.messageRaw) {\n      throw new Error('Raw message required to sign message');\n    }\n    return this.signRequestBase(params, RequestType.message);\n  }\n\n  /**\n   * Get the challenge values for enterprise and BitGo in ECDSA signing\n   * Only returns the challenges if they are verified by the user's enterprise admin's ecdh key\n   * @param {string} txRequestId - transaction request id\n   * @param {RequestType} requestType -  (0 for tx, 1 for message)\n   * @param {number} index - index of the requestType\n   */\n  async getEcdsaSigningChallenges(\n    txRequestId: string,\n    requestType: RequestType,\n    index = 0\n  ): Promise<{\n    enterpriseChallenge: EcdsaTypes.SerializedNtilde;\n    bitgoChallenge: EcdsaTypes.SerializedNtilde;\n  }> {\n    const enterpriseId = this.wallet.toJSON().enterprise;\n    if (!enterpriseId) {\n      throw new Error('Wallet must be an enterprise wallet.');\n    }\n    const shouldUseEnterpriseChallenge = await (async () => {\n      const enterprise = await new Enterprises(this.bitgo, this.baseCoin).get({ id: enterpriseId });\n      return enterprise.hasFeatureFlags(['useEnterpriseEcdsaTssChallenge']);\n    })();\n\n    if (!shouldUseEnterpriseChallenge) {\n      const entChallenge = await EcdsaRangeProof.generateNtilde(3072);\n      return {\n        enterpriseChallenge: EcdsaTypes.serializeNtilde(entChallenge),\n        bitgoChallenge: await getTxRequestChallenge(\n          this.bitgo,\n          this.wallet.id(),\n          txRequestId,\n          index.toString(),\n          requestType,\n          'ecdsa'\n        ),\n      };\n    }\n\n    const result = await this.wallet.getChallengesForEcdsaSigning();\n    const enterpriseChallenge = result.enterpriseChallenge;\n    const bitgoChallenge = result.bitgoChallenge;\n\n    const challengeVerifierUserId = result.createdBy;\n    const adminSigningKeyResponse = await this.bitgo.getSigningKeyForUser(enterpriseId, challengeVerifierUserId);\n    const pubkeyOfAdminEcdhKeyHex = adminSigningKeyResponse.derivedPubkey;\n\n    // Verify enterprise's challenge is signed by the respective admin's ecdh keychain\n    const enterpriseRawChallenge = {\n      ntilde: enterpriseChallenge.ntilde,\n      h1: enterpriseChallenge.h1,\n      h2: enterpriseChallenge.h2,\n    };\n    const adminSignatureOnEntChallenge: string = enterpriseChallenge.verifiers.adminSignature;\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(enterpriseRawChallenge),\n        adminSignatureOnEntChallenge,\n        Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex')\n      )\n    ) {\n      throw new Error(`Admin signature for enterprise challenge is not valid. Please contact your enterprise admin.`);\n    }\n\n    // Verify that the BitGo challenge's ZK proofs have been verified by the admin\n    const bitGoRawChallenge = {\n      ntilde: bitgoChallenge.ntilde,\n      h1: bitgoChallenge.h1,\n      h2: bitgoChallenge.h2,\n    };\n    const adminVerificationSignatureForBitGoChallenge = bitgoChallenge.verifiers.adminSignature;\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(bitGoRawChallenge),\n        adminVerificationSignatureForBitGoChallenge,\n        Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex')\n      )\n    ) {\n      throw new Error(`Admin signature for BitGo's challenge is not valid. Please contact your enterprise admin.`);\n    }\n\n    return {\n      enterpriseChallenge: enterpriseRawChallenge,\n      bitgoChallenge: bitGoRawChallenge,\n    };\n  }\n\n  /**\n   * Verifies the u-value proofs and GPG keys used in generating a TSS ECDSA wallet.\n   * @param userGpgPub The user's public GPG key for encryption between user/server\n   * @param backupGpgPub The backup's public GPG key for encryption between backup/server\n   * @param bitgoKeychain previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param decryptedShare The decrypted bitgo-to-user/backup private share retrieved from the keychain\n   * @param verifierIndex The index of the party to verify: 1 = user, 2 = backup\n   */\n  async verifyWalletSignatures(\n    userGpgPub: string,\n    backupGpgPub: string,\n    bitgoKeychain: Keychain,\n    decryptedShare: string,\n    verifierIndex: 1 | 2\n  ): Promise<void> {\n    assert(bitgoKeychain.commonKeychain);\n    assert(bitgoKeychain.walletHSMGPGPublicKeySigs);\n\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });\n    const userKeyId = userKeyPub.keyPacket.getFingerprint();\n    const backupKeyPub = await openpgp.readKey({ armoredKey: backupGpgPub });\n    const backupKeyId = backupKeyPub.keyPacket.getFingerprint();\n\n    const walletSignatures = await openpgp.readKeys({ armoredKeys: bitgoKeychain.walletHSMGPGPublicKeySigs });\n    if (walletSignatures.length !== 2) {\n      throw new Error('Invalid wallet signatures');\n    }\n    if (userKeyId !== walletSignatures[0].keyPacket.getFingerprint()) {\n      throw new Error(`first wallet signature's fingerprint does not match passed user gpg key's fingerprint`);\n    }\n    if (backupKeyId !== walletSignatures[1].keyPacket.getFingerprint()) {\n      throw new Error(`second wallet signature's fingerprint does not match passed backup gpg key's fingerprint`);\n    }\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[0],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[1],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n  }\n\n  /**\n   * Signs a challenge with the provided v1 ecdh key at a derived path\n   * @param challenge challenge to sign\n   * @param ecdhXprv xprv of the ecdh key\n   * @param derivationPath the derived path at which the ecdh key will sign\n   */\n  static signChallenge(challenge: EcdsaTypes.SerializedNtilde, ecdhXprv: string, derivationPath: string): Buffer {\n    const messageToSign = this.getMessageToSignFromChallenge(challenge);\n    return signMessageWithDerivedEcdhKey(messageToSign, ecdhXprv, derivationPath);\n  }\n\n  /**\n   * Converts challenge to a common message format which can be signed.\n   * @param challenge\n   */\n  static getMessageToSignFromChallenge(challenge: EcdsaTypes.SerializedNtilde): string {\n    return challenge.ntilde.concat(challenge.h1).concat(challenge.h2);\n  }\n\n  /**\n   Verifies ZK proofs of BitGo's challenges for both nitro and institutional HSMs\n   which are fetched from the WP API.\n   */\n  static async verifyBitGoChallenges(bitgoChallenges: GetBitGoChallengesApi): Promise<boolean> {\n    // Verify institutional hsm challenge proof\n    const instChallengeVerified = await this.verifyBitGoChallenge({\n      ntilde: bitgoChallenges.bitgoInstitutionalHsm.ntilde,\n      h1: bitgoChallenges.bitgoInstitutionalHsm.h1,\n      h2: bitgoChallenges.bitgoInstitutionalHsm.h2,\n      ntildeProof: bitgoChallenges.bitgoInstitutionalHsm.ntildeProof,\n    });\n\n    // Verify nitro hsm challenge proof\n    const nitroChallengeVerified = await this.verifyBitGoChallenge({\n      ntilde: bitgoChallenges.bitgoNitroHsm.ntilde,\n      h1: bitgoChallenges.bitgoNitroHsm.h1,\n      h2: bitgoChallenges.bitgoNitroHsm.h2,\n      ntildeProof: bitgoChallenges.bitgoNitroHsm.ntildeProof,\n    });\n\n    return instChallengeVerified && nitroChallengeVerified;\n  }\n\n  /**\n   * Verifies ZK proof for a single BitGo challenge\n   * @param bitgoChallenge\n   */\n  static async verifyBitGoChallenge(bitgoChallenge: EcdsaTypes.SerializedNtildeWithProofs): Promise<boolean> {\n    const deserializedInstChallenge = EcdsaTypes.deserializeNtildeWithProofs(bitgoChallenge);\n    const ntildeProofH1WrtH2Verified = await EcdsaRangeProof.verifyNtildeProof(\n      {\n        ntilde: deserializedInstChallenge.ntilde,\n        h1: deserializedInstChallenge.h1,\n        h2: deserializedInstChallenge.h2,\n      },\n      deserializedInstChallenge.ntildeProof.h1WrtH2\n    );\n    const ntildeProofH2WrtH1Verified = await EcdsaRangeProof.verifyNtildeProof(\n      {\n        ntilde: deserializedInstChallenge.ntilde,\n        h1: deserializedInstChallenge.h2,\n        h2: deserializedInstChallenge.h1,\n      },\n      deserializedInstChallenge.ntildeProof.h2WrtH1\n    );\n    return ntildeProofH1WrtH2Verified && ntildeProofH2WrtH1Verified;\n  }\n\n  /**\n   * Gets the bitgo challenges for both nitro and institutional HSMs from WP API.\n   * @param bitgo\n   */\n  static async getBitGoChallenges(bitgo: BitGoBase): Promise<GetBitGoChallengesApi> {\n    const res = await bitgo.get(bitgo.url('/tss/ecdsa/challenges', 2)).send().result();\n    if (\n      !res.bitgoNitroHsm ||\n      !res.bitgoNitroHsm.ntilde ||\n      !res.bitgoNitroHsm.h1 ||\n      !res.bitgoNitroHsm.h2 ||\n      !res.bitgoNitroHsm.ntildeProof ||\n      !res.bitgoInstitutionalHsm ||\n      !res.bitgoInstitutionalHsm.ntilde ||\n      !res.bitgoInstitutionalHsm.h1 ||\n      !res.bitgoInstitutionalHsm.h2 ||\n      !res.bitgoInstitutionalHsm.ntildeProof\n    ) {\n      throw new Error('Expected BitGo challenge proof to be present. Contact support@bitgo.com.');\n    }\n    return res;\n  }\n\n  /**\n   * Gets BitGo's proofs from API and signs them if the proofs are valid.\n   * @param bitgo\n   * @param enterpriseId\n   * @param userPassword\n   */\n  static async getVerifyAndSignBitGoChallenges(\n    bitgo: BitGoBase,\n    enterpriseId: string,\n    userPassword: string\n  ): Promise<BitGoProofSignatures> {\n    // Fetch BitGo's challenge and verify\n    const bitgoChallengesWithProofs = await EcdsaUtils.getBitGoChallenges(bitgo);\n    if (!(await EcdsaUtils.verifyBitGoChallenges(bitgoChallengesWithProofs))) {\n      throw new Error(\n        `Failed to verify BitGo's challenge needed to enable ECDSA signing. Please contact support@bitgo.com`\n      );\n    }\n    return await EcdsaUtils.signBitgoChallenges(bitgo, enterpriseId, userPassword, bitgoChallengesWithProofs);\n  }\n\n  /**\n   * Sign Bitgo's proofs, verification of proofs is left to the caller\n   * @param bitgo\n   * @param enterpriseId\n   * @param userPassword\n   * @param bitgoChallengesWithProofs Optionally provide Bitgo Challaenge & Proofs instead of fetching from API\n   */\n  static async signBitgoChallenges(\n    bitgo: BitGoBase,\n    enterpriseId: string,\n    userPassword: string,\n    bitgoChallengesWithProofs?: GetBitGoChallengesApi\n  ): Promise<BitGoProofSignatures> {\n    // fetch challenge & proof if none are provided\n    const challengesWithProofs = bitgoChallengesWithProofs\n      ? bitgoChallengesWithProofs\n      : await EcdsaUtils.getBitGoChallenges(bitgo);\n    // Fetch user's ecdh public keychain needed for signing the challenges\n    const userSigningKey = await bitgo.getSigningKeyForUser(enterpriseId);\n    if (!userSigningKey.ecdhKeychain || !userSigningKey.derivationPath) {\n      throw new Error('Something went wrong with the user keychain. Please contact support@bitgo.com.');\n    }\n    const userEcdhKeychain = await bitgo.getECDHKeychain(userSigningKey.ecdhKeychain);\n    let xprv;\n    try {\n      xprv = bitgo.decrypt({\n        password: userPassword,\n        input: userEcdhKeychain.encryptedXprv,\n      });\n    } catch (e) {\n      throw new Error('Incorrect password. Please try again.');\n    }\n    const signedBitGoInstChallenge = EcdsaUtils.signChallenge(\n      challengesWithProofs.bitgoInstitutionalHsm,\n      xprv,\n      userSigningKey.derivationPath\n    );\n    const signedBitGoNitroChallenge = EcdsaUtils.signChallenge(\n      challengesWithProofs.bitgoNitroHsm,\n      xprv,\n      userSigningKey.derivationPath\n    );\n    return {\n      bitgoInstHsmAdminSignature: signedBitGoInstChallenge,\n      bitgoNitroHsmAdminSignature: signedBitGoNitroChallenge,\n    };\n  }\n\n  /**\n   * This is needed to enable ecdsa signing on the enterprise.\n   * It receives the enterprise challenge and signatures of verified bitgo proofs\n   * and uploads them on the enterprise.\n   * @param bitgo\n   * @param entId - enterprise id to enable ecdsa signing on\n   * @param userPassword - enterprise admin's login pw\n   * @param bitgoInstChallengeProofSignature - signature on bitgo's institutional HSM challenge after verification\n   * @param bitgoNitroChallengeProofSignature - signature on bitgo's nitro HSM challenge after verification\n   * @param challenge - optionally use the challenge for enterprise challenge\n   */\n  static async initiateChallengesForEnterprise(\n    bitgo: BitGoBase,\n    entId: string,\n    userPassword: string,\n    bitgoInstChallengeProofSignature: Buffer,\n    bitgoNitroChallengeProofSignature: Buffer,\n    challenge?: EcdsaTypes.DeserializedNtildeWithProofs\n  ): Promise<void> {\n    // Fetch user's ecdh public keychain needed for signing the challenges\n    const userSigningKey = await bitgo.getSigningKeyForUser(entId);\n    if (!userSigningKey.ecdhKeychain || !userSigningKey.derivationPath) {\n      throw new Error('Something went wrong with the user keychain. Please contact support@bitgo.com.');\n    }\n    const userEcdhKeychain = await bitgo.getECDHKeychain(userSigningKey.ecdhKeychain);\n    let xprv;\n    try {\n      xprv = bitgo.decrypt({\n        password: userPassword,\n        input: userEcdhKeychain.encryptedXprv,\n      });\n    } catch (e) {\n      throw new Error('Incorrect password. Please try again.');\n    }\n\n    // Generate and sign enterprise challenge\n    const entChallengeWithProof = challenge ?? (await EcdsaRangeProof.generateNtilde(3072));\n    const serializedEntChallengeWithProof = EcdsaTypes.serializeNtildeWithProofs(entChallengeWithProof);\n    const signedEnterpriseChallenge = EcdsaUtils.signChallenge(\n      serializedEntChallengeWithProof,\n      xprv,\n      userSigningKey.derivationPath\n    );\n\n    await this.uploadChallengesToEnterprise(\n      bitgo,\n      entId,\n      serializedEntChallengeWithProof,\n      signedEnterpriseChallenge.toString('hex'),\n      bitgoInstChallengeProofSignature.toString('hex'),\n      bitgoNitroChallengeProofSignature.toString('hex')\n    );\n  }\n\n  /**\n   * Uploads the signed challenges and their proofs on the enterprise.\n   * This initiates ecdsa signing for the enterprise users.\n   * @param bitgo\n   * @param entId - enterprise to enable ecdsa signing on\n   * @param entChallengeWithProofs - client side generated ent challenge with ZK proofs\n   * @param entChallengeSignature - signature on enterprise challenge\n   * @param bitgoIntChallengeSignature - signature on BitGo's institutional HSM challenge\n   * @param bitgoNitroChallengeSignature - signature on BitGo's nitro HSM challenge\n   */\n  static async uploadChallengesToEnterprise(\n    bitgo: BitGoBase,\n    entId: string,\n    entChallengeWithProofs: EcdsaTypes.SerializedNtildeWithProofs,\n    entChallengeSignature: string,\n    bitgoIntChallengeSignature: string,\n    bitgoNitroChallengeSignature: string\n  ): Promise<void> {\n    const body = {\n      enterprise: {\n        ntilde: entChallengeWithProofs.ntilde,\n        h1: entChallengeWithProofs.h1,\n        h2: entChallengeWithProofs.h2,\n        ntildeProof: {\n          h1WrtH2: entChallengeWithProofs.ntildeProof.h1WrtH2,\n          h2WrtH1: entChallengeWithProofs.ntildeProof.h2WrtH1,\n        },\n        verifiers: {\n          adminSignature: entChallengeSignature,\n        },\n      },\n      bitgoInstitutionalHsm: {\n        verifiers: {\n          adminSignature: bitgoIntChallengeSignature,\n        },\n      },\n      bitgoNitroHsm: {\n        verifiers: {\n          adminSignature: bitgoNitroChallengeSignature,\n        },\n      },\n    };\n    await bitgo\n      .put(bitgo.url(`/enterprise/${entId}/tssconfig/ecdsa/challenge`, 2))\n      .send(body)\n      .result();\n  }\n}\n"]}
|
|
985
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { Buffer } from 'buffer';\nimport { Key, SerializedKeyPair } from 'openpgp';\nimport * as openpgp from 'openpgp';\nimport { ec } from 'elliptic';\n\nimport { EcdsaPaillierProof, EcdsaRangeProof, EcdsaTypes, hexToBigInt, minModulusBitLength } from '@bitgo-beta/sdk-lib-mpc';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\n\nimport { ECDSA, Ecdsa } from '../../../../account-lib/mpc/tss';\nimport { AddKeychainOptions, ApiKeyShare, CreateBackupOptions, Keychain, KeyType } from '../../../keychain';\nimport ECDSAMethods, { ECDSAMethodTypes } from '../../../tss/ecdsa';\nimport { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';\nimport baseTSSUtils from '../baseTSSUtils';\nimport {\n  BitGoProofSignatures,\n  CreateEcdsaBitGoKeychainParams,\n  CreateEcdsaKeychainParams,\n  DecryptableNShare,\n  GetBitGoChallengesApi,\n  KeyShare,\n} from './types';\nimport {\n  BackupGpgKey,\n  BackupKeyShare,\n  BitgoHeldBackupKeyShare,\n  CustomKShareGeneratingFunction,\n  CustomMuDeltaShareGeneratingFunction,\n  CustomPaillierModulusGetterFunction,\n  CustomSShareGeneratingFunction,\n  RequestType,\n  TSSParams,\n  TSSParamsForMessage,\n  TxRequest,\n} from '../baseTypes';\nimport { getTxRequest } from '../../../tss';\nimport { AShare, DShare, EncryptedNShare, OShare, SendShareType, SShare, WShare } from '../../../tss/ecdsa/types';\nimport { createShareProof, generateGPGKeyPair, getBitgoGpgPubKey, getTrustGpgPubKey } from '../../opengpgUtils';\nimport { BitGoBase } from '../../../bitgoBase';\nimport { BackupProvider, IWallet } from '../../../wallet';\nimport { buildNShareFromAPIKeyShare, getParticipantFromIndex, verifyWalletSignature } from '../../../tss/ecdsa/ecdsa';\nimport { signMessageWithDerivedEcdhKey, verifyEcdhSignature } from '../../../ecdh';\nimport { getTxRequestChallenge } from '../../../tss/common';\nimport {\n  ShareKeyPosition,\n  TssEcdsaStep1ReturnMessage,\n  TssEcdsaStep2ReturnMessage,\n  TxRequestChallengeResponse,\n} from '../../../tss/types';\n\nconst encryptNShare = ECDSAMethods.encryptNShare;\n\n/** @inheritdoc */\nexport class EcdsaUtils extends baseTSSUtils<KeyShare> {\n  // We do not have full support for 3-party verification (w/ external source) of key shares and signature shares. There is no 3rd party key service support with this release.\n  private bitgoPublicGpgKey: openpgp.Key | undefined = undefined;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin, wallet);\n    this.setBitgoGpgPubKey(bitgo);\n  }\n\n  private async setBitgoGpgPubKey(bitgo) {\n    this.bitgoPublicGpgKey = await getBitgoGpgPubKey(bitgo);\n  }\n\n  async getBitgoPublicGpgKey(): Promise<openpgp.Key> {\n    if (!this.bitgoPublicGpgKey) {\n      // retry getting bitgo's gpg key\n      await this.setBitgoGpgPubKey(this.bitgo);\n      if (!this.bitgoPublicGpgKey) {\n        throw new Error(\"Failed to get Bitgo's gpg key\");\n      }\n    }\n\n    return this.bitgoPublicGpgKey;\n  }\n\n  /**\n   * Gets the common public key from commonKeychain.\n   *\n   * @param {String} commonKeychain common key chain between n parties\n   * @returns {string} encoded public key\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 130) {\n      throw new Error(`Invalid commonKeychain length, expected 130, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 66);\n    return commonPubHexStr;\n  }\n\n  async finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    thirdPartyBackupPublicGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const encryptedUserToBackupShare = await encryptNShare(\n      userKeyShare,\n      2,\n      thirdPartyBackupPublicGpgKey.armor(),\n      userGpgKey\n    );\n    const bitgoToBackupKeyShare = bitgoKeychain.keyShares?.find(\n      (keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup'\n    );\n    const userPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.nShares[2].y, 'hex'),\n      Buffer.from(userKeyShare.nShares[2].chaincode, 'hex'),\n    ]).toString('hex');\n    assert(bitgoToBackupKeyShare);\n    const keyResponse = await this.bitgo\n      .put(this.baseCoin.url(`/krs/backupkeys/${keyId}`))\n      .send({\n        commonKeychain,\n        keyShares: [\n          {\n            from: 'user',\n            to: 'backup',\n            publicShare: userPublicShare,\n            privateShare: encryptedUserToBackupShare.encryptedPrivateShare,\n            privateShareProof: encryptedUserToBackupShare.privateShareProof,\n            vssProof: encryptedUserToBackupShare.vssProof,\n          },\n          bitgoToBackupKeyShare,\n        ],\n      })\n      .result();\n    if (!keyResponse || !keyResponse.commonKeychain) {\n      throw new Error('Failed backup key verification.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n      commonKeychain: keyResponse.commonKeychain,\n    };\n  }\n\n  /** @inheritdoc */\n  async createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    const MPC = new Ecdsa();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = await MPC.keyShare(1, m, n);\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const isThirdPartyBackup = this.isValidThirdPartyBackupProvider(params.backupProvider);\n    const backupKeyShare = await this.createBackupKeyShares(isThirdPartyBackup, userGpgKey, params.enterprise);\n    const backupGpgKey = await this.getBackupGpgPubKey(isThirdPartyBackup);\n\n    // Get the BitGo public key based on user/enterprise feature flags\n    // If it doesn't work, use the default public key from the constants\n    const bitgoPublicGpgKey =\n      (await this.getBitgoGpgPubkeyBasedOnFeatureFlags(params.enterprise)) ?? this.bitgoPublicGpgKey;\n\n    const bitgoKeychain = await this.createBitgoKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      enterprise: params.enterprise,\n      isThirdPartyBackup,\n    });\n    const userKeychainPromise = this.createUserKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n      isThirdPartyBackup,\n    });\n    const backupKeychainPromise = this.createBackupKeychain({\n      userGpgKey,\n      backupGpgKey,\n      bitgoPublicGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      backupProvider: params.backupProvider,\n    });\n\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    return {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n  }\n\n  /**\n   * If a third party backup is requested, it will create backup shares from\n   * a third party (BitGo as of now), otherwise the key shares will be client generated\n   */\n  async createBackupKeyShares(\n    isThirdPartyBackup = false,\n    userGpgPubKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BackupKeyShare> {\n    let backupKeyShare: BackupKeyShare;\n    if (isThirdPartyBackup) {\n      const bitgoHeldBackupKeyShares = await this.createBitgoHeldBackupKeyShare(userGpgPubKey, enterprise);\n      backupKeyShare = {\n        bitGoHeldKeyShares: bitgoHeldBackupKeyShares,\n      };\n    } else {\n      const MPC = new Ecdsa();\n      const m = 2;\n      const n = 3;\n      backupKeyShare = {\n        userHeldKeyShare: await MPC.keyShare(2, m, n),\n      };\n    }\n    return backupKeyShare;\n  }\n\n  /**\n   * Gets backup pub gpg key string\n   * if a third party provided then get from trust\n   * @param isThirdPartyBackup\n   */\n  async getBackupGpgPubKey(isThirdPartyBackup = false): Promise<BackupGpgKey> {\n    return isThirdPartyBackup ? getTrustGpgPubKey(this.bitgo) : generateGPGKeyPair('secp256k1');\n  }\n\n  createUserKeychain({\n    userGpgKey,\n    backupGpgKey,\n    bitgoPublicGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n    originalPasscodeEncryptionCode,\n    isThirdPartyBackup = false,\n  }: CreateEcdsaKeychainParams): Promise<Keychain> {\n    if (!passphrase) {\n      throw new Error('Please provide a wallet passphrase');\n    }\n    if (isThirdPartyBackup && backupKeyShare.bitGoHeldKeyShares?.keyShares) {\n      return this.createUserKeychainFromThirdPartyBackup(\n        userGpgKey,\n        bitgoPublicGpgKey,\n        backupGpgKey as Key,\n        userKeyShare,\n        backupKeyShare.bitGoHeldKeyShares.keyShares,\n        bitgoKeychain,\n        passphrase,\n        originalPasscodeEncryptionCode\n      );\n    }\n    assert(backupKeyShare.userHeldKeyShare);\n    return this.createParticipantKeychain(\n      userGpgKey,\n      backupGpgKey as SerializedKeyPair<string>,\n      bitgoPublicGpgKey,\n      1,\n      userKeyShare,\n      backupKeyShare.userHeldKeyShare,\n      bitgoKeychain,\n      passphrase,\n      originalPasscodeEncryptionCode\n    );\n  }\n\n  async createBackupKeychain({\n    userGpgKey,\n    userKeyShare,\n    backupGpgKey,\n    backupKeyShare,\n    bitgoKeychain,\n    bitgoPublicGpgKey,\n    passphrase,\n    backupProvider,\n  }: CreateEcdsaKeychainParams): Promise<Keychain> {\n    if (this.isValidThirdPartyBackupProvider(backupProvider) && backupKeyShare.bitGoHeldKeyShares?.keyShares) {\n      assert(bitgoKeychain.commonKeychain);\n      const finalizedBackupKeyShare = await this.finalizeBitgoHeldBackupKeyShare(\n        backupKeyShare.bitGoHeldKeyShares.id,\n        bitgoKeychain.commonKeychain,\n        userKeyShare,\n        bitgoKeychain,\n        userGpgKey,\n        backupGpgKey as Key\n      );\n      if (finalizedBackupKeyShare.commonKeychain !== bitgoKeychain.commonKeychain) {\n        throw new Error('Failed to create backup keychain - commonKeychains do not match');\n      }\n      const backupKeyParams: CreateBackupOptions = {\n        source: 'backup',\n        keyType: 'tss',\n        commonKeychain: finalizedBackupKeyShare.commonKeychain,\n        provider: backupProvider ?? 'BitGoTrustAsKrs',\n      };\n      const backupKeychain = await this.baseCoin.keychains().createBackup(backupKeyParams);\n      backupKeychain.keyShares = finalizedBackupKeyShare.keyShares;\n      return backupKeychain;\n    }\n    assert(backupKeyShare.userHeldKeyShare);\n    assert(passphrase);\n    return this.createParticipantKeychain(\n      userGpgKey,\n      backupGpgKey as SerializedKeyPair<string>,\n      bitgoPublicGpgKey,\n      2,\n      userKeyShare,\n      backupKeyShare.userHeldKeyShare,\n      bitgoKeychain,\n      passphrase\n    );\n  }\n\n  /** @inheritdoc */\n  async createBitgoKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    enterprise,\n    bitgoPublicGpgKey,\n    isThirdPartyBackup = false,\n  }: CreateEcdsaBitGoKeychainParams): Promise<Keychain> {\n    const recipientIndex = 3;\n    const userToBitgoShare = await encryptNShare(userKeyShare, recipientIndex, bitgoPublicGpgKey.armor(), userGpgKey);\n\n    const backupToBitgoShare = await this.getBackupEncryptedNShare(\n      backupKeyShare,\n      recipientIndex,\n      bitgoPublicGpgKey.armor(),\n      backupGpgKey as SerializedKeyPair<string>,\n      isThirdPartyBackup\n    );\n\n    const createBitGoMPCParams: AddKeychainOptions = {\n      keyType: 'tss' as KeyType,\n      source: 'bitgo',\n      keyShares: [\n        {\n          from: 'user',\n          to: 'bitgo',\n          publicShare: userToBitgoShare.publicShare,\n          privateShare: userToBitgoShare.encryptedPrivateShare,\n          n: userToBitgoShare.n,\n          vssProof: userToBitgoShare.vssProof,\n          privateShareProof: userToBitgoShare.privateShareProof,\n        },\n        {\n          from: 'backup',\n          to: 'bitgo',\n          publicShare: backupToBitgoShare.publicShare,\n          privateShare: backupToBitgoShare.encryptedPrivateShare,\n          n: backupToBitgoShare.n,\n          vssProof: backupToBitgoShare.vssProof,\n          privateShareProof: backupToBitgoShare.privateShareProof,\n        },\n      ],\n      userGPGPublicKey: userGpgKey.publicKey,\n      backupGPGPublicKey: isThirdPartyBackup\n        ? (backupGpgKey as Key).armor()\n        : (backupGpgKey as SerializedKeyPair<string>).publicKey,\n      enterprise: enterprise,\n      algoUsed: 'ecdsa',\n    };\n\n    return await this.baseCoin.keychains().add(createBitGoMPCParams);\n  }\n\n  /**\n   * This builds the relevant backup encryptedNShare based on whether the\n   * backup key is user or third party generated\n   * @param backupShare can either have key shares from the user or third party\n   * @param recipientIndex index of the party receiving the backup shares\n   * @param recipientGpgPublicArmor gpg armor of the party receiving the backup shares\n   * @param backupGpgKey backup gpg key\n   * @param isThirdPartyBackup whether the backup is generated by third party\n   */\n  async getBackupEncryptedNShare(\n    backupShare: BackupKeyShare,\n    recipientIndex: number,\n    recipientGpgPublicArmor: string,\n    backupGpgKey: SerializedKeyPair<string>,\n    isThirdPartyBackup = false\n  ): Promise<EncryptedNShare> {\n    let backupToRecipientShare: EncryptedNShare;\n    if (isThirdPartyBackup) {\n      if (!backupShare.bitGoHeldKeyShares) {\n        throw new Error(`Missing third party backup key shares`);\n      }\n      const backupToRecipientApiShare = backupShare.bitGoHeldKeyShares.keyShares.find(\n        (keyShare) => keyShare.from === 'backup' && keyShare.to === getParticipantFromIndex(recipientIndex)\n      );\n      if (!backupToRecipientApiShare) {\n        throw new Error(`Missing backup to ${getParticipantFromIndex(recipientIndex)} key share`);\n      }\n      // Since backup is from a third party, it is already encrypted\n      backupToRecipientShare = await buildNShareFromAPIKeyShare(backupToRecipientApiShare);\n    } else {\n      assert(backupShare.userHeldKeyShare);\n      backupToRecipientShare = await encryptNShare(\n        backupShare.userHeldKeyShare,\n        recipientIndex,\n        recipientGpgPublicArmor,\n        backupGpgKey\n      );\n    }\n    return backupToRecipientShare;\n  }\n\n  /**\n   * This uses the backup key from a third party (bitgo in this case)\n   * to create the user keychain via WP.\n   */\n  async createUserKeychainFromThirdPartyBackup(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    bitgoPublicGpgKey: Key,\n    thirdPartyBackupPublicGpgKey: Key,\n    userKeyShare: KeyShare,\n    thirdPartybackupKeyShares: ApiKeyShare[],\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n    if (!bitgoKeychain.commonKeychain) {\n      throw new Error(`Missing common key chain: ${bitgoKeychain.commonKeychain}`);\n    }\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (!bitGoToUserShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const backupToUserShare = thirdPartybackupKeyShares.find(\n      (keyShare) => keyShare.from === 'backup' && keyShare.to === 'user'\n    );\n    if (!backupToUserShare) {\n      throw new Error('Missing Backup to User key share');\n    }\n\n    const backupToUserNShare = await buildNShareFromAPIKeyShare(backupToUserShare);\n    const bitGoToUserNShare = await buildNShareFromAPIKeyShare(bitGoToUserShare);\n    const encryptedNShares: DecryptableNShare[] = [\n      {\n        nShare: backupToUserNShare,\n        recipientPrivateArmor: userGpgKey.privateKey,\n        senderPublicArmor: thirdPartyBackupPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n      {\n        nShare: bitGoToUserNShare,\n        recipientPrivateArmor: userGpgKey.privateKey,\n        senderPublicArmor: bitgoPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n    ];\n\n    const userCombinedKey = await ECDSAMethods.createCombinedKey(\n      userKeyShare,\n      encryptedNShares,\n      bitgoKeychain.commonKeychain\n    );\n    if (userCombinedKey.commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const prv = JSON.stringify(userCombinedKey.signingMaterial);\n    const userKeychainParams = {\n      source: 'user',\n      keyType: 'tss' as KeyType,\n      commonKeychain: userCombinedKey.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({\n        input: prv,\n        password: passphrase,\n      }),\n      originalPasscodeEncryptionCode,\n    };\n\n    const keychains = this.baseCoin.keychains();\n    return await keychains.add(userKeychainParams);\n  }\n\n  /** @inheritdoc */\n  async createParticipantKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userLocalBackupGpgKey: openpgp.SerializedKeyPair<string>,\n    bitgoPublicGpgKey: Key,\n    recipientIndex: number,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n    if (!bitgoKeychain.commonKeychain) {\n      throw new Error(`Missing common key chain: ${bitgoKeychain.commonKeychain}`);\n    }\n\n    let recipient: string;\n    let keyShare: KeyShare;\n    let otherShare: KeyShare;\n    let recipientGpgKey: openpgp.SerializedKeyPair<string>;\n    let senderGpgKey: openpgp.SerializedKeyPair<string>;\n    if (recipientIndex === 1) {\n      keyShare = userKeyShare;\n      otherShare = backupKeyShare;\n      recipient = 'user';\n      recipientGpgKey = userGpgKey;\n      senderGpgKey = userLocalBackupGpgKey;\n    } else if (recipientIndex === 2) {\n      keyShare = backupKeyShare;\n      otherShare = userKeyShare;\n      recipient = 'backup';\n      recipientGpgKey = userLocalBackupGpgKey;\n      senderGpgKey = userGpgKey;\n    } else {\n      throw new Error('Invalid user index');\n    }\n\n    const bitGoToRecipientShare = bitgoKeyShares.find(\n      (keyShare) => keyShare.from === 'bitgo' && keyShare.to === recipient\n    );\n    if (!bitGoToRecipientShare) {\n      throw new Error(`Missing BitGo to ${recipient} key share`);\n    }\n\n    const decryptedShare = await this.decryptPrivateShare(bitGoToRecipientShare.privateShare, recipientGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      userLocalBackupGpgKey.publicKey,\n      bitgoKeychain,\n      decryptedShare,\n      recipientIndex\n    );\n\n    const senderToRecipientShare = await encryptNShare(\n      otherShare,\n      recipientIndex,\n      recipientGpgKey.publicKey,\n      senderGpgKey\n    );\n    const encryptedNShares: DecryptableNShare[] = [\n      {\n        // userToBackup or backupToUser\n        nShare: senderToRecipientShare,\n        recipientPrivateArmor: recipientGpgKey.privateKey,\n        senderPublicArmor: senderGpgKey.publicKey,\n      },\n      {\n        // bitgoToRecipient\n        nShare: {\n          i: recipientIndex,\n          j: 3,\n          publicShare: bitGoToRecipientShare.publicShare,\n          encryptedPrivateShare: bitGoToRecipientShare.privateShare,\n          n: bitGoToRecipientShare.n!,\n          vssProof: bitGoToRecipientShare.vssProof,\n          privateShareProof: bitGoToRecipientShare.privateShareProof,\n        },\n        recipientPrivateArmor: recipientGpgKey.privateKey,\n        senderPublicArmor: bitgoPublicGpgKey.armor(),\n        isbs58Encoded: false,\n      },\n    ];\n\n    const recipientCombinedKey = await ECDSAMethods.createCombinedKey(\n      keyShare,\n      encryptedNShares,\n      bitgoKeychain.commonKeychain\n    );\n\n    const prv = JSON.stringify(recipientCombinedKey.signingMaterial);\n    const recipientKeychainParams = {\n      source: recipient,\n      keyType: 'tss' as KeyType,\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({\n        input: prv,\n        password: passphrase,\n      }),\n      originalPasscodeEncryptionCode,\n    };\n\n    const keychains = this.baseCoin.keychains();\n    return recipientIndex === 1\n      ? await keychains.add(recipientKeychainParams)\n      : await keychains.createBackup(recipientKeychainParams);\n  }\n\n  private async createTssEcdsaStep1SigningMaterial(params: {\n    challenges: {\n      enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;\n      bitgoChallenge: TxRequestChallengeResponse;\n    };\n    prv: string;\n    derivationPath: string;\n    walletPassphrase?: string;\n  }): Promise<TssEcdsaStep1ReturnMessage> {\n    const { challenges, derivationPath, prv } = params;\n    const userSigningMaterial: ECDSAMethodTypes.SigningMaterial = JSON.parse(prv);\n    if (userSigningMaterial.pShare.i !== 1) {\n      throw new Error('Invalid user key');\n    }\n    if (!userSigningMaterial.backupNShare) {\n      throw new Error('Invalid user key - missing backupNShare');\n    }\n    const MPC = new Ecdsa();\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.pShare,\n      [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare],\n      derivationPath\n    );\n\n    const bitgoIndex = ShareKeyPosition.BITGO;\n    const userIndex = userSigningMaterial.pShare.i;\n\n    const { ntilde: ntildea, h1: h1a, h2: h2a, p: pa } = challenges.enterpriseChallenge;\n    const { ntilde: ntildeb, h1: h1b, h2: h2b, p: pb, n: nb } = challenges.bitgoChallenge;\n    const userXShare = MPC.appendChallenge(signingKey.xShare, { ntilde: ntildea, h1: h1a, h2: h2a }, { p: pa });\n    const bitgoYShare = MPC.appendChallenge(\n      {\n        i: userIndex,\n        j: bitgoIndex,\n        n: nb,\n      },\n      { ntilde: ntildeb, h1: h1b, h2: h2b },\n      { p: pb }\n    );\n\n    const userSignShare = await ECDSAMethods.createUserSignShare(userXShare, bitgoYShare);\n    const u = signingKey.nShares[bitgoIndex].u;\n\n    let chaincode = userSigningMaterial.bitgoNShare.chaincode;\n    while (chaincode.length < 64) {\n      chaincode = '0' + chaincode;\n    }\n    const signerShare = bip32.fromPrivateKey(Buffer.from(u, 'hex'), Buffer.from(chaincode, 'hex')).toBase58();\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = (await openpgp.encrypt({\n      message: await openpgp.createMessage({\n        text: signerShare,\n      }),\n      config: {\n        rejectCurves: new Set(),\n      },\n      encryptionKeys: [bitgoGpgKey],\n    })) as string;\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const privateShareProof = await createShareProof(userGpgKey.privateKey, signingKey.nShares[bitgoIndex].u, 'ecdsa');\n    const vssProof = signingKey.nShares[bitgoIndex].v;\n    const userPublicGpgKey = userGpgKey.publicKey;\n    const publicShare = signingKey.nShares[bitgoIndex].y + signingKey.nShares[bitgoIndex].chaincode;\n    return {\n      privateShareProof: privateShareProof,\n      vssProof: vssProof,\n      publicShare: publicShare,\n      encryptedSignerOffsetShare: encryptedSignerShare,\n      userPublicGpgKey: userPublicGpgKey,\n      kShare: userSignShare.kShare,\n      wShare: params.walletPassphrase\n        ? this.bitgo.encrypt({ input: JSON.stringify(userSignShare.wShare), password: params.walletPassphrase })\n        : userSignShare.wShare,\n    };\n  }\n\n  private async createTssEcdsaStep2SigningMaterial(params: {\n    bitgoChallenge: TxRequestChallengeResponse;\n    wShare: WShare;\n    aShareFromBitgo: Omit<AShare, 'h1' | 'h2' | 'ntilde'>;\n    walletPassphrase?: string;\n  }): Promise<TssEcdsaStep2ReturnMessage> {\n    // Append the BitGo challenge to the Ashare to be used in subsequent proofs\n    const bitgoToUserAShareWithNtilde: AShare = {\n      ...params.aShareFromBitgo,\n      ...params.bitgoChallenge,\n    };\n    const userGammaAndMuShares = await ECDSAMethods.createUserGammaAndMuShare(\n      params.wShare,\n      bitgoToUserAShareWithNtilde\n    );\n    const userOmicronAndDeltaShare = await ECDSAMethods.createUserOmicronAndDeltaShare(\n      userGammaAndMuShares.gShare as ECDSA.GShare\n    );\n    return {\n      muDShare: {\n        muShare: userGammaAndMuShares.muShare,\n        dShare: userOmicronAndDeltaShare.dShare,\n        i: userGammaAndMuShares.muShare.i,\n      },\n      oShare: params.walletPassphrase\n        ? this.bitgo.encrypt({\n            input: JSON.stringify(userOmicronAndDeltaShare.oShare),\n            password: params.walletPassphrase,\n          })\n        : userOmicronAndDeltaShare.oShare,\n    };\n  }\n\n  getOfflineSignerPaillierModulus(params: { prv: string }): { userPaillierModulus: string } {\n    assert(params.prv, 'Params to get paillier modulus are missing prv.');\n    const userSigningMaterial: ECDSAMethodTypes.SigningMaterial = JSON.parse(params.prv);\n    return { userPaillierModulus: userSigningMaterial.pShare.n };\n  }\n\n  async createOfflineKShare(params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    challenges: {\n      enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;\n      bitgoChallenge: TxRequestChallengeResponse;\n    };\n    requestType: RequestType;\n    prv: string;\n    walletPassphrase: string;\n  }): Promise<TssEcdsaStep1ReturnMessage> {\n    const { tssParams, prv, requestType, challenges } = params;\n    assert(typeof tssParams.txRequest !== 'string', 'Invalid txRequest type');\n    const txRequest: TxRequest = tssParams.txRequest;\n    let derivationPath;\n\n    if (requestType === RequestType.tx) {\n      assert(\n        txRequest.transactions || (txRequest as TxRequest).unsignedTxs,\n        'Unable to find transactions in txRequest'\n      );\n      const unsignedTx =\n        txRequest.apiVersion === 'full' ? txRequest.transactions![0].unsignedTx : txRequest.unsignedTxs[0];\n      derivationPath = unsignedTx.derivationPath;\n    } else if (requestType === RequestType.message) {\n      // TODO BG-67299 Message signing with derivation path\n      derivationPath = '';\n    }\n    return this.createTssEcdsaStep1SigningMaterial({\n      prv: prv,\n      challenges: challenges,\n      derivationPath: derivationPath,\n      walletPassphrase: params.walletPassphrase,\n    });\n  }\n\n  async createOfflineMuDeltaShare(params: {\n    aShareFromBitgo: Omit<AShare, 'ntilde' | 'h1' | 'h2'>;\n    bitgoChallenge: TxRequestChallengeResponse;\n    encryptedWShare: string;\n    walletPassphrase: string;\n  }): Promise<TssEcdsaStep2ReturnMessage> {\n    const decryptedWShare = this.bitgo.decrypt({ input: params.encryptedWShare, password: params.walletPassphrase });\n    return await this.createTssEcdsaStep2SigningMaterial({\n      aShareFromBitgo: params.aShareFromBitgo,\n      bitgoChallenge: params.bitgoChallenge,\n      wShare: JSON.parse(decryptedWShare),\n      walletPassphrase: params.walletPassphrase,\n    });\n  }\n\n  async createOfflineSShare(params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    dShareFromBitgo: DShare;\n    requestType: RequestType;\n    encryptedOShare: string;\n    walletPassphrase: string;\n  }): Promise<SShare> {\n    const { tssParams, requestType, dShareFromBitgo, encryptedOShare, walletPassphrase } = params;\n    assert(typeof tssParams.txRequest !== 'string', 'Invalid txRequest type');\n    const txRequest: TxRequest = tssParams.txRequest;\n    let signablePayload;\n    if (requestType === RequestType.tx) {\n      assert(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');\n      const unsignedTx =\n        txRequest.apiVersion === 'full' ? txRequest.transactions![0].unsignedTx : txRequest.unsignedTxs[0];\n      signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n    } else if (requestType === RequestType.message) {\n      signablePayload = (params.tssParams as TSSParamsForMessage).bufferToSign;\n    }\n    const decryptedOShare = this.bitgo.decrypt({ input: encryptedOShare, password: walletPassphrase });\n    return await ECDSAMethods.createUserSignatureShare(JSON.parse(decryptedOShare), dShareFromBitgo, signablePayload);\n  }\n\n  async signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest> {\n    const { txRequest } = params;\n    const pendingEcdsaTssInitialization = this.wallet.coinSpecific()?.pendingEcdsaTssInitialization;\n    if (pendingEcdsaTssInitialization) {\n      throw new Error(\n        'Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.'\n      );\n    }\n    const txRequestObj: TxRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequest as string);\n    const { userPaillierModulus } = await externalSignerPaillierModulusGetter({ txRequest: txRequestObj });\n    const { enterpriseChallenge, bitgoChallenge } = await this.getEcdsaSigningChallenges(\n      txRequest as string,\n      requestType,\n      userPaillierModulus,\n      0\n    );\n    const step1SigningMaterial = await externalSignerKShareGenerator({\n      tssParams: {\n        ...params,\n        txRequest: txRequestObj,\n      },\n      challenges: { enterpriseChallenge, bitgoChallenge },\n      requestType: requestType,\n    });\n    // signing stage one with K share send to bitgo and receives A share\n    const bitgoToUserAShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestObj.txRequestId,\n      requestType,\n      SendShareType.KShare,\n      step1SigningMaterial.kShare,\n      step1SigningMaterial.encryptedSignerOffsetShare,\n      step1SigningMaterial.vssProof,\n      step1SigningMaterial.privateShareProof,\n      step1SigningMaterial.publicShare,\n      step1SigningMaterial.userPublicGpgKey\n    )) as Omit<AShare, 'ntilde' | 'h1' | 'h2'>; // WP/HSM does not return the initial challenge\n    const step2Return = await externalSignerMuDeltaShareGenerator({\n      txRequest: txRequestObj,\n      aShareFromBitgo: bitgoToUserAShare,\n      bitgoChallenge: bitgoChallenge,\n      encryptedWShare: step1SigningMaterial.wShare as string,\n    });\n    // signing stage two with muShare and dShare send to bitgo and receives D share\n    const bitgoToUserDShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestObj.txRequestId,\n      requestType,\n      SendShareType.MUShare,\n      step2Return.muDShare\n    )) as DShare;\n    const userSShare = await externalSignerSShareGenerator({\n      tssParams: {\n        ...params,\n        txRequest: txRequestObj,\n      },\n      dShareFromBitgo: bitgoToUserDShare,\n      requestType: requestType,\n      encryptedOShare: step2Return.oShare as string,\n    });\n    // signing stage three with SShare send to bitgo and receives SShare\n    await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestObj.txRequestId,\n      requestType,\n      SendShareType.SShare,\n      userSShare\n    );\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestObj.txRequestId);\n  }\n\n  /**\n   * Gets signing key, txRequestResolved and txRequestId\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param { string} params.reqId - request id\n   * @returns {Promise<TxRequest>}\n   */\n  private async signRequestBase(params: TSSParams | TSSParamsForMessage, requestType: RequestType): Promise<TxRequest> {\n    const pendingEcdsaTssInitialization = this.wallet.coinSpecific()?.pendingEcdsaTssInitialization;\n    if (pendingEcdsaTssInitialization) {\n      throw new Error(\n        'Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.'\n      );\n    }\n    const userSigningMaterial: ECDSAMethodTypes.SigningMaterial = JSON.parse(params.prv);\n    if (userSigningMaterial.pShare.i !== 1) {\n      throw new Error('Invalid user key');\n    }\n    if (!userSigningMaterial.backupNShare) {\n      throw new Error('Invalid user key - missing backupNShare');\n    }\n\n    const txRequest: TxRequest =\n      typeof params.txRequest === 'string'\n        ? await getTxRequest(this.bitgo, this.wallet.id(), params.txRequest)\n        : params.txRequest;\n\n    let signablePayload = new Buffer('');\n    let derivationPath = '';\n\n    if (requestType === RequestType.tx) {\n      assert(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');\n      const unsignedTx =\n        txRequest.apiVersion === 'full' ? txRequest.transactions![0].unsignedTx : txRequest.unsignedTxs[0];\n      signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n      derivationPath = unsignedTx.derivationPath;\n    } else if (requestType === RequestType.message) {\n      signablePayload = (params as TSSParamsForMessage).bufferToSign;\n      // TODO BG-67299 Message signing with derivation path\n    }\n    const paillierModulus = this.getOfflineSignerPaillierModulus({ prv: params.prv });\n    const challenges = await this.getEcdsaSigningChallenges(\n      txRequest.txRequestId,\n      requestType,\n      paillierModulus.userPaillierModulus,\n      0\n    );\n\n    const step1Return = await this.createTssEcdsaStep1SigningMaterial({\n      prv: params.prv,\n      challenges: challenges,\n      derivationPath: derivationPath,\n    });\n\n    // signing stage one with K share send to bitgo and receives A share\n    const bitgoToUserAShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.KShare,\n      step1Return.kShare,\n      step1Return.encryptedSignerOffsetShare,\n      step1Return.vssProof,\n      step1Return.privateShareProof,\n      step1Return.publicShare,\n      step1Return.userPublicGpgKey\n    )) as Omit<AShare, 'ntilde' | 'h1' | 'h2'>; // WP/HSM does not return the initial challenge\n\n    const step2Return = await this.createTssEcdsaStep2SigningMaterial({\n      aShareFromBitgo: bitgoToUserAShare,\n      bitgoChallenge: challenges.bitgoChallenge,\n      wShare: step1Return.wShare as WShare,\n    });\n\n    // signing stage two with muShare and dShare send to bitgo and receives D share\n    const bitgoToUserDShare = (await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.MUShare,\n      step2Return.muDShare\n    )) as DShare;\n\n    const userSShare = await ECDSAMethods.createUserSignatureShare(\n      step2Return.oShare as OShare,\n      bitgoToUserDShare,\n      signablePayload,\n      params.hash\n    );\n\n    // signing stage three with SShare send to bitgo and receives SShare\n    await ECDSAMethods.sendShareToBitgo(\n      this.bitgo,\n      this.wallet.id(),\n      txRequest.txRequestId,\n      requestType,\n      SendShareType.SShare,\n      userSShare\n    );\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequest.txRequestId);\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param {string} params.reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: TSSParams): Promise<TxRequest> {\n    return this.signRequestBase(params, RequestType.tx);\n  }\n\n  /**\n   * Signs the message associated to the transaction request.\n   * @param {string | TxRequest} params.txRequest - transaction request object or id\n   * @param {string} params.prv - decrypted private key\n   * @param {string} params.reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequestForMessage(params: TSSParamsForMessage): Promise<TxRequest> {\n    if (!params.messageRaw) {\n      throw new Error('Raw message required to sign message');\n    }\n    return this.signRequestBase(params, RequestType.message);\n  }\n\n  /**\n   * Get the challenge values for enterprise and BitGo in ECDSA signing\n   * Only returns the challenges if they are verified by the user's enterprise admin's ecdh key\n   * @param {string} txRequestId - transaction request id\n   * @param {RequestType} requestType -  (0 for tx, 1 for message)\n   * @param {string} walletPaillierModulus - paillier pubkey $n$\n   * @param {number} index - index of the requestType\n   */\n  async getEcdsaSigningChallenges(\n    txRequestId: string,\n    requestType: RequestType,\n    walletPaillierModulus: string,\n    index = 0\n  ): Promise<{\n    enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;\n    bitgoChallenge: TxRequestChallengeResponse;\n  }> {\n    const enterpriseId = this.wallet.toJSON().enterprise;\n    if (!enterpriseId) {\n      throw new Error('Wallet must be an enterprise wallet.');\n    }\n\n    // create BitGo range proof and paillier proof challenge\n    const createBitgoChallengeResponse = await getTxRequestChallenge(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      index.toString(),\n      requestType,\n      walletPaillierModulus\n    );\n\n    const bitgoToEnterprisePaillierChallenge = { p: createBitgoChallengeResponse.p };\n    const enterpriseToBitgoPaillierChallenge = EcdsaTypes.serializePaillierChallenge({\n      p: await EcdsaPaillierProof.generateP(hexToBigInt(createBitgoChallengeResponse.n)),\n    });\n\n    // TODO(BG-78764): once the paillier proofs are complete, reduce challenge creation to one API call\n    const walletChallenges = await this.wallet.getChallengesForEcdsaSigning();\n\n    const challengeVerifierUserId = walletChallenges.createdBy;\n    const adminSigningKeyResponse = await this.bitgo.getSigningKeyForUser(enterpriseId, challengeVerifierUserId);\n    const pubkeyOfAdminEcdhKeyHex = adminSigningKeyResponse.derivedPubkey;\n\n    // Verify enterprise's challenge is signed by the respective admins ecdh keychain\n    const enterpriseRawChallenge = {\n      ntilde: walletChallenges.enterpriseChallenge.ntilde,\n      h1: walletChallenges.enterpriseChallenge.h1,\n      h2: walletChallenges.enterpriseChallenge.h2,\n    };\n    const adminSignatureOnEntChallenge: string = walletChallenges.enterpriseChallenge.verifiers.adminSignature;\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(enterpriseRawChallenge),\n        adminSignatureOnEntChallenge,\n        Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex')\n      )\n    ) {\n      throw new Error(`Admin signature for enterprise challenge is not valid. Please contact your enterprise admin.`);\n    }\n\n    // Verify that the BitGo challenge's ZK proofs have been verified by the admin\n    const bitgoChallenge: TxRequestChallengeResponse = {\n      ntilde: walletChallenges.bitgoChallenge.ntilde,\n      h1: walletChallenges.bitgoChallenge.h1,\n      h2: walletChallenges.bitgoChallenge.h2,\n      p: bitgoToEnterprisePaillierChallenge.p,\n      n: createBitgoChallengeResponse.n,\n    };\n    const adminVerificationSignatureForBitGoChallenge = walletChallenges.bitgoChallenge.verifiers.adminSignature;\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(bitgoChallenge),\n        adminVerificationSignatureForBitGoChallenge,\n        Buffer.from(pubkeyOfAdminEcdhKeyHex, 'hex')\n      )\n    ) {\n      throw new Error(`Admin signature for BitGo's challenge is not valid. Please contact your enterprise admin.`);\n    }\n\n    return {\n      enterpriseChallenge: {\n        ...enterpriseRawChallenge,\n        p: enterpriseToBitgoPaillierChallenge.p,\n      },\n      bitgoChallenge,\n    };\n  }\n\n  /**\n   * Verifies the u-value proofs and GPG keys used in generating a TSS ECDSA wallet.\n   * @param userGpgPub The user's public GPG key for encryption between user/server\n   * @param backupGpgPub The backup's public GPG key for encryption between backup/server\n   * @param bitgoKeychain previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param decryptedShare The decrypted bitgo-to-user/backup private share retrieved from the keychain\n   * @param verifierIndex The index of the party to verify: 1 = user, 2 = backup\n   */\n  async verifyWalletSignatures(\n    userGpgPub: string,\n    backupGpgPub: string,\n    bitgoKeychain: Keychain,\n    decryptedShare: string,\n    verifierIndex: 1 | 2\n  ): Promise<void> {\n    assert(bitgoKeychain.commonKeychain);\n    assert(bitgoKeychain.walletHSMGPGPublicKeySigs);\n\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });\n    const userKeyId = userKeyPub.keyPacket.getFingerprint();\n    const backupKeyPub = await openpgp.readKey({ armoredKey: backupGpgPub });\n    const backupKeyId = backupKeyPub.keyPacket.getFingerprint();\n\n    const walletSignatures = await openpgp.readKeys({ armoredKeys: bitgoKeychain.walletHSMGPGPublicKeySigs });\n    if (walletSignatures.length !== 2) {\n      throw new Error('Invalid wallet signatures');\n    }\n    if (userKeyId !== walletSignatures[0].keyPacket.getFingerprint()) {\n      throw new Error(`first wallet signature's fingerprint does not match passed user gpg key's fingerprint`);\n    }\n    if (backupKeyId !== walletSignatures[1].keyPacket.getFingerprint()) {\n      throw new Error(`second wallet signature's fingerprint does not match passed backup gpg key's fingerprint`);\n    }\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[0],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[1],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n  }\n\n  /**\n   * Signs a challenge with the provided v1 ecdh key at a derived path\n   * @param challenge challenge to sign\n   * @param ecdhXprv xprv of the ecdh key\n   * @param derivationPath the derived path at which the ecdh key will sign\n   */\n  static signChallenge(challenge: EcdsaTypes.SerializedNtilde, ecdhXprv: string, derivationPath: string): Buffer {\n    const messageToSign = this.getMessageToSignFromChallenge(challenge);\n    return signMessageWithDerivedEcdhKey(messageToSign, ecdhXprv, derivationPath);\n  }\n\n  /**\n   * Converts challenge to a common message format which can be signed.\n   * @param challenge\n   */\n  static getMessageToSignFromChallenge(challenge: EcdsaTypes.SerializedNtilde): string {\n    return challenge.ntilde.concat(challenge.h1).concat(challenge.h2);\n  }\n\n  /**\n   Verifies ZK proofs of BitGo's challenges for both nitro and institutional HSMs\n   which are fetched from the WP API.\n   */\n  static async verifyBitGoChallenges(bitgoChallenges: GetBitGoChallengesApi): Promise<boolean> {\n    // Verify institutional hsm challenge proof\n    const instChallengeVerified = await this.verifyBitGoChallenge({\n      ntilde: bitgoChallenges.bitgoInstitutionalHsm.ntilde,\n      h1: bitgoChallenges.bitgoInstitutionalHsm.h1,\n      h2: bitgoChallenges.bitgoInstitutionalHsm.h2,\n      ntildeProof: bitgoChallenges.bitgoInstitutionalHsm.ntildeProof,\n    });\n\n    // Verify nitro hsm challenge proof\n    const nitroChallengeVerified = await this.verifyBitGoChallenge({\n      ntilde: bitgoChallenges.bitgoNitroHsm.ntilde,\n      h1: bitgoChallenges.bitgoNitroHsm.h1,\n      h2: bitgoChallenges.bitgoNitroHsm.h2,\n      ntildeProof: bitgoChallenges.bitgoNitroHsm.ntildeProof,\n    });\n\n    return instChallengeVerified && nitroChallengeVerified;\n  }\n\n  /**\n   * Verifies ZK proof for a single BitGo challenge\n   * @param bitgoChallenge\n   */\n  static async verifyBitGoChallenge(bitgoChallenge: EcdsaTypes.SerializedNtildeWithProofs): Promise<boolean> {\n    const deserializedInstChallenge = EcdsaTypes.deserializeNtildeWithProofs(bitgoChallenge);\n    const ntildeProofH1WrtH2Verified = await EcdsaRangeProof.verifyNtildeProof(\n      {\n        ntilde: deserializedInstChallenge.ntilde,\n        h1: deserializedInstChallenge.h1,\n        h2: deserializedInstChallenge.h2,\n      },\n      deserializedInstChallenge.ntildeProof.h1WrtH2\n    );\n    const ntildeProofH2WrtH1Verified = await EcdsaRangeProof.verifyNtildeProof(\n      {\n        ntilde: deserializedInstChallenge.ntilde,\n        h1: deserializedInstChallenge.h2,\n        h2: deserializedInstChallenge.h1,\n      },\n      deserializedInstChallenge.ntildeProof.h2WrtH1\n    );\n    return ntildeProofH1WrtH2Verified && ntildeProofH2WrtH1Verified;\n  }\n\n  /**\n   * Gets the bitgo challenges for both nitro and institutional HSMs from WP API.\n   * @param bitgo\n   */\n  static async getBitGoChallenges(bitgo: BitGoBase): Promise<GetBitGoChallengesApi> {\n    const res = await bitgo.get(bitgo.url('/tss/ecdsa/challenges', 2)).send().result();\n    if (\n      !res.bitgoNitroHsm ||\n      !res.bitgoNitroHsm.ntilde ||\n      !res.bitgoNitroHsm.h1 ||\n      !res.bitgoNitroHsm.h2 ||\n      !res.bitgoNitroHsm.ntildeProof ||\n      !res.bitgoInstitutionalHsm ||\n      !res.bitgoInstitutionalHsm.ntilde ||\n      !res.bitgoInstitutionalHsm.h1 ||\n      !res.bitgoInstitutionalHsm.h2 ||\n      !res.bitgoInstitutionalHsm.ntildeProof\n    ) {\n      throw new Error('Expected BitGo challenge proof to be present. Contact support@bitgo.com.');\n    }\n    return res;\n  }\n\n  /**\n   * Gets BitGo's proofs from API and signs them if the proofs are valid.\n   * @param bitgo\n   * @param enterpriseId\n   * @param userPassword\n   */\n  static async getVerifyAndSignBitGoChallenges(\n    bitgo: BitGoBase,\n    enterpriseId: string,\n    userPassword: string\n  ): Promise<BitGoProofSignatures> {\n    // Fetch BitGo's challenge and verify\n    const bitgoChallengesWithProofs = await EcdsaUtils.getBitGoChallenges(bitgo);\n    if (!(await EcdsaUtils.verifyBitGoChallenges(bitgoChallengesWithProofs))) {\n      throw new Error(\n        `Failed to verify BitGo's challenge needed to enable ECDSA signing. Please contact support@bitgo.com`\n      );\n    }\n    return await EcdsaUtils.signBitgoChallenges(bitgo, enterpriseId, userPassword, bitgoChallengesWithProofs);\n  }\n\n  /**\n   * Sign Bitgo's proofs, verification of proofs is left to the caller\n   * @param bitgo\n   * @param enterpriseId\n   * @param userPassword\n   * @param bitgoChallengesWithProofs Optionally provide Bitgo Challaenge & Proofs instead of fetching from API\n   */\n  static async signBitgoChallenges(\n    bitgo: BitGoBase,\n    enterpriseId: string,\n    userPassword: string,\n    bitgoChallengesWithProofs?: GetBitGoChallengesApi\n  ): Promise<BitGoProofSignatures> {\n    // fetch challenge & proof if none are provided\n    const challengesWithProofs = bitgoChallengesWithProofs\n      ? bitgoChallengesWithProofs\n      : await EcdsaUtils.getBitGoChallenges(bitgo);\n    // Fetch user's ecdh public keychain needed for signing the challenges\n    const userSigningKey = await bitgo.getSigningKeyForUser(enterpriseId);\n    if (!userSigningKey.ecdhKeychain || !userSigningKey.derivationPath) {\n      throw new Error('Something went wrong with the user keychain. Please contact support@bitgo.com.');\n    }\n    const userEcdhKeychain = await bitgo.getECDHKeychain(userSigningKey.ecdhKeychain);\n    let xprv;\n    try {\n      xprv = bitgo.decrypt({\n        password: userPassword,\n        input: userEcdhKeychain.encryptedXprv,\n      });\n    } catch (e) {\n      throw new Error('Incorrect password. Please try again.');\n    }\n    const signedBitGoInstChallenge = EcdsaUtils.signChallenge(\n      challengesWithProofs.bitgoInstitutionalHsm,\n      xprv,\n      userSigningKey.derivationPath\n    );\n    const signedBitGoNitroChallenge = EcdsaUtils.signChallenge(\n      challengesWithProofs.bitgoNitroHsm,\n      xprv,\n      userSigningKey.derivationPath\n    );\n    return {\n      bitgoInstHsmAdminSignature: signedBitGoInstChallenge,\n      bitgoNitroHsmAdminSignature: signedBitGoNitroChallenge,\n    };\n  }\n\n  /**\n   * This is needed to enable ecdsa signing on the enterprise.\n   * It receives the enterprise challenge and signatures of verified bitgo proofs\n   * and uploads them on the enterprise.\n   * @param bitgo\n   * @param entId - enterprise id to enable ecdsa signing on\n   * @param userPassword - enterprise admin's login pw\n   * @param bitgoInstChallengeProofSignature - signature on bitgo's institutional HSM challenge after verification\n   * @param bitgoNitroChallengeProofSignature - signature on bitgo's nitro HSM challenge after verification\n   * @param challenge - optionally use the challenge for enterprise challenge\n   */\n  static async initiateChallengesForEnterprise(\n    bitgo: BitGoBase,\n    entId: string,\n    userPassword: string,\n    bitgoInstChallengeProofSignature: Buffer,\n    bitgoNitroChallengeProofSignature: Buffer,\n    challenge?: EcdsaTypes.DeserializedNtildeWithProofs\n  ): Promise<void> {\n    // Fetch user's ecdh public keychain needed for signing the challenges\n    const userSigningKey = await bitgo.getSigningKeyForUser(entId);\n    if (!userSigningKey.ecdhKeychain || !userSigningKey.derivationPath) {\n      throw new Error('Something went wrong with the user keychain. Please contact support@bitgo.com.');\n    }\n    const userEcdhKeychain = await bitgo.getECDHKeychain(userSigningKey.ecdhKeychain);\n    let xprv;\n    try {\n      xprv = bitgo.decrypt({\n        password: userPassword,\n        input: userEcdhKeychain.encryptedXprv,\n      });\n    } catch (e) {\n      throw new Error('Incorrect password. Please try again.');\n    }\n\n    // Generate and sign enterprise challenge\n    const entChallengeWithProof = challenge ?? (await EcdsaRangeProof.generateNtilde(minModulusBitLength));\n    const serializedEntChallengeWithProof = EcdsaTypes.serializeNtildeWithProofs(entChallengeWithProof);\n    const signedEnterpriseChallenge = EcdsaUtils.signChallenge(\n      serializedEntChallengeWithProof,\n      xprv,\n      userSigningKey.derivationPath\n    );\n\n    await this.uploadChallengesToEnterprise(\n      bitgo,\n      entId,\n      serializedEntChallengeWithProof,\n      signedEnterpriseChallenge.toString('hex'),\n      bitgoInstChallengeProofSignature.toString('hex'),\n      bitgoNitroChallengeProofSignature.toString('hex')\n    );\n  }\n\n  /**\n   * Uploads the signed challenges and their proofs on the enterprise.\n   * This initiates ecdsa signing for the enterprise users.\n   * @param bitgo\n   * @param entId - enterprise to enable ecdsa signing on\n   * @param entChallengeWithProofs - client side generated ent challenge with ZK proofs\n   * @param entChallengeSignature - signature on enterprise challenge\n   * @param bitgoIntChallengeSignature - signature on BitGo's institutional HSM challenge\n   * @param bitgoNitroChallengeSignature - signature on BitGo's nitro HSM challenge\n   */\n  static async uploadChallengesToEnterprise(\n    bitgo: BitGoBase,\n    entId: string,\n    entChallengeWithProofs: EcdsaTypes.SerializedNtildeWithProofs,\n    entChallengeSignature: string,\n    bitgoIntChallengeSignature: string,\n    bitgoNitroChallengeSignature: string\n  ): Promise<void> {\n    const body = {\n      enterprise: {\n        ntilde: entChallengeWithProofs.ntilde,\n        h1: entChallengeWithProofs.h1,\n        h2: entChallengeWithProofs.h2,\n        ntildeProof: {\n          h1WrtH2: entChallengeWithProofs.ntildeProof.h1WrtH2,\n          h2WrtH1: entChallengeWithProofs.ntildeProof.h2WrtH1,\n        },\n        verifiers: {\n          adminSignature: entChallengeSignature,\n        },\n      },\n      bitgoInstitutionalHsm: {\n        verifiers: {\n          adminSignature: bitgoIntChallengeSignature,\n        },\n      },\n      bitgoNitroHsm: {\n        verifiers: {\n          adminSignature: bitgoNitroChallengeSignature,\n        },\n      },\n    };\n    await bitgo\n      .put(bitgo.url(`/enterprise/${entId}/tssconfig/ecdsa/challenge`, 2))\n      .send(body)\n      .result();\n  }\n\n  /**\n   * util function that checks that a commonKeychain is valid and can ultimately resolve to a valid public key\n   * @param commonKeychain - a user uploaded commonKeychain string\n   * @throws if the commonKeychain is invalid length or invalid format\n   */\n\n  static validateCommonKeychainPublicKey(commonKeychain: string) {\n    const pub = EcdsaUtils.getPublicKeyFromCommonKeychain(commonKeychain);\n    const secp256k1 = new ec('secp256k1');\n    const key = secp256k1.keyFromPublic(pub, 'hex');\n    return key.getPublic().encode('hex', false).slice(2);\n  }\n}\n"]}
|