@bitgo-beta/sdk-core 8.2.1-beta.9 → 8.2.1-beta.91

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/CHANGELOG.md +151 -0
  2. package/dist/src/account-lib/baseCoin/enum.d.ts +4 -1
  3. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/enum.js +7 -1
  5. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +33 -10
  6. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
  7. package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +551 -141
  8. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
  9. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
  10. package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
  11. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +70 -55
  12. package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
  13. package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
  14. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
  15. package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
  16. package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
  17. package/dist/src/bitgo/baseCoin/baseCoin.d.ts +16 -0
  18. package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
  19. package/dist/src/bitgo/baseCoin/baseCoin.js +15 -1
  20. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +18 -2
  21. package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
  22. package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
  23. package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
  24. package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
  25. package/dist/src/bitgo/environments.d.ts +7 -0
  26. package/dist/src/bitgo/environments.d.ts.map +1 -1
  27. package/dist/src/bitgo/environments.js +17 -3
  28. package/dist/src/bitgo/keychain/iKeychains.d.ts +1 -0
  29. package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
  30. package/dist/src/bitgo/keychain/iKeychains.js +1 -1
  31. package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
  32. package/dist/src/bitgo/keychain/keychains.js +30 -24
  33. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
  34. package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
  35. package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
  36. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
  37. package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
  38. package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
  39. package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
  40. package/dist/src/bitgo/pendingApproval/pendingApproval.js +12 -1
  41. package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
  42. package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
  43. package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
  44. package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
  45. package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
  46. package/dist/src/bitgo/staking/stakingWallet.js +9 -1
  47. package/dist/src/bitgo/tss/common.d.ts +15 -4
  48. package/dist/src/bitgo/tss/common.d.ts.map +1 -1
  49. package/dist/src/bitgo/tss/common.js +26 -11
  50. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +11 -8
  51. package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
  52. package/dist/src/bitgo/tss/ecdsa/ecdsa.js +36 -33
  53. package/dist/src/bitgo/tss/ecdsa/types.d.ts +2 -2
  54. package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
  55. package/dist/src/bitgo/tss/ecdsa/types.js +1 -1
  56. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +4 -3
  57. package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
  58. package/dist/src/bitgo/tss/eddsa/eddsa.js +16 -5
  59. package/dist/src/bitgo/tss/types.d.ts +19 -0
  60. package/dist/src/bitgo/tss/types.d.ts.map +1 -1
  61. package/dist/src/bitgo/tss/types.js +1 -1
  62. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +53 -12
  63. package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
  64. package/dist/src/bitgo/utils/tss/baseTSSUtils.js +62 -9
  65. package/dist/src/bitgo/utils/tss/baseTypes.d.ts +99 -8
  66. package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
  67. package/dist/src/bitgo/utils/tss/baseTypes.js +26 -2
  68. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +44 -5
  69. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
  70. package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +229 -86
  71. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
  72. package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
  73. package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +76 -22
  74. package/dist/src/bitgo/wallet/iWallet.d.ts +12 -1
  75. package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
  76. package/dist/src/bitgo/wallet/iWallet.js +1 -1
  77. package/dist/src/bitgo/wallet/wallet.d.ts +10 -2
  78. package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
  79. package/dist/src/bitgo/wallet/wallet.js +108 -14
  80. package/dist/src/index.d.ts +4 -0
  81. package/dist/src/index.d.ts.map +1 -1
  82. package/dist/src/index.js +4 -2
  83. package/dist/src/openssl/index.d.ts +4 -1
  84. package/dist/src/openssl/index.d.ts.map +1 -1
  85. package/dist/src/openssl/index.js +7 -12
  86. package/dist/tsconfig.tsbuildinfo +1 -8272
  87. package/package.json +8 -7
  88. package/dist/src/openssl/openssl.d.ts +0 -12
  89. package/dist/src/openssl/openssl.d.ts.map +0 -1
  90. package/dist/src/openssl/openssl.js +0 -48
  91. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  92. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  93. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -1,7 +1,7 @@
1
1
  import { SignShare, GShare } from '../../../../account-lib/mpc/tss';
2
2
  import { Keychain } from '../../../keychain';
3
- import { CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, SignatureShareRecord, TSSParams, TxRequest } from '../baseTypes';
4
- import { CreateEddsaBitGoKeychainParams, CreateEddsaKeychainParams, KeyShare, YShare } from './types';
3
+ import { CommitmentShareRecord, CustomCommitmentGeneratingFunction, CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, EncryptedSignerShareRecord, SignatureShareRecord, TSSParams, TxRequest } from '../baseTypes';
4
+ import { CreateEddsaBitGoKeychainParams, CreateEddsaKeychainParams, KeyShare } from './types';
5
5
  import baseTSSUtils from '../baseTSSUtils';
6
6
  import { KeychainsTriplet } from '../../../baseCoin';
7
7
  /**
@@ -52,20 +52,30 @@ export declare class EddsaUtils extends baseTSSUtils<KeyShare> {
52
52
  enterprise?: string;
53
53
  originalPasscodeEncryptionCode?: string;
54
54
  }): Promise<KeychainsTriplet>;
55
- createRShareFromTxRequest(params: {
55
+ createCommitmentShareFromTxRequest(params: {
56
56
  txRequest: TxRequest;
57
57
  prv: string;
58
+ walletPassphrase: string;
59
+ }): Promise<{
60
+ userToBitgoCommitment: CommitmentShareRecord;
61
+ encryptedSignerShare: EncryptedSignerShareRecord;
62
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
63
+ }>;
64
+ createRShareFromTxRequest(params: {
65
+ txRequest: TxRequest;
66
+ walletPassphrase: string;
67
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
58
68
  }): Promise<{
59
69
  rShare: SignShare;
60
- signingKeyYShare: YShare;
61
70
  }>;
62
71
  createGShareFromTxRequest(params: {
63
72
  txRequest: string | TxRequest;
64
73
  prv: string;
65
74
  bitgoToUserRShare: SignatureShareRecord;
66
75
  userToBitgoRShare: SignShare;
76
+ bitgoToUserCommitment: CommitmentShareRecord;
67
77
  }): Promise<GShare>;
68
- signUsingExternalSigner(txRequest: string | TxRequest, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
78
+ signEddsaTssUsingExternalSigner(txRequest: string | TxRequest, externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
69
79
  /**
70
80
  * Signs the transaction associated to the transaction request.
71
81
  *
@@ -82,6 +92,9 @@ export declare class EddsaUtils extends baseTSSUtils<KeyShare> {
82
92
  * @returns {string}
83
93
  */
