PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-core/dist/src/bitgo/utils/tss/ecdsa/SMC

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.MPCv2SMCUtils = void 0;
const assert_1 = __importDefault(require("assert"));
const public_types_1 = require("@bitgo/public-types");
const ecdsaMPCv2_1 = require("../ecdsaMPCv2");
const __1 = require("../../../..");
const ecdsaMPCv2KeyGenSender_1 = require("../ecdsaMPCv2KeyGenSender");
class MPCv2SMCUtils {
    constructor(bitgo, baseCoin) {
        this.bitgo = bitgo;
        this.baseCoin = baseCoin;
        this.MPCv2Utils = new ecdsaMPCv2_1.EcdsaMPCv2Utils(bitgo, baseCoin);
    }
    async keyGenRound1(enterprise, payload) {
        return this.keyGenRound1BySender((0, ecdsaMPCv2KeyGenSender_1.KeyGenSenderForEnterprise)(this.bitgo, enterprise), payload);
    }
    async keyGenRound2(enterprise, payload) {
        return this.keyGenRound2BySender((0, ecdsaMPCv2KeyGenSender_1.KeyGenSenderForEnterprise)(this.bitgo, enterprise), payload);
    }
    async keyGenRound3(enterprise, payload) {
        return this.keyGenRound3BySender((0, ecdsaMPCv2KeyGenSender_1.KeyGenSenderForEnterprise)(this.bitgo, enterprise), payload);
    }
    async keyGenRound1BySender(senderFn, payload) {
        (0, assert_1.default)(payload.state === public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound1Data, `Invalid state for round 1, expected: ${public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound1Data}, got: ${payload.state}`);
        (0, __1.decodeOrElse)(public_types_1.OVC2ToBitgoRound1Payload.name, public_types_1.OVC2ToBitgoRound1Payload, payload, (errors) => {
            throw new Error(`error(s) parsing payload: ${errors}`);
        });
        const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
        const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
        const userGpgPublicKey = ovc1.gpgPubKey;
        const backupGpgPublicKey = ovc2.gpgPubKey;
        const messages = { p2pMessages: [], broadcastMessages: [ovc1.ovcMsg1, ovc2.ovcMsg1] };
        const result = await this.MPCv2Utils.sendKeyGenerationRound1BySender(senderFn, userGpgPublicKey, backupGpgPublicKey, messages);
        const response = {
            state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1Round2Data,
            tssVersion: payload.tssVersion,
            walletType: payload.walletType,
            coin: payload.coin,
            ovc: payload.ovc,
            platform: {
                walletGpgPubKeySigs: result.walletGpgPubKeySigs,
                sessionId: result.sessionId,
                bitgoMsg1: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg1),
                ovc: {
                    [public_types_1.OVCIndexEnum.ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },
                    [public_types_1.OVCIndexEnum.TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },
                },
            },
        };
        return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round1Response.name, public_types_1.BitgoToOVC1Round1Response, response, (errors) => {
            throw new Error(`error(s) parsing response: ${errors}`);
        });
    }
    async keyGenRound2BySender(senderFn, payload) {
        (0, assert_1.default)(payload.state === public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound2Data, `Invalid state for round 2, expected: ${public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound2Data}, got: ${payload.state}`);
        (0, __1.decodeOrElse)(public_types_1.OVC2ToBitgoRound2Payload.name, public_types_1.OVC2ToBitgoRound2Payload, payload, (errors) => {
            throw new Error(`error(s) parsing payload: ${errors}`);
        });
        const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
        const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
        const sessionId = payload.platform.sessionId;
        const messages = { p2pMessages: [ovc1.ovcToBitgoMsg2, ovc2.ovcToBitgoMsg2], broadcastMessages: [] };
        const result = await this.MPCv2Utils.sendKeyGenerationRound2BySender(senderFn, sessionId, messages);
        const response = {
            state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1Round3aData,
            tssVersion: payload.tssVersion,
            walletType: payload.walletType,
            coin: payload.coin,
            ovc: payload.ovc,
            platform: {
                ...payload.platform,
                sessionId: result.sessionId,
                bitgoCommitment2: result.bitgoCommitment2,
                ovc: {
                    [public_types_1.OVCIndexEnum.ONE]: {
                        ...payload.platform.ovc[public_types_1.OVCIndexEnum.ONE],
                        bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg3),
                    },
                    [public_types_1.OVCIndexEnum.TWO]: {
                        ...payload.platform.ovc[public_types_1.OVCIndexEnum.TWO],
                        bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg3),
                    },
                },
            },
        };
        return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round2Response.name, public_types_1.BitgoToOVC1Round2Response, response, (errors) => {
            throw new Error(`error(s) parsing response: ${errors}`);
        });
    }
    async keyGenRound3BySender(senderFn, payload) {
        (0, assert_1.default)(payload.state === public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound3Data, `Invalid state for round 3, expected: ${public_types_1.KeyCreationMPCv2StateEnum.WaitingForBitgoRound3Data}, got: ${payload.state}`);
        (0, __1.decodeOrElse)(public_types_1.OVC1ToBitgoRound3Payload.name, public_types_1.OVC1ToBitgoRound3Payload, payload, (errors) => {
            throw new Error(`error(s) parsing payload: ${errors}`);
        });
        const ovc1 = payload.ovc[public_types_1.OVCIndexEnum.ONE];
        const ovc2 = payload.ovc[public_types_1.OVCIndexEnum.TWO];
        const sessionId = payload.platform.sessionId;
        const messages = {
            p2pMessages: [ovc1.ovcToBitgoMsg3, ovc2.ovcToBitgoMsg3],
            broadcastMessages: [ovc1.ovcMsg4, ovc2.ovcMsg4],
        };
        const result = await this.MPCv2Utils.sendKeyGenerationRound3BySender(senderFn, sessionId, messages);
        const keychains = this.baseCoin.keychains();
        const bitgoKeychain = await keychains.add({
            source: 'bitgo',
            keyType: 'tss',
            commonKeychain: result.commonKeychain,
            isMPCv2: true,
        });
        const response = {
            state: public_types_1.KeyCreationMPCv2StateEnum.WaitingForOVC1GenerateKey,
            bitGoKeyId: bitgoKeychain.id,
            tssVersion: payload.tssVersion,
            walletType: payload.walletType,
            coin: payload.coin,
            ovc: payload.ovc,
            platform: {
                ...payload.platform,
                commonKeychain: result.commonKeychain,
                bitgoMsg4: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg4),
            },
        };
        return (0, __1.decodeOrElse)(public_types_1.BitgoToOVC1Round3Response.name, public_types_1.BitgoToOVC1Round3Response, response, (errors) => {
            throw new Error(`error(s) parsing response: ${errors}`);
        });
    }
    async uploadClientKeys(bitgoKeyId, userCommonKeychain, backupCommonKeychain) {
        (0, assert_1.default)(userCommonKeychain === backupCommonKeychain, 'Common keychain mismatch between the user and backup keychains');
        const keychains = this.baseCoin.keychains();
        const bitgoKeychain = await keychains.get({ id: bitgoKeyId });
        (0, assert_1.default)(bitgoKeychain, 'Keychain not found');
        (0, assert_1.default)(bitgoKeychain.source === 'bitgo', 'The keychain is not a BitGo keychain');
        (0, assert_1.default)(bitgoKeychain.type === 'tss', 'BitGo keychain is not a TSS keychain');
        (0, assert_1.default)(bitgoKeychain.commonKeychain, 'BitGo keychain does not have a common keychain');
        (0, assert_1.default)(bitgoKeychain.commonKeychain === userCommonKeychain, 'Common keychain mismatch between the OVCs and BitGo');
        const userKeychainPromise = keychains.add({
            source: 'user',
            keyType: 'tss',
            commonKeychain: userCommonKeychain,
            isMPCv2: true,
        });
        const backupKeychainPromise = keychains.add({
            source: 'backup',
            keyType: 'tss',
            commonKeychain: backupCommonKeychain,
            isMPCv2: true,
        });
        const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);
        return { userKeychain, backupKeychain, bitgoKeychain };
    }
}
exports.MPCv2SMCUtils = MPCv2SMCUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../src/bitgo/utils/tss/ecdsa/SMC/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport {\n  BitgoToOVC1Round1Response,\n  BitgoToOVC1Round2Response,\n  BitgoToOVC1Round3Response,\n  KeyCreationMPCv2StateEnum,\n  MPCv2KeyGenRound1Response,\n  MPCv2KeyGenRound2Response,\n  MPCv2KeyGenRound3Response,\n  OVC1ToBitgoRound3Payload,\n  OVC2ToBitgoRound1Payload,\n  OVC2ToBitgoRound2Payload,\n  OVCIndexEnum,\n} from '@bitgo/public-types';\nimport { IBaseCoin } from '../../../../baseCoin';\nimport { BitGoBase } from '../../../../bitgoBase';\nimport { EcdsaMPCv2Utils } from '../ecdsaMPCv2';\nimport { decodeOrElse, Keychain } from '../../../..';\nimport { EcdsaMPCv2KeyGenSendFn, KeyGenSenderForEnterprise } from '../ecdsaMPCv2KeyGenSender';\n\nexport class MPCv2SMCUtils {\n  private MPCv2Utils: EcdsaMPCv2Utils;\n\n  constructor(private bitgo: BitGoBase, private baseCoin: IBaseCoin) {\n    this.MPCv2Utils = new EcdsaMPCv2Utils(bitgo, baseCoin);\n  }\n\n  public async keyGenRound1(enterprise: string, payload: OVC2ToBitgoRound1Payload): Promise<BitgoToOVC1Round1Response> {\n    return this.keyGenRound1BySender(KeyGenSenderForEnterprise(this.bitgo, enterprise), payload);\n  }\n\n  public async keyGenRound2(enterprise: string, payload: OVC2ToBitgoRound2Payload): Promise<BitgoToOVC1Round2Response> {\n    return this.keyGenRound2BySender(KeyGenSenderForEnterprise(this.bitgo, enterprise), payload);\n  }\n\n  public async keyGenRound3(enterprise: string, payload: OVC1ToBitgoRound3Payload): Promise<BitgoToOVC1Round3Response> {\n    return this.keyGenRound3BySender(KeyGenSenderForEnterprise(this.bitgo, enterprise), payload);\n  }\n\n  public async keyGenRound1BySender(\n    senderFn: EcdsaMPCv2KeyGenSendFn<MPCv2KeyGenRound1Response>,\n    payload: OVC2ToBitgoRound1Payload\n  ): Promise<BitgoToOVC1Round1Response> {\n    assert(\n      payload.state === KeyCreationMPCv2StateEnum.WaitingForBitgoRound1Data,\n      `Invalid state for round 1, expected: ${KeyCreationMPCv2StateEnum.WaitingForBitgoRound1Data}, got: ${payload.state}`\n    );\n    decodeOrElse(OVC2ToBitgoRound1Payload.name, OVC2ToBitgoRound1Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const userGpgPublicKey = ovc1.gpgPubKey;\n    const backupGpgPublicKey = ovc2.gpgPubKey;\n    const messages = { p2pMessages: [], broadcastMessages: [ovc1.ovcMsg1, ovc2.ovcMsg1] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound1BySender(\n      senderFn,\n      userGpgPublicKey,\n      backupGpgPublicKey,\n      messages\n    );\n\n    const response = {\n      state: KeyCreationMPCv2StateEnum.WaitingForOVC1Round2Data,\n      tssVersion: payload.tssVersion,\n      walletType: payload.walletType,\n      coin: payload.coin,\n      ovc: payload.ovc,\n      platform: {\n        walletGpgPubKeySigs: result.walletGpgPubKeySigs,\n        sessionId: result.sessionId,\n        bitgoMsg1: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg1),\n        ovc: {\n          [OVCIndexEnum.ONE]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg2) },\n          [OVCIndexEnum.TWO]: { bitgoToOvcMsg2: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg2) },\n        },\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round1Response.name, BitgoToOVC1Round1Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async keyGenRound2BySender(\n    senderFn: EcdsaMPCv2KeyGenSendFn<MPCv2KeyGenRound2Response>,\n    payload: OVC2ToBitgoRound2Payload\n  ): Promise<BitgoToOVC1Round2Response> {\n    assert(\n      payload.state === KeyCreationMPCv2StateEnum.WaitingForBitgoRound2Data,\n      `Invalid state for round 2, expected: ${KeyCreationMPCv2StateEnum.WaitingForBitgoRound2Data}, got: ${payload.state}`\n    );\n    decodeOrElse(OVC2ToBitgoRound2Payload.name, OVC2ToBitgoRound2Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = { p2pMessages: [ovc1.ovcToBitgoMsg2, ovc2.ovcToBitgoMsg2], broadcastMessages: [] };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound2BySender(senderFn, sessionId, messages);\n\n    const response = {\n      state: KeyCreationMPCv2StateEnum.WaitingForOVC1Round3aData,\n      tssVersion: payload.tssVersion,\n      walletType: payload.walletType,\n      coin: payload.coin,\n      ovc: payload.ovc,\n      platform: {\n        ...payload.platform,\n        sessionId: result.sessionId,\n        bitgoCommitment2: result.bitgoCommitment2,\n        ovc: {\n          [OVCIndexEnum.ONE]: {\n            ...payload.platform.ovc[OVCIndexEnum.ONE],\n            bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToUserMsg3),\n          },\n          [OVCIndexEnum.TWO]: {\n            ...payload.platform.ovc[OVCIndexEnum.TWO],\n            bitgoToOvcMsg3: this.MPCv2Utils.formatP2PMessage(result.bitgoToBackupMsg3),\n          },\n        },\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round2Response.name, BitgoToOVC1Round2Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async keyGenRound3BySender(\n    senderFn: EcdsaMPCv2KeyGenSendFn<MPCv2KeyGenRound3Response>,\n    payload: OVC1ToBitgoRound3Payload\n  ): Promise<BitgoToOVC1Round3Response> {\n    assert(\n      payload.state === KeyCreationMPCv2StateEnum.WaitingForBitgoRound3Data,\n      `Invalid state for round 3, expected: ${KeyCreationMPCv2StateEnum.WaitingForBitgoRound3Data}, got: ${payload.state}`\n    );\n    decodeOrElse(OVC1ToBitgoRound3Payload.name, OVC1ToBitgoRound3Payload, payload, (errors) => {\n      throw new Error(`error(s) parsing payload: ${errors}`);\n    });\n    const ovc1 = payload.ovc[OVCIndexEnum.ONE];\n    const ovc2 = payload.ovc[OVCIndexEnum.TWO];\n    const sessionId = payload.platform.sessionId;\n    const messages = {\n      p2pMessages: [ovc1.ovcToBitgoMsg3, ovc2.ovcToBitgoMsg3],\n      broadcastMessages: [ovc1.ovcMsg4, ovc2.ovcMsg4],\n    };\n    const result = await this.MPCv2Utils.sendKeyGenerationRound3BySender(senderFn, sessionId, messages);\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.add({\n      source: 'bitgo',\n      keyType: 'tss',\n      commonKeychain: result.commonKeychain,\n      isMPCv2: true,\n    });\n\n    const response = {\n      state: KeyCreationMPCv2StateEnum.WaitingForOVC1GenerateKey,\n      bitGoKeyId: bitgoKeychain.id,\n      tssVersion: payload.tssVersion,\n      walletType: payload.walletType,\n      coin: payload.coin,\n      ovc: payload.ovc,\n      platform: {\n        ...payload.platform,\n        commonKeychain: result.commonKeychain,\n        bitgoMsg4: this.MPCv2Utils.formatBitgoBroadcastMessage(result.bitgoMsg4),\n      },\n    };\n\n    return decodeOrElse(BitgoToOVC1Round3Response.name, BitgoToOVC1Round3Response, response, (errors) => {\n      throw new Error(`error(s) parsing response: ${errors}`);\n    });\n  }\n\n  public async uploadClientKeys(\n    bitgoKeyId: string,\n    userCommonKeychain: string,\n    backupCommonKeychain: string\n  ): Promise<{ userKeychain: Keychain; backupKeychain: Keychain; bitgoKeychain: Keychain }> {\n    assert(\n      userCommonKeychain === backupCommonKeychain,\n      'Common keychain mismatch between the user and backup keychains'\n    );\n\n    const keychains = this.baseCoin.keychains();\n    const bitgoKeychain = await keychains.get({ id: bitgoKeyId });\n    assert(bitgoKeychain, 'Keychain not found');\n    assert(bitgoKeychain.source === 'bitgo', 'The keychain is not a BitGo keychain');\n    assert(bitgoKeychain.type === 'tss', 'BitGo keychain is not a TSS keychain');\n    assert(bitgoKeychain.commonKeychain, 'BitGo keychain does not have a common keychain');\n    assert(bitgoKeychain.commonKeychain === userCommonKeychain, 'Common keychain mismatch between the OVCs and BitGo');\n\n    const userKeychainPromise = keychains.add({\n      source: 'user',\n      keyType: 'tss',\n      commonKeychain: userCommonKeychain,\n      isMPCv2: true,\n    });\n    const backupKeychainPromise = keychains.add({\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: backupCommonKeychain,\n      isMPCv2: true,\n    });\n\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n    return { userKeychain, backupKeychain, bitgoKeychain };\n  }\n}\n"]}

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


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