@bitgo-beta/sdk-core 8.2.1-beta.344 → 8.2.1-beta.345
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/dist/src/bitgo/tss/common.d.ts.map +1 -1
- package/dist/src/bitgo/tss/common.js +2 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +2 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.js +5 -4
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -7
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,22 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [26.11.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@26.10.0...@bitgo/sdk-core@26.11.0) (2024-05-08)
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
- **root:** fix keychains updatePassword for tss ([4cc09a8](https://github.com/BitGo/BitGoJS/commit/4cc09a8882194e19b55c10f21937ef0ffff39465))
|
|
11
|
+
- rsa decrypt only needed for node ([3ce36cc](https://github.com/BitGo/BitGoJS/commit/3ce36ccc65b1f6a82fd15a6c7a49359a8eb7098e))
|
|
12
|
+
- **sdk-core:** fix ci check issue ([d0eb311](https://github.com/BitGo/BitGoJS/commit/d0eb311141bee9b52919178a5f033212a299ddcf))
|
|
13
|
+
- **sdk-core:** route PA flow to use MPCv2 ([7c116e9](https://github.com/BitGo/BitGoJS/commit/7c116e9e84d858953746b68ee693c25845feaebd))
|
|
14
|
+
- use native crypto when overridden ([027245e](https://github.com/BitGo/BitGoJS/commit/027245eff5e320ecc679d97081a3c94a8e22c55b))
|
|
15
|
+
|
|
16
|
+
### Features
|
|
17
|
+
|
|
18
|
+
- add network connection encryption function ([8d43b26](https://github.com/BitGo/BitGoJS/commit/8d43b26d99ba7a07ce5e35cbf1906131e2779269))
|
|
19
|
+
- breakout encryption logic functions ([af048f7](https://github.com/BitGo/BitGoJS/commit/af048f76709aa89c000b7bf43cdb2931cb00d7fa))
|
|
20
|
+
- **sdk-lib-mpc:** support mpcv1 to mpcv2 retrofit ([b54a465](https://github.com/BitGo/BitGoJS/commit/b54a46575be40a51b4791cfc082695591dfd5d14))
|
|
21
|
+
|
|
6
22
|
# [26.10.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@26.9.0...@bitgo/sdk-core@26.10.0) (2024-05-01)
|
|
7
23
|
|
|
8
24
|
### Bug Fixes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"AACA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EACL,WAAW,EACX,SAAS,EAET,oBAAoB,EACpB,qBAAqB,EACrB,0BAA0B,EAC1B,0BAA0B,EAC3B,MAAM,UAAU,CAAC;AAElB;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"AACA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EACL,WAAW,EACX,SAAS,EAET,oBAAoB,EACpB,qBAAqB,EACrB,0BAA0B,EAC1B,0BAA0B,EAC3B,MAAM,UAAU,CAAC;AAElB;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAY9G;AAED;;;;;;;;;;;;GAYG;AACH,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,oBAAoB,EACpC,WAAW,EAAE,WAAW,EACxB,WAAW,CAAC,EAAE,MAAM,EACpB,YAAY,GAAE,OAAO,GAAG,OAAiB,EACzC,OAAO,GAAE,MAAM,GAAG,MAAe,EACjC,gBAAgB,CAAC,EAAE,MAAM,GACxB,OAAO,CAAC,oBAAoB,CAAC,CAuB/B;AAED;;;;;;;;;GASG;AACH,wBAAsB,wBAAwB,CAC5C,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,eAAe,EAAE,qBAAqB,EACtC,oBAAoB,EAAE,0BAA0B,EAChD,OAAO,GAAE,MAAM,GAAG,MAAe,GAChC,OAAO,CAAC,0BAA0B,CAAC,CAOrC;AAED;;;GAGG;AACH,wBAAsB,2BAA2B,CAAC,MAAM,EAAE;IACxD,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;CACrB,GAAG,OAAO,CAAC;IAAE,KAAK,EAAE,WAAW,CAAA;CAAE,EAAE,CAAC,CAkCpC;AAED;;;;;;;;;GASG;AACH,wBAAsB,qBAAqB,CACzC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,WAAW,EACxB,eAAe,EAAE,MAAM,GACtB,OAAO,CAAC,0BAA0B,CAAC,CAYrC"}
|
|
@@ -18,6 +18,7 @@ async function getTxRequest(bitgo, walletId, txRequestId) {
|
|
|
18
18
|
const txRequestRes = await bitgo
|
|
19
19
|
.get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))
|
|
20
20
|
.query({ txRequestIds: txRequestId, latest: 'true' })
|
|
21
|
+
.retry(3)
|
|
21
22
|
.result();
|
|
22
23
|
if (txRequestRes.txRequests.length <= 0) {
|
|
23
24
|
throw new Error(`Unable to find TxRequest with id ${txRequestId}`);
|
|
@@ -134,4 +135,4 @@ async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, reques
|
|
|
134
135
|
return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();
|
|
135
136
|
}
|
|
136
137
|
exports.getTxRequestChallenge = getTxRequestChallenge;
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\n\nimport { BitGoBase } from '../bitgoBase';\nimport { TxRequestChallengeResponse } from './types';\nimport {\n  RequestType,\n  TxRequest,\n  verifyPrimaryUserWrapper,\n  SignatureShareRecord,\n  CommitmentShareRecord,\n  EncryptedSignerShareRecord,\n  ExchangeCommitmentResponse,\n} from '../utils';\n\n/**\n * Gets the latest Tx Request by id\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<TxRequest>}\n */\nexport async function getTxRequest(bitgo: BitGoBase, walletId: string, txRequestId: string): Promise<TxRequest> {\n  const txRequestRes = await bitgo\n    .get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))\n    .query({ txRequestIds: txRequestId, latest: 'true' })\n    .result();\n\n  if (txRequestRes.txRequests.length <= 0) {\n    throw new Error(`Unable to find TxRequest with id ${txRequestId}`);\n  }\n\n  return txRequestRes.txRequests[0];\n}\n\n/**\n * Sends a Signature Share\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param {SignatureShareRecord} signatureShare - a Signature Share\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param signerShare\n * @param mpcAlgorithm\n * @param apiMode\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendSignatureShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  signatureShare: SignatureShareRecord,\n  requestType: RequestType,\n  signerShare?: string,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'eddsa',\n  apiMode: 'full' | 'lite' = 'lite',\n  userPublicGpgKey?: string\n): Promise<SignatureShareRecord> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/transactions/0';\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/messages/0';\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/signatureshares';\n  return bitgo\n    .post(bitgo.url(urlPath, 2))\n    .send({\n      signatureShare,\n      signerShare,\n      userPublicGpgKey,\n    })\n    .result();\n}\n\n/**\n * Sends the client commitment and encrypted signer share to the server, getting back the server commitment\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {string} walletId - the wallet id\n * @param {string} txRequestId - the txRequest Id\n * @param {CommitmentShareRecord} commitmentShare - the client commitment share\n * @param {EncryptedSignerShareRecord} encryptedSignerShare - the client encrypted signer share\n * @param {string} [apiMode] - the txRequest api mode (full or lite) - defaults to lite\n * @returns {Promise<ExchangeCommitmentResponse>} - the server commitment share\n */\nexport async function exchangeEddsaCommitments(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  commitmentShare: CommitmentShareRecord,\n  encryptedSignerShare: EncryptedSignerShareRecord,\n  apiMode: 'full' | 'lite' = 'lite'\n): Promise<ExchangeCommitmentResponse> {\n  let addendum = '';\n  if (apiMode === 'full') {\n    addendum = '/transactions/0';\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/commit';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({ commitmentShare, encryptedSignerShare }).result();\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 as well as the expected user and backup key ids\n */\nexport async function commonVerifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n}): Promise<{ value: ArrayBuffer }[]> {\n  const { walletSignature, bitgoPub, commonKeychain, userKeyId, backupKeyId } = params;\n\n  // By ensuring that the fingerprints of the walletSignature and the bitgoPub are different and that any of the results\n  // from calling verifyPrimaryUser is valid we know that the signature was actually produced by the private key\n  // belonging to the bitgoPub.\n  if (walletSignature.keyPacket.getFingerprint() === bitgoPub.keyPacket.getFingerprint()) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n\n  const verificationResult = await verifyPrimaryUserWrapper(walletSignature, bitgoPub, false);\n  const isValid = verificationResult.some((result) => result.valid);\n  if (!isValid) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n  const primaryUser = await walletSignature.getPrimaryUser();\n\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore the rawNotations property is missing from the type but it actually exists\n  const rawNotations: { value: Uint8Array }[] = primaryUser.user.otherCertifications[0].rawNotations;\n\n  assert(rawNotations.length === 5, 'invalid wallet signatures');\n\n  assert(\n    commonKeychain === Buffer.from(rawNotations[0].value).toString(),\n    'wallet signature does not match common keychain'\n  );\n  assert(userKeyId === Buffer.from(rawNotations[1].value).toString(), `wallet signature does not match user key id`);\n  assert(\n    backupKeyId === Buffer.from(rawNotations[2].value).toString(),\n    'wallet signature does not match backup key id'\n  );\n\n  return rawNotations;\n}\n\n/**\n * Gets challenge for a tx request from BitGo\n * supports Message and regular Transaction\n * @param bitgo\n * @param walletId\n * @param txRequestId\n * @param index\n * @param requestType\n * @param paillierModulus\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  paillierModulus: string\n): Promise<TxRequestChallengeResponse> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      addendum = '/transactions/' + index;\n      break;\n    case RequestType.message:\n      addendum = '/messages/' + index;\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();\n}\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\n\nimport { BitGoBase } from '../bitgoBase';\nimport { TxRequestChallengeResponse } from './types';\nimport {\n  RequestType,\n  TxRequest,\n  verifyPrimaryUserWrapper,\n  SignatureShareRecord,\n  CommitmentShareRecord,\n  EncryptedSignerShareRecord,\n  ExchangeCommitmentResponse,\n} from '../utils';\n\n/**\n * Gets the latest Tx Request by id\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<TxRequest>}\n */\nexport async function getTxRequest(bitgo: BitGoBase, walletId: string, txRequestId: string): Promise<TxRequest> {\n  const txRequestRes = await bitgo\n    .get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))\n    .query({ txRequestIds: txRequestId, latest: 'true' })\n    .retry(3)\n    .result();\n\n  if (txRequestRes.txRequests.length <= 0) {\n    throw new Error(`Unable to find TxRequest with id ${txRequestId}`);\n  }\n\n  return txRequestRes.txRequests[0];\n}\n\n/**\n * Sends a Signature Share\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param {SignatureShareRecord} signatureShare - a Signature Share\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param signerShare\n * @param mpcAlgorithm\n * @param apiMode\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendSignatureShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  signatureShare: SignatureShareRecord,\n  requestType: RequestType,\n  signerShare?: string,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'eddsa',\n  apiMode: 'full' | 'lite' = 'lite',\n  userPublicGpgKey?: string\n): Promise<SignatureShareRecord> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/transactions/0';\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/messages/0';\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/signatureshares';\n  return bitgo\n    .post(bitgo.url(urlPath, 2))\n    .send({\n      signatureShare,\n      signerShare,\n      userPublicGpgKey,\n    })\n    .result();\n}\n\n/**\n * Sends the client commitment and encrypted signer share to the server, getting back the server commitment\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {string} walletId - the wallet id\n * @param {string} txRequestId - the txRequest Id\n * @param {CommitmentShareRecord} commitmentShare - the client commitment share\n * @param {EncryptedSignerShareRecord} encryptedSignerShare - the client encrypted signer share\n * @param {string} [apiMode] - the txRequest api mode (full or lite) - defaults to lite\n * @returns {Promise<ExchangeCommitmentResponse>} - the server commitment share\n */\nexport async function exchangeEddsaCommitments(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  commitmentShare: CommitmentShareRecord,\n  encryptedSignerShare: EncryptedSignerShareRecord,\n  apiMode: 'full' | 'lite' = 'lite'\n): Promise<ExchangeCommitmentResponse> {\n  let addendum = '';\n  if (apiMode === 'full') {\n    addendum = '/transactions/0';\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/commit';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({ commitmentShare, encryptedSignerShare }).result();\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 as well as the expected user and backup key ids\n */\nexport async function commonVerifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n}): Promise<{ value: ArrayBuffer }[]> {\n  const { walletSignature, bitgoPub, commonKeychain, userKeyId, backupKeyId } = params;\n\n  // By ensuring that the fingerprints of the walletSignature and the bitgoPub are different and that any of the results\n  // from calling verifyPrimaryUser is valid we know that the signature was actually produced by the private key\n  // belonging to the bitgoPub.\n  if (walletSignature.keyPacket.getFingerprint() === bitgoPub.keyPacket.getFingerprint()) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n\n  const verificationResult = await verifyPrimaryUserWrapper(walletSignature, bitgoPub, false);\n  const isValid = verificationResult.some((result) => result.valid);\n  if (!isValid) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n  const primaryUser = await walletSignature.getPrimaryUser();\n\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore the rawNotations property is missing from the type but it actually exists\n  const rawNotations: { value: Uint8Array }[] = primaryUser.user.otherCertifications[0].rawNotations;\n\n  assert(rawNotations.length === 5, 'invalid wallet signatures');\n\n  assert(\n    commonKeychain === Buffer.from(rawNotations[0].value).toString(),\n    'wallet signature does not match common keychain'\n  );\n  assert(userKeyId === Buffer.from(rawNotations[1].value).toString(), `wallet signature does not match user key id`);\n  assert(\n    backupKeyId === Buffer.from(rawNotations[2].value).toString(),\n    'wallet signature does not match backup key id'\n  );\n\n  return rawNotations;\n}\n\n/**\n * Gets challenge for a tx request from BitGo\n * supports Message and regular Transaction\n * @param bitgo\n * @param walletId\n * @param txRequestId\n * @param index\n * @param requestType\n * @param paillierModulus\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  paillierModulus: string\n): Promise<TxRequestChallengeResponse> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      addendum = '/transactions/' + index;\n      break;\n    case RequestType.message:\n      addendum = '/messages/' + index;\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();\n}\n"]}
|
|
@@ -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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"}
|
|
@@ -294,6 +294,7 @@ class BaseTssUtils extends mpcUtils_1.MpcUtils {
|
|
|
294
294
|
const response = await this.bitgo
|
|
295
295
|
.get(this.baseCoin.url('/tss/pubkey'))
|
|
296
296
|
.query({ enterpriseId })
|
|
297
|
+
.retry(3)
|
|
297
298
|
.result();
|
|
298
299
|
const bitgoPublicKeyStr = isMPCv2 ? response.mpcv2PublicKey : response.publicKey;
|
|
299
300
|
return (0, openpgp_1.readKey)({ armoredKey: bitgoPublicKeyStr });
|
|
@@ -330,4 +331,4 @@ class BaseTssUtils extends mpcUtils_1.MpcUtils {
|
|
|
330
331
|
}
|
|
331
332
|
}
|
|
332
333
|
exports.default = BaseTssUtils;
|
|
333
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTSSUtils.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRequestTracer } from '../../../api';\nimport { Key, readKey, SerializedKeyPair } from 'openpgp';\nimport { IBaseCoin, KeychainsTriplet } from '../../baseCoin';\nimport { BitGoBase } from '../../bitgoBase';\nimport { Keychain } from '../../keychain';\nimport { getTxRequest } from '../../tss';\nimport { IWallet, BackupProvider } from '../../wallet';\nimport { MpcUtils } from '../mpcUtils';\nimport * as _ from 'lodash';\nimport {\n  BitgoGPGPublicKey,\n  BitgoHeldBackupKeyShare,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  ITssUtils,\n  PrebuildTransactionWithIntentOptions,\n  SignatureShareRecord,\n  TSSParams,\n  TxRequest,\n  TxRequestVersion,\n  CreateKeychainParamsBase,\n  IntentOptionsForMessage,\n  PopulatedIntentForMessageSigning,\n  IntentOptionsForTypedData,\n  PopulatedIntentForTypedDataSigning,\n  CreateBitGoKeychainParamsBase,\n  CommitmentShareRecord,\n  EncryptedSignerShareRecord,\n  CustomCommitmentGeneratingFunction,\n  TSSParamsForMessage,\n  RequestType,\n  CustomPaillierModulusGetterFunction,\n  CustomKShareGeneratingFunction,\n  CustomMuDeltaShareGeneratingFunction,\n  CustomSShareGeneratingFunction,\n} from './baseTypes';\nimport { GShare, SignShare } from '../../../account-lib/mpc/tss';\n\n/**\n * BaseTssUtil class which different signature schemes have to extend\n */\nexport default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtils<KeyShare> {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  async createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const keyResponse = await this.bitgo\n      .post(this.baseCoin.url('/krs/backupkeys'))\n      .send({\n        enterprise,\n        userGPGPublicKey: userGpgKey.publicKey,\n      })\n      .result();\n    if (!keyResponse || !keyResponse.keyShares) {\n      throw new Error('Failed to get backup shares from BitGo.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n    };\n  }\n\n  public finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    backupGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    isThirdPartyBackup?: boolean;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequest(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for EdDSA and through utilization of custom share generators\n   *\n   * @param {string | TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {CustomRShareGeneratingFunction} externalSignerRShareGenerator a function that creates R shares in the EdDSA TSS flow\n   * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow\n   * @returns {Promise<TxRequest>} - a signed tx request\n   */\n  signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for ECDSA and through utilization of custom share generators\n   *\n   * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.\n   * @param {RequestType} requestType - the type of the request to sign (transaction or message).\n   * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.\n   * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.\n   * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.\n   * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.\n   */\n  signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material\n   * EDDSA only\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} params.walletPassphrase - wallet passphrase\n   *\n   * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo\n   */\n  createCommitmentShareFromTxRequest(params: { txRequest: TxRequest; prv: string; walletPassphrase: string }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an R (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} [params.walletPassphrase] - wallet passphrase\n   * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase\n   * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo\n   */\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create a G (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share\n   * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share\n   * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment\n   * @returns {Promise<GShare>} - GShare from User to BitGo\n   */\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param {TxRequestVersion} apiVersion lite or full\n   * @param {boolean} preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion: TxRequestVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions = this.populateIntent(this.baseCoin, params);\n\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Create a tx request from params for message signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForMessageSigning(\n    params: IntentOptionsForMessage,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForMessageSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.messageRaw,\n      messageEncoded: params.messageEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Create a tx request from params for type data signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForTypedDataSigning(\n    params: IntentOptionsForTypedData,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForTypedDataSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.typedDataRaw,\n      messageEncoded: params.typedDataEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Calls Bitgo API to create tx request.\n   *\n   * @private\n   */\n  private async createTxRequestBase(\n    intentOptions: PopulatedIntentForTypedDataSigning | PopulatedIntentForMessageSigning,\n    apiVersion: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion,\n      preview,\n    };\n\n    return this.bitgo\n      .post(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests`, 2))\n      .send(whitelistedParams)\n      .result();\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Checks whether the third party backup provider is valid/supported\n   * @param backupProvider - the backup provider client selected\n   */\n  isValidThirdPartyBackupProvider(\n    backupProvider: BackupProvider | string | undefined\n  ): backupProvider is BackupProvider {\n    // As of now, BitGo is the only supported KRS provider for TSS\n    return !!(backupProvider && backupProvider === 'BitGoTrustAsKrs');\n  }\n\n  /**\n   * It gets the appropriate BitGo GPG public key for key creation based on a\n   * combination of coin and the feature flags on the user and their enterprise if set.\n   * @param enterpriseId - enterprise under which user wants to create the wallet\n   * @param isMPCv2 - true to get the MPCv2 GPG public key, defaults to false\n   */\n  public async getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined, isMPCv2 = false): Promise<Key> {\n    const response: BitgoGPGPublicKey = await this.bitgo\n      .get(this.baseCoin.url('/tss/pubkey'))\n      .query({ enterpriseId })\n      .result();\n    const bitgoPublicKeyStr = isMPCv2 ? response.mpcv2PublicKey : response.publicKey;\n    return readKey({ armoredKey: bitgoPublicKeyStr as string });\n  }\n\n  /**\n   * Returns supported TxRequest versions for this wallet\n   */\n  public supportedTxRequestVersions(): TxRequestVersion[] {\n    const walletType = this._wallet?.type();\n    const supportedWalletTypes = ['custodial', 'cold', 'hot'];\n    if (!walletType || this._wallet?.multisigType() !== 'tss' || !supportedWalletTypes.includes(walletType)) {\n      return [];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'ecdsa') {\n      return ['full'];\n    } else if (walletType === 'custodial' || walletType === 'cold') {\n      return ['full'];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'eddsa' && walletType === 'hot') {\n      return ['lite', 'full'];\n    }\n    return [];\n  }\n\n  /**\n   * Returns true if the txRequest is using apiVersion == full and is pending approval\n   * @param txRequest\n   * @returns boolean\n   */\n  isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean {\n    const { apiVersion, state } = txRequest;\n    return apiVersion === 'full' && 'pendingApproval' === state;\n  }\n}\n"]}
|
|
334
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTSSUtils.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTSSUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import { IRequestTracer } from '../../../api';\nimport { Key, readKey, SerializedKeyPair } from 'openpgp';\nimport { IBaseCoin, KeychainsTriplet } from '../../baseCoin';\nimport { BitGoBase } from '../../bitgoBase';\nimport { Keychain } from '../../keychain';\nimport { getTxRequest } from '../../tss';\nimport { IWallet, BackupProvider } from '../../wallet';\nimport { MpcUtils } from '../mpcUtils';\nimport * as _ from 'lodash';\nimport {\n  BitgoGPGPublicKey,\n  BitgoHeldBackupKeyShare,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  ITssUtils,\n  PrebuildTransactionWithIntentOptions,\n  SignatureShareRecord,\n  TSSParams,\n  TxRequest,\n  TxRequestVersion,\n  CreateKeychainParamsBase,\n  IntentOptionsForMessage,\n  PopulatedIntentForMessageSigning,\n  IntentOptionsForTypedData,\n  PopulatedIntentForTypedDataSigning,\n  CreateBitGoKeychainParamsBase,\n  CommitmentShareRecord,\n  EncryptedSignerShareRecord,\n  CustomCommitmentGeneratingFunction,\n  TSSParamsForMessage,\n  RequestType,\n  CustomPaillierModulusGetterFunction,\n  CustomKShareGeneratingFunction,\n  CustomMuDeltaShareGeneratingFunction,\n  CustomSShareGeneratingFunction,\n} from './baseTypes';\nimport { GShare, SignShare } from '../../../account-lib/mpc/tss';\n\n/**\n * BaseTssUtil class which different signature schemes have to extend\n */\nexport default class BaseTssUtils<KeyShare> extends MpcUtils implements ITssUtils<KeyShare> {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  async createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare> {\n    const keyResponse = await this.bitgo\n      .post(this.baseCoin.url('/krs/backupkeys'))\n      .send({\n        enterprise,\n        userGPGPublicKey: userGpgKey.publicKey,\n      })\n      .result();\n    if (!keyResponse || !keyResponse.keyShares) {\n      throw new Error('Failed to get backup shares from BitGo.');\n    }\n    return {\n      id: keyResponse.id,\n      keyShares: keyResponse.keyShares,\n    };\n  }\n\n  public finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    userGpgKey: SerializedKeyPair<string>,\n    backupGpgKey: Key\n  ): Promise<BitgoHeldBackupKeyShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain> {\n    throw new Error('Method not implemented.');\n  }\n\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string | undefined;\n    originalPasscodeEncryptionCode?: string | undefined;\n    isThirdPartyBackup?: boolean;\n    backupProvider?: BackupProvider;\n  }): Promise<KeychainsTriplet> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequest(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for EdDSA and through utilization of custom share generators\n   *\n   * @param {string | TxRequest} txRequest - transaction request with unsigned transaction\n   * @param {CustomRShareGeneratingFunction} externalSignerRShareGenerator a function that creates R shares in the EdDSA TSS flow\n   * @param {CustomGShareGeneratingFunction} externalSignerGShareGenerator a function that creates G shares in the EdDSA TSS flow\n   * @returns {Promise<TxRequest>} - a signed tx request\n   */\n  signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Signs a transaction using TSS for ECDSA and through utilization of custom share generators\n   *\n   * @param {params: TSSParams | TSSParamsForMessage} params - params object that represents parameters to sign a transaction or a message.\n   * @param {RequestType} requestType - the type of the request to sign (transaction or message).\n   * @param {CustomPaillierModulusGetterFunction} externalSignerPaillierModulusGetter a function that creates Paillier Modulus shares in the ECDSA TSS flow.\n   * @param {CustomKShareGeneratingFunction} externalSignerKShareGenerator a function that creates K shares in the ECDSA TSS flow.\n   * @param {CustomMuDeltaShareGeneratingFunction} externalSignerMuDeltaShareGenerator a function that creates Mu and Delta shares in the ECDSA TSS flow.\n   * @param {CustomSShareGeneratingFunction} externalSignerSShareGenerator a function that creates S shares in the ECDSA TSS flow.\n   */\n  signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an Commitment (User to BitGo) share from an unsigned transaction and private user signing material\n   * EDDSA only\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} params.walletPassphrase - wallet passphrase\n   *\n   * @returns {Promise<{ userToBitgoCommitment: CommitmentShareRecor, encryptedSignerShare: EncryptedSignerShareRecord }>} - Commitment Share and the Encrypted Signer Share to BitGo\n   */\n  createCommitmentShareFromTxRequest(params: { txRequest: TxRequest; prv: string; walletPassphrase: string }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create an R (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {string} [params.walletPassphrase] - wallet passphrase\n   * @param {EncryptedSignerShareRecord} [params.encryptedUserToBitgoRShare] - encrypted user to bitgo R share generated in the commitment phase\n   * @returns {Promise<{ rShare: SignShare }>} - R Share to BitGo\n   */\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Create a G (User to BitGo) share from an unsigned transaction and private user signing material\n   *\n   * @param {Object} params - params object\n   * @param {TxRequest} params.txRequest - transaction request with unsigned transaction\n   * @param {string} params.prv - user signing material\n   * @param {SignatureShareRecord} params.bitgoToUserRShare - BitGo to User R Share\n   * @param {SignShare} params.userToBitgoRShare - User to BitGo R Share\n   * @param {CommitmentShareRecord} params.bitgoToUserCommitment - BitGo to User Commitment\n   * @returns {Promise<GShare>} - GShare from User to BitGo\n   */\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param {TxRequestVersion} apiVersion lite or full\n   * @param {boolean} preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion: TxRequestVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions = this.populateIntent(this.baseCoin, params);\n\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Create a tx request from params for message signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForMessageSigning(\n    params: IntentOptionsForMessage,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForMessageSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.messageRaw,\n      messageEncoded: params.messageEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Create a tx request from params for type data signing\n   *\n   * @param params\n   * @param apiVersion\n   * @param preview\n   */\n  async createTxRequestWithIntentForTypedDataSigning(\n    params: IntentOptionsForTypedData,\n    apiVersion: TxRequestVersion = 'full',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const intentOptions: PopulatedIntentForTypedDataSigning = {\n      custodianMessageId: params.custodianMessageId,\n      intentType: params.intentType,\n      sequenceId: params.sequenceId,\n      comment: params.comment,\n      memo: params.memo?.value,\n      isTss: params.isTss,\n      messageRaw: params.typedDataRaw,\n      messageEncoded: params.typedDataEncoded ?? '',\n    };\n\n    return this.createTxRequestBase(intentOptions, apiVersion, preview);\n  }\n\n  /**\n   * Calls Bitgo API to create tx request.\n   *\n   * @private\n   */\n  private async createTxRequestBase(\n    intentOptions: PopulatedIntentForTypedDataSigning | PopulatedIntentForMessageSigning,\n    apiVersion: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const whitelistedParams = {\n      intent: {\n        ...intentOptions,\n      },\n      apiVersion,\n      preview,\n    };\n\n    return this.bitgo\n      .post(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests`, 2))\n      .send(whitelistedParams)\n      .result();\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Checks whether the third party backup provider is valid/supported\n   * @param backupProvider - the backup provider client selected\n   */\n  isValidThirdPartyBackupProvider(\n    backupProvider: BackupProvider | string | undefined\n  ): backupProvider is BackupProvider {\n    // As of now, BitGo is the only supported KRS provider for TSS\n    return !!(backupProvider && backupProvider === 'BitGoTrustAsKrs');\n  }\n\n  /**\n   * It gets the appropriate BitGo GPG public key for key creation based on a\n   * combination of coin and the feature flags on the user and their enterprise if set.\n   * @param enterpriseId - enterprise under which user wants to create the wallet\n   * @param isMPCv2 - true to get the MPCv2 GPG public key, defaults to false\n   */\n  public async getBitgoGpgPubkeyBasedOnFeatureFlags(enterpriseId: string | undefined, isMPCv2 = false): Promise<Key> {\n    const response: BitgoGPGPublicKey = await this.bitgo\n      .get(this.baseCoin.url('/tss/pubkey'))\n      .query({ enterpriseId })\n      .retry(3)\n      .result();\n    const bitgoPublicKeyStr = isMPCv2 ? response.mpcv2PublicKey : response.publicKey;\n    return readKey({ armoredKey: bitgoPublicKeyStr as string });\n  }\n\n  /**\n   * Returns supported TxRequest versions for this wallet\n   */\n  public supportedTxRequestVersions(): TxRequestVersion[] {\n    const walletType = this._wallet?.type();\n    const supportedWalletTypes = ['custodial', 'cold', 'hot'];\n    if (!walletType || this._wallet?.multisigType() !== 'tss' || !supportedWalletTypes.includes(walletType)) {\n      return [];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'ecdsa') {\n      return ['full'];\n    } else if (walletType === 'custodial' || walletType === 'cold') {\n      return ['full'];\n    } else if (this._wallet?.baseCoin.getMPCAlgorithm() === 'eddsa' && walletType === 'hot') {\n      return ['lite', 'full'];\n    }\n    return [];\n  }\n\n  /**\n   * Returns true if the txRequest is using apiVersion == full and is pending approval\n   * @param txRequest\n   * @returns boolean\n   */\n  isPendingApprovalTxRequestFull(txRequest: TxRequest): boolean {\n    const { apiVersion, state } = txRequest;\n    return apiVersion === 'full' && 'pendingApproval' === state;\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ecdsaMPCv2.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAKhC,OAAO,EAAE,QAAQ,EAAW,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EACL,UAAU,EAWX,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAe,SAAS,EAAuB,SAAS,EAAE,MAAM,cAAc,CAAC;AAUtF,qBAAa,eAAgB,SAAQ,cAAc;IACjD,kBAAkB;IACZ,eAAe,CAAC,MAAM,EAAE;QAC5B,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,8BAA8B,CAAC,EAAE,MAAM,CAAC;KACzC,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAmRvB,yBAAyB,CAC7B,gBAAgB,EAAE,UAAU,EAC5B,cAAc,EAAE,MAAM,EACtB,eAAe,CAAC,EAAE,MAAM,EACxB,UAAU,CAAC,EAAE,MAAM,EACnB,8BAA8B,CAAC,EAAE,MAAM,GACtC,OAAO,CAAC,QAAQ,CAAC;YAiCN,eAAe;YAef,iBAAiB;YAejB,gBAAgB;YAMhB,wBAAwB;YAWxB,uBAAuB;YAqBvB,uBAAuB;YAsCvB,uBAAuB;IA4BrC;;;;;;OAMG;IACG,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;YAK5C,eAAe;
|
|
1
|
+
{"version":3,"file":"ecdsaMPCv2.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsaMPCv2.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAKhC,OAAO,EAAE,QAAQ,EAAW,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EACL,UAAU,EAWX,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAe,SAAS,EAAuB,SAAS,EAAE,MAAM,cAAc,CAAC;AAUtF,qBAAa,eAAgB,SAAQ,cAAc;IACjD,kBAAkB;IACZ,eAAe,CAAC,MAAM,EAAE;QAC5B,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,8BAA8B,CAAC,EAAE,MAAM,CAAC;KACzC,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAmRvB,yBAAyB,CAC7B,gBAAgB,EAAE,UAAU,EAC5B,cAAc,EAAE,MAAM,EACtB,eAAe,CAAC,EAAE,MAAM,EACxB,UAAU,CAAC,EAAE,MAAM,EACnB,8BAA8B,CAAC,EAAE,MAAM,GACtC,OAAO,CAAC,QAAQ,CAAC;YAiCN,eAAe;YAef,iBAAiB;YAejB,gBAAgB;YAMhB,wBAAwB;YAWxB,uBAAuB;YAqBvB,uBAAuB;YAsCvB,uBAAuB;IA4BrC;;;;;;OAMG;IACG,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;YAK5C,eAAe;IAmJ7B,OAAO,CAAC,2BAA2B;IAOnC,OAAO,CAAC,gBAAgB;CASzB"}
|