84
94
  static getPublicKeyFromCommonKeychain(commonKeychain: string): string;
95
+ createUserToBitgoCommitmentShare(commitment: string): CommitmentShareRecord;
96
+ createUserToBitgoEncryptedSignerShare(encryptedSignerShare: string): EncryptedSignerShareRecord;
97
+ createUserToBitgoEncryptedRShare(encryptedRShare: string): EncryptedSignerShareRecord;
85
98
  }
86
99
  /**
87
100
  * @deprecated - use EddsaUtils
@@ -1 +1 @@
1
- {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"AAOA,OAAc,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,iCAAiC,CAAC;AAC3E,OAAO,EAAsB,QAAQ,EAAgC,MAAM,mBAAmB,CAAC;AAY/F,OAAO,EACL,8BAA8B,EAC9B,8BAA8B,EAC9B,oBAAoB,EACpB,SAAS,EACT,SAAS,EACV,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,8BAA8B,EAAE,yBAAyB,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACtG,OAAO,YAAY,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD;;GAEG;AAEH,qBAAa,UAAW,SAAQ,YAAY,CAAC,QAAQ,CAAC;IAC9C,sBAAsB,CAC1B,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,aAAa,EAAE,QAAQ,EACvB,cAAc,EAAE,MAAM,EACtB,aAAa,EAAE,CAAC,GAAG,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC;IA8ChB;;;;;;;;;;OAUG;IACG,kBAAkB,CAAC,EACvB,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,8BAA8B,GAC/B,EAAE,yBAAyB,GAAG,OAAO,CAAC,QAAQ,CAAC;IA4DhD;;;;;;;;;;OAUG;IACG,oBAAoB,CAAC,EACzB,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,GACX,EAAE,yBAAyB,GAAG,OAAO,CAAC,QAAQ,CAAC;IA2DhD;;;;;;;OAOG;IACG,mBAAmB,CAAC,EACxB,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,UAAU,GACX,EAAE,8BAA8B,GAAG,OAAO,CAAC,QAAQ,CAAC;IA8CrD;;;;OAIG;IACG,eAAe,CAAC,MAAM,EAAE;QAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,8BAA8B,CAAC,EAAE,MAAM,CAAC;KACzC,GAAG,OAAO,CAAC,gBAAgB,CAAC;IA+CvB,yBAAyB,CAAC,MAAM,EAAE;QACtC,SAAS,EAAE,SAAS,CAAC;QACrB,GAAG,EAAE,MAAM,CAAC;KACb,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,SAAS,CAAC;QAAC,gBAAgB,EAAE,MAAM,CAAA;KAAE,CAAC;IA+BtD,yBAAyB,CAAC,MAAM,EAAE;QACtC,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;QAC9B,GAAG,EAAE,MAAM,CAAC;QACZ,iBAAiB,EAAE,oBAAoB,CAAC;QACxC,iBAAiB,EAAE,SAAS,CAAC;KAC9B,GAAG,OAAO,CAAC,MAAM,CAAC;IAkCb,uBAAuB,CAC3B,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,6BAA6B,EAAE,8BAA8B,EAC7D,6BAA6B,EAAE,8BAA8B,GAC5D,OAAO,CAAC,SAAS,CAAC;IA6BrB;;;;;;;OAOG;IACG,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;IA6E1D;;;;;OAKG;IACH,MAAM,CAAC,8BAA8B,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM;CAOtE;AACD;;GAEG;AACH,eAAO,MAAM,QAAQ,mBAAa,CAAC"}
1
+ {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}
@@ -34,7 +34,9 @@ const tss_1 = __importDefault(require("../../../../account-lib/mpc/tss"));
34
34
  const eddsa_1 = require("../../../tss/eddsa/eddsa");
35
35
  const opengpgUtils_1 = require("../../opengpgUtils");
36
36
  const tss_2 = require("../../../tss");
37
+ const baseTypes_1 = require("../baseTypes");
37
38
  const baseTSSUtils_1 = __importDefault(require("../baseTSSUtils"));
39
+ const common_1 = require("../../../tss/common");
38
40
  /**
39
41
  * Utility functions for TSS work flows.
40
42
  */
@@ -272,7 +274,9 @@ class EddsaUtils extends baseTSSUtils_1.default {
272
274
  };
273
275
  return keychains;
274
276
  }
