@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
@@ -3,7 +3,7 @@ import openpgp from 'openpgp';
3
3
  import Eddsa, { GShare, KeyShare, PShare, SignShare, YShare } from './../../../account-lib/mpc/tss';
4
4
  import { BitGoBase } from './../../bitgoBase';
5
5
  import { DecryptableYShare, CombinedKey, EncryptedYShare, UserSigningMaterial, BackupSigningMaterial } from './types';
6
- import { SignatureShareRecord } from './../../utils';
6
+ import { SignatureShareRecord, CommitmentShareRecord } from './../../utils';
7
7
  import { BaseTransaction } from './../../../account-lib/baseCoin/baseTransaction';
8
8
  import { getTxRequest, sendSignatureShare } from '../common';
9
9
  export { getTxRequest, sendSignatureShare };
@@ -22,7 +22,7 @@ export declare function createCombinedKey(params: {
22
22
  commonKeychain: string;
23
23
  }): Promise<CombinedKey>;
24
24
  /**
25
- * Creates the User Sign Share containing the User XShare and the User to Bitgo RShare
25
+ * Creates the User Sign Share containing the User XShare , the User to Bitgo RShare and User to Bitgo commitment
26
26
  *
27
27
  * @param {Buffer} signablePayload - the signablePayload as a buffer
28
28
  * @param {PShare} pShare - User's signing material
@@ -36,9 +36,10 @@ export declare function createUserSignShare(signablePayload: Buffer, pShare: PSh
36
36
  * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare
37
37
  * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation
38
38
  * @param {Buffer} signablePayload - the signable payload from a tx
39
+ * @param {CommitmentShareRecord} [bitgoToUserCommitment] - the Bitgo to User Commitment
39
40
  * @returns {Promise<GShare>} - the User to Bitgo GShare
40
41
  */
41
- export declare function createUserToBitGoGShare(userSignShare: SignShare, bitgoToUserRShare: SignatureShareRecord, backupToUserYShare: YShare, bitgoToUserYShare: YShare, signablePayload: Buffer): Promise<GShare>;
42
+ export declare function createUserToBitGoGShare(userSignShare: SignShare, bitgoToUserRShare: SignatureShareRecord, backupToUserYShare: YShare, bitgoToUserYShare: YShare, signablePayload: Buffer, bitgoToUserCommitment?: CommitmentShareRecord): Promise<GShare>;
42
43
  /**
43
44
  * Sends the User to Bitgo RShare to Bitgo
44
45
  * @param {BitGoBase} bitgo - the bitgo instance
@@ -1 +1 @@
1
- {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":";AACA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,KAAK,EAAE,EAAE,MAAM,EAAU,QAAQ,EAAE,MAAM,EAAU,SAAS,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACpH,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EACL,iBAAiB,EACjB,WAAW,EAEX,eAAe,EACf,mBAAmB,EACnB,qBAAqB,EACtB,MAAM,SAAS,CAAC;AAEjB,OAAO,EAGL,oBAAoB,EAGpB,qBAAqB,EAEtB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,iDAAiD,CAAC;AAGlF,OAAO,EAA+B,YAAY,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAE1F,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,CAAC;AAE5C;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CAAC,MAAM,EAAE;IAC9C,QAAQ,EAAE,QAAQ,CAAC;IACnB,gBAAgB,EAAE,iBAAiB,EAAE,CAAC;IACtC,cAAc,EAAE,MAAM,CAAC;CACxB,GAAG,OAAO,CAAC,WAAW,CAAC,CA+DvB;AAED;;;;;;GAMG;AACH,wBAAsB,mBAAmB,CAAC,eAAe,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAQrG;AAED;;;;;;;;;GASG;AACH,wBAAsB,uBAAuB,CAC3C,aAAa,EAAE,SAAS,EACxB,iBAAiB,EAAE,oBAAoB,EACvC,kBAAkB,EAAE,MAAM,EAC1B,iBAAiB,EAAE,MAAM,EACzB,eAAe,EAAE,MAAM,EACvB,qBAAqB,CAAC,EAAE,qBAAqB,GAC5C,OAAO,CAAC,MAAM,CAAC,CAiDjB;AAED;;;;;;;;GAQG;AACH,wBAAsB,sBAAsB,CAC1C,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,SAAS,EACxB,oBAAoB,EAAE,MAAM,EAC5B,OAAO,GAAE,MAAM,GAAG,MAAe,EACjC,QAAQ,CAAC,EAAE,MAAM,EACjB,iBAAiB,CAAC,EAAE,MAAM,EAC1B,gBAAgB,CAAC,EAAE,MAAM,EACzB,WAAW,CAAC,EAAE,MAAM,GACnB,OAAO,CAAC,IAAI,CAAC,CA6Bf;AAED;;;;;;;GAOG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,oBAAoB,CAAC,CAoB/B;AAED;;;;;;;;GAQG;AACH,wBAAsB,qBAAqB,CACzC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,iBAAiB,EAAE,MAAM,EACzB,OAAO,GAAE,MAAM,GAAG,MAAe,GAChC,OAAO,CAAC,IAAI,CAAC,CAYf;AAED;;;;;;;;;GASG;AACH,wBAAsB,aAAa,CAAC,MAAM,EAAE;IAC1C,QAAQ,EAAE,QAAQ,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,uBAAuB,EAAE,MAAM,CAAC;IAChC,qBAAqB,EAAE,MAAM,CAAC;CAC/B,GAAG,OAAO,CAAC,eAAe,CAAC,CA0B3B;AAED;;;;;GAKG;AACH,wBAAsB,yBAAyB,mBAG9C;AAED;;;;;;;;;GASG;AACH,wBAAsB,eAAe,CACnC,mBAAmB,EAAE,mBAAmB,EACxC,qBAAqB,EAAE,qBAAqB,EAC5C,IAAI,oBAAQ,EACZ,WAAW,EAAE,eAAe,GAC3B,OAAO,CAAC,MAAM,CAAC,CA6CjB;AAED;;;;GAIG;AACH,wBAAsB,qBAAqB,CAAC,MAAM,EAAE;IAClD,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC;IAC7B,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC;CACtB,GAAG,OAAO,CAAC,IAAI,CAAC,CAehB"}
@@ -76,7 +76,7 @@ async function createCombinedKey(params) {
76
76
  }
77
77
  exports.createCombinedKey = createCombinedKey;
78
78
  /**
79
- * Creates the User Sign Share containing the User XShare and the User to Bitgo RShare
79
+ * Creates the User Sign Share containing the User XShare , the User to Bitgo RShare and User to Bitgo commitment
80
80
  *
81
81
  * @param {Buffer} signablePayload - the signablePayload as a buffer
82
82
  * @param {PShare} pShare - User's signing material
@@ -98,9 +98,10 @@ exports.createUserSignShare = createUserSignShare;
98
98
  * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare
99
99
  * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation
100
100
  * @param {Buffer} signablePayload - the signable payload from a tx
101
+ * @param {CommitmentShareRecord} [bitgoToUserCommitment] - the Bitgo to User Commitment
101
102
  * @returns {Promise<GShare>} - the User to Bitgo GShare
102
103
  */
