@bitgo-beta/sdk-core 8.2.1-beta.75 → 8.2.1-beta.77
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/dist/src/bitgo/environments.d.ts +1 -0
- package/dist/src/bitgo/environments.d.ts.map +1 -1
- package/dist/src/bitgo/environments.js +3 -1
- package/dist/src/bitgo/tss/types.d.ts +15 -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 +13 -2
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +15 -2
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts +51 -1
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTypes.js +17 -2
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +40 -4
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +183 -42
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +2 -2
- package/dist/src/bitgo/wallet/iWallet.d.ts +9 -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 +7 -1
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +52 -3
- 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/tsconfig.tsbuildinfo +1 -1
- package/package.json +6 -6
|
@@ -423,47 +423,19 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
423
423
|
? await keychains.add(recipientKeychainParams)
|
|
424
424
|
: await keychains.createBackup(recipientKeychainParams);
|
|
425
425
|
}
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
* @param {string} params.prv - decrypted private key
|
|
430
|
-
* @param { string} params.reqId - request id
|
|
431
|
-
* @returns {Promise<TxRequest>}
|
|
432
|
-
*/
|
|
433
|
-
async signRequestBase(params, requestType) {
|
|
434
|
-
var _a;
|
|
435
|
-
const pendingEcdsaTssInitialization = (_a = this.wallet.coinSpecific()) === null || _a === void 0 ? void 0 : _a.pendingEcdsaTssInitialization;
|
|
436
|
-
if (pendingEcdsaTssInitialization) {
|
|
437
|
-
throw new Error('Wallet is not ready for TSS ECDSA signing. Please contact your enterprise admin to finish the enterprise TSS initialization.');
|
|
438
|
-
}
|
|
439
|
-
const userSigningMaterial = JSON.parse(params.prv);
|
|
426
|
+
async createTssEcdsaStep1SigningMaterial(params) {
|
|
427
|
+
const { challenges, derivationPath, prv } = params;
|
|
428
|
+
const userSigningMaterial = JSON.parse(prv);
|
|
440
429
|
if (userSigningMaterial.pShare.i !== 1) {
|
|
441
430
|
throw new Error('Invalid user key');
|
|
442
431
|
}
|
|
443
432
|
if (!userSigningMaterial.backupNShare) {
|
|
444
433
|
throw new Error('Invalid user key - missing backupNShare');
|
|
445
434
|
}
|
|
446
|
-
const txRequest = typeof params.txRequest === 'string'
|
|
447
|
-
? await tss_2.getTxRequest(this.bitgo, this.wallet.id(), params.txRequest)
|
|
448
|
-
: params.txRequest;
|
|
449
|
-
let signablePayload;
|
|
450
|
-
let derivationPath;
|
|
451
|
-
if (requestType === baseTypes_1.RequestType.tx) {
|
|
452
|
-
assert_1.default(txRequest.transactions || txRequest.unsignedTxs, 'Unable to find transactions in txRequest');
|
|
453
|
-
const unsignedTx = txRequest.apiVersion === 'full' ? txRequest.transactions[0].unsignedTx : txRequest.unsignedTxs[0];
|
|
454
|
-
signablePayload = buffer_1.Buffer.from(unsignedTx.signableHex, 'hex');
|
|
455
|
-
derivationPath = unsignedTx.derivationPath;
|
|
456
|
-
}
|
|
457
|
-
else if (requestType === baseTypes_1.RequestType.message) {
|
|
458
|
-
signablePayload = params.bufferToSign;
|
|
459
|
-
// TODO BG-67299 Message signing with derivation path
|
|
460
|
-
derivationPath = '';
|
|
461
|
-
}
|
|
462
435
|
const MPC = new tss_1.Ecdsa();
|
|
463
436
|
const signingKey = MPC.keyDerive(userSigningMaterial.pShare, [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare], derivationPath);
|
|
464
437
|
const bitgoIndex = types_2.ShareKeyPosition.BITGO;
|
|
465
438
|
const userIndex = userSigningMaterial.pShare.i;
|
|
466
|
-
const challenges = await this.getEcdsaSigningChallenges(txRequest.txRequestId, requestType, signingKey.xShare.n, 0);
|
|
467
439
|
const { ntilde: ntildea, h1: h1a, h2: h2a, p: pa } = challenges.enterpriseChallenge;
|
|
468
440
|
const { ntilde: ntildeb, h1: h1b, h2: h2b, p: pb, n: nb } = challenges.bitgoChallenge;
|
|
469
441
|
const userXShare = MPC.appendChallenge(signingKey.xShare, { ntilde: ntildea, h1: h1a, h2: h2a }, { p: pa });
|
|
@@ -494,20 +466,184 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
494
466
|
const vssProof = signingKey.nShares[bitgoIndex].v;
|
|
495
467
|
const userPublicGpgKey = userGpgKey.publicKey;
|
|
496
468
|
const publicShare = signingKey.nShares[bitgoIndex].y + signingKey.nShares[bitgoIndex].chaincode;
|
|
497
|
-
|
|
498
|
-
|
|
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) {
|
|
499
482
|
// Append the BitGo challenge to the Ashare to be used in subsequent proofs
|
|
500
483
|
const bitgoToUserAShareWithNtilde = {
|
|
501
|
-
...
|
|
502
|
-
...
|
|
484
|
+
...params.aShareFromBitgo,
|
|
485
|
+
...params.bitgoChallenge,
|
|
503
486
|
};
|
|
504
|
-
const userGammaAndMuShares = await ecdsa_1.default.createUserGammaAndMuShare(
|
|
487
|
+
const userGammaAndMuShares = await ecdsa_1.default.createUserGammaAndMuShare(params.wShare, bitgoToUserAShareWithNtilde);
|
|
505
488
|
const userOmicronAndDeltaShare = await ecdsa_1.default.createUserOmicronAndDeltaShare(userGammaAndMuShares.gShare);
|
|
506
|
-
|
|
507
|
-
|
|
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
|
+
});
|
|
508
644
|
// signing stage two with muShare and dShare send to bitgo and receives D share
|
|
509
|
-
const bitgoToUserDShare = (await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.MUShare,
|
|
510
|
-
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);
|
|
511
647
|
// signing stage three with SShare send to bitgo and receives SShare
|
|
512
648
|
await ecdsa_1.default.sendShareToBitgo(this.bitgo, this.wallet.id(), txRequest.txRequestId, requestType, types_1.SendShareType.SShare, userSShare);
|
|
513
649
|
return await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequest.txRequestId);
|
|
@@ -833,7 +969,12 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
833
969
|
.send(body)
|
|
834
970
|
.result();
|
|
835
971
|
}
|
|
836
|
-
|
|
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) {
|
|
837
978
|
const pub = EcdsaUtils.getPublicKeyFromCommonKeychain(commonKeychain);
|
|
838
979
|
const secp256k1 = new elliptic_1.ec('secp256k1');
|
|
839
980
|
const key = secp256k1.keyFromPublic(pub, 'hex');
|
|
@@ -841,4 +982,4 @@ class EcdsaUtils extends baseTSSUtils_1.default {
|
|
|
841
982
|
}
|
|
842
983
|
}
|
|
843
984
|
exports.EcdsaUtils = EcdsaUtils;
|
|
844
|
-
//# 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  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 { ShareKeyPosition, TxRequestChallengeResponse } 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  /**\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 = ShareKeyPosition.BITGO;\n    const userIndex = userSigningMaterial.pShare.i;\n\n    const challenges = await this.getEcdsaSigningChallenges(txRequest.txRequestId, requestType, signingKey.xShare.n, 0);\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\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 {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  static publicKeyFromCommonKeychain(commonKeychain: string): 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"]}
|
|
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"]}
|