275
- async createRShareFromTxRequest(params) {
277
+ async createCommitmentShareFromTxRequest(params) {
278
+ var _a;
279
+ const bitgoIndex = tss_2.ShareKeyPosition.BITGO;
276
280
  const { txRequest, prv } = params;
277
281
  const txRequestResolved = txRequest;
278
282
  const hdTree = await account_lib_1.Ed25519BIP32.initialize();
@@ -288,11 +292,32 @@ class EddsaUtils extends baseTSSUtils_1.default {
288
292
  const signingKey = MPC.keyDerive(userSigningMaterial.uShare, [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare], unsignedTx.derivationPath);
289
293
  const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
290
294
  const userSignShare = await tss_2.createUserSignShare(signablePayload, signingKey.pShare);
291
- return { rShare: userSignShare, signingKeyYShare: signingKey.yShares[3] };
295
+ const commitment = (_a = userSignShare.rShares[bitgoIndex]) === null || _a === void 0 ? void 0 : _a.commitment;
296
+ assert_1.default(commitment, 'Unable to find commitment in userSignShare');
297
+ const userToBitgoCommitment = this.createUserToBitgoCommitmentShare(commitment);
298
+ const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;
299
+ const bitgoGpgKey = await opengpgUtils_1.getBitgoGpgPubKey(this.bitgo);
300
+ const userToBitgoEncryptedSignerShare = await opengpgUtils_1.encryptText(signerShare, bitgoGpgKey);
301
+ const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);
302
+ const stringifiedRShare = JSON.stringify(userSignShare);
303
+ const encryptedRShare = this.bitgo.encrypt({ input: stringifiedRShare, password: params.walletPassphrase });
304
+ const encryptedUserToBitgoRShare = this.createUserToBitgoEncryptedRShare(encryptedRShare);
305
+ return { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare };
306
+ }
307
+ async createRShareFromTxRequest(params) {
308
+ const { walletPassphrase, encryptedUserToBitgoRShare } = params;
309
+ const decryptedRShare = this.bitgo.decrypt({
310
+ input: encryptedUserToBitgoRShare.share,
311
+ password: walletPassphrase,
312
+ });
313
+ const rShare = JSON.parse(decryptedRShare);
314
+ assert_1.default(rShare.xShare, 'Unable to find xShare in decryptedRShare');
315
+ assert_1.default(rShare.rShares, 'Unable to find rShares in decryptedRShare');
316
+ return { rShare };
292
317
  }
293
318
  async createGShareFromTxRequest(params) {
294
319
  let txRequestResolved;
295
- const { txRequest, prv, bitgoToUserRShare, userToBitgoRShare } = params;
320
+ const { txRequest, prv, bitgoToUserCommitment, bitgoToUserRShare, userToBitgoRShare } = params;
296
321
  if (typeof txRequest === 'string') {
297
322
  txRequestResolved = await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequest);
298
323
  }
@@ -308,10 +333,10 @@ class EddsaUtils extends baseTSSUtils_1.default {
308
333
  ? txRequestResolved.transactions[0].unsignedTx
309
334
  : txRequestResolved.unsignedTxs[0];
310
335
  const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
311
- const userToBitGoGShare = await tss_2.createUserToBitGoGShare(userToBitgoRShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload);
336
+ const userToBitGoGShare = await tss_2.createUserToBitGoGShare(userToBitgoRShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload, bitgoToUserCommitment);
312
337
  return userToBitGoGShare;
313
338
  }
314
- async signUsingExternalSigner(txRequest, externalSignerRShareGenerator, externalSignerGShareGenerator) {
339
+ async signEddsaTssUsingExternalSigner(txRequest, externalSignerCommitmentGenerator, externalSignerRShareGenerator, externalSignerGShareGenerator) {
315
340
  let txRequestResolved;
316
341
  let txRequestId;
317
342
  if (typeof txRequest === 'string') {
@@ -322,22 +347,23 @@ class EddsaUtils extends baseTSSUtils_1.default {
322
347
  txRequestResolved = txRequest;
323
348
  txRequestId = txRequest.txRequestId;
324
349
  }
325
- const rSignShareTransactionParams = {
350
+ const { apiVersion } = txRequestResolved;
351
+ const { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare } = await externalSignerCommitmentGenerator({ txRequest: txRequestResolved });
352
+ const { commitmentShare: bitgoToUserCommitment } = await common_1.exchangeEddsaCommitments(this.bitgo, this.wallet.id(), txRequestId, userToBitgoCommitment, encryptedSignerShare, apiVersion);
353
+ const { rShare } = await externalSignerRShareGenerator({
326
354
  txRequest: txRequestResolved,
327
- };
328
- const { rShare, signingKeyYShare } = await externalSignerRShareGenerator(rSignShareTransactionParams);
329
- const signerShare = signingKeyYShare.u + signingKeyYShare.chaincode;
330
- const bitgoGpgKey = await opengpgUtils_1.getBitgoGpgPubKey(this.bitgo);
331
- const encryptedSignerShare = await opengpgUtils_1.encryptText(signerShare, bitgoGpgKey);
332
- await tss_2.offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, rShare, encryptedSignerShare, 'full');
355
+ encryptedUserToBitgoRShare,
356
+ });
357
+ await tss_2.offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, rShare, encryptedSignerShare.share, apiVersion);
333
358
  const bitgoToUserRShare = await tss_2.getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);
334
359
  const gSignShareTransactionParams = {
335
360
  txRequest: txRequestResolved,
336
361
  bitgoToUserRShare: bitgoToUserRShare,
337
362
  userToBitgoRShare: rShare,
363
+ bitgoToUserCommitment,
338
364
  };
339
365
  const gShare = await externalSignerGShareGenerator(gSignShareTransactionParams);
340
- await tss_2.sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, gShare, 'full');
366
+ await tss_2.sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, gShare, apiVersion);
341
367
  return await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequestId);
342
368
  }