103
- async function createUserToBitGoGShare(userSignShare, bitgoToUserRShare, backupToUserYShare, bitgoToUserYShare, signablePayload) {
104
+ async function createUserToBitGoGShare(userSignShare, bitgoToUserRShare, backupToUserYShare, bitgoToUserYShare, signablePayload, bitgoToUserCommitment) {
104
105
  if (userSignShare.xShare.i !== types_1.ShareKeyPosition.USER) {
105
106
  throw new Error('Invalid XShare, doesnt belong to the User');
106
107
  }
@@ -123,7 +124,7 @@ async function createUserToBitGoGShare(userSignShare, bitgoToUserRShare, backupT
123
124
  r = bitgoToUserRShare.share.substring(0, 64);
124
125
  R = bitgoToUserRShare.share.substring(64, 128);
125
126
  }
126
- const RShare = {
127
+ const updatedBitgoToUserRShare = {
127
128
  i: types_1.ShareKeyPosition.USER,
128
129
  j: types_1.ShareKeyPosition.BITGO,
129
130
  u: bitgoToUserYShare.u,
@@ -132,7 +133,17 @@ async function createUserToBitGoGShare(userSignShare, bitgoToUserRShare, backupT
132
133
  R,
133
134
  };
134
135
  const MPC = await tss_1.default.initialize();
135
- return MPC.sign(signablePayload, userSignShare.xShare, [RShare], [backupToUserYShare]);
136
+ if (bitgoToUserCommitment) {
137
+ if (bitgoToUserCommitment.from !== utils_1.SignatureShareType.BITGO ||
138
+ bitgoToUserCommitment.to !== utils_1.SignatureShareType.USER) {
139
+ throw new Error('Invalid Commitment, is not from Bitgo to User');
140
+ }
141
+ if (bitgoToUserCommitment.type !== utils_1.CommitmentType.COMMITMENT) {
142
+ throw new Error('Invalid Commitment type, got: ' + bitgoToUserCommitment.type + ' expected: commitment');
143
+ }
144
+ updatedBitgoToUserRShare.commitment = bitgoToUserCommitment.share;
145
+ }
146
+ return MPC.sign(signablePayload, userSignShare.xShare, [updatedBitgoToUserRShare], [backupToUserYShare]);
136
147
  }
137
148
  exports.createUserToBitGoGShare = createUserToBitGoGShare;
138
149
  /**
@@ -309,4 +320,4 @@ async function verifyWalletSignature(params) {
309
320
  assert_1.default(publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(), 'bitgo share mismatch');
310
321
  }
311
322
  exports.verifyWalletSignature = verifyWalletSignature;
312
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\nimport sodium from 'libsodium-wrappers-sumo';\nimport Eddsa, { GShare, JShare, KeyShare, PShare, RShare, SignShare, YShare } from './../../../account-lib/mpc/tss';\nimport { BitGoBase } from './../../bitgoBase';\nimport {\n  DecryptableYShare,\n  CombinedKey,\n  SigningMaterial,\n  EncryptedYShare,\n  UserSigningMaterial,\n  BackupSigningMaterial,\n} from './types';\nimport { ShareKeyPosition } from './../types';\nimport {\n  encryptAndSignText,\n  readSignedMessage,\n  SignatureShareRecord,\n  SignatureShareType,\n  RequestType,\n} from './../../utils';\nimport { BaseTransaction } from './../../../account-lib/baseCoin/baseTransaction';\nimport { Ed25519BIP32 } from './../../../account-lib/mpc/hdTree';\nimport _ = require('lodash');\nimport { commonVerifyWalletSignature, getTxRequest, sendSignatureShare } from '../common';\n\nexport { getTxRequest, sendSignatureShare };\n\n/**\n * Combines YShares to combine the final TSS key\n * This can only be used to create the User or Backup key since it requires the common keychain from BitGo first\n *\n * @param params.keyShare - TSS key share\n * @param params.encryptedYShares - encrypted YShares with information on how to decrypt\n * @param params.commonKeychain - expected common keychain of the combined key\n * @returns {CombinedKey} combined TSS key\n */\nexport async function createCombinedKey(params: {\n  keyShare: KeyShare;\n  encryptedYShares: DecryptableYShare[];\n  commonKeychain: string;\n}): Promise<CombinedKey> {\n  await Eddsa.initialize();\n  const MPC = new Eddsa();\n\n  const { keyShare, encryptedYShares, commonKeychain } = params;\n  const yShares: YShare[] = [];\n\n  let bitgoYShare: YShare | undefined;\n  let userYShare: YShare | undefined;\n  let backupYShare: YShare | undefined;\n\n  for (const encryptedYShare of encryptedYShares) {\n    const privateShare = await readSignedMessage(\n      encryptedYShare.yShare.encryptedPrivateShare,\n      encryptedYShare.senderPublicArmor,\n      encryptedYShare.recipientPrivateArmor\n    );\n\n    const yShare: YShare = {\n      i: encryptedYShare.yShare.i,\n      j: encryptedYShare.yShare.j,\n      y: encryptedYShare.yShare.publicShare.slice(0, 64),\n      v: encryptedYShare.yShare.publicShare.slice(64, 128),\n      u: privateShare.slice(0, 64),\n      chaincode: privateShare.slice(64),\n    };\n\n    switch (encryptedYShare.yShare.j) {\n      case 1:\n        userYShare = yShare;\n        break;\n      case 2:\n        backupYShare = yShare;\n        break;\n      case 3:\n        bitgoYShare = yShare;\n        break;\n      default:\n        throw new Error('Invalid YShare index');\n    }\n\n    yShares.push(yShare);\n  }\n\n  const combinedKey = MPC.keyCombine(keyShare.uShare, yShares);\n  if (combinedKey.pShare.y + combinedKey.pShare.chaincode !== commonKeychain) {\n    throw new Error('Common keychains do not match');\n  }\n  if (!bitgoYShare) {\n    throw new Error('Missing BitGo Y Share');\n  }\n\n  const signingMaterial: SigningMaterial = {\n    uShare: keyShare.uShare,\n    bitgoYShare,\n    backupYShare,\n    userYShare,\n  };\n\n  return {\n    signingMaterial,\n    commonKeychain,\n  };\n}\n\n/**\n * Creates the User Sign Share containing the User XShare and the User to Bitgo RShare\n *\n * @param {Buffer} signablePayload - the signablePayload as a buffer\n * @param {PShare} pShare - User's signing material\n * @returns {Promise<SignShare>} - User Sign Share\n */\nexport async function createUserSignShare(signablePayload: Buffer, pShare: PShare): Promise<SignShare> {\n  const MPC = await Eddsa.initialize();\n\n  if (pShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid PShare, PShare doesnt belong to the User');\n  }\n  const jShare: JShare = { i: ShareKeyPosition.BITGO, j: ShareKeyPosition.USER };\n  return MPC.signShare(signablePayload, pShare, [jShare]);\n}\n\n/**\n * Creates the User to Bitgo GShare\n *\n * @param {SignShare} userSignShare - the User Sign Share\n * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare\n * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation\n * @param {Buffer} signablePayload - the signable payload from a tx\n * @returns {Promise<GShare>} - the User to Bitgo GShare\n */\nexport async function createUserToBitGoGShare(\n  userSignShare: SignShare,\n  bitgoToUserRShare: SignatureShareRecord,\n  backupToUserYShare: YShare,\n  bitgoToUserYShare: YShare,\n  signablePayload: Buffer\n): Promise<GShare> {\n  if (userSignShare.xShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid XShare, doesnt belong to the User');\n  }\n  if (bitgoToUserRShare.from !== SignatureShareType.BITGO || bitgoToUserRShare.to !== SignatureShareType.USER) {\n    throw new Error('Invalid RShare, is not from Bitgo to User');\n  }\n  if (backupToUserYShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid YShare, doesnt belong to the User');\n  }\n  if (backupToUserYShare.j !== ShareKeyPosition.BACKUP) {\n    throw new Error('Invalid YShare, is not backup key');\n  }\n\n  let v, r, R;\n  if (bitgoToUserRShare.share.length > 128) {\n    v = bitgoToUserRShare.share.substring(0, 64);\n    r = bitgoToUserRShare.share.substring(64, 128);\n    R = bitgoToUserRShare.share.substring(128, 192);\n  } else {\n    r = bitgoToUserRShare.share.substring(0, 64);\n    R = bitgoToUserRShare.share.substring(64, 128);\n  }\n\n  const RShare: RShare = {\n    i: ShareKeyPosition.USER,\n    j: ShareKeyPosition.BITGO,\n    u: bitgoToUserYShare.u,\n    v,\n    r,\n    R,\n  };\n\n  const MPC = await Eddsa.initialize();\n  return MPC.sign(signablePayload, userSignShare.xShare, [RShare], [backupToUserYShare]);\n}\n\n/**\n * Sends the User to Bitgo RShare to Bitgo\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {SignShare} userSignShare - the user Sign Share\n * @param {String} encryptedSignerShare - signer share encrypted to bitgo key\n * @returns {Promise<void>}\n */\nexport async function offerUserToBitgoRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userSignShare: SignShare,\n  encryptedSignerShare: string,\n  apiMode: 'full' | 'lite' = 'lite',\n  vssProof?: string,\n  privateShareProof?: string,\n  userPublicGpgKey?: string,\n  publicShare?: string\n): Promise<void> {\n  const rShare: RShare = userSignShare.rShares[ShareKeyPosition.BITGO];\n  if (_.isNil(rShare)) {\n    throw new Error('userToBitgo RShare not found');\n  }\n  if (rShare.i !== ShareKeyPosition.BITGO || rShare.j !== ShareKeyPosition.USER) {\n    throw new Error('Invalid RShare, is not from User to Bitgo');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: rShare.r + rShare.R,\n    vssProof,\n    privateShareProof,\n    publicShare,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    encryptedSignerShare,\n    'eddsa',\n    apiMode,\n    userPublicGpgKey\n  );\n}\n\n/**\n * Gets the Bitgo to User RShare from Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function getBitgoToUserRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string\n): Promise<SignatureShareRecord> {\n  const txRequest = await getTxRequest(bitgo, walletId, txRequestId);\n  let signatureShares;\n  if (txRequest.apiVersion === 'full') {\n    assert(txRequest.transactions, 'transactions required as part of txRequest');\n    signatureShares = txRequest.transactions[0].signatureShares;\n  } else {\n    signatureShares = txRequest.signatureShares;\n  }\n  if (_.isNil(signatureShares) || _.isEmpty(signatureShares)) {\n    throw new Error(`No signatures shares found for id: ${txRequestId}`);\n  }\n  // at this point we expect the only share to be the RShare\n  const bitgoToUserRShare = signatureShares.find(\n    (sigShare) => sigShare.from === SignatureShareType.BITGO && sigShare.to === SignatureShareType.USER\n  );\n  if (_.isNil(bitgoToUserRShare)) {\n    throw new Error(`Bitgo to User RShare not found for id: ${txRequestId}`);\n  }\n  return bitgoToUserRShare;\n}\n\n/**\n * Sends the User to Bitgo GShare to Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {GShare} userToBitgoGShare - the User to Bitgo GShare\n * @returns {Promise<void>}\n */\nexport async function sendUserToBitgoGShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userToBitgoGShare: GShare,\n  apiMode: 'full' | 'lite' = 'lite'\n): Promise<void> {\n  if (userToBitgoGShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid GShare, doesnt belong to the User');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: userToBitgoGShare.R + userToBitgoGShare.gamma,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(bitgo, walletId, txRequestId, signatureShare, RequestType.tx, undefined, 'eddsa', apiMode);\n}\n\n/**\n * Prepares a YShare to be exchanged with other key holders.\n * Output is in a format that is usable within BitGo's ecosystem.\n *\n * @param params.keyShare - TSS key share of the party preparing exchange materials\n * @param params.recipientIndex - index of the recipient (1, 2, or 3)\n * @param params.recipientGpgPublicArmor - recipient's public gpg key in armor format\n * @param params.senderGpgPrivateArmor - sender's private gpg key in armor format\n * @returns { EncryptedYShare } encrypted Y Share\n */\nexport async function encryptYShare(params: {\n  keyShare: KeyShare;\n  recipientIndex: number;\n  recipientGpgPublicArmor: string;\n  senderGpgPrivateArmor: string;\n}): Promise<EncryptedYShare> {\n  const { keyShare, recipientIndex, recipientGpgPublicArmor, senderGpgPrivateArmor } = params;\n\n  const yShare = keyShare.yShares[recipientIndex];\n  if (!yShare) {\n    throw new Error('Invalid recipient');\n  }\n\n  const publicShare = Buffer.concat([\n    Buffer.from(keyShare.uShare.y, 'hex'),\n    Buffer.from(yShare.v!, 'hex'),\n    Buffer.from(keyShare.uShare.chaincode, 'hex'),\n  ]).toString('hex');\n\n  const privateShare = Buffer.concat([Buffer.from(yShare.u, 'hex'), Buffer.from(yShare.chaincode, 'hex')]).toString(\n    'hex'\n  );\n\n  const encryptedPrivateShare = await encryptAndSignText(privateShare, recipientGpgPublicArmor, senderGpgPrivateArmor);\n\n  return {\n    i: yShare.i,\n    j: yShare.j,\n    publicShare,\n    encryptedPrivateShare,\n  };\n}\n\n/**\n *\n * Initializes Eddsa instance\n *\n * @returns {Promise<Eddsa>} the Eddsa instance\n */\nexport async function getInitializedMpcInstance() {\n  const hdTree = await Ed25519BIP32.initialize();\n  return await Eddsa.initialize(hdTree);\n}\n\n/**\n *\n * Generates a TSS signature using the user and backup key\n *\n * @param {UserSigningMaterial} userSigningMaterial decrypted user TSS key\n * @param {BackupSigningMaterial} backupSigningMaterial decrypted backup TSS key\n * @param {string} path bip32 derivation path\n * @param {BaseTransaction} transaction the transaction to sign\n * @returns {Buffer} the signature\n */\nexport async function getTSSSignature(\n  userSigningMaterial: UserSigningMaterial,\n  backupSigningMaterial: BackupSigningMaterial,\n  path = 'm/0',\n  transaction: BaseTransaction\n): Promise<Buffer> {\n  const MPC = await getInitializedMpcInstance();\n\n  const userCombine = MPC.keyCombine(userSigningMaterial.uShare, [\n    userSigningMaterial.bitgoYShare,\n    userSigningMaterial.backupYShare,\n  ]);\n  const backupCombine = MPC.keyCombine(backupSigningMaterial.uShare, [\n    backupSigningMaterial.bitgoYShare,\n    backupSigningMaterial.userYShare,\n  ]);\n\n  const userSubkey = MPC.keyDerive(\n    userSigningMaterial.uShare,\n    [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n    path\n  );\n\n  const backupSubkey = MPC.keyCombine(backupSigningMaterial.uShare, [\n    userSubkey.yShares[2],\n    backupSigningMaterial.bitgoYShare,\n  ]);\n\n  const messageBuffer = transaction.signablePayload;\n  const userSignShare = MPC.signShare(messageBuffer, userSubkey.pShare, [userCombine.jShares[2]]);\n  const backupSignShare = MPC.signShare(messageBuffer, backupSubkey.pShare, [backupCombine.jShares[1]]);\n  const userSign = MPC.sign(\n    messageBuffer,\n    userSignShare.xShare,\n    [backupSignShare.rShares[1]],\n    [userSigningMaterial.bitgoYShare]\n  );\n  const backupSign = MPC.sign(\n    messageBuffer,\n    backupSignShare.xShare,\n    [userSignShare.rShares[2]],\n    [backupSigningMaterial.bitgoYShare]\n  );\n  const signature = MPC.signCombine([userSign, backupSign]);\n  const result = MPC.verify(messageBuffer, signature);\n  if (!result) {\n    throw new Error('Invalid signature');\n  }\n  const rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n  return rawSignature;\n}\n\n/**\n * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the\n * expected common keychain, the expected user and backup key ids as well as the public share that is generated from the\n * private share that was passed in.\n */\nexport async function verifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n  decryptedShare: string;\n  verifierIndex: 1 | 2; // the index of the verifier, 1 means user, 2 means backup\n}): Promise<void> {\n  const rawNotations = await commonVerifyWalletSignature(params);\n\n  const { decryptedShare, verifierIndex } = params;\n\n  const publicShare =\n    Buffer.from(\n      await sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(decryptedShare.slice(0, 64), 'hex'))\n    ).toString('hex') + decryptedShare.slice(64);\n  const publicShareRawNotationIndex = 2 + verifierIndex;\n\n  assert(\n    publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(),\n    'bitgo share mismatch'\n  );\n}\n"]}
323
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\nimport sodium from 'libsodium-wrappers-sumo';\nimport Eddsa, { GShare, JShare, KeyShare, PShare, RShare, SignShare, YShare } from './../../../account-lib/mpc/tss';\nimport { BitGoBase } from './../../bitgoBase';\nimport {\n  DecryptableYShare,\n  CombinedKey,\n  SigningMaterial,\n  EncryptedYShare,\n  UserSigningMaterial,\n  BackupSigningMaterial,\n} from './types';\nimport { ShareKeyPosition } from './../types';\nimport {\n  encryptAndSignText,\n  readSignedMessage,\n  SignatureShareRecord,\n  SignatureShareType,\n  RequestType,\n  CommitmentShareRecord,\n  CommitmentType,\n} from './../../utils';\nimport { BaseTransaction } from './../../../account-lib/baseCoin/baseTransaction';\nimport { Ed25519BIP32 } from './../../../account-lib/mpc/hdTree';\nimport _ = require('lodash');\nimport { commonVerifyWalletSignature, getTxRequest, sendSignatureShare } from '../common';\n\nexport { getTxRequest, sendSignatureShare };\n\n/**\n * Combines YShares to combine the final TSS key\n * This can only be used to create the User or Backup key since it requires the common keychain from BitGo first\n *\n * @param params.keyShare - TSS key share\n * @param params.encryptedYShares - encrypted YShares with information on how to decrypt\n * @param params.commonKeychain - expected common keychain of the combined key\n * @returns {CombinedKey} combined TSS key\n */\nexport async function createCombinedKey(params: {\n  keyShare: KeyShare;\n  encryptedYShares: DecryptableYShare[];\n  commonKeychain: string;\n}): Promise<CombinedKey> {\n  await Eddsa.initialize();\n  const MPC = new Eddsa();\n\n  const { keyShare, encryptedYShares, commonKeychain } = params;\n  const yShares: YShare[] = [];\n\n  let bitgoYShare: YShare | undefined;\n  let userYShare: YShare | undefined;\n  let backupYShare: YShare | undefined;\n\n  for (const encryptedYShare of encryptedYShares) {\n    const privateShare = await readSignedMessage(\n      encryptedYShare.yShare.encryptedPrivateShare,\n      encryptedYShare.senderPublicArmor,\n      encryptedYShare.recipientPrivateArmor\n    );\n\n    const yShare: YShare = {\n      i: encryptedYShare.yShare.i,\n      j: encryptedYShare.yShare.j,\n      y: encryptedYShare.yShare.publicShare.slice(0, 64),\n      v: encryptedYShare.yShare.publicShare.slice(64, 128),\n      u: privateShare.slice(0, 64),\n      chaincode: privateShare.slice(64),\n    };\n\n    switch (encryptedYShare.yShare.j) {\n      case 1:\n        userYShare = yShare;\n        break;\n      case 2:\n        backupYShare = yShare;\n        break;\n      case 3:\n        bitgoYShare = yShare;\n        break;\n      default:\n        throw new Error('Invalid YShare index');\n    }\n\n    yShares.push(yShare);\n  }\n\n  const combinedKey = MPC.keyCombine(keyShare.uShare, yShares);\n  if (combinedKey.pShare.y + combinedKey.pShare.chaincode !== commonKeychain) {\n    throw new Error('Common keychains do not match');\n  }\n  if (!bitgoYShare) {\n    throw new Error('Missing BitGo Y Share');\n  }\n\n  const signingMaterial: SigningMaterial = {\n    uShare: keyShare.uShare,\n    bitgoYShare,\n    backupYShare,\n    userYShare,\n  };\n\n  return {\n    signingMaterial,\n    commonKeychain,\n  };\n}\n\n/**\n * Creates the User Sign Share containing the User XShare , the User to Bitgo RShare and User to Bitgo commitment\n *\n * @param {Buffer} signablePayload - the signablePayload as a buffer\n * @param {PShare} pShare - User's signing material\n * @returns {Promise<SignShare>} - User Sign Share\n */\nexport async function createUserSignShare(signablePayload: Buffer, pShare: PShare): Promise<SignShare> {\n  const MPC = await Eddsa.initialize();\n\n  if (pShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid PShare, PShare doesnt belong to the User');\n  }\n  const jShare: JShare = { i: ShareKeyPosition.BITGO, j: ShareKeyPosition.USER };\n  return MPC.signShare(signablePayload, pShare, [jShare]);\n}\n\n/**\n * Creates the User to Bitgo GShare\n *\n * @param {SignShare} userSignShare - the User Sign Share\n * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare\n * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation\n * @param {Buffer} signablePayload - the signable payload from a tx\n * @param {CommitmentShareRecord} [bitgoToUserCommitment] - the Bitgo to User Commitment\n * @returns {Promise<GShare>} - the User to Bitgo GShare\n */\nexport async function createUserToBitGoGShare(\n  userSignShare: SignShare,\n  bitgoToUserRShare: SignatureShareRecord,\n  backupToUserYShare: YShare,\n  bitgoToUserYShare: YShare,\n  signablePayload: Buffer,\n  bitgoToUserCommitment?: CommitmentShareRecord\n): Promise<GShare> {\n  if (userSignShare.xShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid XShare, doesnt belong to the User');\n  }\n  if (bitgoToUserRShare.from !== SignatureShareType.BITGO || bitgoToUserRShare.to !== SignatureShareType.USER) {\n    throw new Error('Invalid RShare, is not from Bitgo to User');\n  }\n  if (backupToUserYShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid YShare, doesnt belong to the User');\n  }\n  if (backupToUserYShare.j !== ShareKeyPosition.BACKUP) {\n    throw new Error('Invalid YShare, is not backup key');\n  }\n\n  let v, r, R;\n  if (bitgoToUserRShare.share.length > 128) {\n    v = bitgoToUserRShare.share.substring(0, 64);\n    r = bitgoToUserRShare.share.substring(64, 128);\n    R = bitgoToUserRShare.share.substring(128, 192);\n  } else {\n    r = bitgoToUserRShare.share.substring(0, 64);\n    R = bitgoToUserRShare.share.substring(64, 128);\n  }\n\n  const updatedBitgoToUserRShare: RShare = {\n    i: ShareKeyPosition.USER,\n    j: ShareKeyPosition.BITGO,\n    u: bitgoToUserYShare.u,\n    v,\n    r,\n    R,\n  };\n\n  const MPC = await Eddsa.initialize();\n\n  if (bitgoToUserCommitment) {\n    if (\n      bitgoToUserCommitment.from !== SignatureShareType.BITGO ||\n      bitgoToUserCommitment.to !== SignatureShareType.USER\n    ) {\n      throw new Error('Invalid Commitment, is not from Bitgo to User');\n    }\n    if (bitgoToUserCommitment.type !== CommitmentType.COMMITMENT) {\n      throw new Error('Invalid Commitment type, got: ' + bitgoToUserCommitment.type + ' expected: commitment');\n    }\n    updatedBitgoToUserRShare.commitment = bitgoToUserCommitment.share;\n  }\n\n  return MPC.sign(signablePayload, userSignShare.xShare, [updatedBitgoToUserRShare], [backupToUserYShare]);\n}\n\n/**\n * Sends the User to Bitgo RShare to Bitgo\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {SignShare} userSignShare - the user Sign Share\n * @param {String} encryptedSignerShare - signer share encrypted to bitgo key\n * @returns {Promise<void>}\n */\nexport async function offerUserToBitgoRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userSignShare: SignShare,\n  encryptedSignerShare: string,\n  apiMode: 'full' | 'lite' = 'lite',\n  vssProof?: string,\n  privateShareProof?: string,\n  userPublicGpgKey?: string,\n  publicShare?: string\n): Promise<void> {\n  const rShare: RShare = userSignShare.rShares[ShareKeyPosition.BITGO];\n  if (_.isNil(rShare)) {\n    throw new Error('userToBitgo RShare not found');\n  }\n  if (rShare.i !== ShareKeyPosition.BITGO || rShare.j !== ShareKeyPosition.USER) {\n    throw new Error('Invalid RShare, is not from User to Bitgo');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: rShare.r + rShare.R,\n    vssProof,\n    privateShareProof,\n    publicShare,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    encryptedSignerShare,\n    'eddsa',\n    apiMode,\n    userPublicGpgKey\n  );\n}\n\n/**\n * Gets the Bitgo to User RShare from Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function getBitgoToUserRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string\n): Promise<SignatureShareRecord> {\n  const txRequest = await getTxRequest(bitgo, walletId, txRequestId);\n  let signatureShares;\n  if (txRequest.apiVersion === 'full') {\n    assert(txRequest.transactions, 'transactions required as part of txRequest');\n    signatureShares = txRequest.transactions[0].signatureShares;\n  } else {\n    signatureShares = txRequest.signatureShares;\n  }\n  if (_.isNil(signatureShares) || _.isEmpty(signatureShares)) {\n    throw new Error(`No signatures shares found for id: ${txRequestId}`);\n  }\n  // at this point we expect the only share to be the RShare\n  const bitgoToUserRShare = signatureShares.find(\n    (sigShare) => sigShare.from === SignatureShareType.BITGO && sigShare.to === SignatureShareType.USER\n  );\n  if (_.isNil(bitgoToUserRShare)) {\n    throw new Error(`Bitgo to User RShare not found for id: ${txRequestId}`);\n  }\n  return bitgoToUserRShare;\n}\n\n/**\n * Sends the User to Bitgo GShare to Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {GShare} userToBitgoGShare - the User to Bitgo GShare\n * @returns {Promise<void>}\n */\nexport async function sendUserToBitgoGShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userToBitgoGShare: GShare,\n  apiMode: 'full' | 'lite' = 'lite'\n): Promise<void> {\n  if (userToBitgoGShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid GShare, doesnt belong to the User');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: userToBitgoGShare.R + userToBitgoGShare.gamma,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(bitgo, walletId, txRequestId, signatureShare, RequestType.tx, undefined, 'eddsa', apiMode);\n}\n\n/**\n * Prepares a YShare to be exchanged with other key holders.\n * Output is in a format that is usable within BitGo's ecosystem.\n *\n * @param params.keyShare - TSS key share of the party preparing exchange materials\n * @param params.recipientIndex - index of the recipient (1, 2, or 3)\n * @param params.recipientGpgPublicArmor - recipient's public gpg key in armor format\n * @param params.senderGpgPrivateArmor - sender's private gpg key in armor format\n * @returns { EncryptedYShare } encrypted Y Share\n */\nexport async function encryptYShare(params: {\n  keyShare: KeyShare;\n  recipientIndex: number;\n  recipientGpgPublicArmor: string;\n  senderGpgPrivateArmor: string;\n}): Promise<EncryptedYShare> {\n  const { keyShare, recipientIndex, recipientGpgPublicArmor, senderGpgPrivateArmor } = params;\n\n  const yShare = keyShare.yShares[recipientIndex];\n  if (!yShare) {\n    throw new Error('Invalid recipient');\n  }\n\n  const publicShare = Buffer.concat([\n    Buffer.from(keyShare.uShare.y, 'hex'),\n    Buffer.from(yShare.v!, 'hex'),\n    Buffer.from(keyShare.uShare.chaincode, 'hex'),\n  ]).toString('hex');\n\n  const privateShare = Buffer.concat([Buffer.from(yShare.u, 'hex'), Buffer.from(yShare.chaincode, 'hex')]).toString(\n    'hex'\n  );\n\n  const encryptedPrivateShare = await encryptAndSignText(privateShare, recipientGpgPublicArmor, senderGpgPrivateArmor);\n\n  return {\n    i: yShare.i,\n    j: yShare.j,\n    publicShare,\n    encryptedPrivateShare,\n  };\n}\n\n/**\n *\n * Initializes Eddsa instance\n *\n * @returns {Promise<Eddsa>} the Eddsa instance\n */\nexport async function getInitializedMpcInstance() {\n  const hdTree = await Ed25519BIP32.initialize();\n  return await Eddsa.initialize(hdTree);\n}\n\n/**\n *\n * Generates a TSS signature using the user and backup key\n *\n * @param {UserSigningMaterial} userSigningMaterial decrypted user TSS key\n * @param {BackupSigningMaterial} backupSigningMaterial decrypted backup TSS key\n * @param {string} path bip32 derivation path\n * @param {BaseTransaction} transaction the transaction to sign\n * @returns {Buffer} the signature\n */\nexport async function getTSSSignature(\n  userSigningMaterial: UserSigningMaterial,\n  backupSigningMaterial: BackupSigningMaterial,\n  path = 'm/0',\n  transaction: BaseTransaction\n): Promise<Buffer> {\n  const MPC = await getInitializedMpcInstance();\n\n  const userCombine = MPC.keyCombine(userSigningMaterial.uShare, [\n    userSigningMaterial.bitgoYShare,\n    userSigningMaterial.backupYShare,\n  ]);\n  const backupCombine = MPC.keyCombine(backupSigningMaterial.uShare, [\n    backupSigningMaterial.bitgoYShare,\n    backupSigningMaterial.userYShare,\n  ]);\n\n  const userSubkey = MPC.keyDerive(\n    userSigningMaterial.uShare,\n    [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n    path\n  );\n\n  const backupSubkey = MPC.keyCombine(backupSigningMaterial.uShare, [\n    userSubkey.yShares[2],\n    backupSigningMaterial.bitgoYShare,\n  ]);\n\n  const messageBuffer = transaction.signablePayload;\n  const userSignShare = MPC.signShare(messageBuffer, userSubkey.pShare, [userCombine.jShares[2]]);\n  const backupSignShare = MPC.signShare(messageBuffer, backupSubkey.pShare, [backupCombine.jShares[1]]);\n  const userSign = MPC.sign(\n    messageBuffer,\n    userSignShare.xShare,\n    [backupSignShare.rShares[1]],\n    [userSigningMaterial.bitgoYShare]\n  );\n  const backupSign = MPC.sign(\n    messageBuffer,\n    backupSignShare.xShare,\n    [userSignShare.rShares[2]],\n    [backupSigningMaterial.bitgoYShare]\n  );\n  const signature = MPC.signCombine([userSign, backupSign]);\n  const result = MPC.verify(messageBuffer, signature);\n  if (!result) {\n    throw new Error('Invalid signature');\n  }\n  const rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n  return rawSignature;\n}\n\n/**\n * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the\n * expected common keychain, the expected user and backup key ids as well as the public share that is generated from the\n * private share that was passed in.\n */\nexport async function verifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n  decryptedShare: string;\n  verifierIndex: 1 | 2; // the index of the verifier, 1 means user, 2 means backup\n}): Promise<void> {\n  const rawNotations = await commonVerifyWalletSignature(params);\n\n  const { decryptedShare, verifierIndex } = params;\n\n  const publicShare =\n    Buffer.from(\n      await sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(decryptedShare.slice(0, 64), 'hex'))\n    ).toString('hex') + decryptedShare.slice(64);\n  const publicShareRawNotationIndex = 2 + verifierIndex;\n\n  assert(\n    publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(),\n    'bitgo share mismatch'\n  );\n}\n"]}
@@ -1,6 +1,25 @@
1
+ import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
2
+ import { KShare, OShare, WShare } from './ecdsa/types';
3
+ import { MuDShare } from './ecdsa/ecdsa';
1
4
  export declare enum ShareKeyPosition {
2
5
  USER = 1,
3
6
  BACKUP = 2,
4
7
  BITGO = 3
5
8
  }
9
+ export declare type TxRequestChallengeResponse = EcdsaTypes.SerializedEcdsaChallenges & {
10
+ n: string;
11
+ };
12
+ export declare type TssEcdsaStep1ReturnMessage = {
13
+ privateShareProof: string;
14
+ vssProof?: string;
15
+ userPublicGpgKey: string;
16
+ publicShare: string;
17
+ encryptedSignerOffsetShare: string;
18
+ kShare: KShare;
19
+ wShare: WShare | string;
20
+ };
21
+ export declare type TssEcdsaStep2ReturnMessage = {
22
+ muDShare: MuDShare;
23
+ oShare: OShare | string;
24
+ };
6
25
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/types.ts"],"names":[],"mappings":"AAAA,oBAAY,gBAAgB;IAC1B,IAAI,IAAI;IACR,MAAM,IAAI;IACV,KAAK,IAAI;CACV"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEzC,oBAAY,gBAAgB;IAC1B,IAAI,IAAI;IACR,MAAM,IAAI;IACV,KAAK,IAAI;CACV;AAED,oBAAY,0BAA0B,GAAG,UAAU,CAAC,yBAAyB,GAAG;IAC9E,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,oBAAY,0BAA0B,GAAG;IACvC,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,0BAA0B,EAAE,MAAM,CAAC;IACnC,MAAM,EAAE,MAAM,CAAC;IAEf,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB,CAAC;AAEF,oBAAY,0BAA0B,GAAG;IACvC,QAAQ,EAAE,QAAQ,CAAC;IAEnB,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB,CAAC"}
@@ -7,4 +7,4 @@ var ShareKeyPosition;
7
7
  ShareKeyPosition[ShareKeyPosition["BACKUP"] = 2] = "BACKUP";
8
8
  ShareKeyPosition[ShareKeyPosition["BITGO"] = 3] = "BITGO";
9
9
  })(ShareKeyPosition = exports.ShareKeyPosition || (exports.ShareKeyPosition = {}));
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vdHNzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLElBQVksZ0JBSVg7QUFKRCxXQUFZLGdCQUFnQjtJQUMxQix1REFBUSxDQUFBO0lBQ1IsMkRBQVUsQ0FBQTtJQUNWLHlEQUFTLENBQUE7QUFDWCxDQUFDLEVBSlcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFJM0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBTaGFyZUtleVBvc2l0aW9uIHtcbiAgVVNFUiA9IDEsXG4gIEJBQ0tVUCA9IDIsXG4gIEJJVEdPID0gMyxcbn1cbiJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vdHNzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUlBLElBQVksZ0JBSVg7QUFKRCxXQUFZLGdCQUFnQjtJQUMxQix1REFBUSxDQUFBO0lBQ1IsMkRBQVUsQ0FBQTtJQUNWLHlEQUFTLENBQUE7QUFDWCxDQUFDLEVBSlcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFJM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFY2RzYVR5cGVzIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWxpYi1tcGMnO1xuaW1wb3J0IHsgS1NoYXJlLCBPU2hhcmUsIFdTaGFyZSB9IGZyb20gJy4vZWNkc2EvdHlwZXMnO1xuaW1wb3J0IHsgTXVEU2hhcmUgfSBmcm9tICcuL2VjZHNhL2VjZHNhJztcblxuZXhwb3J0IGVudW0gU2hhcmVLZXlQb3NpdGlvbiB7XG4gIFVTRVIgPSAxLFxuICBCQUNLVVAgPSAyLFxuICBCSVRHTyA9IDMsXG59XG5cbmV4cG9ydCB0eXBlIFR4UmVxdWVzdENoYWxsZW5nZVJlc3BvbnNlID0gRWNkc2FUeXBlcy5TZXJpYWxpemVkRWNkc2FDaGFsbGVuZ2VzICYge1xuICBuOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBUc3NFY2RzYVN0ZXAxUmV0dXJuTWVzc2FnZSA9IHtcbiAgcHJpdmF0ZVNoYXJlUHJvb2Y6IHN0cmluZztcbiAgdnNzUHJvb2Y/OiBzdHJpbmc7XG4gIHVzZXJQdWJsaWNHcGdLZXk6IHN0cmluZztcbiAgcHVibGljU2hhcmU6IHN0cmluZztcbiAgZW5jcnlwdGVkU2lnbmVyT2Zmc2V0U2hhcmU6IHN0cmluZztcbiAga1NoYXJlOiBLU2hhcmU7XG4gIC8vIHdTaGFyZSBjb3VsZCBiZSBlbmNyeXB0ZWQuIElmIGl0IGlzIGVuY3J5cHRlZCwgaXQgd2lsbCBiZSBhIHN0cmluZywgb3RoZXJ3aXNlIGl0IHdpbGwgYmUgYSBXU2hhcmUuXG4gIHdTaGFyZTogV1NoYXJlIHwgc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgVHNzRWNkc2FTdGVwMlJldHVybk1lc3NhZ2UgPSB7XG4gIG11RFNoYXJlOiBNdURTaGFyZTtcbiAgLy8gb1NoYXJlIGNvdWxkIGJlIGVuY3J5cHRlZC4gSWYgaXQgaXMgZW5jcnlwdGVkLCBpdCB3aWxsIGJlIGEgc3RyaW5nLCBvdGhlcndpc2UgaXQgd2lsbCBiZSBhbiBPU2hhcmUuXG4gIG9TaGFyZTogT1NoYXJlIHwgc3RyaW5nO1xufTtcbiJdfQ==
@@ -5,8 +5,8 @@ import { BitGoBase } from '../../bitgoBase';
5
5
  import { Keychain } from '../../keychain';
