PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getSignatureShareRoundOne = getSignatureShareRoundOne;
exports.getSignatureShareRoundTwo = getSignatureShareRoundTwo;
exports.getSignatureShareRoundThree = getSignatureShareRoundThree;
exports.verifyBitGoMessagesAndSignaturesRoundOne = verifyBitGoMessagesAndSignaturesRoundOne;
exports.verifyBitGoMessagesAndSignaturesRoundTwo = verifyBitGoMessagesAndSignaturesRoundTwo;
exports.getBitGoPartyGpgKey = getBitGoPartyGpgKey;
exports.getUserPartyGpgKey = getUserPartyGpgKey;
const utils_1 = require("../../utils");
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
const public_types_1 = require("@bitgo/public-types");
const assert_1 = __importDefault(require("assert"));
function partyIdToSignatureShareType(partyId) {
    (0, assert_1.default)(partyId === 0 || partyId === 1 || partyId === 2, 'Invalid partyId for MPCv2 signing');
    switch (partyId) {
        case 0:
            return utils_1.SignatureShareType.USER;
        case 1:
            return utils_1.SignatureShareType.BACKUP;
        case 2:
            return utils_1.SignatureShareType.BITGO;
    }
}
/**
 Helpers in this take care of all interaction with WP API's
**/
async function getSignatureShareRoundOne(round1Message, userGpgKey, partyId = 0, otherSignerPartyId = 2) {
    const serializedMessages = sdk_lib_mpc_1.DklsTypes.serializeMessages({
        broadcastMessages: [round1Message],
        p2pMessages: [],
    });
    const authEncBroadcastMessage = (await sdk_lib_mpc_1.DklsComms.encryptAndAuthOutgoingMessages(serializedMessages, [], // Broadcast message so doesn't need to encrypt to BitGo's GPG key
    [getUserPartyGpgKey(userGpgKey, partyId)])).broadcastMessages[0];
    // Share type expected by Wallet Platform's API
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(authEncBroadcastMessage.from));
    const share = {
        type: 'round1Input',
        data: {
            msg1: {
                from: authEncBroadcastMessage.from,
                message: authEncBroadcastMessage.payload.message,
                signature: authEncBroadcastMessage.payload.signature,
            },
        },
    };
    const serializedShare = JSON.stringify(share);
    return {
        from: partyIdToSignatureShareType(partyId),
        to: partyIdToSignatureShareType(otherSignerPartyId),
        share: serializedShare,
    };
}
async function getSignatureShareRoundTwo(userToBitGoMessages2, userToBitGoMessages3, userGpgKey, otherPartyGpgKey, partyId = 0, otherSignerPartyId = 2) {
    const userToBitGoEncryptedMsg2 = await sdk_lib_mpc_1.DklsComms.encryptAndAuthOutgoingMessages(sdk_lib_mpc_1.DklsTypes.serializeMessages(userToBitGoMessages2), [getBitGoPartyGpgKey(otherPartyGpgKey, otherSignerPartyId)], [getUserPartyGpgKey(userGpgKey, partyId)]);
    const userToBitGoEncryptedMsg3 = await sdk_lib_mpc_1.DklsComms.encryptAndAuthOutgoingMessages(sdk_lib_mpc_1.DklsTypes.serializeMessages(userToBitGoMessages3), [getBitGoPartyGpgKey(otherPartyGpgKey, otherSignerPartyId)], [getUserPartyGpgKey(userGpgKey, partyId)]);
    (0, assert_1.default)(userToBitGoEncryptedMsg2.p2pMessages.length, 'User to BitGo messages 2 not present.');
    (0, assert_1.default)(userToBitGoEncryptedMsg3.p2pMessages.length, 'User to BitGo messages 3 not present.');
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg2.p2pMessages[0].from));
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg2.p2pMessages[0].to));
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg3.p2pMessages[0].from));
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg3.p2pMessages[0].to));
    const share = {
        type: 'round2Input',
        data: {
            msg2: {
                from: userToBitGoEncryptedMsg2.p2pMessages[0].from,
                to: userToBitGoEncryptedMsg2.p2pMessages[0].to,
                encryptedMessage: userToBitGoEncryptedMsg2.p2pMessages[0].payload.encryptedMessage,
                signature: userToBitGoEncryptedMsg2.p2pMessages[0].payload.signature,
            },
            msg3: {
                from: userToBitGoEncryptedMsg3.p2pMessages[0].from,
                to: userToBitGoEncryptedMsg3.p2pMessages[0].to,
                encryptedMessage: userToBitGoEncryptedMsg3.p2pMessages[0].payload.encryptedMessage,
                signature: userToBitGoEncryptedMsg3.p2pMessages[0].payload.signature,
            },
        },
    };
    return {
        from: partyIdToSignatureShareType(partyId),
        to: partyIdToSignatureShareType(otherSignerPartyId),
        share: JSON.stringify(share),
    };
}
async function getSignatureShareRoundThree(userToBitGoMessages4, userGpgKey, bitgoGpgKey, partyId = 0, otherSignerPartyId = 2) {
    const userToBitGoEncryptedMsg4 = await sdk_lib_mpc_1.DklsComms.encryptAndAuthOutgoingMessages(sdk_lib_mpc_1.DklsTypes.serializeMessages(userToBitGoMessages4), [getBitGoPartyGpgKey(bitgoGpgKey, otherSignerPartyId)], [getUserPartyGpgKey(userGpgKey, partyId)]);
    (0, assert_1.default)(public_types_1.MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg4.broadcastMessages[0].from));
    if (!userToBitGoEncryptedMsg4.broadcastMessages[0].signatureR?.message) {
        throw Error('signatureR should be defined');
    }
    const share = {
        type: 'round3Input',
        data: {
            msg4: {
                from: userToBitGoEncryptedMsg4.broadcastMessages[0].from,
                message: userToBitGoEncryptedMsg4.broadcastMessages[0].payload.message,
                signature: userToBitGoEncryptedMsg4.broadcastMessages[0].payload.signature,
                signatureR: userToBitGoEncryptedMsg4.broadcastMessages[0].signatureR.message,
            },
        },
    };
    return {
        from: partyIdToSignatureShareType(partyId),
        to: partyIdToSignatureShareType(otherSignerPartyId),
        share: JSON.stringify(share),
    };
}
async function verifyBitGoMessagesAndSignaturesRoundOne(parsedSignatureShare, userGpgKey, bitgoGpgKey, partyId = 0) {
    return await sdk_lib_mpc_1.DklsComms.decryptAndVerifyIncomingMessages({
        p2pMessages: [
            {
                from: parsedSignatureShare.data.msg2.from,
                to: parsedSignatureShare.data.msg2.to,
                payload: {
                    encryptedMessage: parsedSignatureShare.data.msg2.encryptedMessage,
                    signature: parsedSignatureShare.data.msg2.signature,
                },
            },
        ],
        broadcastMessages: [
            {
                from: parsedSignatureShare.data.msg1.from,
                payload: {
                    message: parsedSignatureShare.data.msg1.message,
                    signature: parsedSignatureShare.data.msg1.signature,
                },
            },
        ],
    }, [getBitGoPartyGpgKey(bitgoGpgKey)], [getUserPartyGpgKey(userGpgKey, partyId)]);
}
async function verifyBitGoMessagesAndSignaturesRoundTwo(parsedSignatureShare, userGpgKey, bitgoGpgKey, partyId = 0) {
    return await sdk_lib_mpc_1.DklsComms.decryptAndVerifyIncomingMessages({
        p2pMessages: [
            {
                from: parsedSignatureShare.data.msg3.from,
                to: parsedSignatureShare.data.msg3.to,
                payload: {
                    encryptedMessage: parsedSignatureShare.data.msg3.encryptedMessage,
                    signature: parsedSignatureShare.data.msg3.signature,
                },
            },
        ],
        broadcastMessages: [],
    }, [getBitGoPartyGpgKey(bitgoGpgKey)], [getUserPartyGpgKey(userGpgKey, partyId)]);
}
function getBitGoPartyGpgKey(key, partyId = 2) {
    return {
        partyId: partyId,
        gpgKey: key.armor(),
    };
}
function getUserPartyGpgKey(key, partyId = 0) {
    return {
        partyId: partyId,
        gpgKey: key.privateKey,
    };
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsaMPCv2.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/ecdsa/ecdsaMPCv2.ts"],"names":[],"mappings":"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","sourcesContent":["import { SignatureShareRecord, SignatureShareType } from '../../utils';\nimport openpgp from 'openpgp';\nimport { DklsComms, DklsTypes } from '@bitgo/sdk-lib-mpc';\nimport {\n  MPCv2SignatureShareRound1Input,\n  MPCv2SignatureShareRound1Output,\n  MPCv2SignatureShareRound2Input,\n  MPCv2SignatureShareRound2Output,\n  MPCv2SignatureShareRound3Input,\n  MPCv2PartyFromStringOrNumber,\n} from '@bitgo/public-types';\nimport assert from 'assert';\n\nfunction partyIdToSignatureShareType(partyId: 0 | 1 | 2): SignatureShareType {\n  assert(partyId === 0 || partyId === 1 || partyId === 2, 'Invalid partyId for MPCv2 signing');\n  switch (partyId) {\n    case 0:\n      return SignatureShareType.USER;\n    case 1:\n      return SignatureShareType.BACKUP;\n    case 2:\n      return SignatureShareType.BITGO;\n  }\n}\n\n/**\n Helpers in this take care of all interaction with WP API's\n**/\n\nexport async function getSignatureShareRoundOne(\n  round1Message: DklsTypes.DeserializedBroadcastMessage,\n  userGpgKey: openpgp.SerializedKeyPair<string>,\n  partyId: 0 | 1 = 0,\n  otherSignerPartyId: 0 | 1 | 2 = 2\n): Promise<SignatureShareRecord> {\n  const serializedMessages = DklsTypes.serializeMessages({\n    broadcastMessages: [round1Message],\n    p2pMessages: [],\n  });\n  const authEncBroadcastMessage = (\n    await DklsComms.encryptAndAuthOutgoingMessages(\n      serializedMessages,\n      [], // Broadcast message so doesn't need to encrypt to BitGo's GPG key\n      [getUserPartyGpgKey(userGpgKey, partyId)]\n    )\n  ).broadcastMessages[0];\n  // Share type expected by Wallet Platform's API\n  assert(MPCv2PartyFromStringOrNumber.is(authEncBroadcastMessage.from));\n  const share: MPCv2SignatureShareRound1Input = {\n    type: 'round1Input',\n    data: {\n      msg1: {\n        from: authEncBroadcastMessage.from,\n        message: authEncBroadcastMessage.payload.message,\n        signature: authEncBroadcastMessage.payload.signature,\n      },\n    },\n  };\n  const serializedShare = JSON.stringify(share);\n  return {\n    from: partyIdToSignatureShareType(partyId),\n    to: partyIdToSignatureShareType(otherSignerPartyId),\n    share: serializedShare,\n  };\n}\n\nexport async function getSignatureShareRoundTwo(\n  userToBitGoMessages2: DklsTypes.DeserializedMessages,\n  userToBitGoMessages3: DklsTypes.DeserializedMessages,\n  userGpgKey: openpgp.SerializedKeyPair<string>,\n  otherPartyGpgKey: openpgp.Key,\n  partyId: 0 | 1 = 0,\n  otherSignerPartyId: 0 | 1 | 2 = 2\n): Promise<SignatureShareRecord> {\n  const userToBitGoEncryptedMsg2 = await DklsComms.encryptAndAuthOutgoingMessages(\n    DklsTypes.serializeMessages(userToBitGoMessages2),\n    [getBitGoPartyGpgKey(otherPartyGpgKey, otherSignerPartyId)],\n    [getUserPartyGpgKey(userGpgKey, partyId)]\n  );\n\n  const userToBitGoEncryptedMsg3 = await DklsComms.encryptAndAuthOutgoingMessages(\n    DklsTypes.serializeMessages(userToBitGoMessages3),\n    [getBitGoPartyGpgKey(otherPartyGpgKey, otherSignerPartyId)],\n    [getUserPartyGpgKey(userGpgKey, partyId)]\n  );\n  assert(userToBitGoEncryptedMsg2.p2pMessages.length, 'User to BitGo messages 2 not present.');\n  assert(userToBitGoEncryptedMsg3.p2pMessages.length, 'User to BitGo messages 3 not present.');\n  assert(MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg2.p2pMessages[0].from));\n  assert(MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg2.p2pMessages[0].to));\n  assert(MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg3.p2pMessages[0].from));\n  assert(MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg3.p2pMessages[0].to));\n  const share: MPCv2SignatureShareRound2Input = {\n    type: 'round2Input',\n    data: {\n      msg2: {\n        from: userToBitGoEncryptedMsg2.p2pMessages[0].from,\n        to: userToBitGoEncryptedMsg2.p2pMessages[0].to,\n        encryptedMessage: userToBitGoEncryptedMsg2.p2pMessages[0].payload.encryptedMessage,\n        signature: userToBitGoEncryptedMsg2.p2pMessages[0].payload.signature,\n      },\n      msg3: {\n        from: userToBitGoEncryptedMsg3.p2pMessages[0].from,\n        to: userToBitGoEncryptedMsg3.p2pMessages[0].to,\n        encryptedMessage: userToBitGoEncryptedMsg3.p2pMessages[0].payload.encryptedMessage,\n        signature: userToBitGoEncryptedMsg3.p2pMessages[0].payload.signature,\n      },\n    },\n  };\n  return {\n    from: partyIdToSignatureShareType(partyId),\n    to: partyIdToSignatureShareType(otherSignerPartyId),\n    share: JSON.stringify(share),\n  };\n}\n\nexport async function getSignatureShareRoundThree(\n  userToBitGoMessages4: DklsTypes.DeserializedMessages,\n  userGpgKey: openpgp.SerializedKeyPair<string>,\n  bitgoGpgKey: openpgp.Key,\n  partyId: 0 | 1 = 0,\n  otherSignerPartyId: 0 | 1 | 2 = 2\n): Promise<SignatureShareRecord> {\n  const userToBitGoEncryptedMsg4 = await DklsComms.encryptAndAuthOutgoingMessages(\n    DklsTypes.serializeMessages(userToBitGoMessages4),\n    [getBitGoPartyGpgKey(bitgoGpgKey, otherSignerPartyId)],\n    [getUserPartyGpgKey(userGpgKey, partyId)]\n  );\n  assert(MPCv2PartyFromStringOrNumber.is(userToBitGoEncryptedMsg4.broadcastMessages[0].from));\n  if (!userToBitGoEncryptedMsg4.broadcastMessages[0].signatureR?.message) {\n    throw Error('signatureR should be defined');\n  }\n  const share: MPCv2SignatureShareRound3Input = {\n    type: 'round3Input',\n    data: {\n      msg4: {\n        from: userToBitGoEncryptedMsg4.broadcastMessages[0].from,\n        message: userToBitGoEncryptedMsg4.broadcastMessages[0].payload.message,\n        signature: userToBitGoEncryptedMsg4.broadcastMessages[0].payload.signature,\n        signatureR: userToBitGoEncryptedMsg4.broadcastMessages[0].signatureR.message,\n      },\n    },\n  };\n  return {\n    from: partyIdToSignatureShareType(partyId),\n    to: partyIdToSignatureShareType(otherSignerPartyId),\n    share: JSON.stringify(share),\n  };\n}\n\nexport async function verifyBitGoMessagesAndSignaturesRoundOne(\n  parsedSignatureShare: MPCv2SignatureShareRound1Output,\n  userGpgKey: openpgp.SerializedKeyPair<string>,\n  bitgoGpgKey: openpgp.Key,\n  partyId: 0 | 1 = 0\n): Promise<DklsTypes.SerializedMessages> {\n  return await DklsComms.decryptAndVerifyIncomingMessages(\n    {\n      p2pMessages: [\n        {\n          from: parsedSignatureShare.data.msg2.from,\n          to: parsedSignatureShare.data.msg2.to,\n          payload: {\n            encryptedMessage: parsedSignatureShare.data.msg2.encryptedMessage,\n            signature: parsedSignatureShare.data.msg2.signature,\n          },\n        },\n      ],\n      broadcastMessages: [\n        {\n          from: parsedSignatureShare.data.msg1.from,\n          payload: {\n            message: parsedSignatureShare.data.msg1.message,\n            signature: parsedSignatureShare.data.msg1.signature,\n          },\n        },\n      ],\n    },\n    [getBitGoPartyGpgKey(bitgoGpgKey)],\n    [getUserPartyGpgKey(userGpgKey, partyId)]\n  );\n}\n\nexport async function verifyBitGoMessagesAndSignaturesRoundTwo(\n  parsedSignatureShare: MPCv2SignatureShareRound2Output,\n  userGpgKey: openpgp.SerializedKeyPair<string>,\n  bitgoGpgKey: openpgp.Key,\n  partyId: 0 | 1 = 0\n): Promise<DklsTypes.SerializedMessages> {\n  return await DklsComms.decryptAndVerifyIncomingMessages(\n    {\n      p2pMessages: [\n        {\n          from: parsedSignatureShare.data.msg3.from,\n          to: parsedSignatureShare.data.msg3.to,\n          payload: {\n            encryptedMessage: parsedSignatureShare.data.msg3.encryptedMessage,\n            signature: parsedSignatureShare.data.msg3.signature,\n          },\n        },\n      ],\n      broadcastMessages: [],\n    },\n    [getBitGoPartyGpgKey(bitgoGpgKey)],\n    [getUserPartyGpgKey(userGpgKey, partyId)]\n  );\n}\n\nexport function getBitGoPartyGpgKey(key: openpgp.Key, partyId: 0 | 1 | 2 = 2): DklsTypes.PartyGpgKey {\n  return {\n    partyId: partyId,\n    gpgKey: key.armor(),\n  };\n}\n\nexport function getUserPartyGpgKey(key: openpgp.SerializedKeyPair<string>, partyId: 0 | 1 = 0): DklsTypes.PartyGpgKey {\n  return {\n    partyId: partyId,\n    gpgKey: key.privateKey,\n  };\n}\n"]}

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


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