343
369
  /**
@@ -351,7 +377,7 @@ class EddsaUtils extends baseTSSUtils_1.default {
351
377
  async signTxRequest(params) {
352
378
  let txRequestResolved;
353
379
  let txRequestId;
354
- const { txRequest, prv, apiVersion } = params;
380
+ const { txRequest, prv } = params;
355
381
  if (typeof txRequest === 'string') {
356
382
  txRequestResolved = await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequest);
357
383
  txRequestId = txRequestResolved.txRequestId;
@@ -366,25 +392,29 @@ class EddsaUtils extends baseTSSUtils_1.default {
366
392
  if (!userSigningMaterial.backupYShare) {
367
393
  throw new Error('Invalid user key - missing backupYShare');
368
394
  }
395
+ const { apiVersion } = txRequestResolved;
369
396
  assert_1.default(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');
370
- const unsignedTx = txRequestResolved.apiVersion === 'full'
371
- ? txRequestResolved.transactions[0].unsignedTx
372
- : txRequestResolved.unsignedTxs[0];
397
+ const unsignedTx = apiVersion === 'full' ? txRequestResolved.transactions[0].unsignedTx : txRequestResolved.unsignedTxs[0];
373
398
  const signingKey = MPC.keyDerive(userSigningMaterial.uShare, [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare], unsignedTx.derivationPath);
374
399
  const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
375
400
  const userSignShare = await tss_2.createUserSignShare(signablePayload, signingKey.pShare);
376
- const bitgoIndex = 3;
401
+ const bitgoIndex = tss_2.ShareKeyPosition.BITGO;
377
402
  const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;
378
403
  const bitgoGpgKey = await opengpgUtils_1.getBitgoGpgPubKey(this.bitgo);
379
- const encryptedSignerShare = await opengpgUtils_1.encryptText(signerShare, bitgoGpgKey);
404
+ const userToBitgoEncryptedSignerShare = await opengpgUtils_1.encryptText(signerShare, bitgoGpgKey);
380
405
  const userGpgKey = await opengpgUtils_1.generateGPGKeyPair('secp256k1');
381
406
  const privateShareProof = await opengpgUtils_1.createShareProof(userGpgKey.privateKey, signingKey.yShares[bitgoIndex].u, 'eddsa');
382
407
  const vssProof = signingKey.yShares[bitgoIndex].v;
383
408
  const userPublicGpgKey = userGpgKey.publicKey;
384
409
  const publicShare = signingKey.yShares[bitgoIndex].y + signingKey.yShares[bitgoIndex].chaincode;
385
- await tss_2.offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, userSignShare, encryptedSignerShare, apiVersion, vssProof, privateShareProof, userPublicGpgKey, publicShare);
410
+ const userToBitgoCommitment = userSignShare.rShares[bitgoIndex].commitment;
411
+ assert_1.default(userToBitgoCommitment, 'Missing userToBitgoCommitment commitment');
412
+ const commitmentShare = this.createUserToBitgoCommitmentShare(userToBitgoCommitment);
413
+ const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);
414
+ const { commitmentShare: bitgoToUserCommitment } = await common_1.exchangeEddsaCommitments(this.bitgo, this.wallet.id(), txRequestId, commitmentShare, encryptedSignerShare, apiVersion);
415
+ await tss_2.offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, userSignShare, userToBitgoEncryptedSignerShare, apiVersion, vssProof, privateShareProof, userPublicGpgKey, publicShare);
386
416
  const bitgoToUserRShare = await tss_2.getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);
387
- const userToBitGoGShare = await tss_2.createUserToBitGoGShare(userSignShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload);
417
+ const userToBitGoGShare = await tss_2.createUserToBitGoGShare(userSignShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload, bitgoToUserCommitment);
388
418
  await tss_2.sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare, apiVersion);
389
419
  return await tss_2.getTxRequest(this.bitgo, this.wallet.id(), txRequestId);
390
420
  }
@@ -401,10 +431,34 @@ class EddsaUtils extends baseTSSUtils_1.default {
401
431
  const commonPubHexStr = commonKeychain.slice(0, 64);
402
432
  return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));
403
433
  }
434
+ createUserToBitgoCommitmentShare(commitment) {
435
+ return {
436
+ from: baseTypes_1.SignatureShareType.USER,
437
+ to: baseTypes_1.SignatureShareType.BITGO,
438
+ share: commitment,
439
+ type: baseTypes_1.CommitmentType.COMMITMENT,
440
+ };
441
+ }
442
+ createUserToBitgoEncryptedSignerShare(encryptedSignerShare) {
443
+ return {
444
+ from: baseTypes_1.SignatureShareType.USER,
445
+ to: baseTypes_1.SignatureShareType.BITGO,
446
+ share: encryptedSignerShare,
447
+ type: baseTypes_1.EncryptedSignerShareType.ENCRYPTED_SIGNER_SHARE,
448
+ };
449
+ }
450
+ createUserToBitgoEncryptedRShare(encryptedRShare) {
451
+ return {
452
+ from: baseTypes_1.SignatureShareType.USER,
453
+ to: baseTypes_1.SignatureShareType.BITGO,
454
+ share: encryptedRShare,
455
+ type: baseTypes_1.EncryptedSignerShareType.ENCRYPTED_R_SHARE,
456
+ };
457
+ }
404
458
  }
405
459
  exports.EddsaUtils = EddsaUtils;
406
460
  /**
407
461
  * @deprecated - use EddsaUtils
408
462
  */
409
463
  exports.TssUtils = EddsaUtils;