6
6
  import { IWallet, BackupProvider } from '../../wallet';
7
7
  import { MpcUtils } from '../mpcUtils';
8
- import { BitgoHeldBackupKeyShare, CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TSSParams, TxRequest, TxRequestVersion, CreateKeychainParamsBase, IntentOptionsForMessage, IntentOptionsForTypedData, CreateBitGoKeychainParamsBase } from './baseTypes';
9
- import { GShare, SignShare, YShare } from '../../../account-lib/mpc/tss';
8
+ import { BitgoHeldBackupKeyShare, CustomGShareGeneratingFunction, CustomRShareGeneratingFunction, ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TSSParams, TxRequest, TxRequestVersion, CreateKeychainParamsBase, IntentOptionsForMessage, IntentOptionsForTypedData, CreateBitGoKeychainParamsBase, CommitmentShareRecord, EncryptedSignerShareRecord, CustomCommitmentGeneratingFunction, TSSParamsForMessage, RequestType, CustomPaillierModulusGetterFunction, CustomKShareGeneratingFunction, CustomMuDeltaShareGeneratingFunction, CustomSShareGeneratingFunction } from './baseTypes';
9
+ import { GShare, SignShare } from '../../../account-lib/mpc/tss';
10
10
  /**
11
11
  * BaseTssUtil class which different signature schemes have to extend
12
12
  */
