PHP WebShell

Текущая директория: /opt/BitGoJS/modules/bitgo/dist/test/v2/unit/tss

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.nockSendSignatureShare = nockSendSignatureShare;
exports.nockGetTxRequest = nockGetTxRequest;
exports.nockGetEnterprise = nockGetEnterprise;
exports.nockGetChallenges = nockGetChallenges;
exports.nockGetChallenge = nockGetChallenge;
exports.nockGetSigningKey = nockGetSigningKey;
exports.createWalletSignatures = createWalletSignatures;
const openpgp = require("openpgp");
const sdk_core_1 = require("@bitgo/sdk-core");
const common_1 = require("../internal/tssUtils/common");
const nock = require("nock");
async function nockSendSignatureShare(params, status = 200) {
    const { signatureShare, signerShare, tssType } = params;
    const transactions = (0, common_1.getRoute)(tssType);
    const requestBody = signerShare === undefined ? { signatureShare } : { signatureShare, signerShare };
    return nock('https://bitgo.fakeurl')
        .post(`/api/v2/wallet/${params.walletId}/txrequests/${params.txRequestId + transactions}/signatureshares`, requestBody)
        .reply(status, status === 200 ? (params.response ? params.response : params.signatureShare) : { error: 'some error' });
}
async function nockGetTxRequest(params) {
    const n = nock('https://bitgo.fakeurl').get(`/api/v2/wallet/${params.walletId}/txrequests?txRequestIds=${params.txRequestId}&latest=true`);
    if (params.times !== undefined) {
        return n.times(params.times).reply(200, params.response);
    }
    return n.reply(200, params.response);
}
async function nockGetEnterprise(params) {
    const n = nock('https://bitgo.fakeurl').get(`/api/v1/enterprise/${params.enterpriseId}`);
    if (params.times !== undefined) {
        return n.times(params.times).reply(200, params.response);
    }
    return n.reply(200, params.response);
}
async function nockGetChallenges(params) {
    return nock('https://bitgo.fakeurl')
        .get('/api/v2/wallet/' + params.walletId + '/challenges')
        .reply(200, params.response);
}
async function nockGetChallenge(params) {
    const n = nock('https://bitgo.fakeurl').post('/api/v2/wallet/' + params.walletId + '/txrequests/' + params.txRequestId + params.addendum + '/challenge');
    if (params.times !== undefined) {
        return n.times(params.times).reply(200, params.response);
    }
    return n.reply(200, params.response);
}
async function nockGetSigningKey(params) {
    const path = `/api/v2/enterprise/${params.enterpriseId}/user/${params.userId}/signingkey`;
    const n = nock('https://bitgo.fakeurl').get(path);
    if (params.times !== undefined) {
        return n.times(params.times).reply(200, params.response);
    }
    return n.reply(200, params.response);
}
async function createWalletSignatures(privateKeyArmored, publicKeyToCertArmoredUser, publicKeyToCertArmoredBackup, notations) {
    const userWalletSigArmored = await (0, sdk_core_1.createSharedDataProof)(privateKeyArmored, publicKeyToCertArmoredUser, notations);
    const backupWalletSigArmored = await (0, sdk_core_1.createSharedDataProof)(privateKeyArmored, publicKeyToCertArmoredBackup, notations);
    const certsUserKey = await openpgp.readKey({ armoredKey: userWalletSigArmored });
    const certsBackupKey = await openpgp.readKey({ armoredKey: backupWalletSigArmored });
    const mergedWalletKeys = new openpgp.PacketList();
    certsUserKey.toPacketList().forEach((packet) => mergedWalletKeys.push(packet));
    certsBackupKey.toPacketList().forEach((packet) => mergedWalletKeys.push(packet));
    // the underlying function only requires two arguments but the according .d.ts file for openpgp has the further
    // arguments marked as mandatory as well.
    // Once the following PR has been merged and released we no longer need the ts-ignore:
    // https://github.com/openpgpjs/openpgpjs/pull/1576
    // eslint-disable-next-line @typescript-eslint/ban-ts-comment
    // @ts-ignore
    return openpgp.armor(openpgp.enums.armor.publicKey, mergedWalletKeys.write());
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../../../test/v2/unit/tss/helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import * as openpgp from 'openpgp';\nimport { createSharedDataProof, SignatureShareRecord } from '@bitgo/sdk-core';\nimport { getRoute } from '../internal/tssUtils/common';\nimport * as nock from 'nock';\n\nexport async function nockSendSignatureShare(\n  params: {\n    walletId: string;\n    txRequestId: string;\n    signatureShare: any;\n    signerShare?: string;\n    response?: SignatureShareRecord;\n    tssType?: 'ecdsa' | 'eddsa';\n  },\n  status = 200\n): Promise<nock.Scope> {\n  const { signatureShare, signerShare, tssType } = params;\n  const transactions = getRoute(tssType);\n  const requestBody = signerShare === undefined ? { signatureShare } : { signatureShare, signerShare };\n\n  return nock('https://bitgo.fakeurl')\n    .post(\n      `/api/v2/wallet/${params.walletId}/txrequests/${params.txRequestId + transactions}/signatureshares`,\n      requestBody\n    )\n    .reply(\n      status,\n      status === 200 ? (params.response ? params.response : params.signatureShare) : { error: 'some error' }\n    );\n}\n\nexport async function nockGetTxRequest(params: {\n  walletId: string;\n  txRequestId: string;\n  response: any;\n  times?: number;\n}): Promise<nock.Scope> {\n  const n = nock('https://bitgo.fakeurl').get(\n    `/api/v2/wallet/${params.walletId}/txrequests?txRequestIds=${params.txRequestId}&latest=true`\n  );\n  if (params.times !== undefined) {\n    return n.times(params.times).reply(200, params.response);\n  }\n  return n.reply(200, params.response);\n}\nexport async function nockGetEnterprise(params: {\n  enterpriseId: string;\n  response: any;\n  times?: number;\n}): Promise<nock.Scope> {\n  const n = nock('https://bitgo.fakeurl').get(`/api/v1/enterprise/${params.enterpriseId}`);\n  if (params.times !== undefined) {\n    return n.times(params.times).reply(200, params.response);\n  }\n  return n.reply(200, params.response);\n}\n\nexport async function nockGetChallenges(params: { walletId: string; response: any }): Promise<nock.Scope> {\n  return nock('https://bitgo.fakeurl')\n    .get('/api/v2/wallet/' + params.walletId + '/challenges')\n    .reply(200, params.response);\n}\n\nexport async function nockGetChallenge(params: {\n  walletId: string;\n  txRequestId: string;\n  addendum: string;\n  response: any;\n  times?: number;\n}): Promise<nock.Scope> {\n  const n = nock('https://bitgo.fakeurl').post(\n    '/api/v2/wallet/' + params.walletId + '/txrequests/' + params.txRequestId + params.addendum + '/challenge'\n  );\n  if (params.times !== undefined) {\n    return n.times(params.times).reply(200, params.response);\n  }\n  return n.reply(200, params.response);\n}\n\nexport async function nockGetSigningKey(params: {\n  enterpriseId: string;\n  userId: string;\n  response: any;\n  times?: number;\n}): Promise<nock.Scope> {\n  const path = `/api/v2/enterprise/${params.enterpriseId}/user/${params.userId}/signingkey`;\n  const n = nock('https://bitgo.fakeurl').get(path);\n  if (params.times !== undefined) {\n    return n.times(params.times).reply(200, params.response);\n  }\n  return n.reply(200, params.response);\n}\nexport async function createWalletSignatures(\n  privateKeyArmored: string,\n  publicKeyToCertArmoredUser: string,\n  publicKeyToCertArmoredBackup: string,\n  notations: { name: string; value: string }[]\n): Promise<string> {\n  const userWalletSigArmored = await createSharedDataProof(privateKeyArmored, publicKeyToCertArmoredUser, notations);\n  const backupWalletSigArmored = await createSharedDataProof(\n    privateKeyArmored,\n    publicKeyToCertArmoredBackup,\n    notations\n  );\n\n  const certsUserKey = await openpgp.readKey({ armoredKey: userWalletSigArmored });\n  const certsBackupKey = await openpgp.readKey({ armoredKey: backupWalletSigArmored });\n\n  const mergedWalletKeys = new openpgp.PacketList();\n  certsUserKey.toPacketList().forEach((packet) => mergedWalletKeys.push(packet));\n  certsBackupKey.toPacketList().forEach((packet) => mergedWalletKeys.push(packet));\n\n  // the underlying function only requires two arguments but the according .d.ts file for openpgp has the further\n  // arguments marked as mandatory as well.\n  // Once the following PR has been merged and released we no longer need the ts-ignore:\n  // https://github.com/openpgpjs/openpgpjs/pull/1576\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore\n  return openpgp.armor(openpgp.enums.armor.publicKey, mergedWalletKeys.write());\n}\n"]}

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


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