410
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport assert from 'assert';\nimport * as bs58 from 'bs58';\nimport * as openpgp from 'openpgp';\nimport { Ed25519BIP32 } from '../../../../account-lib';\nimport Eddsa, { SignShare, GShare } from '../../../../account-lib/mpc/tss';\nimport { AddKeychainOptions, Keychain, KeyType, CreateBackupOptions } from '../../../keychain';\nimport { verifyWalletSignature } from '../../../tss/eddsa/eddsa';\nimport { encryptText, getBitgoGpgPubKey, createShareProof, generateGPGKeyPair } from '../../opengpgUtils';\nimport {\n  createUserSignShare,\n  createUserToBitGoGShare,\n  getBitgoToUserRShare,\n  getTxRequest,\n  offerUserToBitgoRShare,\n  sendUserToBitgoGShare,\n  SigningMaterial,\n} from '../../../tss';\nimport {\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  SignatureShareRecord,\n  TSSParams,\n  TxRequest,\n} from '../baseTypes';\nimport { CreateEddsaBitGoKeychainParams, CreateEddsaKeychainParams, KeyShare, YShare } from './types';\nimport baseTSSUtils from '../baseTSSUtils';\nimport { KeychainsTriplet } from '../../../baseCoin';\n\n/**\n * Utility functions for TSS work flows.\n */\n\nexport class EddsaUtils extends baseTSSUtils<KeyShare> {\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\n    const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });\n    const userKeyId = userKeyPub.keyPacket.getFingerprint();\n\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\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\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   * Creates a Keychain containing the User's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets\n   */\n  async createUserKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n    originalPasscodeEncryptionCode,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\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 bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToUserPrivateShare,\n      1\n    );\n\n    const bitgoToUser: YShare = {\n      i: 1,\n      j: 3,\n      y: bitGoToUserShare.publicShare.slice(0, 64),\n      v: bitGoToUserShare.vssProof,\n      u: bitGoToUserPrivateShare.slice(0, 64),\n      chaincode: bitGoToUserPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);\n    const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const userSigningMaterial: SigningMaterial = {\n      uShare: userKeyShare.uShare,\n      bitgoYShare: bitgoToUser,\n      backupYShare: backupKeyShare.yShares[1],\n    };\n\n    const userKeychainParams: AddKeychainOptions = {\n      source: 'user',\n      keyType: 'tss' as KeyType,\n      commonKeychain: bitgoKeychain.commonKeychain,\n      originalPasscodeEncryptionCode,\n    };\n    if (passphrase !== undefined) {\n      userKeychainParams.encryptedPrv = this.bitgo.encrypt({\n        input: JSON.stringify(userSigningMaterial),\n        password: passphrase,\n      });\n    }\n\n    return await this.baseCoin.keychains().add(userKeychainParams);\n  }\n\n  /**\n   * Creates a Keychain containing the Backup party's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - User's TSS Keyshare\n   * @param backupGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between backup and server\n   * @param backupKeyShare - Backup's TSS Keyshare\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   */\n  async createBackupKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Invalid bitgo keyshares');\n    }\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (!bitGoToBackupShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, backupGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToBackupPrivateShare,\n      2\n    );\n\n    const bitgoToBackup: YShare = {\n      i: 2,\n      j: 3,\n      y: bitGoToBackupShare.publicShare.slice(0, 64),\n      v: bitGoToBackupShare.vssProof,\n      u: bitGoToBackupPrivateShare.slice(0, 64),\n      chaincode: bitGoToBackupPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);\n    const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create backup keychain - commonKeychains do not match.');\n    }\n\n    const backupSigningMaterial: SigningMaterial = {\n      uShare: backupKeyShare.uShare,\n      bitgoYShare: bitgoToBackup,\n      userYShare: userKeyShare.yShares[2],\n    };\n    const prv = JSON.stringify(backupSigningMaterial);\n\n    const params: CreateBackupOptions = {\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n    };\n\n    if (passphrase !== undefined) {\n      params.encryptedPrv = this.bitgo.encrypt({ input: prv, password: passphrase });\n    }\n\n    return await this.baseCoin.keychains().createBackup(params);\n  }\n\n  /**\n   * Creates a Keychain containing BitGo's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param enterprise - enterprise associated to the wallet\n   */\n  async createBitgoKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    enterprise,\n  }: CreateEddsaBitGoKeychainParams): Promise<Keychain> {\n    // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported\n    const userToBitgoPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.uShare.y, 'hex'),\n      Buffer.from(userKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(userKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoKeyShare = {\n      publicShare: userToBitgoPublicShare,\n      privateShare: userToBitgoPrivateShare,\n      privateShareProof: await createShareProof(userGpgKey.privateKey, userToBitgoPrivateShare.slice(0, 64), 'eddsa'),\n      vssProof: userKeyShare.yShares[3].v,\n    };\n\n    const backupToBitgoPublicShare = Buffer.concat([\n      Buffer.from(backupKeyShare.uShare.y, 'hex'),\n      Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(backupKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoKeyShare = {\n      publicShare: backupToBitgoPublicShare,\n      privateShare: backupToBitgoPrivateShare,\n      privateShareProof: await createShareProof(\n        backupGpgKey.privateKey,\n        backupToBitgoPrivateShare.slice(0, 64),\n        'eddsa'\n      ),\n      vssProof: backupKeyShare.yShares[3].v,\n    };\n\n    return await this.createBitgoKeychainInWP(\n      userGpgKey,\n      backupGpgKey,\n      userToBitgoKeyShare,\n      backupToBitgoKeyShare,\n      'tss',\n      enterprise\n    );\n  }\n\n  /**\n   * Creates User, Backup, and BitGo TSS Keychains.\n   *\n   * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup\n   */\n  async createKeychains(params: {\n    passphrase?: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n  }): Promise<KeychainsTriplet> {\n    const MPC = await Eddsa.initialize();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = MPC.keyShare(1, m, n);\n    const backupKeyShare = MPC.keyShare(2, m, n);\n\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const backupGpgKey = await generateGPGKeyPair('secp256k1');\n\n    const bitgoKeychain = await this.createBitgoKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      enterprise: params.enterprise,\n    });\n    const userKeychainPromise = this.createUserKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n    });\n    const backupKeychainPromise = this.createBackupKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n    });\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    // create wallet\n    const keychains = {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n\n    return keychains;\n  }\n\n  async createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n  }): Promise<{ rShare: SignShare; signingKeyYShare: YShare }> {\n    const { txRequest, prv } = params;\n    const txRequestResolved: TxRequest = txRequest;\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    return { rShare: userSignShare, signingKeyYShare: signingKey.yShares[3] };\n  }\n\n  async createGShareFromTxRequest(params: {\n    txRequest: string | TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n  }): Promise<GShare> {\n    let txRequestResolved: TxRequest;\n\n    const { txRequest, prv, bitgoToUserRShare, userToBitgoRShare } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n    } else {\n      txRequestResolved = txRequest;\n    }\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userToBitgoRShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload\n    );\n    return userToBitGoGShare;\n  }\n\n  async signUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n    const rSignShareTransactionParams = {\n      txRequest: txRequestResolved,\n    };\n    const { rShare, signingKeyYShare } = await externalSignerRShareGenerator(rSignShareTransactionParams);\n    const signerShare = signingKeyYShare.u + signingKeyYShare.chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n    await offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, rShare, encryptedSignerShare, 'full');\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n    const gSignShareTransactionParams = {\n      txRequest: txRequestResolved,\n      bitgoToUserRShare: bitgoToUserRShare,\n      userToBitgoRShare: rShare,\n    };\n    const gShare = await externalSignerGShareGenerator(gSignShareTransactionParams);\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, gShare, 'full');\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   *\n   * @param txRequest - transaction request object or id\n   * @param prv - decrypted private key\n   * @param reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: TSSParams): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n\n    const { txRequest, prv, apiVersion } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    const bitgoIndex = 3;\n    const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const privateShareProof = await createShareProof(userGpgKey.privateKey, signingKey.yShares[bitgoIndex].u, 'eddsa');\n    const vssProof = signingKey.yShares[bitgoIndex].v;\n    const userPublicGpgKey = userGpgKey.publicKey;\n    const publicShare = signingKey.yShares[bitgoIndex].y + signingKey.yShares[bitgoIndex].chaincode;\n\n    await offerUserToBitgoRShare(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      userSignShare,\n      encryptedSignerShare,\n      apiVersion,\n      vssProof,\n      privateShareProof,\n      userPublicGpgKey,\n      publicShare\n    );\n\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userSignShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload\n    );\n\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare, apiVersion);\n\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Get the commonPub portion of the commonKeychain.\n   *\n   * @param {String} commonKeychain\n   * @returns {string}\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 128) {\n      throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 64);\n    return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));\n  }\n}\n/**\n * @deprecated - use EddsaUtils\n */\nexport const TssUtils = EddsaUtils;\n"]}
464
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport assert from 'assert';\nimport * as bs58 from 'bs58';\nimport * as openpgp from 'openpgp';\nimport { Ed25519BIP32 } from '../../../../account-lib';\nimport Eddsa, { SignShare, GShare } from '../../../../account-lib/mpc/tss';\nimport { AddKeychainOptions, Keychain, CreateBackupOptions } from '../../../keychain';\nimport { verifyWalletSignature } from '../../../tss/eddsa/eddsa';\nimport { encryptText, getBitgoGpgPubKey, createShareProof, generateGPGKeyPair } from '../../opengpgUtils';\nimport {\n  createUserSignShare,\n  createUserToBitGoGShare,\n  getBitgoToUserRShare,\n  getTxRequest,\n  offerUserToBitgoRShare,\n  sendUserToBitgoGShare,\n  ShareKeyPosition,\n  SigningMaterial,\n} from '../../../tss';\nimport {\n  CommitmentShareRecord,\n  CommitmentType,\n  CustomCommitmentGeneratingFunction,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  EncryptedSignerShareRecord,\n  EncryptedSignerShareType,\n  SignatureShareRecord,\n  SignatureShareType,\n  TSSParams,\n  TxRequest,\n} from '../baseTypes';\nimport { CreateEddsaBitGoKeychainParams, CreateEddsaKeychainParams, KeyShare, YShare } from './types';\nimport baseTSSUtils from '../baseTSSUtils';\nimport { KeychainsTriplet } from '../../../baseCoin';\nimport { exchangeEddsaCommitments } from '../../../tss/common';\n\n/**\n * Utility functions for TSS work flows.\n */\n\nexport class EddsaUtils extends baseTSSUtils<KeyShare> {\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\n    const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });\n    const userKeyId = userKeyPub.keyPacket.getFingerprint();\n\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\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\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   * Creates a Keychain containing the User's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets\n   */\n  async createUserKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n    originalPasscodeEncryptionCode,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\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 bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToUserPrivateShare,\n      1\n    );\n\n    const bitgoToUser: YShare = {\n      i: 1,\n      j: 3,\n      y: bitGoToUserShare.publicShare.slice(0, 64),\n      v: bitGoToUserShare.vssProof,\n      u: bitGoToUserPrivateShare.slice(0, 64),\n      chaincode: bitGoToUserPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);\n    const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const userSigningMaterial: SigningMaterial = {\n      uShare: userKeyShare.uShare,\n      bitgoYShare: bitgoToUser,\n      backupYShare: backupKeyShare.yShares[1],\n    };\n\n    const userKeychainParams: AddKeychainOptions = {\n      source: 'user',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      originalPasscodeEncryptionCode,\n    };\n    if (passphrase !== undefined) {\n      userKeychainParams.encryptedPrv = this.bitgo.encrypt({\n        input: JSON.stringify(userSigningMaterial),\n        password: passphrase,\n      });\n    }\n\n    return await this.baseCoin.keychains().add(userKeychainParams);\n  }\n\n  /**\n   * Creates a Keychain containing the Backup party's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - User's TSS Keyshare\n   * @param backupGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between backup and server\n   * @param backupKeyShare - Backup's TSS Keyshare\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   */\n  async createBackupKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Invalid bitgo keyshares');\n    }\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (!bitGoToBackupShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, backupGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToBackupPrivateShare,\n      2\n    );\n\n    const bitgoToBackup: YShare = {\n      i: 2,\n      j: 3,\n      y: bitGoToBackupShare.publicShare.slice(0, 64),\n      v: bitGoToBackupShare.vssProof,\n      u: bitGoToBackupPrivateShare.slice(0, 64),\n      chaincode: bitGoToBackupPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);\n    const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create backup keychain - commonKeychains do not match.');\n    }\n\n    const backupSigningMaterial: SigningMaterial = {\n      uShare: backupKeyShare.uShare,\n      bitgoYShare: bitgoToBackup,\n      userYShare: userKeyShare.yShares[2],\n    };\n    const prv = JSON.stringify(backupSigningMaterial);\n\n    const params: CreateBackupOptions = {\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n    };\n\n    if (passphrase !== undefined) {\n      params.encryptedPrv = this.bitgo.encrypt({ input: prv, password: passphrase });\n    }\n\n    return await this.baseCoin.keychains().createBackup(params);\n  }\n\n  /**\n   * Creates a Keychain containing BitGo's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param enterprise - enterprise associated to the wallet\n   */\n  async createBitgoKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    enterprise,\n  }: CreateEddsaBitGoKeychainParams): Promise<Keychain> {\n    // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported\n    const userToBitgoPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.uShare.y, 'hex'),\n      Buffer.from(userKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(userKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoKeyShare = {\n      publicShare: userToBitgoPublicShare,\n      privateShare: userToBitgoPrivateShare,\n      privateShareProof: await createShareProof(userGpgKey.privateKey, userToBitgoPrivateShare.slice(0, 64), 'eddsa'),\n      vssProof: userKeyShare.yShares[3].v,\n    };\n\n    const backupToBitgoPublicShare = Buffer.concat([\n      Buffer.from(backupKeyShare.uShare.y, 'hex'),\n      Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(backupKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoKeyShare = {\n      publicShare: backupToBitgoPublicShare,\n      privateShare: backupToBitgoPrivateShare,\n      privateShareProof: await createShareProof(\n        backupGpgKey.privateKey,\n        backupToBitgoPrivateShare.slice(0, 64),\n        'eddsa'\n      ),\n      vssProof: backupKeyShare.yShares[3].v,\n    };\n\n    return await this.createBitgoKeychainInWP(\n      userGpgKey,\n      backupGpgKey,\n      userToBitgoKeyShare,\n      backupToBitgoKeyShare,\n      'tss',\n      enterprise\n    );\n  }\n\n  /**\n   * Creates User, Backup, and BitGo TSS Keychains.\n   *\n   * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup\n   */\n  async createKeychains(params: {\n    passphrase?: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n  }): Promise<KeychainsTriplet> {\n    const MPC = await Eddsa.initialize();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = MPC.keyShare(1, m, n);\n    const backupKeyShare = MPC.keyShare(2, m, n);\n\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const backupGpgKey = await generateGPGKeyPair('secp256k1');\n\n    const bitgoKeychain = await this.createBitgoKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      enterprise: params.enterprise,\n    });\n    const userKeychainPromise = this.createUserKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n    });\n    const backupKeychainPromise = this.createBackupKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n    });\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    // create wallet\n    const keychains = {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n\n    return keychains;\n  }\n\n  async createCommitmentShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    walletPassphrase: string;\n  }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }> {\n    const bitgoIndex = ShareKeyPosition.BITGO;\n    const { txRequest, prv } = params;\n    const txRequestResolved: TxRequest = txRequest;\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n    const commitment = userSignShare.rShares[bitgoIndex]?.commitment;\n    assert(commitment, 'Unable to find commitment in userSignShare');\n    const userToBitgoCommitment = this.createUserToBitgoCommitmentShare(commitment);\n\n    const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const userToBitgoEncryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);\n    const stringifiedRShare = JSON.stringify(userSignShare);\n    const encryptedRShare = this.bitgo.encrypt({ input: stringifiedRShare, password: params.walletPassphrase });\n    const encryptedUserToBitgoRShare = this.createUserToBitgoEncryptedRShare(encryptedRShare);\n\n    return { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare };\n  }\n\n  async createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }> {\n    const { walletPassphrase, encryptedUserToBitgoRShare } = params;\n\n    const decryptedRShare = this.bitgo.decrypt({\n      input: encryptedUserToBitgoRShare.share,\n      password: walletPassphrase,\n    });\n    const rShare = JSON.parse(decryptedRShare);\n    assert(rShare.xShare, 'Unable to find xShare in decryptedRShare');\n    assert(rShare.rShares, 'Unable to find rShares in decryptedRShare');\n\n    return { rShare };\n  }\n\n  async createGShareFromTxRequest(params: {\n    txRequest: string | TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare> {\n    let txRequestResolved: TxRequest;\n\n    const { txRequest, prv, bitgoToUserCommitment, bitgoToUserRShare, userToBitgoRShare } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n    } else {\n      txRequestResolved = txRequest;\n    }\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userToBitgoRShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload,\n      bitgoToUserCommitment\n    );\n    return userToBitGoGShare;\n  }\n\n  async signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const { apiVersion } = txRequestResolved;\n\n    const { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare } =\n      await externalSignerCommitmentGenerator({ txRequest: txRequestResolved });\n\n    const { commitmentShare: bitgoToUserCommitment } = await exchangeEddsaCommitments(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      userToBitgoCommitment,\n      encryptedSignerShare,\n      apiVersion\n    );\n\n    const { rShare } = await externalSignerRShareGenerator({\n      txRequest: txRequestResolved,\n      encryptedUserToBitgoRShare,\n    });\n\n    await offerUserToBitgoRShare(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      rShare,\n      encryptedSignerShare.share,\n      apiVersion\n    );\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n    const gSignShareTransactionParams = {\n      txRequest: txRequestResolved,\n      bitgoToUserRShare: bitgoToUserRShare,\n      userToBitgoRShare: rShare,\n      bitgoToUserCommitment,\n    };\n    const gShare = await externalSignerGShareGenerator(gSignShareTransactionParams);\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, gShare, apiVersion);\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   *\n   * @param txRequest - transaction request object or id\n   * @param prv - decrypted private key\n   * @param reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: TSSParams): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n\n    const { txRequest, prv } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    const { apiVersion } = txRequestResolved;\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      apiVersion === 'full' ? txRequestResolved.transactions![0].unsignedTx : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    const bitgoIndex = ShareKeyPosition.BITGO;\n    const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const userToBitgoEncryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const privateShareProof = await createShareProof(userGpgKey.privateKey, signingKey.yShares[bitgoIndex].u, 'eddsa');\n    const vssProof = signingKey.yShares[bitgoIndex].v;\n    const userPublicGpgKey = userGpgKey.publicKey;\n    const publicShare = signingKey.yShares[bitgoIndex].y + signingKey.yShares[bitgoIndex].chaincode;\n\n    const userToBitgoCommitment = userSignShare.rShares[bitgoIndex].commitment;\n    assert(userToBitgoCommitment, 'Missing userToBitgoCommitment commitment');\n\n    const commitmentShare = this.createUserToBitgoCommitmentShare(userToBitgoCommitment);\n    const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);\n\n    const { commitmentShare: bitgoToUserCommitment } = await exchangeEddsaCommitments(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      commitmentShare,\n      encryptedSignerShare,\n      apiVersion\n    );\n\n    await offerUserToBitgoRShare(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      userSignShare,\n      userToBitgoEncryptedSignerShare,\n      apiVersion,\n      vssProof,\n      privateShareProof,\n      userPublicGpgKey,\n      publicShare\n    );\n\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userSignShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload,\n      bitgoToUserCommitment\n    );\n\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare, apiVersion);\n\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Get the commonPub portion of the commonKeychain.\n   *\n   * @param {String} commonKeychain\n   * @returns {string}\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 128) {\n      throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 64);\n    return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));\n  }\n\n  createUserToBitgoCommitmentShare(commitment: string): CommitmentShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: commitment,\n      type: CommitmentType.COMMITMENT,\n    };\n  }\n\n  createUserToBitgoEncryptedSignerShare(encryptedSignerShare: string): EncryptedSignerShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: encryptedSignerShare,\n      type: EncryptedSignerShareType.ENCRYPTED_SIGNER_SHARE,\n    };\n  }\n\n  createUserToBitgoEncryptedRShare(encryptedRShare: string): EncryptedSignerShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: encryptedRShare,\n      type: EncryptedSignerShareType.ENCRYPTED_R_SHARE,\n    };\n  }\n}\n/**\n * @deprecated - use EddsaUtils\n */\nexport const TssUtils = EddsaUtils;\n"]}
@@ -5,7 +5,7 @@ import { Keychain } from '../keychain';
5
5
  import { IPendingApproval, PendingApprovalData } from '../pendingApproval';
6
6
  import { IStakingWallet } from '../staking';
7
7
  import { ITradingAccount } from '../trading';
8
- import { CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, TokenEnablement, TokenTransferRecipientParams } from '../utils';
8
+ import { CustomCommitmentGeneratingFunction, CustomGShareGeneratingFunction, CustomKShareGeneratingFunction, CustomMuDeltaShareGeneratingFunction, CustomPaillierModulusGetterFunction, CustomRShareGeneratingFunction, CustomSShareGeneratingFunction, TokenEnablement, TokenTransferRecipientParams } from '../utils';
9
9
  import { ILightning } from '../lightning';
10
10
  import { SerializedNtilde } from '../../account-lib/mpc/tss/ecdsa/types';
11
11
  export interface MaximumSpendableOptions {
@@ -133,14 +133,23 @@ export interface WalletSignBaseOptions {
133
133
  }
134
134
  export interface WalletSignTransactionOptions extends WalletSignBaseOptions {
135
135
  txPrebuild?: TransactionPrebuild;
136
+ customCommitmentGeneratingFunction?: CustomCommitmentGeneratingFunction;
136
137
  customRShareGeneratingFunction?: CustomRShareGeneratingFunction;
137
138
  customGShareGeneratingFunction?: CustomGShareGeneratingFunction;
139
+ customPaillierModulusGeneratingFunction?: CustomPaillierModulusGetterFunction;
140
+ customKShareGeneratingFunction?: CustomKShareGeneratingFunction;
141
+ customMuDeltaShareGeneratingFunction?: CustomMuDeltaShareGeneratingFunction;
142
+ customSShareGeneratingFunction?: CustomSShareGeneratingFunction;
138
143
  apiVersion?: ApiVersion;
139
144
  [index: string]: unknown;
140
145
  }
141
146
  interface WalletSignMessageBase extends WalletSignBaseOptions {
142
147
  walletPassphrase?: string;
143
148
  custodianMessageId?: string;
149
+ customPaillierModulusGeneratingFunction?: CustomPaillierModulusGetterFunction;
150
+ customKShareGeneratingFunction?: CustomKShareGeneratingFunction;
151
+ customMuDeltaShareGeneratingFunction?: CustomMuDeltaShareGeneratingFunction;
152
+ customSShareGeneratingFunction?: CustomSShareGeneratingFunction;
144
153
  }
145
154
  export interface WalletSignMessageOptions extends WalletSignMessageBase {
146
155
  message?: Message;
@@ -540,6 +549,8 @@ export interface IWallet {
540
549
  confirmedBalanceString(): string;
541
550
  spendableBalanceString(): string;
542
551
  coin(): string;
552
+ type(): WalletType | undefined;
553
+ multisigType(): 'onchain' | 'tss';
543
554
  label(): string;
544
555
  keyIds(): string[];
545
556
  receiveAddress(): string;