@@ -36,28 +36,64 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
36
36
  * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow
37
37
  * @returns {Promise<TxRequest>} - a signed tx request
38
38
  */
39
- signUsingExternalSigner(txRequest: string | TxRequest, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
39
+ signEddsaTssUsingExternalSigner(txRequest: string | TxRequest, externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction, externalSignerRShareGenerator: CustomRShareGeneratingFunction, externalSignerGShareGenerator: CustomGShareGeneratingFunction): Promise<TxRequest>;
40
+ /**
41
+ * Signs a transaction using TSS for ECDSA and through utilization of custom share generators
42
+ *
43
+ * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.
44
+ * @param {RequestType} requestType - the type of the request to sign (transaction or message).
45
+ * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.
46
+ * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.
47
+ * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.
48
+ * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.
49
+ */
50
+ signEcdsaTssUsingExternalSigner(params: TSSParams | TSSParamsForMessage, requestType: RequestType, externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction, externalSignerKShareGenerator: CustomKShareGeneratingFunction, externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction, externalSignerSShareGenerator: CustomSShareGeneratingFunction): Promise<TxRequest>;
51
+ /**
52
+ * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material
53
+ * EDDSA only
54
+ *
55
+ * @param {Object} params - params object
56
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
57
+ * @param {string} params.prv - user signing material
58
+ * @param {string} params.walletPassphrase - wallet passphrase
59
+ *
60
+ * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo
61
+ */
62
+ createCommitmentShareFromTxRequest(params: {
63
+ txRequest: TxRequest;
64
+ prv: string;
65
+ walletPassphrase: string;
66
+ }): Promise<{
67
+ userToBitgoCommitment: CommitmentShareRecord;
68
+ encryptedSignerShare: EncryptedSignerShareRecord;
69
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
70
+ }>;
40
71
  /**
41
72
  * Create an R (User to BitGo) share from an unsigned transaction and private user signing material
42
73
  *
43
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
44
- * @param {string} prv - user signing material
45
- * @returns {Promise<{ rShare: SignShare; signingKeyYShare: YShare }>} - R Share and the Signing Key's Y share to BitGo
74
+ * @param {Object} params - params object
75
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
76
+ * @param {string} params.prv - user signing material
77
+ * @param {string} [params.walletPassphrase] - wallet passphrase
78
+ * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase
79
+ * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo
46
80
  */
47
81
  createRShareFromTxRequest(params: {
48
82
  txRequest: TxRequest;
49
- prv: string;
83
+ walletPassphrase: string;
84
+ encryptedUserToBitgoRShare: EncryptedSignerShareRecord;
50
85
  }): Promise<{
51
86
  rShare: SignShare;
52
- signingKeyYShare: YShare;
53
87
  }>;
54
88
  /**
55
89
  * Create a G (User to BitGo) share from an unsigned transaction and private user signing material
56
90
  *
57
- * @param {TxRequest} txRequest - transaction request with unsigned transaction
58
- * @param {string} prv - user signing material
59
- * @param {SignatureShareRecord} bitgoToUserRShare - BitGo to User R Share
60
- * @param {SignShare} userToBitgoRShare - User to BitGo R Share
91
+ * @param {Object} params - params object
92
+ * @param {TxRequest} params.txRequest - transaction request with unsigned transaction
93
+ * @param {string} params.prv - user signing material
94
+ * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share
95
+ * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share
96
+ * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment
61
97
  * @returns {Promise<GShare>} - GShare from User to BitGo
62
98
  */
63
99
  createGShareFromTxRequest(params: {
@@ -65,6 +101,7 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
65
101
  prv: string;
66
102
  bitgoToUserRShare: SignatureShareRecord;
67
103
  userToBitgoRShare: SignShare;
104
+ bitgoToUserCommitment: CommitmentShareRecord;
68
105
  }): Promise<GShare>;
69
106
  /**
70
107
  * Builds a tx request from params and verify it
@@ -140,5 +177,9 @@ export default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtil
140
177
  * @param enterpriseId - enterprise under which user wants to create the wallet
141
178
  */
142
179
  getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined): Promise<Key>;
180
+ /**
181
+ * Returns supported TxRequest versions for this wallet
182
+ */
183
+ supportedTxRequestVersions(): TxRequestVersion[];
143
184
  }
144
185
  //# sourceMappingURL=baseTSSUtils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"baseTSSUtils.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"baseTSSUtils.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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"}