PHP WebShell

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

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

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.TssUtils = exports.EddsaUtils = void 0;
/**
 * @prettier
 */
const assert_1 = __importDefault(require("assert"));
const bs58 = __importStar(require("bs58"));
const openpgp = __importStar(require("openpgp"));
const tss_1 = __importDefault(require("../../../../account-lib/mpc/tss"));
const eddsa_1 = require("../../../tss/eddsa/eddsa");
const opengpgUtils_1 = require("../../opengpgUtils");
const tss_2 = require("../../../tss");
const baseTypes_1 = require("../baseTypes");
const baseTSSUtils_1 = __importDefault(require("../baseTSSUtils"));
const common_1 = require("../../../tss/common");
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
/**
 * Utility functions for TSS work flows.
 */
class EddsaUtils extends baseTSSUtils_1.default {
    async verifyWalletSignatures(userGpgPub, backupGpgPub, bitgoKeychain, decryptedShare, verifierIndex) {
        (0, assert_1.default)(bitgoKeychain.commonKeychain);
        (0, assert_1.default)(bitgoKeychain.walletHSMGPGPublicKeySigs);
        const bitgoGpgKey = (await (0, opengpgUtils_1.getBitgoGpgPubKey)(this.bitgo)).mpcV1;
        const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });
        const userKeyId = userKeyPub.keyPacket.getFingerprint();
        const backupKeyPub = await openpgp.readKey({ armoredKey: backupGpgPub });
        const backupKeyId = backupKeyPub.keyPacket.getFingerprint();
        const walletSignatures = await openpgp.readKeys({ armoredKeys: bitgoKeychain.walletHSMGPGPublicKeySigs });
        if (walletSignatures.length !== 2) {
            throw new Error('Invalid wallet signatures');
        }
        if (userKeyId !== walletSignatures[0].keyPacket.getFingerprint()) {
            throw new Error(`first wallet signature's fingerprint does not match passed user gpg key's fingerprint`);
        }
        if (backupKeyId !== walletSignatures[1].keyPacket.getFingerprint()) {
            throw new Error(`second wallet signature's fingerprint does not match passed backup gpg key's fingerprint`);
        }
        await (0, eddsa_1.verifyWalletSignature)({
            walletSignature: walletSignatures[0],
            commonKeychain: bitgoKeychain.commonKeychain,
            userKeyId,
            backupKeyId,
            bitgoPub: bitgoGpgKey,
            decryptedShare,
            verifierIndex,
        });
        await (0, eddsa_1.verifyWalletSignature)({
            walletSignature: walletSignatures[1],
            commonKeychain: bitgoKeychain.commonKeychain,
            userKeyId,
            backupKeyId,
            bitgoPub: bitgoGpgKey,
            decryptedShare,
            verifierIndex,
        });
    }
    /**
     * Creates a Keychain containing the User's TSS signing materials.
     * We need to have the passphrase be optional to allow for the client to store their backup key on their premises
     *
     * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server
     * @param userKeyShare - user's TSS key share
     * @param backupKeyShare - backup's TSS key share
     * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares
     * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials
     * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets
     */
    async createUserKeychain({ userGpgKey, backupGpgKey, userKeyShare, backupKeyShare, bitgoKeychain, passphrase, originalPasscodeEncryptionCode, }) {
        const MPC = await tss_1.default.initialize();
        const bitgoKeyShares = bitgoKeychain.keyShares;
        if (!bitgoKeyShares) {
            throw new Error('Missing BitGo key shares');
        }
        const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');
        if (!bitGoToUserShare) {
            throw new Error('Missing BitGo to User key share');
        }
        const bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);
        await this.verifyWalletSignatures(userGpgKey.publicKey, backupGpgKey.publicKey, bitgoKeychain, bitGoToUserPrivateShare, 1);
        const bitgoToUser = {
            i: 1,
            j: 3,
            y: bitGoToUserShare.publicShare.slice(0, 64),
            v: bitGoToUserShare.vssProof,
            u: bitGoToUserPrivateShare.slice(0, 64),
            chaincode: bitGoToUserPrivateShare.slice(64),
        };
        const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');
        if (bitGoToBackupShare) {
            (0, assert_1.default)(bitGoToBackupShare.vssProof === bitGoToUserShare.vssProof, 'VSS proofs to user and backup do not match');
        }
        // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported
        const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);
        const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;
        if (commonKeychain !== bitgoKeychain.commonKeychain) {
            throw new Error('Failed to create user keychain - commonKeychains do not match.');
        }
        const userSigningMaterial = {
            uShare: userKeyShare.uShare,
            bitgoYShare: bitgoToUser,
            backupYShare: backupKeyShare.yShares[1],
        };
        const userKeychainParams = {
            source: 'user',
            keyType: 'tss',
            commonKeychain: bitgoKeychain.commonKeychain,
            originalPasscodeEncryptionCode,
        };
        if (passphrase !== undefined) {
            userKeychainParams.encryptedPrv = this.bitgo.encrypt({
                input: JSON.stringify(userSigningMaterial),
                password: passphrase,
            });
        }
        return await this.baseCoin.keychains().add(userKeychainParams);
    }
    /**
     * Creates a Keychain containing the Backup party's TSS signing materials.
     * We need to have the passphrase be optional to allow for the client to store their backup key on their premises
     *
     * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server
     * @param userKeyShare - User's TSS Keyshare
     * @param backupGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between backup and server
     * @param backupKeyShare - Backup's TSS Keyshare
     * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares
     * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials
     */
    async createBackupKeychain({ userGpgKey, backupGpgKey, userKeyShare, backupKeyShare, bitgoKeychain, passphrase, }) {
        const MPC = await tss_1.default.initialize();
        const bitgoKeyShares = bitgoKeychain.keyShares;
        if (!bitgoKeyShares) {
            throw new Error('Invalid bitgo keyshares');
        }
        const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');
        if (!bitGoToBackupShare) {
            throw new Error('Missing BitGo to User key share');
        }
        const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, backupGpgKey);
        await this.verifyWalletSignatures(userGpgKey.publicKey, backupGpgKey.publicKey, bitgoKeychain, bitGoToBackupPrivateShare, 2);
        const bitgoToBackup = {
            i: 2,
            j: 3,
            y: bitGoToBackupShare.publicShare.slice(0, 64),
            v: bitGoToBackupShare.vssProof,
            u: bitGoToBackupPrivateShare.slice(0, 64),
            chaincode: bitGoToBackupPrivateShare.slice(64),
        };
        const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');
        if (bitGoToUserShare) {
            (0, assert_1.default)(bitGoToUserShare.vssProof === bitGoToBackupShare.vssProof, 'VSS proofs to user and backup do not match');
        }
        // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported
        const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);
        const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;
        if (commonKeychain !== bitgoKeychain.commonKeychain) {
            throw new Error('Failed to create backup keychain - commonKeychains do not match.');
        }
        const backupSigningMaterial = {
            uShare: backupKeyShare.uShare,
            bitgoYShare: bitgoToBackup,
            userYShare: userKeyShare.yShares[2],
        };
        const prv = JSON.stringify(backupSigningMaterial);
        const params = {
            source: 'backup',
            keyType: 'tss',
            commonKeychain: bitgoKeychain.commonKeychain,
            prv: prv,
        };
        if (passphrase !== undefined) {
            params.encryptedPrv = this.bitgo.encrypt({ input: prv, password: passphrase });
        }
        return await this.baseCoin.keychains().createBackup(params);
    }
    /**
     * Creates a Keychain containing BitGo's TSS signing materials.
     *
     * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server
     * @param userKeyShare - user's TSS key share
     * @param backupKeyShare - backup's TSS key share
     * @param enterprise - enterprise associated to the wallet
     */
    async createBitgoKeychain({ userGpgKey, backupGpgKey, userKeyShare, backupKeyShare, enterprise, }) {
        // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported
        const userToBitgoPublicShare = Buffer.concat([
            Buffer.from(userKeyShare.uShare.y, 'hex'),
            Buffer.from(userKeyShare.uShare.chaincode, 'hex'),
        ]).toString('hex');
        const userToBitgoPrivateShare = Buffer.concat([
            Buffer.from(userKeyShare.yShares[3].u, 'hex'),
            Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),
        ]).toString('hex');
        const userToBitgoKeyShare = {
            publicShare: userToBitgoPublicShare,
            privateShare: userToBitgoPrivateShare,
            privateShareProof: await (0, opengpgUtils_1.createShareProof)(userGpgKey.privateKey, userToBitgoPrivateShare.slice(0, 64), 'eddsa'),
            vssProof: userKeyShare.yShares[3].v,
        };
        const backupToBitgoPublicShare = Buffer.concat([
            Buffer.from(backupKeyShare.uShare.y, 'hex'),
            Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),
        ]).toString('hex');
        const backupToBitgoPrivateShare = Buffer.concat([
            Buffer.from(backupKeyShare.yShares[3].u, 'hex'),
            Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),
        ]).toString('hex');
        const backupToBitgoKeyShare = {
            publicShare: backupToBitgoPublicShare,
            privateShare: backupToBitgoPrivateShare,
            privateShareProof: await (0, opengpgUtils_1.createShareProof)(backupGpgKey.privateKey, backupToBitgoPrivateShare.slice(0, 64), 'eddsa'),
            vssProof: backupKeyShare.yShares[3].v,
        };
        return await this.createBitgoKeychainInWP(userGpgKey, backupGpgKey, userToBitgoKeyShare, backupToBitgoKeyShare, 'tss', enterprise);
    }
    /**
     * Creates User, Backup, and BitGo TSS Keychains.
     *
     * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup
     */
    async createKeychains(params) {
        const MPC = await tss_1.default.initialize();
        const m = 2;
        const n = 3;
        const userKeyShare = MPC.keyShare(1, m, n);
        const backupKeyShare = MPC.keyShare(2, m, n);
        const userGpgKey = await (0, opengpgUtils_1.generateGPGKeyPair)('secp256k1');
        const backupGpgKey = await (0, opengpgUtils_1.generateGPGKeyPair)('secp256k1');
        const bitgoKeychain = await this.createBitgoKeychain({
            userGpgKey,
            userKeyShare,
            backupGpgKey,
            backupKeyShare,
            enterprise: params.enterprise,
        });
        const userKeychainPromise = this.createUserKeychain({
            userGpgKey,
            userKeyShare,
            backupGpgKey,
            backupKeyShare,
            bitgoKeychain,
            passphrase: params.passphrase,
            originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,
        });
        const backupKeychainPromise = this.createBackupKeychain({
            userGpgKey,
            userKeyShare,
            backupGpgKey,
            backupKeyShare,
            bitgoKeychain,
            passphrase: params.passphrase,
        });
        const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);
        // create wallet
        const keychains = {
            userKeychain,
            backupKeychain,
            bitgoKeychain,
        };
        return keychains;
    }
    async createCommitmentShareFromTxRequest(params) {
        const bitgoIndex = tss_2.ShareKeyPosition.BITGO;
        const { txRequest, prv } = params;
        const txRequestResolved = txRequest;
        const hdTree = await sdk_lib_mpc_1.Ed25519Bip32HdTree.initialize();
        const MPC = await tss_1.default.initialize(hdTree);
        const userSigningMaterial = JSON.parse(prv);
        if (!userSigningMaterial.backupYShare) {
            throw new Error('Invalid user key - missing backupYShare');
        }
        (0, assert_1.default)(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');
        const unsignedTx = txRequestResolved.apiVersion === 'full'
            ? txRequestResolved.transactions[0].unsignedTx
            : txRequestResolved.unsignedTxs[0];
        const signingKey = MPC.keyDerive(userSigningMaterial.uShare, [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare], unsignedTx.derivationPath);
        const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
        const userSignShare = await (0, tss_2.createUserSignShare)(signablePayload, signingKey.pShare);
        const commitment = userSignShare.rShares[bitgoIndex]?.commitment;
        (0, assert_1.default)(commitment, 'Unable to find commitment in userSignShare');
        const userToBitgoCommitment = this.createUserToBitgoCommitmentShare(commitment);
        const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;
        const userToBitgoEncryptedSignerShare = await (0, opengpgUtils_1.encryptText)(signerShare, await openpgp.readKey({ armoredKey: params.bitgoGpgPubKey }));
        const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);
        const stringifiedRShare = JSON.stringify(userSignShare);
        const encryptedRShare = this.bitgo.encrypt({ input: stringifiedRShare, password: params.walletPassphrase });
        const encryptedUserToBitgoRShare = this.createUserToBitgoEncryptedRShare(encryptedRShare);
        return { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare };
    }
    async createRShareFromTxRequest(params) {
        const { walletPassphrase, encryptedUserToBitgoRShare } = params;
        const decryptedRShare = this.bitgo.decrypt({
            input: encryptedUserToBitgoRShare.share,
            password: walletPassphrase,
        });
        const rShare = JSON.parse(decryptedRShare);
        (0, assert_1.default)(rShare.xShare, 'Unable to find xShare in decryptedRShare');
        (0, assert_1.default)(rShare.rShares, 'Unable to find rShares in decryptedRShare');
        return { rShare };
    }
    async createGShareFromTxRequest(params) {
        let txRequestResolved;
        const { txRequest, prv, bitgoToUserCommitment, bitgoToUserRShare, userToBitgoRShare } = params;
        if (typeof txRequest === 'string') {
            txRequestResolved = await (0, tss_2.getTxRequest)(this.bitgo, this.wallet.id(), txRequest);
        }
        else {
            txRequestResolved = txRequest;
        }
        const userSigningMaterial = JSON.parse(prv);
        if (!userSigningMaterial.backupYShare) {
            throw new Error('Invalid user key - missing backupYShare');
        }
        (0, assert_1.default)(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');
        const unsignedTx = txRequestResolved.apiVersion === 'full'
            ? txRequestResolved.transactions[0].unsignedTx
            : txRequestResolved.unsignedTxs[0];
        const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
        const userToBitGoGShare = await (0, tss_2.createUserToBitGoGShare)(userToBitgoRShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload, bitgoToUserCommitment);
        return userToBitGoGShare;
    }
    async signEddsaTssUsingExternalSigner(txRequest, externalSignerCommitmentGenerator, externalSignerRShareGenerator, externalSignerGShareGenerator, reqId) {
        let txRequestResolved;
        let txRequestId;
        if (typeof txRequest === 'string') {
            txRequestResolved = await (0, tss_2.getTxRequest)(this.bitgo, this.wallet.id(), txRequest, reqId);
            txRequestId = txRequestResolved.txRequestId;
        }
        else {
            txRequestResolved = txRequest;
            txRequestId = txRequest.txRequestId;
        }
        const { apiVersion } = txRequestResolved;
        const bitgoGpgKey = await this.pickBitgoPubGpgKeyForSigning(false, reqId, txRequestResolved.enterpriseId);
        const { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare } = await externalSignerCommitmentGenerator({ txRequest: txRequestResolved, bitgoGpgPubKey: bitgoGpgKey.armor() });
        const { commitmentShare: bitgoToUserCommitment } = await (0, common_1.exchangeEddsaCommitments)(this.bitgo, this.wallet.id(), txRequestId, userToBitgoCommitment, encryptedSignerShare, apiVersion, reqId);
        const { rShare } = await externalSignerRShareGenerator({
            txRequest: txRequestResolved,
            encryptedUserToBitgoRShare,
        });
        await (0, tss_2.offerUserToBitgoRShare)(this.bitgo, this.wallet.id(), txRequestId, rShare, encryptedSignerShare.share, apiVersion, reqId);
        const bitgoToUserRShare = await (0, tss_2.getBitgoToUserRShare)(this.bitgo, this.wallet.id(), txRequestId, reqId);
        const gSignShareTransactionParams = {
            txRequest: txRequestResolved,
            bitgoToUserRShare: bitgoToUserRShare,
            userToBitgoRShare: rShare,
            bitgoToUserCommitment,
        };
        const gShare = await externalSignerGShareGenerator(gSignShareTransactionParams);
        await (0, tss_2.sendUserToBitgoGShare)(this.bitgo, this.wallet.id(), txRequestId, gShare, apiVersion, reqId);
        return await (0, tss_2.getTxRequest)(this.bitgo, this.wallet.id(), txRequestId, reqId);
    }
    /**
     * Signs the transaction associated to the transaction request.
     *
     * @param txRequest - transaction request object or id
     * @param prv - decrypted private key
     * @param reqId - request id
     * @returns {Promise<TxRequest>} fully signed TxRequest object
     */
    async signTxRequest(params) {
        this.bitgo.setRequestTracer(params.reqId);
        let txRequestResolved;
        let txRequestId;
        const { txRequest, prv } = params;
        if (typeof txRequest === 'string') {
            txRequestResolved = await (0, tss_2.getTxRequest)(this.bitgo, this.wallet.id(), txRequest, params.reqId);
            txRequestId = txRequestResolved.txRequestId;
        }
        else {
            txRequestResolved = txRequest;
            txRequestId = txRequest.txRequestId;
        }
        const hdTree = await sdk_lib_mpc_1.Ed25519Bip32HdTree.initialize();
        const MPC = await tss_1.default.initialize(hdTree);
        const userSigningMaterial = JSON.parse(prv);
        if (!userSigningMaterial.backupYShare) {
            throw new Error('Invalid user key - missing backupYShare');
        }
        const { apiVersion } = txRequestResolved;
        (0, assert_1.default)(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');
        const unsignedTx = apiVersion === 'full' ? txRequestResolved.transactions[0].unsignedTx : txRequestResolved.unsignedTxs[0];
        const signingKey = MPC.keyDerive(userSigningMaterial.uShare, [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare], unsignedTx.derivationPath);
        const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');
        const userSignShare = await (0, tss_2.createUserSignShare)(signablePayload, signingKey.pShare);
        const bitgoIndex = tss_2.ShareKeyPosition.BITGO;
        const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;
        const bitgoGpgKey = await this.pickBitgoPubGpgKeyForSigning(false, params.reqId, txRequestResolved.enterpriseId);
        const userToBitgoEncryptedSignerShare = await (0, opengpgUtils_1.encryptText)(signerShare, bitgoGpgKey);
        const userToBitgoCommitment = userSignShare.rShares[bitgoIndex].commitment;
        (0, assert_1.default)(userToBitgoCommitment, 'Missing userToBitgoCommitment commitment');
        const commitmentShare = this.createUserToBitgoCommitmentShare(userToBitgoCommitment);
        const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);
        const { commitmentShare: bitgoToUserCommitment } = await (0, common_1.exchangeEddsaCommitments)(this.bitgo, this.wallet.id(), txRequestId, commitmentShare, encryptedSignerShare, apiVersion, params.reqId);
        await (0, tss_2.offerUserToBitgoRShare)(this.bitgo, this.wallet.id(), txRequestId, userSignShare, userToBitgoEncryptedSignerShare, apiVersion, params.reqId);
        const bitgoToUserRShare = await (0, tss_2.getBitgoToUserRShare)(this.bitgo, this.wallet.id(), txRequestId, params.reqId);
        const userToBitGoGShare = await (0, tss_2.createUserToBitGoGShare)(userSignShare, bitgoToUserRShare, userSigningMaterial.backupYShare, userSigningMaterial.bitgoYShare, signablePayload, bitgoToUserCommitment);
        await (0, tss_2.sendUserToBitgoGShare)(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare, apiVersion, params.reqId);
        return await (0, tss_2.getTxRequest)(this.bitgo, this.wallet.id(), txRequestId, params.reqId);
    }
    /**
     * Get the commonPub portion of the commonKeychain.
     *
     * @param {String} commonKeychain
     * @returns {string}
     */
    static getPublicKeyFromCommonKeychain(commonKeychain) {
        if (commonKeychain.length !== 128) {
            throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);
        }
        const commonPubHexStr = commonKeychain.slice(0, 64);
        return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));
    }
    createUserToBitgoCommitmentShare(commitment) {
        return {
            from: baseTypes_1.SignatureShareType.USER,
            to: baseTypes_1.SignatureShareType.BITGO,
            share: commitment,
            type: baseTypes_1.CommitmentType.COMMITMENT,
        };
    }
    createUserToBitgoEncryptedSignerShare(encryptedSignerShare) {
        return {
            from: baseTypes_1.SignatureShareType.USER,
            to: baseTypes_1.SignatureShareType.BITGO,
            share: encryptedSignerShare,
            type: baseTypes_1.EncryptedSignerShareType.ENCRYPTED_SIGNER_SHARE,
        };
    }
    createUserToBitgoEncryptedRShare(encryptedRShare) {
        return {
            from: baseTypes_1.SignatureShareType.USER,
            to: baseTypes_1.SignatureShareType.BITGO,
            share: encryptedRShare,
            type: baseTypes_1.EncryptedSignerShareType.ENCRYPTED_R_SHARE,
        };
    }
}
exports.EddsaUtils = EddsaUtils;
/**
 * @deprecated - use EddsaUtils
 */
