@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.
- package/CHANGELOG.md +151 -0
- package/dist/src/account-lib/baseCoin/enum.d.ts +3 -1
- package/dist/src/account-lib/baseCoin/enum.d.ts.map +1 -1
- package/dist/src/account-lib/baseCoin/enum.js +5 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +33 -10
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +551 -141
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts +2 -2
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/rangeproof.js +3 -3
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +70 -55
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts +0 -3
- package/dist/src/account-lib/mpc/tss/eddsa/types.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/eddsa/types.js +1 -1
- package/dist/src/bitgo/baseCoin/baseCoin.d.ts +16 -0
- package/dist/src/bitgo/baseCoin/baseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/baseCoin.js +15 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts +18 -2
- package/dist/src/bitgo/baseCoin/iBaseCoin.d.ts.map +1 -1
- package/dist/src/bitgo/baseCoin/iBaseCoin.js +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
- package/dist/src/bitgo/environments.d.ts +7 -0
- package/dist/src/bitgo/environments.d.ts.map +1 -1
- package/dist/src/bitgo/environments.js +17 -3
- package/dist/src/bitgo/keychain/iKeychains.d.ts +1 -0
- package/dist/src/bitgo/keychain/iKeychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/iKeychains.js +1 -1
- package/dist/src/bitgo/keychain/keychains.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/keychains.js +30 -24
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts +124 -89
- package/dist/src/bitgo/keychain/ovcJsonCodec.d.ts.map +1 -1
- package/dist/src/bitgo/keychain/ovcJsonCodec.js +31 -24
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts +1 -0
- package/dist/src/bitgo/pendingApproval/iPendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/iPendingApproval.js +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.d.ts.map +1 -1
- package/dist/src/bitgo/pendingApproval/pendingApproval.js +12 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts +11 -1
- package/dist/src/bitgo/staking/iStakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/iStakingWallet.js +1 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts +7 -1
- package/dist/src/bitgo/staking/stakingWallet.d.ts.map +1 -1
- package/dist/src/bitgo/staking/stakingWallet.js +9 -1
- package/dist/src/bitgo/tss/common.d.ts +15 -4
- package/dist/src/bitgo/tss/common.d.ts.map +1 -1
- package/dist/src/bitgo/tss/common.js +26 -11
- package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts +11 -8
- package/dist/src/bitgo/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/ecdsa/ecdsa.js +36 -33
- package/dist/src/bitgo/tss/ecdsa/types.d.ts +2 -2
- package/dist/src/bitgo/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/bitgo/tss/ecdsa/types.js +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts +4 -3
- package/dist/src/bitgo/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/tss/eddsa/eddsa.js +16 -5
- package/dist/src/bitgo/tss/types.d.ts +19 -0
- package/dist/src/bitgo/tss/types.d.ts.map +1 -1
- package/dist/src/bitgo/tss/types.js +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts +53 -12
- package/dist/src/bitgo/utils/tss/baseTSSUtils.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTSSUtils.js +62 -9
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts +99 -8
- package/dist/src/bitgo/utils/tss/baseTypes.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/baseTypes.js +26 -2
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +44 -5
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +229 -86
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts +18 -5
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/eddsa/eddsa.js +76 -22
- package/dist/src/bitgo/wallet/iWallet.d.ts +12 -1
- package/dist/src/bitgo/wallet/iWallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/iWallet.js +1 -1
- package/dist/src/bitgo/wallet/wallet.d.ts +10 -2
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +108 -14
- package/dist/src/index.d.ts +4 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -2
- package/dist/src/openssl/index.d.ts +4 -1
- package/dist/src/openssl/index.d.ts.map +1 -1
- package/dist/src/openssl/index.js +7 -12
- package/dist/tsconfig.tsbuildinfo +1 -8272
- package/package.json +8 -7
- package/dist/src/openssl/openssl.d.ts +0 -12
- package/dist/src/openssl/openssl.d.ts.map +0 -1
- package/dist/src/openssl/openssl.js +0 -48
- package/dist/src/openssl/opensslbytes.d.ts +0 -4
- package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
- 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
|
|
121
|
+
* @param paillierModulus
|
|
103
122
|
*/
|
|
104
|
-
async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, requestType,
|
|
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
|
-
|
|
109
|
-
addendum = '/transactions/' + index;
|
|
110
|
-
}
|
|
127
|
+
addendum = '/transactions/' + index;
|
|
111
128
|
break;
|
|
112
129
|
case utils_1.RequestType.message:
|
|
113
|
-
|
|
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 {
|
|
3
|
-
import { SignatureShareRecord, SignatureShareType
|
|
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:
|
|
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<
|
|
31
|
+
* @returns {Promise<SignConvertStep2Response>}
|
|
32
32
|
*/
|
|
33
|
-
export declare function createUserGammaAndMuShare(wShare: WShare, aShare: AShare): Promise<
|
|
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
|
|
106
|
-
* @param commonKeyChain - common
|
|
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":";AACA,OAAO,EACL,
|
|
1
|
+
{"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":";AACA,OAAO,EACL,MAAM,EACN,MAAM,EACN,WAAW,EACX,gCAAgC,EAChC,iBAAiB,EACjB,MAAM,EACN,eAAe,EACf,MAAM,EACN,QAAQ,EACR,MAAM,EACN,MAAM,EACN,iBAAiB,EACjB,kBAAkB,EAClB,aAAa,EACb,SAAS,EACT,cAAc,EAEd,SAAS,EACT,MAAM,EACN,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAoB,WAAW,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACtG,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EACL,MAAM,EACN,OAAO,EAGP,wBAAwB,EACxB,MAAM,EACP,MAAM,0CAA0C,CAAC;AAKlD,OAAO,KAAK,GAAG,MAAM,SAAS,CAAC;AAE/B,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAK9B;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,iBAAiB,EAAE,EACrC,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC,WAAW,CAAC,CA+CtB;AAED;;;;;GAKG;AACH,wBAAsB,mBAAmB,CACvC,MAAM,EAAE,oBAAoB,EAC5B,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,SAAS,CAAC,CASpB;AAED;;;;;GAKG;AACH,wBAAsB,yBAAyB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAQjH;AAED;;;;GAIG;AACH,wBAAsB,8BAA8B,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,gCAAgC,CAAC,CAW9G;AAED;;;;;;GAMG;AACH,wBAAsB,wBAAwB,CAC5C,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,IAAI,GAAE,IAAoC,GACzC,OAAO,CAAC,cAAc,CAAC,CASzB;AAED,oBAAY,QAAQ,GAAG;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,gBAAgB,CAAA;CAAE,CAAC;AAEjF;;;;;;;;;;;;;;GAcG;AACH,wBAAsB,gBAAgB,CACpC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,aAAa,EACxB,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,EACjC,WAAW,CAAC,EAAE,MAAM,EACpB,QAAQ,CAAC,EAAE,MAAM,EACjB,iBAAiB,CAAC,EAAE,MAAM,EAC1B,WAAW,CAAC,EAAE,MAAM,EACpB,gBAAgB,CAAC,EAAE,MAAM,GACxB,OAAO,CAAC,kBAAkB,CAAC,CA+D7B;AAED;;;;;;;GAOG;AACH,wBAAsB,yBAAyB,CAC7C,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,iBAAiB,EAC5B,WAAW,EAAE,WAAW,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAkC7B;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,aAAa,CACjC,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,MAAM,EACtB,uBAAuB,EAAE,MAAM,EAC/B,YAAY,EAAE,GAAG,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAC3C,aAAa,UAAO,GACnB,OAAO,CAAC,eAAe,CAAC,CAmC1B;AAED;;;;;;GAMG;AACH,wBAAsB,0BAA0B,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,eAAe,CAAC,CAUhG;AAED;;;;;GAKG;AACH,wBAAsB,aAAa,CAAC,eAAe,EAAE,iBAAiB,EAAE,aAAa,UAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CA0B7G;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM,CAE3D;AAED,eAAO,MAAM,SAAS,MAAM,CAAC;AAC7B,eAAO,MAAM,kBAAkB,MAAM,CAAC;AAoBtC;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,oBAAoB,GAAG,MAAM,CA4B/D;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB,CAYjE;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,oBAAoB,GAAG,MAAM,CAmE/D;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB,CA4BjE;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,oBAAoB,GAAG,OAAO,CAkDjE;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,oBAAoB,CAsBnE;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,oBAAoB,GAAG,MAAM,CAU/D;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB,CAMjE;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,oBAAoB,GAAG;IAAE,MAAM,EAAE,cAAc,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAQpG;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GAAG,oBAAoB,CAM9F;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,oBAAoB,GAAG,cAAc,CAU/E;AAED;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,oBAAoB,CAMtG;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,oBAAoB,GAAG,SAAS,CAU7E;AAED;;;;;;GAMG;AACH,wBAAgB,qBAAqB,CACnC,KAAK,EAAE,cAAc,EACrB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,MAAM,GACrB,oBAAoB,CAMtB;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB,CAYjE;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,oBAAoB,GAAG,MAAM,CAqB/D;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB,CAMjE;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,oBAAoB,GAAG,MAAM,CAY/D;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,GAAG,MAAM,CAWpF;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,MAAM,GAAG,kBAAkB,CAWzE;AAED;;;GAGG;AACH,wBAAsB,qBAAqB,CAAC,MAAM,EAAE;IAClD,eAAe,EAAE,GAAG,CAAC,GAAG,CAAC;IACzB,QAAQ,EAAE,GAAG,CAAC,GAAG,CAAC;IAClB,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,CAahB"}
|