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

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 +3 -1
  3. package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
  4. package/dist/src/account-lib/baseCoin/enum.js +5 -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 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getTxRequestChallenge = exports.commonVerifyWalletSignature = exports.sendSignatureShare = exports.getTxRequest = void 0;
6
+ exports.getTxRequestChallenge = exports.commonVerifyWalletSignature = exports.exchangeEddsaCommitments = exports.sendSignatureShare = exports.getTxRequest = void 0;
7
7
  const assert_1 = __importDefault(require("assert"));
8
8
  const utils_1 = require("../utils");
9
9
  /**
@@ -63,6 +63,25 @@ async function sendSignatureShare(bitgo, walletId, txRequestId, signatureShare,
63
63
  .result();
64
64
  }
65
65
  exports.sendSignatureShare = sendSignatureShare;
66
+ /**
67
+ * Sends the client commitment and encrypted signer share to the server, getting back the server commitment
68
+ * @param {BitGoBase} bitgo - the bitgo instance
69
+ * @param {string} walletId - the wallet id
70
+ * @param {string} txRequestId - the txRequest Id
71
+ * @param {CommitmentShareRecord} commitmentShare - the client commitment share
72
+ * @param {EncryptedSignerShareRecord} encryptedSignerShare - the client encrypted signer share
73
+ * @param {string} [apiMode] - the txRequest api mode (full or lite) - defaults to lite
74
+ * @returns {Promise<ExchangeCommitmentResponse>} - the server commitment share
75
+ */
76
+ async function exchangeEddsaCommitments(bitgo, walletId, txRequestId, commitmentShare, encryptedSignerShare, apiMode = 'lite') {
77
+ let addendum = '';
78
+ if (apiMode === 'full') {
79
+ addendum = '/transactions/0';
80
+ }
81
+ const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/commit';
82
+ return await bitgo.post(bitgo.url(urlPath, 2)).send({ commitmentShare, encryptedSignerShare }).result();
83
+ }
84
+ exports.exchangeEddsaCommitments = exchangeEddsaCommitments;
66
85
  /**
67
86
  * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the
68
87
  * expected common keychain as well as the expected user and backup key ids
@@ -99,24 +118,20 @@ exports.commonVerifyWalletSignature = commonVerifyWalletSignature;
99
118
  * @param txRequestId
100
119
  * @param index
101
120
  * @param requestType
102
- * @param mpcAlgorithm
121
+ * @param paillierModulus
103
122
  */
104
- async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, requestType, mpcAlgorithm = 'ecdsa') {
123
+ async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, requestType, paillierModulus) {
105
124
  let addendum = '';
106
125
  switch (requestType) {
107
126
  case utils_1.RequestType.tx:
108
- if (mpcAlgorithm === 'ecdsa') {
109
- addendum = '/transactions/' + index;
110
- }
127
+ addendum = '/transactions/' + index;
111
128
  break;
112
129
  case utils_1.RequestType.message:
113
- if (mpcAlgorithm === 'ecdsa') {
114
- addendum = '/messages/' + index;
115
- }
130
+ addendum = '/messages/' + index;
116
131
  break;
117
132
  }
118
133
  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';
119
- return await bitgo.post(bitgo.url(urlPath, 2)).send({}).result();
134
+ return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();
120
135
  }
121
136
  exports.getTxRequestChallenge = getTxRequestChallenge;
122
- //# 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 { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\n\nimport { BitGoBase } from '../bitgoBase';\nimport { RequestType, TxRequest, verifyPrimaryUserWrapper, SignatureShareRecord } 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 * 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 mpcAlgorithm\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'ecdsa'\n): Promise<EcdsaTypes.SerializedNtilde> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/transactions/' + index;\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/messages/' + index;\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({}).result();\n}\n"]}
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"]}
@@ -1,9 +1,9 @@
1
1
  /// <reference types="node" />