exports.TssUtils = EddsaUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport assert from 'assert';\nimport * as bs58 from 'bs58';\nimport * as openpgp from 'openpgp';\nimport Eddsa, { SignShare, GShare } from '../../../../account-lib/mpc/tss';\nimport { AddKeychainOptions, Keychain, CreateBackupOptions } from '../../../keychain';\nimport { verifyWalletSignature } from '../../../tss/eddsa/eddsa';\nimport { encryptText, getBitgoGpgPubKey, createShareProof, generateGPGKeyPair } from '../../opengpgUtils';\nimport {\n  createUserSignShare,\n  createUserToBitGoGShare,\n  getBitgoToUserRShare,\n  getTxRequest,\n  offerUserToBitgoRShare,\n  sendUserToBitgoGShare,\n  ShareKeyPosition,\n  SigningMaterial,\n} from '../../../tss';\nimport {\n  CommitmentShareRecord,\n  CommitmentType,\n  CustomCommitmentGeneratingFunction,\n  CustomGShareGeneratingFunction,\n  CustomRShareGeneratingFunction,\n  EncryptedSignerShareRecord,\n  EncryptedSignerShareType,\n  SignatureShareRecord,\n  SignatureShareType,\n  TSSParamsWithPrv,\n  TxRequest,\n} from '../baseTypes';\nimport { CreateEddsaBitGoKeychainParams, CreateEddsaKeychainParams, KeyShare, YShare } from './types';\nimport baseTSSUtils from '../baseTSSUtils';\nimport { KeychainsTriplet } from '../../../baseCoin';\nimport { exchangeEddsaCommitments } from '../../../tss/common';\nimport { Ed25519Bip32HdTree } from '@bitgo/sdk-lib-mpc';\nimport { IRequestTracer } from '../../../../api';\n\n/**\n * Utility functions for TSS work flows.\n */\n\nexport class EddsaUtils extends baseTSSUtils<KeyShare> {\n  async verifyWalletSignatures(\n    userGpgPub: string,\n    backupGpgPub: string,\n    bitgoKeychain: Keychain,\n    decryptedShare: string,\n    verifierIndex: 1 | 2\n  ): Promise<void> {\n    assert(bitgoKeychain.commonKeychain);\n    assert(bitgoKeychain.walletHSMGPGPublicKeySigs);\n\n    const bitgoGpgKey = (await getBitgoGpgPubKey(this.bitgo)).mpcV1;\n\n    const userKeyPub = await openpgp.readKey({ armoredKey: userGpgPub });\n    const userKeyId = userKeyPub.keyPacket.getFingerprint();\n\n    const backupKeyPub = await openpgp.readKey({ armoredKey: backupGpgPub });\n    const backupKeyId = backupKeyPub.keyPacket.getFingerprint();\n\n    const walletSignatures = await openpgp.readKeys({ armoredKeys: bitgoKeychain.walletHSMGPGPublicKeySigs });\n    if (walletSignatures.length !== 2) {\n      throw new Error('Invalid wallet signatures');\n    }\n\n    if (userKeyId !== walletSignatures[0].keyPacket.getFingerprint()) {\n      throw new Error(`first wallet signature's fingerprint does not match passed user gpg key's fingerprint`);\n    }\n\n    if (backupKeyId !== walletSignatures[1].keyPacket.getFingerprint()) {\n      throw new Error(`second wallet signature's fingerprint does not match passed backup gpg key's fingerprint`);\n    }\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[0],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n\n    await verifyWalletSignature({\n      walletSignature: walletSignatures[1],\n      commonKeychain: bitgoKeychain.commonKeychain,\n      userKeyId,\n      backupKeyId,\n      bitgoPub: bitgoGpgKey,\n      decryptedShare,\n      verifierIndex,\n    });\n  }\n\n  /**\n   * Creates a Keychain containing the User's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets\n   */\n  async createUserKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n    originalPasscodeEncryptionCode,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (!bitGoToUserShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToUserPrivateShare,\n      1\n    );\n\n    const bitgoToUser: YShare = {\n      i: 1,\n      j: 3,\n      y: bitGoToUserShare.publicShare.slice(0, 64),\n      v: bitGoToUserShare.vssProof,\n      u: bitGoToUserPrivateShare.slice(0, 64),\n      chaincode: bitGoToUserPrivateShare.slice(64),\n    };\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (bitGoToBackupShare) {\n      assert(bitGoToBackupShare.vssProof === bitGoToUserShare.vssProof, 'VSS proofs to user and backup do not match');\n    }\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);\n    const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const userSigningMaterial: SigningMaterial = {\n      uShare: userKeyShare.uShare,\n      bitgoYShare: bitgoToUser,\n      backupYShare: backupKeyShare.yShares[1],\n    };\n\n    const userKeychainParams: AddKeychainOptions = {\n      source: 'user',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      originalPasscodeEncryptionCode,\n    };\n    if (passphrase !== undefined) {\n      userKeychainParams.encryptedPrv = this.bitgo.encrypt({\n        input: JSON.stringify(userSigningMaterial),\n        password: passphrase,\n      });\n    }\n\n    return await this.baseCoin.keychains().add(userKeychainParams);\n  }\n\n  /**\n   * Creates a Keychain containing the Backup party's TSS signing materials.\n   * We need to have the passphrase be optional to allow for the client to store their backup key on their premises\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - User's TSS Keyshare\n   * @param backupGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between backup and server\n   * @param backupKeyShare - Backup's TSS Keyshare\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param [passphrase] - optional wallet passphrase used to encrypt user's signing materials\n   */\n  async createBackupKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    bitgoKeychain,\n    passphrase,\n  }: CreateEddsaKeychainParams): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Invalid bitgo keyshares');\n    }\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (!bitGoToBackupShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, backupGpgKey);\n\n    await this.verifyWalletSignatures(\n      userGpgKey.publicKey,\n      backupGpgKey.publicKey,\n      bitgoKeychain,\n      bitGoToBackupPrivateShare,\n      2\n    );\n\n    const bitgoToBackup: YShare = {\n      i: 2,\n      j: 3,\n      y: bitGoToBackupShare.publicShare.slice(0, 64),\n      v: bitGoToBackupShare.vssProof,\n      u: bitGoToBackupPrivateShare.slice(0, 64),\n      chaincode: bitGoToBackupPrivateShare.slice(64),\n    };\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (bitGoToUserShare) {\n      assert(bitGoToUserShare.vssProof === bitGoToBackupShare.vssProof, 'VSS proofs to user and backup do not match');\n    }\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);\n    const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create backup keychain - commonKeychains do not match.');\n    }\n\n    const backupSigningMaterial: SigningMaterial = {\n      uShare: backupKeyShare.uShare,\n      bitgoYShare: bitgoToBackup,\n      userYShare: userKeyShare.yShares[2],\n    };\n    const prv = JSON.stringify(backupSigningMaterial);\n\n    const params: CreateBackupOptions = {\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n    };\n\n    if (passphrase !== undefined) {\n      params.encryptedPrv = this.bitgo.encrypt({ input: prv, password: passphrase });\n    }\n\n    return await this.baseCoin.keychains().createBackup(params);\n  }\n\n  /**\n   * Creates a Keychain containing BitGo's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param enterprise - enterprise associated to the wallet\n   */\n  async createBitgoKeychain({\n    userGpgKey,\n    backupGpgKey,\n    userKeyShare,\n    backupKeyShare,\n    enterprise,\n  }: CreateEddsaBitGoKeychainParams): Promise<Keychain> {\n    // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported\n    const userToBitgoPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.uShare.y, 'hex'),\n      Buffer.from(userKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(userKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoKeyShare = {\n      publicShare: userToBitgoPublicShare,\n      privateShare: userToBitgoPrivateShare,\n      privateShareProof: await createShareProof(userGpgKey.privateKey, userToBitgoPrivateShare.slice(0, 64), 'eddsa'),\n      vssProof: userKeyShare.yShares[3].v,\n    };\n\n    const backupToBitgoPublicShare = Buffer.concat([\n      Buffer.from(backupKeyShare.uShare.y, 'hex'),\n      Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(backupKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoKeyShare = {\n      publicShare: backupToBitgoPublicShare,\n      privateShare: backupToBitgoPrivateShare,\n      privateShareProof: await createShareProof(\n        backupGpgKey.privateKey,\n        backupToBitgoPrivateShare.slice(0, 64),\n        'eddsa'\n      ),\n      vssProof: backupKeyShare.yShares[3].v,\n    };\n\n    return await this.createBitgoKeychainInWP(\n      userGpgKey,\n      backupGpgKey,\n      userToBitgoKeyShare,\n      backupToBitgoKeyShare,\n      'tss',\n      enterprise\n    );\n  }\n\n  /**\n   * Creates User, Backup, and BitGo TSS Keychains.\n   *\n   * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup\n   */\n  async createKeychains(params: {\n    passphrase?: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n  }): Promise<KeychainsTriplet> {\n    const MPC = await Eddsa.initialize();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = MPC.keyShare(1, m, n);\n    const backupKeyShare = MPC.keyShare(2, m, n);\n\n    const userGpgKey = await generateGPGKeyPair('secp256k1');\n    const backupGpgKey = await generateGPGKeyPair('secp256k1');\n\n    const bitgoKeychain = await this.createBitgoKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      enterprise: params.enterprise,\n    });\n    const userKeychainPromise = this.createUserKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n    });\n    const backupKeychainPromise = this.createBackupKeychain({\n      userGpgKey,\n      userKeyShare,\n      backupGpgKey,\n      backupKeyShare,\n      bitgoKeychain,\n      passphrase: params.passphrase,\n    });\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    // create wallet\n    const keychains = {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n\n    return keychains;\n  }\n\n  async createCommitmentShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    walletPassphrase: string;\n    bitgoGpgPubKey: string;\n  }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }> {\n    const bitgoIndex = ShareKeyPosition.BITGO;\n    const { txRequest, prv } = params;\n    const txRequestResolved: TxRequest = txRequest;\n\n    const hdTree = await Ed25519Bip32HdTree.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n    const commitment = userSignShare.rShares[bitgoIndex]?.commitment;\n    assert(commitment, 'Unable to find commitment in userSignShare');\n    const userToBitgoCommitment = this.createUserToBitgoCommitmentShare(commitment);\n\n    const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;\n\n    const userToBitgoEncryptedSignerShare = await encryptText(\n      signerShare,\n      await openpgp.readKey({ armoredKey: params.bitgoGpgPubKey })\n    );\n\n    const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);\n    const stringifiedRShare = JSON.stringify(userSignShare);\n    const encryptedRShare = this.bitgo.encrypt({ input: stringifiedRShare, password: params.walletPassphrase });\n    const encryptedUserToBitgoRShare = this.createUserToBitgoEncryptedRShare(encryptedRShare);\n\n    return { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare };\n  }\n\n  async createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }> {\n    const { walletPassphrase, encryptedUserToBitgoRShare } = params;\n\n    const decryptedRShare = this.bitgo.decrypt({\n      input: encryptedUserToBitgoRShare.share,\n      password: walletPassphrase,\n    });\n    const rShare = JSON.parse(decryptedRShare);\n    assert(rShare.xShare, 'Unable to find xShare in decryptedRShare');\n    assert(rShare.rShares, 'Unable to find rShares in decryptedRShare');\n\n    return { rShare };\n  }\n\n  async createGShareFromTxRequest(params: {\n    txRequest: string | TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare> {\n    let txRequestResolved: TxRequest;\n\n    const { txRequest, prv, bitgoToUserCommitment, bitgoToUserRShare, userToBitgoRShare } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n    } else {\n      txRequestResolved = txRequest;\n    }\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      txRequestResolved.apiVersion === 'full'\n        ? txRequestResolved.transactions![0].unsignedTx\n        : txRequestResolved.unsignedTxs[0];\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userToBitgoRShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload,\n      bitgoToUserCommitment\n    );\n    return userToBitGoGShare;\n  }\n\n  async signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction,\n    reqId?: IRequestTracer\n  ): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest, reqId);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const { apiVersion } = txRequestResolved;\n    const bitgoGpgKey = await this.pickBitgoPubGpgKeyForSigning(false, reqId, txRequestResolved.enterpriseId);\n\n    const { userToBitgoCommitment, encryptedSignerShare, encryptedUserToBitgoRShare } =\n      await externalSignerCommitmentGenerator({ txRequest: txRequestResolved, bitgoGpgPubKey: bitgoGpgKey.armor() });\n\n    const { commitmentShare: bitgoToUserCommitment } = await exchangeEddsaCommitments(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      userToBitgoCommitment,\n      encryptedSignerShare,\n      apiVersion,\n      reqId\n    );\n\n    const { rShare } = await externalSignerRShareGenerator({\n      txRequest: txRequestResolved,\n      encryptedUserToBitgoRShare,\n    });\n\n    await offerUserToBitgoRShare(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      rShare,\n      encryptedSignerShare.share,\n      apiVersion,\n      reqId\n    );\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId, reqId);\n    const gSignShareTransactionParams = {\n      txRequest: txRequestResolved,\n      bitgoToUserRShare: bitgoToUserRShare,\n      userToBitgoRShare: rShare,\n      bitgoToUserCommitment,\n    };\n    const gShare = await externalSignerGShareGenerator(gSignShareTransactionParams);\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, gShare, apiVersion, reqId);\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId, reqId);\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   *\n   * @param txRequest - transaction request object or id\n   * @param prv - decrypted private key\n   * @param reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: TSSParamsWithPrv): Promise<TxRequest> {\n    this.bitgo.setRequestTracer(params.reqId);\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n\n    const { txRequest, prv } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest, params.reqId);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const hdTree = await Ed25519Bip32HdTree.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    const { apiVersion } = txRequestResolved;\n    assert(txRequestResolved.transactions || txRequestResolved.unsignedTxs, 'Unable to find transactions in txRequest');\n    const unsignedTx =\n      apiVersion === 'full' ? txRequestResolved.transactions![0].unsignedTx : txRequestResolved.unsignedTxs[0];\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      unsignedTx.derivationPath\n    );\n\n    const signablePayload = Buffer.from(unsignedTx.signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    const bitgoIndex = ShareKeyPosition.BITGO;\n    const signerShare = signingKey.yShares[bitgoIndex].u + signingKey.yShares[bitgoIndex].chaincode;\n    const bitgoGpgKey = await this.pickBitgoPubGpgKeyForSigning(false, params.reqId, txRequestResolved.enterpriseId);\n    const userToBitgoEncryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    const userToBitgoCommitment = userSignShare.rShares[bitgoIndex].commitment;\n    assert(userToBitgoCommitment, 'Missing userToBitgoCommitment commitment');\n\n    const commitmentShare = this.createUserToBitgoCommitmentShare(userToBitgoCommitment);\n    const encryptedSignerShare = this.createUserToBitgoEncryptedSignerShare(userToBitgoEncryptedSignerShare);\n\n    const { commitmentShare: bitgoToUserCommitment } = await exchangeEddsaCommitments(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      commitmentShare,\n      encryptedSignerShare,\n      apiVersion,\n      params.reqId\n    );\n\n    await offerUserToBitgoRShare(\n      this.bitgo,\n      this.wallet.id(),\n      txRequestId,\n      userSignShare,\n      userToBitgoEncryptedSignerShare,\n      apiVersion,\n      params.reqId\n    );\n\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId, params.reqId);\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userSignShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload,\n      bitgoToUserCommitment\n    );\n\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare, apiVersion, params.reqId);\n\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId, params.reqId);\n  }\n\n  /**\n   * Get the commonPub portion of the commonKeychain.\n   *\n   * @param {String} commonKeychain\n   * @returns {string}\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 128) {\n      throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 64);\n    return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));\n  }\n\n  createUserToBitgoCommitmentShare(commitment: string): CommitmentShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: commitment,\n      type: CommitmentType.COMMITMENT,\n    };\n  }\n\n  createUserToBitgoEncryptedSignerShare(encryptedSignerShare: string): EncryptedSignerShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: encryptedSignerShare,\n      type: EncryptedSignerShareType.ENCRYPTED_SIGNER_SHARE,\n    };\n  }\n\n  createUserToBitgoEncryptedRShare(encryptedRShare: string): EncryptedSignerShareRecord {\n    return {\n      from: SignatureShareType.USER,\n      to: SignatureShareType.BITGO,\n      share: encryptedRShare,\n      type: EncryptedSignerShareType.ENCRYPTED_R_SHARE,\n    };\n  }\n}\n/**\n * @deprecated - use EddsaUtils\n */\nexport const TssUtils = EddsaUtils;\n"]}

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


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