PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-core/dist/src/bitgo/tss

Просмотр файла: common.js

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getTxRequest = getTxRequest;
exports.sendSignatureShare = sendSignatureShare;
exports.sendSignatureShareV2 = sendSignatureShareV2;
exports.sendTxRequest = sendTxRequest;
exports.exchangeEddsaCommitments = exchangeEddsaCommitments;
exports.commonVerifyWalletSignature = commonVerifyWalletSignature;
exports.getTxRequestChallenge = getTxRequestChallenge;
const assert_1 = __importDefault(require("assert"));
const utils_1 = require("../utils");
const debug = require('debug')('bitgo:tss:common');
/**
 * Gets the latest Tx Request by id
 *
 * @param {BitGoBase} bitgo - the bitgo instance
 * @param {String} walletId - the wallet id
 * @param {String} txRequestId - the txRequest id
 * @param {IRequestTracer} reqId - the request tracer request id
 * @returns {Promise<TxRequest>}
 */
async function getTxRequest(bitgo, walletId, txRequestId, reqId) {
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    const txRequestRes = await bitgo
        .get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))
        .query({ txRequestIds: txRequestId, latest: 'true' })
        .retry(3)
        .result();
    if (txRequestRes.txRequests.length <= 0) {
        throw new Error(`Unable to find TxRequest with id ${txRequestId}`);
    }
    return txRequestRes.txRequests[0];
}
/**
 * Sends a Signature Share
 *
 * @param {BitGoBase} bitgo - the bitgo instance
 * @param {String} walletId - the wallet id  *
 * @param {String} txRequestId - the txRequest Id
 * @param {SignatureShareRecord} signatureShare - a Signature Share
 * @param requestType - The type of request being submitted (either tx or message for signing)
 * @param signerShare
 * @param mpcAlgorithm
 * @param apiMode
 * @param {IRequestTracer} reqId - the request tracer request id
 * @returns {Promise<SignatureShareRecord>} - a Signature Share
 */
async function sendSignatureShare(bitgo, walletId, txRequestId, signatureShare, requestType, signerShare, mpcAlgorithm = 'eddsa', apiMode = 'lite', userPublicGpgKey, reqId) {
    let addendum = '';
    switch (requestType) {
        case utils_1.RequestType.tx:
            if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {
                addendum = '/transactions/0';
            }
            break;
        case utils_1.RequestType.message:
            if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {
                addendum = '/messages/0';
            }
            break;
    }
    const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/signatureshares';
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    return bitgo
        .post(bitgo.url(urlPath, 2))
        .send({
        signatureShare,
        signerShare,
        userPublicGpgKey,
    })
        .result();
}
/**
 * Sends a Signature Share using the sign txRequest route
 *
 * @param {BitGoBase} bitgo - the bitgo instance
 * @param {String} walletId - the wallet id  *
 * @param {String} txRequestId - the txRequest Id
 * @param signatureShares
 * @param requestType - The type of request being submitted (either tx or message for signing)
 * @param signerShare
 * @param mpcAlgorithm
 * @param multisigTypeVersion
 * @param signerGpgPublicKey
 * @param reqId
 * @returns {Promise<SignatureShareRecord>} - a Signature Share
 */