2
- import { DecryptableNShare, CombinedKey, EncryptedNShare, AShare, CreateUserGammaAndMuShareRT, CreateUserOmicronAndDeltaShareRT, DShare, GShare, KeyShare, NShare, OShare, SendShareType, SignatureShare, SignShare, XShare, WShare, XShareWithNtilde, YShareWithNtilde, SendShareToBitgoRT, ReceivedShareType, BShare, Signature } from './types';
3
- import { SignatureShareRecord, SignatureShareType, RequestType } from '../../utils';
2
+ import { AShare, BShare, CombinedKey, CreateUserOmicronAndDeltaShareRT, DecryptableNShare, DShare, EncryptedNShare, GShare, KeyShare, NShare, OShare, ReceivedShareType, SendShareToBitgoRT, SendShareType, Signature, SignatureShare, SignShare, WShare, XShareWithChallenges, YShareWithChallenges } from './types';
3
+ import { RequestType, SignatureShareRecord, SignatureShareType } from '../../utils';
4
4
  import { ShareKeyPosition } from '../types';
5
5
  import { BitGoBase } from '../../bitgoBase';
6
- import { KShare, MUShare, SShare } from '../../../account-lib/mpc/tss/ecdsa/types';
6
+ import { KShare, MUShare, SignConvertStep2Response, SShare } from '../../../account-lib/mpc/tss/ecdsa/types';
7
7
  import * as pgp from 'openpgp';
8
8
  import { ApiKeyShare } from '../../keychain';
9
9
  import { Hash } from 'crypto';
@@ -23,14 +23,14 @@ export declare function createCombinedKey(keyShare: KeyShare, encryptedNShares:
23
23
  * @param {YShare} yShare YShare from Bitgo
24
24
  * @returns {Promise<SignShare>}
25
25
  */
26
- export declare function createUserSignShare(xShare: XShare | XShareWithNtilde, yShare: YShareWithNtilde): Promise<SignShare>;
26
+ export declare function createUserSignShare(xShare: XShareWithChallenges, yShare: YShareWithChallenges): Promise<SignShare>;
27
27
  /**
28
28
  * Creates the Gamma Share and MuShare with User WShare and AShare From BitGo
29
29
  * @param {WShare} wShare User WShare
30
30
  * @param {AShare} aShare AShare from Bitgo
31
- * @returns {Promise<CreateUserGammaAndMuShareRT>}
31
+ * @returns {Promise<SignConvertStep2Response>}
32
32
  */
33
- export declare function createUserGammaAndMuShare(wShare: WShare, aShare: AShare): Promise<CreateUserGammaAndMuShareRT>;
33
+ export declare function createUserGammaAndMuShare(wShare: WShare, aShare: AShare): Promise<SignConvertStep2Response>;
34
34
  /**
35
35
  * Creates the Omicron Share and Delta share with user GShare
36
36
  * @param {GShare} gShare User GShare
@@ -98,12 +98,13 @@ export declare function buildNShareFromAPIKeyShare(keyShare: ApiKeyShare): Promi
98
98
  /**
99
99
  * Decrypts encrypted n share
100
100
  * @param encryptedNShare - decryptable n share with recipient private gpg key armor and sender public gpg key
101
+ * @param isbs58Encoded
101
102
  * @returns N share
102
103
  */
103
104
  export declare function decryptNShare(encryptedNShare: DecryptableNShare, isbs58Encoded?: boolean): Promise<NShare>;
104
105
  /**
105
- * Gets public key from common key chain
106
- * @param commonKeyChain - common key chain of ecdsa tss
106
+ * Gets public key from common keychain
107
+ * @param commonKeyChain - common keychain of ecdsa tss
107
108
  * @returns public key
108
109
  */
109
110
  export declare function getPublicKey(commonKeyChain: string): string;
@@ -192,6 +193,8 @@ export declare function parseCombinedSignature(share: SignatureShareRecord): Sig
192
193
  /**
193
194
  * convert signature share to signature share record
194
195
  * @param share - Signature share
196
+ * @param senderIndex
197
+ * @param recipientIndex
195
198
  * @returns signature share record
196
199
  */
197
200
  export declare function convertSignatureShare(share: SignatureShare, senderIndex: number, recipientIndex: number): SignatureShareRecord;
@@ -1 +1 @@
1
- {"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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"}