async function sendSignatureShareV2(bitgo, walletId, txRequestId, signatureShares, requestType, mpcAlgorithm, signerGpgPublicKey, signerShare, multisigTypeVersion, reqId) {
    const addendum = requestType === utils_1.RequestType.tx ? '/transactions/0' : '/messages/0';
    const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/sign';
    let type = '';
    if (multisigTypeVersion === 'MPCv2' && mpcAlgorithm === 'ecdsa') {
        type = 'ecdsaMpcV2';
    }
    else if (multisigTypeVersion === undefined && mpcAlgorithm === 'eddsa') {
        type = 'eddsaMpcV1';
    }
    const requestBody = {
        type,
        signatureShares,
        signerShare,
        signerGpgPublicKey,
    };
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    let attempts = 0;
    const maxAttempts = 3;
    while (attempts < maxAttempts) {
        try {
            return await bitgo.post(bitgo.url(urlPath, 2)).send(requestBody).result();
        }
        catch (err) {
            if (err?.status === 429) {
                const sleepTime = 1000 * (attempts + 1);
                debug(`MPC Signing rate limit error - retrying in ${sleepTime / 1000} seconds`);
                // sleep for a bit before retrying
                await new Promise((resolve) => setTimeout(resolve, sleepTime));
                attempts++;
            }
            else {
                throw err;
            }
        }
    }
    return await bitgo.post(bitgo.url(urlPath, 2)).send(requestBody).result();
}
/**
 * Sends a Transaction Request for broadcast once signing is complete
 *
 * @param {BitGoBase} bitgo - the bitgo instance
 * @param {String} walletId - the wallet id  *
 * @param {String} txRequestId - the txRequest Id
 * @param requestType - The type of request being submitted (either tx or message for signing)
 * @param {IRequestTracer} reqId - request tracer request id
 * @returns {Promise<SignatureShareRecord>} - a Signature Share
 */
async function sendTxRequest(bitgo, walletId, txRequestId, requestType, reqId) {
    const addendum = requestType === utils_1.RequestType.tx ? '/transactions/0' : '/messages/0';
    const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/send';
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    return bitgo.post(bitgo.url(urlPath, 2)).send().result();
}
/**
 * Sends the client commitment and encrypted signer share to the server, getting back the server commitment
 * @param {BitGoBase} bitgo - the bitgo instance
 * @param {string} walletId - the wallet id
 * @param {string} txRequestId - the txRequest Id
 * @param {CommitmentShareRecord} commitmentShare - the client commitment share
 * @param {EncryptedSignerShareRecord} encryptedSignerShare - the client encrypted signer share
 * @param {string} [apiMode] - the txRequest api mode (full or lite) - defaults to lite
 * @param {IRequestTracer} reqId - the request tracer request Id
 * @returns {Promise<ExchangeCommitmentResponse>} - the server commitment share
 */
async function exchangeEddsaCommitments(bitgo, walletId, txRequestId, commitmentShare, encryptedSignerShare, apiMode = 'lite', reqId) {
    let addendum = '';
    if (apiMode === 'full') {
        addendum = '/transactions/0';
    }
    const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/commit';
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    return await bitgo.post(bitgo.url(urlPath, 2)).send({ commitmentShare, encryptedSignerShare }).result();
}
/**
 * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the
 * expected common keychain as well as the expected user and backup key ids
 */
async function commonVerifyWalletSignature(params) {
    const { walletSignature, bitgoPub, commonKeychain, userKeyId, backupKeyId } = params;
    // By ensuring that the fingerprints of the walletSignature and the bitgoPub are different and that any of the results
    // from calling verifyPrimaryUser is valid we know that the signature was actually produced by the private key
    // belonging to the bitgoPub.
    if (walletSignature.keyPacket.getFingerprint() === bitgoPub.keyPacket.getFingerprint()) {
        throw new Error('Invalid HSM GPG signature');
    }
    const verificationResult = await (0, utils_1.verifyPrimaryUserWrapper)(walletSignature, bitgoPub, false);
    const isValid = verificationResult.some((result) => result.valid);
    if (!isValid) {
        throw new Error('Invalid HSM GPG signature');
    }
    const primaryUser = await walletSignature.getPrimaryUser();
    // eslint-disable-next-line @typescript-eslint/ban-ts-comment
    // @ts-ignore the rawNotations property is missing from the type but it actually exists
    const rawNotations = primaryUser.user.otherCertifications[0].rawNotations;
    (0, assert_1.default)(rawNotations.length === 5, 'invalid wallet signatures');
    (0, assert_1.default)(commonKeychain === Buffer.from(rawNotations[0].value).toString(), 'wallet signature does not match common keychain');
    (0, assert_1.default)(userKeyId === Buffer.from(rawNotations[1].value).toString(), `wallet signature does not match user key id`);
    (0, assert_1.default)(backupKeyId === Buffer.from(rawNotations[2].value).toString(), 'wallet signature does not match backup key id');
    return rawNotations;
}
/**
 * Gets challenge for a tx request from BitGo
 * supports Message and regular Transaction
 * @param bitgo
 * @param walletId
 * @param txRequestId
 * @param index
 * @param requestType
 * @param paillierModulus
 * @param reqId
 */
async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, requestType, paillierModulus, reqId) {
    let addendum = '';
    switch (requestType) {
        case utils_1.RequestType.tx:
            addendum = '/transactions/' + index;
            break;
        case utils_1.RequestType.message:
            addendum = '/messages/' + index;
            break;
    }
    const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';
    const reqTracer = reqId || new utils_1.RequestTracer();
    bitgo.setRequestTracer(reqTracer);
    return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();
}
//# 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  RequestTracer,\n} from '../utils';\nimport { IRequestTracer } from '../../api';\n\nconst debug = require('debug')('bitgo:tss:common');\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 * @param {IRequestTracer} reqId - the request tracer request id\n * @returns {Promise<TxRequest>}\n */\nexport async function getTxRequest(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  reqId?: IRequestTracer\n): Promise<TxRequest> {\n  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\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 * @param {IRequestTracer} reqId - the request tracer request id\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  reqId?: IRequestTracer\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  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\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 a Signature Share using the sign txRequest route\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param signatureShares\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param signerShare\n * @param mpcAlgorithm\n * @param multisigTypeVersion\n * @param signerGpgPublicKey\n * @param reqId\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendSignatureShareV2(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  signatureShares: SignatureShareRecord[],\n  requestType: RequestType,\n  mpcAlgorithm: 'eddsa' | 'ecdsa',\n  signerGpgPublicKey: string,\n  signerShare?: string,\n  multisigTypeVersion?: 'MPCv2' | undefined,\n  reqId?: IRequestTracer\n): Promise<TxRequest> {\n  const addendum = requestType === RequestType.tx ? '/transactions/0' : '/messages/0';\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/sign';\n  let type = '';\n  if (multisigTypeVersion === 'MPCv2' && mpcAlgorithm === 'ecdsa') {\n    type = 'ecdsaMpcV2';\n  } else if (multisigTypeVersion === undefined && mpcAlgorithm === 'eddsa') {\n    type = 'eddsaMpcV1';\n  }\n  const requestBody = {\n    type,\n    signatureShares,\n    signerShare,\n    signerGpgPublicKey,\n  };\n  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\n\n  let attempts = 0;\n  const maxAttempts = 3;\n\n  while (attempts < maxAttempts) {\n    try {\n      return await bitgo.post(bitgo.url(urlPath, 2)).send(requestBody).result();\n    } catch (err) {\n      if (err?.status === 429) {\n        const sleepTime = 1000 * (attempts + 1);\n        debug(`MPC Signing rate limit error - retrying in ${sleepTime / 1000} seconds`);\n        // sleep for a bit before retrying\n        await new Promise((resolve) => setTimeout(resolve, sleepTime));\n        attempts++;\n      } else {\n        throw err;\n      }\n    }\n  }\n  return await bitgo.post(bitgo.url(urlPath, 2)).send(requestBody).result();\n}\n\n/**\n * Sends a Transaction Request for broadcast once signing is complete\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param {IRequestTracer} reqId - request tracer request id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendTxRequest(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  requestType: RequestType,\n  reqId?: IRequestTracer\n): Promise<TxRequest> {\n  const addendum = requestType === RequestType.tx ? '/transactions/0' : '/messages/0';\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/send';\n  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\n  return bitgo.post(bitgo.url(urlPath, 2)).send().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 * @param {IRequestTracer} reqId - the request tracer request Id\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  reqId?: IRequestTracer\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  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\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 * @param reqId\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  paillierModulus: string,\n  reqId?: IRequestTracer\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  const reqTracer = reqId || new RequestTracer();\n  bitgo.setRequestTracer(reqTracer);\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({ paillierModulus }).result();\n}\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!