PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const sdk_core_1 = require("@bitgo/sdk-core");
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
const openpgp = require("openpgp");
const should = require("should");
const sdk_test_1 = require("@bitgo/sdk-test");
const src_1 = require("../../../../src");
const helpers_1 = require("./helpers");
const ecdsaFixtures_1 = require("../../fixtures/tss/ecdsaFixtures");
const nock = require("nock");
const encryptNShare = sdk_core_1.ECDSAMethods.encryptNShare;
const createCombinedKey = sdk_core_1.ECDSAMethods.createCombinedKey;
describe('Ecdsa tss helper functions tests', function () {
    let mpc;
    let userKeyShare;
    let backupKeyShare;
    let bitgoKeyShare;
    let userKey;
    let backupKey;
    let bitgoKey;
    let userGpgKeypair;
    let backupGpgKeypair;
    let bitgoGpgKeypair;
    let commonKeychain;
    before(async function () {
        mpc = new sdk_core_1.Ecdsa();
        userKeyShare = ecdsaFixtures_1.keyShares.userKeyShare;
        backupKeyShare = ecdsaFixtures_1.keyShares.backupKeyShare;
        bitgoKeyShare = ecdsaFixtures_1.keyShares.bitgoKeyShare;
        userKey = mpc.keyCombine(userKeyShare.pShare, [backupKeyShare.nShares[1], bitgoKeyShare.nShares[1]]);
        backupKey = mpc.keyCombine(backupKeyShare.pShare, [userKeyShare.nShares[2], bitgoKeyShare.nShares[2]]);
        bitgoKey = mpc.keyCombine(bitgoKeyShare.pShare, [backupKeyShare.nShares[3], userKeyShare.nShares[3]]);
        (userKey.xShare.y + userKey.xShare.chaincode).should.equal(backupKey.xShare.y + backupKey.xShare.chaincode);
        (userKey.xShare.y + userKey.xShare.chaincode).should.equal(bitgoKey.xShare.y + bitgoKey.xShare.chaincode);
        commonKeychain = userKey.xShare.y + userKey.xShare.chaincode;
        const gpgKeypairPromises = [
            { name: 'user', email: 'user@bitgo.com' },
            { name: 'backup', email: 'backup@bitgo.com' },
            { name: 'bitgo', email: 'bitgo@bitgo.com' },
        ].map(async (user) => {
            return openpgp.generateKey({
                userIDs: [
                    {
                        name: user.name,
                        email: user.email,
                    },
                ],
                curve: 'secp256k1',
            });
        });
        const gpgKeypairs = await Promise.all(gpgKeypairPromises);
        userGpgKeypair = gpgKeypairs[0];
        backupGpgKeypair = gpgKeypairs[1];
        bitgoGpgKeypair = gpgKeypairs[2];
    });
    after(function () {
        nock.cleanAll();
    });
    describe('encryptNShare and decryptNShare', function () {
        after(function () {
            nock.cleanAll();
        });
        it('should encrypt n shares foreach user', async function () {
            for (let i = 2; i <= 3; i++) {
                const encryptedNShare = await sdk_core_1.ECDSAMethods.encryptNShare(userKeyShare, i, bitgoGpgKeypair.publicKey, userGpgKeypair);
                const decryptedNShare = await sdk_core_1.ECDSAMethods.decryptNShare({
                    nShare: encryptedNShare,
                    senderPublicArmor: userGpgKeypair.publicKey,
                    recipientPrivateArmor: bitgoGpgKeypair.privateKey,
                });
                decryptedNShare.u.should.equal(userKeyShare.nShares[i].u);
                const publicKey = userKeyShare.pShare.y + userKeyShare.pShare.chaincode;
                encryptedNShare.i.should.equal(i);
                encryptedNShare.vssProof.should.equal(userKeyShare.nShares[3].v);
                encryptedNShare.j.should.equal(1);
                encryptedNShare.publicShare.should.equal(publicKey);
            }
        });
        it('should error for invalid recipient', async function () {
            await encryptNShare(userKeyShare, 1, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith('Invalid recipient');
            await encryptNShare(backupKeyShare, 2, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith('Invalid recipient');
            await encryptNShare(bitgoKeyShare, 3, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith('Invalid recipient');
        });
        it('should decrypt n share', async function () {
            const encryptedNShare = await sdk_core_1.ECDSAMethods.encryptNShare(userKeyShare, 3, bitgoGpgKeypair.publicKey, userGpgKeypair);
            const decryptedNShare = await sdk_core_1.ECDSAMethods.decryptNShare({
                nShare: encryptedNShare,
                recipientPrivateArmor: bitgoGpgKeypair.privateKey,
                senderPublicArmor: userGpgKeypair.publicKey,
            });
            decryptedNShare.i.should.equal(userKeyShare.nShares[3].i);
            decryptedNShare.j.should.equal(userKeyShare.nShares[3].j);
            decryptedNShare.n.should.equal(userKeyShare.nShares[3].n);
            decryptedNShare.u.should.equal(userKeyShare.nShares[3].u);
            decryptedNShare.y.should.equal(userKeyShare.nShares[3].y);
        });
    });
    describe('createCombinedKey', function () {
        after(function () {
            nock.cleanAll();
        });
        it('should create combined user key', async function () {
            const bitgoToUserShare = await sdk_core_1.ECDSAMethods.encryptNShare(bitgoKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair, false);
            const backupToUserShare = await sdk_core_1.ECDSAMethods.encryptNShare(backupKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair, false);
            const combinedUserKey = await createCombinedKey(userKeyShare, [
                {
                    nShare: bitgoToUserShare,
                    recipientPrivateArmor: userGpgKeypair.privateKey,
                    senderPublicArmor: bitgoGpgKeypair.publicKey,
                    isbs58Encoded: false,
                },
                {
                    nShare: backupToUserShare,
                    recipientPrivateArmor: userGpgKeypair.privateKey,
                    senderPublicArmor: backupGpgKeypair.publicKey,
                    isbs58Encoded: false,
                },
            ], commonKeychain);
            combinedUserKey.commonKeychain.should.equal(commonKeychain);
            combinedUserKey.signingMaterial.pShare.should.deepEqual(userKeyShare.pShare);
            should.exist(combinedUserKey.signingMaterial.backupNShare);
            combinedUserKey.signingMaterial.backupNShare?.should.deepEqual(backupKeyShare.nShares[1]);
            combinedUserKey.signingMaterial.bitgoNShare.should.deepEqual(bitgoKeyShare.nShares[1]);
            should.not.exist(combinedUserKey.signingMaterial.userNShare);
        });
        it('should create combined backup key', async function () {
            const bitgoToBackupShare = await encryptNShare(bitgoKeyShare, 2, backupGpgKeypair.publicKey, userGpgKeypair);
            const userToBackupShare = await encryptNShare(userKeyShare, 2, backupGpgKeypair.publicKey, userGpgKeypair);
            const combinedBackupKey = await createCombinedKey(backupKeyShare, [
                {
                    nShare: bitgoToBackupShare,
                    recipientPrivateArmor: backupGpgKeypair.privateKey,
                    senderPublicArmor: bitgoGpgKeypair.publicKey,
                },
                {
                    nShare: userToBackupShare,
                    recipientPrivateArmor: backupGpgKeypair.privateKey,
                    senderPublicArmor: userGpgKeypair.publicKey,
                },
            ], commonKeychain);
            combinedBackupKey.commonKeychain.should.equal(commonKeychain);
            combinedBackupKey.signingMaterial.pShare.should.deepEqual(backupKeyShare.pShare);
            should.exist(combinedBackupKey.signingMaterial.userNShare);
            combinedBackupKey.signingMaterial.userNShare?.should.deepEqual(userKeyShare.nShares[2]);
            combinedBackupKey.signingMaterial.bitgoNShare.should.deepEqual(bitgoKeyShare.nShares[2]);
            should.not.exist(combinedBackupKey.signingMaterial.backupNShare);
        });
        it('should fail if common keychains do not match', async function () {
            const bitgoToUserShare = await encryptNShare(bitgoKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);
            const backupToUserShare = await encryptNShare(backupKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);
            // this should fail to combine the keys because we pass in invalid common key chain
            await createCombinedKey(userKeyShare, [
                {
                    nShare: bitgoToUserShare,
                    recipientPrivateArmor: userGpgKeypair.privateKey,
                    senderPublicArmor: bitgoGpgKeypair.publicKey,
                },
                {
                    nShare: backupToUserShare,
                    recipientPrivateArmor: userGpgKeypair.privateKey,
                    senderPublicArmor: backupGpgKeypair.publicKey,
                },
            ], 'nottherightkeychain').should.be.rejectedWith('Common keychains do not match');
        });
        it('should fail if gpg keys are mismatched', async function () {
            const bitgoToUserShare = await encryptNShare(bitgoKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);
            const backupToUserShare = await encryptNShare(backupKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);
            await createCombinedKey(userKeyShare, [
                {
                    nShare: bitgoToUserShare,
                    recipientPrivateArmor: backupGpgKeypair.privateKey,
                    senderPublicArmor: bitgoGpgKeypair.publicKey,
                },
                {
                    nShare: backupToUserShare,
                    recipientPrivateArmor: userGpgKeypair.privateKey,
                    senderPublicArmor: backupGpgKeypair.publicKey,
                },
            ], 'nottherightkeychain').should.be.rejectedWith('Error decrypting message: Session key decryption failed.');
        });
    });
    describe('tss signing helper function', async function () {
        const bitgo = sdk_test_1.TestBitGo.decorate(src_1.BitGo, { env: 'mock' });
        bitgo.initializeTestVars();
        let wallet;
        const txRequest = {
            txRequestId: 'randomId',
            unsignedTxs: [{ signableHex: 'TOO MANY SECRETS', serializedTxHex: 'randomhex2' }],
            signatureShares: [
                {
                    from: 'bitgo',
                    to: 'user',
                    share: '',
                },
            ],
        };
        const signablePayload = Buffer.from(txRequest.unsignedTxs[0].signableHex, 'hex');
        before('initializes', async function () {
            const baseCoin = bitgo.coin('hteth');
            const walletData = {
                id: '5b34252f1bf349930e34020a00000000',
                coin: 'hteth',
                keys: [
                    '5b3424f91bf349930e34017500000000',
                    '5b3424f91bf349930e34017600000000',
                    '5b3424f91bf349930e34017700000000',
                ],
                coinSpecific: {},
            };
            wallet = new sdk_core_1.Wallet(bitgo, baseCoin, walletData);
        });
        describe('createUserSignShare:', async function () {
            let userToBitGoPaillierChallenge;
            let bitgoToUserPaillierChallenge;
            before(async function () {
                userToBitGoPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({
                    p: await sdk_lib_mpc_1.EcdsaPaillierProof.generateP((0, sdk_core_1.hexToBigInt)(userKey.yShares[3].n)),
                });
                bitgoToUserPaillierChallenge = sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({
                    p: await sdk_lib_mpc_1.EcdsaPaillierProof.generateP((0, sdk_core_1.hexToBigInt)(userKey.xShare.n)),
                });
            });
            it('should succeed to create User SignShare', async function () {
                const xShare = mpc.appendChallenge(userKey.xShare, sdk_test_1.mockSerializedChallengeWithProofs, userToBitGoPaillierChallenge);
                const yShare = mpc.appendChallenge(userKey.yShares[3], { ntilde: xShare.ntilde, h1: xShare.h1, h2: xShare.h2 }, bitgoToUserPaillierChallenge);
                const userSignShare = await sdk_core_1.ECDSAMethods.createUserSignShare(xShare, yShare);
                userSignShare.should.have.properties(['wShare', 'kShare']);
                const { wShare, kShare } = userSignShare;
                wShare.should.have.property('gamma').and.be.a.String();
                wShare.should.have.property('w').and.be.a.String();
                wShare.should.have.property('k').and.be.a.String();
                wShare.should.have.property('ck').and.be.a.String();
                wShare.should.have.property('h2').and.be.a.String();
                wShare.should.have.property('h1').and.be.a.String();
                wShare.should.have.property('ntilde').and.be.a.String();
                wShare.should.have.property('y').and.be.a.String();
                wShare.should.have.property('n').and.be.a.String();
                wShare.should.have.property('m').and.be.a.String();
                wShare.should.have.property('l').and.be.a.String();
                wShare.should.have.property('i').and.be.a.Number();
                kShare['i'].should.equal(3);
                kShare['j'].should.equal(1);
                kShare.should.have.property('n').and.be.a.String();
                kShare.should.have.property('k').and.be.a.String();
                kShare.should.have.property('ntilde').and.be.a.String();
                kShare.should.have.property('h1').and.be.a.String();
                kShare.should.have.property('h2').and.be.a.String();
            });
            it('should fail if the Xshare doesnt belong to the User', async function () {
                let xShare = mpc.appendChallenge(userKey.xShare, sdk_test_1.mockSerializedChallengeWithProofs, userToBitGoPaillierChallenge);
                xShare = { ...xShare, i: 3 };
                const yShare = mpc.appendChallenge(userKey.yShares[3], {
                    ntilde: xShare.ntilde,
                    h1: xShare.h1,
                    h2: xShare.h2,
                }, bitgoToUserPaillierChallenge);
                await sdk_core_1.ECDSAMethods.createUserSignShare(xShare, yShare).should.be.rejectedWith(`Invalid XShare, XShare doesn't belong to the User`);
            });
        });
        describe('createUserGammaAndMuShare:', async function () {
            it('should succeed to create User Gamma Share and MuShare', async function () {
                const userShare = await sdk_core_1.ECDSAMethods.createUserGammaAndMuShare(ecdsaFixtures_1.gammaAndMuShareCreationParams.wShare, ecdsaFixtures_1.gammaAndMuShareCreationParams.aShare);
                userShare.should.have.properties(['muShare', 'gShare']);
                const { muShare, gShare } = userShare;
                muShare?.i?.should.equal(3);
                muShare?.j?.should.equal(1);
                muShare?.should.have.property('alpha').and.be.a.String();
                muShare?.should.have.property('mu').and.be.a.String();
                gShare?.should.have.property('beta').and.be.a.String();
                gShare?.should.have.property('nu').and.be.a.String();
            });
            it('should fail if the Wshare / AShare doesnt belong to the User', async function () {
                const invalidWShare = { ...ecdsaFixtures_1.gammaAndMuShareCreationParams.wShare, i: 3 };
                const invalidAShare = { ...ecdsaFixtures_1.gammaAndMuShareCreationParams.aShare, i: 3 };
                await sdk_core_1.ECDSAMethods.createUserGammaAndMuShare(invalidWShare, ecdsaFixtures_1.gammaAndMuShareCreationParams.aShare).should.be.rejectedWith(`Invalid WShare, doesn't belong to the User`);
                await sdk_core_1.ECDSAMethods.createUserGammaAndMuShare(ecdsaFixtures_1.gammaAndMuShareCreationParams.wShare, invalidAShare).should.be.rejectedWith(`Invalid AShare, is not from Bitgo to User`);
            });
        });
        describe('createUserOmicronAndDeltaShare:', async function () {
            it('should succeed to create User Omicron and Mu Shares', async function () {
                const userShare = await sdk_core_1.ECDSAMethods.createUserOmicronAndDeltaShare(ecdsaFixtures_1.omicronAndDeltaShareCreationParams.gShare);
                userShare.should.have.properties(['dShare', 'oShare']);
                const { dShare, oShare } = userShare;
                dShare?.i?.should.equal(3);
                dShare?.j?.should.equal(1);
                dShare?.should.have.property('delta').and.be.a.String();
                dShare?.should.have.property('Gamma').and.be.a.String();
                oShare?.should.have.property('omicron').and.be.a.String();
                oShare?.should.have.property('delta').and.be.a.String();
            });
            it(`should fail if the gShare doesn't belong to the User`, async function () {
                const invalidGShare = { ...ecdsaFixtures_1.omicronAndDeltaShareCreationParams.gShare, i: 3 };
                await sdk_core_1.ECDSAMethods.createUserOmicronAndDeltaShare(invalidGShare).should.be.rejectedWith(`Invalid GShare, doesn't belong to the User`);
            });
        });
        describe('createUserSignatureShare:', async function () {
            afterEach(function () {
                nock.cleanAll();
            });
            it('should succeed to create User Signature Share', async function () {
                const userSignatureShare = await sdk_core_1.ECDSAMethods.createUserSignatureShare(ecdsaFixtures_1.createUserSignatureParams.oShare, ecdsaFixtures_1.createUserSignatureParams.dShare, signablePayload);
                const { R, s, y, i } = userSignatureShare;
                i.should.be.Number();
                R.should.be.a.String();
                s.should.be.a.String();
                y.should.be.a.String();
            });
            it(`should fail if the OShare / dShare doesn't belong to the User`, async function () {
                const invalidOShare = { ...ecdsaFixtures_1.createUserSignatureParams.oShare, i: 3 };
                await sdk_core_1.ECDSAMethods.createUserSignatureShare(invalidOShare, ecdsaFixtures_1.createUserSignatureParams.dShare, signablePayload).should.be.rejectedWith(`Invalid OShare, doesn't belong to the User`);
                const invalidDShare = { ...ecdsaFixtures_1.createUserSignatureParams.dShare, i: 3 };
                await sdk_core_1.ECDSAMethods.createUserSignatureShare(ecdsaFixtures_1.createUserSignatureParams.oShare, invalidDShare, signablePayload).should.be.rejectedWith(`Invalid DShare, doesn't seem to be from BitGo`);
            });
        });
        describe('sendSignatureShare Tests', async function () {
            afterEach(function () {
                nock.cleanAll();
            });
            const mockAShareString = sdk_core_1.ECDSAMethods.convertAShare(ecdsaFixtures_1.mockAShare).share;
            const mockDShareString = sdk_core_1.ECDSAMethods.convertDShare(ecdsaFixtures_1.mockDShare).share;
            const config = [
                {
                    shareToSend: 'KShare',
                    mockShareToSend: ecdsaFixtures_1.mockSignRT.kShare,
                    mockShareToSendString: sdk_core_1.ECDSAMethods.convertKShare(ecdsaFixtures_1.mockSignRT.kShare).share,
                    sendType: sdk_core_1.ECDSAMethodTypes.SendShareType.KShare,
                    mockShareAsResponse: ecdsaFixtures_1.mockAShare,
                    mockShareAsResponseString: mockAShareString,
                    shareReceived: 'AShare',
                    incorrectReceivedShareString: ecdsaFixtures_1.mockAShare.k,
                    signerShare: 'a valid signer share',
                },
                {
                    shareToSend: 'MUShare',
                    mockShareToSend: { muShare: ecdsaFixtures_1.mockMuShare, dShare: ecdsaFixtures_1.mockDShareToBitgo, i: ecdsaFixtures_1.mockMuShare.i },
                    mockShareToSendString: `${sdk_core_1.ECDSAMethods.convertMuShare(ecdsaFixtures_1.mockMuShare).share}${sdk_core_1.ECDSAMethods.secondaryDelimeter}${sdk_core_1.ECDSAMethods.convertDShare(ecdsaFixtures_1.mockDShareToBitgo).share}`,
                    sendType: sdk_core_1.ECDSAMethodTypes.SendShareType.MUShare,
                    mockShareAsResponse: ecdsaFixtures_1.mockDShare,
                    mockShareAsResponseString: mockDShareString,
                    shareReceived: 'DShare',
                    incorrectReceivedShareString: ecdsaFixtures_1.mockDShare.Gamma,
                },
            ];
            for (let index = 0; index < config.length; index++) {
                describe(`sendSignatureShare: ${config[index].shareToSend}`, async function () {
                    it(`should succeed to send ${config[index].shareToSend}`, async function () {
                        const mockSendReq = {
                            from: 'user',
                            to: 'bitgo',
                            share: config[index].mockShareToSendString,
                        };
                        const shareRecord = {
                            from: 'bitgo',
                            to: 'user',
                            share: config[index].mockShareAsResponseString,
                        };
                        await (0, helpers_1.nockSendSignatureShare)({
                            walletId: wallet.id(),
                            txRequestId: txRequest.txRequestId,
                            signatureShare: mockSendReq,
                            response: shareRecord,
                            tssType: 'ecdsa',
                            signerShare: config[index].signerShare,
                        });
                        txRequest.signatureShares = [shareRecord];
                        const response = { txRequests: [{ transactions: [{ ...txRequest }] }] };
                        await (0, helpers_1.nockGetTxRequest)({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response: response });
                        const responseAShare = await sdk_core_1.ECDSAMethods.sendShareToBitgo(bitgo, wallet.id(), txRequest.txRequestId, sdk_core_1.RequestType.tx, config[index].sendType, config[index].mockShareToSend, config[index].signerShare);
                        responseAShare.should.deepEqual(config[index].mockShareAsResponse);
                    });
                    it(`should fail if we get an invalid ${config[index].shareReceived} as response`, async function () {
                        const mockSendReq = {
                            from: 'user',
                            to: 'bitgo',
                            share: config[index].mockShareToSendString,
                        };
                        const invalidSignatureShare = {
                            from: 'bitgo',
                            to: 'user',
                            share: JSON.stringify(config[index].incorrectReceivedShareString),
                        };
                        const nock = await (0, helpers_1.nockSendSignatureShare)({
                            walletId: wallet.id(),
                            txRequestId: txRequest.txRequestId,
                            signatureShare: mockSendReq,
                            response: invalidSignatureShare,
                            tssType: 'ecdsa',
                            signerShare: config[index].signerShare,
                        }, 200);
                        txRequest.signatureShares = [invalidSignatureShare];
                        const response = { txRequests: [{ transactions: [{ ...txRequest }] }] };
                        await (0, helpers_1.nockGetTxRequest)({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response: response });
                        await sdk_core_1.ECDSAMethods.sendShareToBitgo(bitgo, wallet.id(), txRequest.txRequestId, sdk_core_1.RequestType.tx, config[index].sendType, config[index].mockShareToSend, config[index].signerShare).should.be.rejectedWith(/Invalid .* share/g); // `Invalid ${shareName} share`
                        nock.isDone().should.equal(true);
                    });
                });
            }
        });
        describe('getTxRequest:', async function () {
            afterEach(function () {
                nock.cleanAll();
            });
            it('should succeed to get txRequest by id', async function () {
                const response = { txRequests: [txRequest] };
                const nock = await (0, helpers_1.nockGetTxRequest)({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response });
                const txReq = await (0, sdk_core_1.getTxRequest)(bitgo, wallet.id(), txRequest.txRequestId);
                txReq.should.deepEqual(txRequest);
                nock.isDone().should.equal(true);
            });
            it('should fail if there are no txRequests', async function () {
                const response = { txRequests: [] };
                const nock = await (0, helpers_1.nockGetTxRequest)({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response });
                await (0, sdk_core_1.getTxRequest)(bitgo, wallet.id(), txRequest.txRequestId).should.be.rejectedWith('Unable to find TxRequest with id randomId');
                nock.isDone().should.equal(true);
            });
        });
        describe('signing share parsers and converters', function () {
            afterEach(function () {
                nock.cleanAll();
            });
            it('should successfully parse K share', function () {
                const bitgoKShare = ecdsaFixtures_1.mockSignWithPaillierChallengeRT.kShare;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: sdk_core_1.ECDSAMethods.convertKShare(ecdsaFixtures_1.mockSignWithPaillierChallengeRT.kShare).share,
                };
                const kShare = sdk_core_1.ECDSAMethods.parseKShare(share);
                kShare.should.deepEqual(bitgoKShare);
            });
            it('should successfully convert K share to signature share record', function () {
                const bitgoKShare = ecdsaFixtures_1.mockSignWithPaillierChallengeRT.kShare;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockSignRT.kShare.k}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.n}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.ntilde}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.h1}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.h2}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSignRT.kShare.proof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${bitgoKShare.p.join(sdk_core_1.ECDSAMethods.delimeter)}${sdk_core_1.ECDSAMethods.delimeter}${bitgoKShare.sigma.join(sdk_core_1.ECDSAMethods.delimeter)}`,
                };
                const kshare = sdk_core_1.ECDSAMethods.convertKShare(bitgoKShare);
                kshare.from.should.equal(share.from);
                kshare.to.should.equal(share.to);
                kshare.share.should.equal(share.share);
            });
            it('should successfully parse A share without paillier challenge', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.USER,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: sdk_core_1.ECDSAMethods.convertAShare(ecdsaFixtures_1.mockAShare).share,
                };
                const aShare = sdk_core_1.ECDSAMethods.parseAShare(share);
                should.exist(aShare);
                aShare.should.deepEqual(ecdsaFixtures_1.mockAShare);
            });
            it('should successfully parse A share', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.USER,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: sdk_core_1.ECDSAMethods.convertAShare(ecdsaFixtures_1.mockAShare).share,
                };
                const aShare = sdk_core_1.ECDSAMethods.parseAShare(share);
                should.exist(aShare);
                aShare.should.deepEqual(ecdsaFixtures_1.mockAShare);
            });
            it('should successfully convert A share to signature share record', function () {
                const mockShare = ecdsaFixtures_1.mockAShare;
                const share = {
                    to: sdk_core_1.SignatureShareType.USER,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${mockShare.k}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.alpha}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.mu}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.n}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.ntilde}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.h1}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.h2}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.proof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.zprm || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.t || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.v || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.t1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.t2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.gammaProof?.x || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.zprm || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.t || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.v || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.t1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.t2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.wProof?.x || ''}${sdk_core_1.ECDSAMethods.delimeter}${mockShare.sigma.join(sdk_core_1.ECDSAMethods.delimeter)}`,
                };
                const aShare = sdk_core_1.ECDSAMethods.convertAShare(mockShare);
                aShare.from.should.equal(share.from);
                aShare.to.should.equal(share.to);
                aShare.share.should.equal(share.share);
            });
            it('should successfully parse Mu share', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: sdk_core_1.ECDSAMethods.convertMuShare(ecdsaFixtures_1.mockMuShare).share,
                };
                const muShare = sdk_core_1.ECDSAMethods.parseMuShare(share);
                muShare.i.should.equal(ecdsaFixtures_1.mockMuShare.i);
                muShare.j.should.equal(ecdsaFixtures_1.mockMuShare.j);
                muShare.alpha.should.equal(ecdsaFixtures_1.mockMuShare.alpha);
                muShare.mu.should.equal(ecdsaFixtures_1.mockMuShare.mu);
            });
            it('should successfully convert Mu share to signature share record', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockMuShare.alpha}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.mu}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.zprm || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.t || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.v || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.t1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.t2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.gammaProof?.x || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.z || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.zprm || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.t || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.v || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.w || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.s || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.s1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.s2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.t1 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.t2 || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.u || ''}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockMuShare.wProof?.x || ''}`,
                };
                const muShare = sdk_core_1.ECDSAMethods.convertMuShare(ecdsaFixtures_1.mockMuShare);
                muShare.from.should.equal(share.from);
                muShare.to.should.equal(share.to);
                muShare.share.should.equal(share.share);
            });
            it('should successfully parse D share', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: sdk_core_1.ECDSAMethods.convertDShare(ecdsaFixtures_1.mockDShareToBitgo).share,
                };
                const dShare = sdk_core_1.ECDSAMethods.parseDShare(share);
                dShare.i.should.equal(ecdsaFixtures_1.mockDShareToBitgo.i);
                dShare.j.should.equal(ecdsaFixtures_1.mockDShareToBitgo.j);
                dShare.delta.should.equal(ecdsaFixtures_1.mockDShareToBitgo.delta);
                dShare.Gamma.should.equal(ecdsaFixtures_1.mockDShareToBitgo.Gamma);
            });
            it('should successfully convert D share to signature share record', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockDShareToBitgo.delta}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockDShareToBitgo.Gamma}`,
                };
                const dShare = sdk_core_1.ECDSAMethods.convertDShare(ecdsaFixtures_1.mockDShareToBitgo);
                dShare.from.should.equal(share.from);
                dShare.to.should.equal(share.to);
                dShare.share.should.equal(share.share);
            });
            it('should successfully parse S and D share', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockSShareFromUser.R}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.s}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.y}${sdk_core_1.ECDSAMethods.secondaryDelimeter}${ecdsaFixtures_1.mockDShareToBitgo.delta}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockDShareToBitgo.Gamma}`,
                };
                const { sShare, dShare } = sdk_core_1.ECDSAMethods.parseSDShare(share);
                sShare.i.should.equal(3);
                sShare.R.should.equal(ecdsaFixtures_1.mockSShareFromUser.R);
                sShare.s.should.equal(ecdsaFixtures_1.mockSShareFromUser.s);
                sShare.y.should.equal(ecdsaFixtures_1.mockSShareFromUser.y);
                dShare.i.should.equal(ecdsaFixtures_1.mockDShareToBitgo.i);
                dShare.j.should.equal(ecdsaFixtures_1.mockDShareToBitgo.j);
                dShare.delta.should.equal(ecdsaFixtures_1.mockDShareToBitgo.delta);
                dShare.Gamma.should.equal(ecdsaFixtures_1.mockDShareToBitgo.Gamma);
            });
            it('should successfully convert S and D share to signature share record', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockSShareFromUser.R}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.s}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.y}${sdk_core_1.ECDSAMethods.secondaryDelimeter}${ecdsaFixtures_1.mockDShareToBitgo.delta}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockDShareToBitgo.Gamma}`,
                };
                const sdShare = sdk_core_1.ECDSAMethods.convertSDShare({ sShare: ecdsaFixtures_1.mockSShareFromUser, dShare: ecdsaFixtures_1.mockDShareToBitgo });
                sdShare.from.should.equal(share.from);
                sdShare.to.should.equal(share.to);
                sdShare.share.should.equal(share.share);
            });
            it('should successfully parse signature share', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.USER,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${ecdsaFixtures_1.mockSShareFromUser.R}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.s}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.y}`,
                };
                const signature = sdk_core_1.ECDSAMethods.parseSignatureShare(share);
                signature.i.should.equal(1);
                signature.R.should.equal(ecdsaFixtures_1.mockSShareFromUser.R);
                signature.s.should.equal(ecdsaFixtures_1.mockSShareFromUser.s);
                signature.y.should.equal(ecdsaFixtures_1.mockSShareFromUser.y);
            });
            it('should succuesfully parse combined signature', function () {
                const mockCombinedSignature = mpc.constructSignature([ecdsaFixtures_1.mockSShareFromUser, ecdsaFixtures_1.mockSShare]);
                const share = {
                    to: sdk_core_1.SignatureShareType.USER,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${mockCombinedSignature.recid}${sdk_core_1.ECDSAMethods.delimeter}${mockCombinedSignature.r}${sdk_core_1.ECDSAMethods.delimeter}${mockCombinedSignature.s}${sdk_core_1.ECDSAMethods.delimeter}${mockCombinedSignature.y}`,
                };
                const signature = sdk_core_1.ECDSAMethods.parseCombinedSignature(share);
                signature.recid.should.equal(mockCombinedSignature.recid);
                signature.r.should.equal(mockCombinedSignature.r);
                signature.s.should.equal(mockCombinedSignature.s);
                signature.y.should.equal(mockCombinedSignature.y);
            });
            it('should successfully convert signature share to signature share record', function () {
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.USER,
                    share: `${ecdsaFixtures_1.mockSShareFromUser.R}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.s}${sdk_core_1.ECDSAMethods.delimeter}${ecdsaFixtures_1.mockSShareFromUser.y}`,
                };
                const signatureShare = sdk_core_1.ECDSAMethods.convertSignatureShare(ecdsaFixtures_1.mockSShareFromUser, sdk_core_1.ECDSAMethods.getParticipantIndex('user'), sdk_core_1.ECDSAMethods.getParticipantIndex('bitgo'));
                signatureShare.from.should.equal(share.from);
                signatureShare.to.should.equal(share.to);
                signatureShare.share.should.equal(share.share);
            });
            it('should successfully convert B share to signature share record', function () {
                const bShare = ecdsaFixtures_1.mockedBitgoBShare.bShare;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${bShare.beta}${sdk_core_1.ECDSAMethods.delimeter}${bShare.gamma}${sdk_core_1.ECDSAMethods.delimeter}${bShare.k}${sdk_core_1.ECDSAMethods.delimeter}${bShare.nu}${sdk_core_1.ECDSAMethods.delimeter}${bShare.w}${sdk_core_1.ECDSAMethods.delimeter}${bShare.y}${sdk_core_1.ECDSAMethods.delimeter}${bShare.l}${sdk_core_1.ECDSAMethods.delimeter}${bShare.m}${sdk_core_1.ECDSAMethods.delimeter}${bShare.n}${sdk_core_1.ECDSAMethods.delimeter}${bShare.ntilde}${sdk_core_1.ECDSAMethods.delimeter}${bShare.h1}${sdk_core_1.ECDSAMethods.delimeter}${bShare.h2}${sdk_core_1.ECDSAMethods.delimeter}${bShare.ck}${sdk_core_1.ECDSAMethods.delimeter}${bShare.p.join(sdk_core_1.ECDSAMethods.delimeter)}`,
                };
                const signatureShare = sdk_core_1.ECDSAMethods.convertBShare(bShare);
                signatureShare.from.should.equal(share.from);
                signatureShare.to.should.equal(share.to);
                signatureShare.share.should.equal(share.share);
            });
            it('should successfully parse B share', function () {
                const bShare = ecdsaFixtures_1.mockedBitgoBShare.bShare;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: sdk_core_1.ECDSAMethods.convertBShare(ecdsaFixtures_1.mockedBitgoBShare.bShare).share,
                };
                const parsedBShare = sdk_core_1.ECDSAMethods.parseBShare(share);
                parsedBShare.should.deepEqual(bShare);
            });
            it('should successfully convert O share to signature share record', function () {
                const oShare = ecdsaFixtures_1.mockedBitgoOAndDShare.oShare;
                const delimeter = sdk_core_1.ECDSAMethods.delimeter;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${oShare.Gamma}${delimeter}${oShare.delta}${delimeter}${oShare.k}${delimeter}${oShare.omicron}${delimeter}${oShare.y}`,
                };
                const oShareSigRecord = sdk_core_1.ECDSAMethods.convertOShare(oShare);
                oShareSigRecord.from.should.equal(share.from);
                oShareSigRecord.to.should.equal(share.to);
                oShareSigRecord.share.should.equal(share.share);
            });
            it('should successfully parse O share', function () {
                const oShare = ecdsaFixtures_1.mockedBitgoOAndDShare.oShare;
                const delimeter = sdk_core_1.ECDSAMethods.delimeter;
                const share = {
                    to: sdk_core_1.SignatureShareType.BITGO,
                    from: sdk_core_1.SignatureShareType.BITGO,
                    share: `${oShare.Gamma}${delimeter}${oShare.delta}${delimeter}${oShare.k}${delimeter}${oShare.omicron}${delimeter}${oShare.y}`,
                };
                const parsedOShare = sdk_core_1.ECDSAMethods.parseOShare(share);
                parsedOShare.i.should.equal(oShare.i);
                parsedOShare.y.should.equal(oShare.y);
                parsedOShare.k.should.equal(oShare.k);
                parsedOShare.omicron.should.equal(oShare.omicron);
                parsedOShare.delta.should.equal(oShare.delta);
                parsedOShare.Gamma.should.equal(oShare.Gamma);
            });
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../test/v2/unit/tss/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Ecdsa,\n  ECDSA,\n  ECDSAMethodTypes,\n  Wallet,\n  SignatureShareRecord,\n  getTxRequest,\n  ECDSAMethods,\n  RequestType,\n  SignatureShareType,\n  hexToBigInt,\n} from '@bitgo/sdk-core';\nimport { EcdsaTypes, EcdsaPaillierProof } from '@bitgo/sdk-lib-mpc';\nimport * as openpgp from 'openpgp';\nimport * as should from 'should';\nimport { mockSerializedChallengeWithProofs, TestBitGo } from '@bitgo/sdk-test';\nimport { BitGo } from '../../../../src';\nimport { nockGetTxRequest, nockSendSignatureShare } from './helpers';\nimport {\n  gammaAndMuShareCreationParams,\n  omicronAndDeltaShareCreationParams,\n  keyShares,\n  createUserSignatureParams,\n  mockSignRT,\n  mockAShare,\n  mockMuShare,\n  mockDShare,\n  mockSShareFromUser,\n  mockDShareToBitgo,\n  mockedBitgoBShare,\n  mockedBitgoOAndDShare,\n  mockSShare,\n  mockSignWithPaillierChallengeRT,\n} from '../../fixtures/tss/ecdsaFixtures';\n\nimport nock = require('nock');\n\ntype KeyShare = ECDSA.KeyShare;\nconst encryptNShare = ECDSAMethods.encryptNShare;\nconst createCombinedKey = ECDSAMethods.createCombinedKey;\ntype GpgKeypair = {\n  publicKey: string;\n  privateKey: string;\n};\n\ndescribe('Ecdsa tss helper functions tests', function () {\n  let mpc: Ecdsa;\n\n  let userKeyShare: KeyShare;\n  let backupKeyShare: KeyShare;\n  let bitgoKeyShare: KeyShare;\n\n  let userKey: ECDSA.KeyCombined;\n  let backupKey: ECDSA.KeyCombined;\n  let bitgoKey: ECDSA.KeyCombined;\n\n  let userGpgKeypair: GpgKeypair;\n  let backupGpgKeypair: GpgKeypair;\n  let bitgoGpgKeypair: GpgKeypair;\n  let commonKeychain: string;\n\n  before(async function () {\n    mpc = new Ecdsa();\n    userKeyShare = keyShares.userKeyShare;\n    backupKeyShare = keyShares.backupKeyShare;\n    bitgoKeyShare = keyShares.bitgoKeyShare;\n\n    userKey = mpc.keyCombine(userKeyShare.pShare, [backupKeyShare.nShares[1], bitgoKeyShare.nShares[1]]);\n    backupKey = mpc.keyCombine(backupKeyShare.pShare, [userKeyShare.nShares[2], bitgoKeyShare.nShares[2]]);\n    bitgoKey = mpc.keyCombine(bitgoKeyShare.pShare, [backupKeyShare.nShares[3], userKeyShare.nShares[3]]);\n\n    (userKey.xShare.y + userKey.xShare.chaincode).should.equal(backupKey.xShare.y + backupKey.xShare.chaincode);\n    (userKey.xShare.y + userKey.xShare.chaincode).should.equal(bitgoKey.xShare.y + bitgoKey.xShare.chaincode);\n    commonKeychain = userKey.xShare.y + userKey.xShare.chaincode;\n    const gpgKeypairPromises = [\n      { name: 'user', email: 'user@bitgo.com' },\n      { name: 'backup', email: 'backup@bitgo.com' },\n      { name: 'bitgo', email: 'bitgo@bitgo.com' },\n    ].map(async (user) => {\n      return openpgp.generateKey({\n        userIDs: [\n          {\n            name: user.name,\n            email: user.email,\n          },\n        ],\n        curve: 'secp256k1',\n      });\n    });\n\n    const gpgKeypairs = await Promise.all(gpgKeypairPromises);\n    userGpgKeypair = gpgKeypairs[0];\n    backupGpgKeypair = gpgKeypairs[1];\n    bitgoGpgKeypair = gpgKeypairs[2];\n  });\n\n  after(function () {\n    nock.cleanAll();\n  });\n\n  describe('encryptNShare and decryptNShare', function () {\n    after(function () {\n      nock.cleanAll();\n    });\n\n    it('should encrypt n shares foreach user', async function () {\n      for (let i = 2; i <= 3; i++) {\n        const encryptedNShare = await ECDSAMethods.encryptNShare(\n          userKeyShare,\n          i,\n          bitgoGpgKeypair.publicKey,\n          userGpgKeypair\n        );\n        const decryptedNShare = await ECDSAMethods.decryptNShare({\n          nShare: encryptedNShare,\n          senderPublicArmor: userGpgKeypair.publicKey,\n          recipientPrivateArmor: bitgoGpgKeypair.privateKey,\n        });\n        decryptedNShare.u.should.equal(userKeyShare.nShares[i].u);\n        const publicKey = userKeyShare.pShare.y + userKeyShare.pShare.chaincode;\n        encryptedNShare.i.should.equal(i);\n        encryptedNShare.vssProof!.should.equal(userKeyShare.nShares[3].v!);\n        encryptedNShare.j.should.equal(1);\n        encryptedNShare.publicShare.should.equal(publicKey);\n      }\n    });\n\n    it('should error for invalid recipient', async function () {\n      await encryptNShare(userKeyShare, 1, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith(\n        'Invalid recipient'\n      );\n      await encryptNShare(backupKeyShare, 2, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith(\n        'Invalid recipient'\n      );\n      await encryptNShare(bitgoKeyShare, 3, userGpgKeypair.privateKey, userGpgKeypair).should.be.rejectedWith(\n        'Invalid recipient'\n      );\n    });\n\n    it('should decrypt n share', async function () {\n      const encryptedNShare = await ECDSAMethods.encryptNShare(\n        userKeyShare,\n        3,\n        bitgoGpgKeypair.publicKey,\n        userGpgKeypair\n      );\n      const decryptedNShare = await ECDSAMethods.decryptNShare({\n        nShare: encryptedNShare,\n        recipientPrivateArmor: bitgoGpgKeypair.privateKey,\n        senderPublicArmor: userGpgKeypair.publicKey,\n      });\n      decryptedNShare.i.should.equal(userKeyShare.nShares[3].i);\n      decryptedNShare.j.should.equal(userKeyShare.nShares[3].j);\n      decryptedNShare.n.should.equal(userKeyShare.nShares[3].n);\n      decryptedNShare.u.should.equal(userKeyShare.nShares[3].u);\n      decryptedNShare.y.should.equal(userKeyShare.nShares[3].y);\n    });\n  });\n\n  describe('createCombinedKey', function () {\n    after(function () {\n      nock.cleanAll();\n    });\n\n    it('should create combined user key', async function () {\n      const bitgoToUserShare = await ECDSAMethods.encryptNShare(\n        bitgoKeyShare,\n        1,\n        userGpgKeypair.publicKey,\n        userGpgKeypair,\n        false\n      );\n      const backupToUserShare = await ECDSAMethods.encryptNShare(\n        backupKeyShare,\n        1,\n        userGpgKeypair.publicKey,\n        userGpgKeypair,\n        false\n      );\n      const combinedUserKey = await createCombinedKey(\n        userKeyShare,\n        [\n          {\n            nShare: bitgoToUserShare,\n            recipientPrivateArmor: userGpgKeypair.privateKey,\n            senderPublicArmor: bitgoGpgKeypair.publicKey,\n            isbs58Encoded: false,\n          },\n          {\n            nShare: backupToUserShare,\n            recipientPrivateArmor: userGpgKeypair.privateKey,\n            senderPublicArmor: backupGpgKeypair.publicKey,\n            isbs58Encoded: false,\n          },\n        ],\n        commonKeychain\n      );\n\n      combinedUserKey.commonKeychain.should.equal(commonKeychain);\n      combinedUserKey.signingMaterial.pShare.should.deepEqual(userKeyShare.pShare);\n      should.exist(combinedUserKey.signingMaterial.backupNShare);\n      combinedUserKey.signingMaterial.backupNShare?.should.deepEqual(backupKeyShare.nShares[1]);\n      combinedUserKey.signingMaterial.bitgoNShare.should.deepEqual(bitgoKeyShare.nShares[1]);\n      should.not.exist(combinedUserKey.signingMaterial.userNShare);\n    });\n\n    it('should create combined backup key', async function () {\n      const bitgoToBackupShare = await encryptNShare(bitgoKeyShare, 2, backupGpgKeypair.publicKey, userGpgKeypair);\n\n      const userToBackupShare = await encryptNShare(userKeyShare, 2, backupGpgKeypair.publicKey, userGpgKeypair);\n\n      const combinedBackupKey = await createCombinedKey(\n        backupKeyShare,\n        [\n          {\n            nShare: bitgoToBackupShare,\n            recipientPrivateArmor: backupGpgKeypair.privateKey,\n            senderPublicArmor: bitgoGpgKeypair.publicKey,\n          },\n          {\n            nShare: userToBackupShare,\n            recipientPrivateArmor: backupGpgKeypair.privateKey,\n            senderPublicArmor: userGpgKeypair.publicKey,\n          },\n        ],\n        commonKeychain\n      );\n\n      combinedBackupKey.commonKeychain.should.equal(commonKeychain);\n      combinedBackupKey.signingMaterial.pShare.should.deepEqual(backupKeyShare.pShare);\n      should.exist(combinedBackupKey.signingMaterial.userNShare);\n      combinedBackupKey.signingMaterial.userNShare?.should.deepEqual(userKeyShare.nShares[2]);\n      combinedBackupKey.signingMaterial.bitgoNShare.should.deepEqual(bitgoKeyShare.nShares[2]);\n      should.not.exist(combinedBackupKey.signingMaterial.backupNShare);\n    });\n\n    it('should fail if common keychains do not match', async function () {\n      const bitgoToUserShare = await encryptNShare(bitgoKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);\n      const backupToUserShare = await encryptNShare(backupKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);\n\n      // this should fail to combine the keys because we pass in invalid common key chain\n      await createCombinedKey(\n        userKeyShare,\n        [\n          {\n            nShare: bitgoToUserShare,\n            recipientPrivateArmor: userGpgKeypair.privateKey,\n            senderPublicArmor: bitgoGpgKeypair.publicKey,\n          },\n          {\n            nShare: backupToUserShare,\n            recipientPrivateArmor: userGpgKeypair.privateKey,\n            senderPublicArmor: backupGpgKeypair.publicKey,\n          },\n        ],\n        'nottherightkeychain'\n      ).should.be.rejectedWith('Common keychains do not match');\n    });\n\n    it('should fail if gpg keys are mismatched', async function () {\n      const bitgoToUserShare = await encryptNShare(bitgoKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);\n      const backupToUserShare = await encryptNShare(backupKeyShare, 1, userGpgKeypair.publicKey, userGpgKeypair);\n\n      await createCombinedKey(\n        userKeyShare,\n        [\n          {\n            nShare: bitgoToUserShare,\n            recipientPrivateArmor: backupGpgKeypair.privateKey,\n            senderPublicArmor: bitgoGpgKeypair.publicKey,\n          },\n          {\n            nShare: backupToUserShare,\n            recipientPrivateArmor: userGpgKeypair.privateKey,\n            senderPublicArmor: backupGpgKeypair.publicKey,\n          },\n        ],\n        'nottherightkeychain'\n      ).should.be.rejectedWith('Error decrypting message: Session key decryption failed.');\n    });\n  });\n\n  describe('tss signing helper function', async function () {\n    const bitgo = TestBitGo.decorate(BitGo, { env: 'mock' });\n    bitgo.initializeTestVars();\n\n    let wallet: Wallet;\n    const txRequest = {\n      txRequestId: 'randomId',\n      unsignedTxs: [{ signableHex: 'TOO MANY SECRETS', serializedTxHex: 'randomhex2' }],\n      signatureShares: [\n        {\n          from: 'bitgo',\n          to: 'user',\n          share: '',\n        },\n      ],\n    };\n    const signablePayload = Buffer.from(txRequest.unsignedTxs[0].signableHex, 'hex');\n\n    before('initializes', async function () {\n      const baseCoin = bitgo.coin('hteth');\n      const walletData = {\n        id: '5b34252f1bf349930e34020a00000000',\n        coin: 'hteth',\n        keys: [\n          '5b3424f91bf349930e34017500000000',\n          '5b3424f91bf349930e34017600000000',\n          '5b3424f91bf349930e34017700000000',\n        ],\n        coinSpecific: {},\n      };\n      wallet = new Wallet(bitgo, baseCoin, walletData);\n    });\n\n    describe('createUserSignShare:', async function () {\n      let userToBitGoPaillierChallenge: EcdsaTypes.SerializedPaillierChallenge;\n      let bitgoToUserPaillierChallenge: EcdsaTypes.SerializedPaillierChallenge;\n\n      before(async function () {\n        userToBitGoPaillierChallenge = EcdsaTypes.serializePaillierChallenge({\n          p: await EcdsaPaillierProof.generateP(hexToBigInt(userKey.yShares[3].n)),\n        });\n        bitgoToUserPaillierChallenge = EcdsaTypes.serializePaillierChallenge({\n          p: await EcdsaPaillierProof.generateP(hexToBigInt(userKey.xShare.n)),\n        });\n      });\n\n      it('should succeed to create User SignShare', async function () {\n        const xShare = mpc.appendChallenge(\n          userKey.xShare,\n          mockSerializedChallengeWithProofs,\n          userToBitGoPaillierChallenge\n        );\n        const yShare = mpc.appendChallenge(\n          userKey.yShares[3],\n          { ntilde: xShare.ntilde, h1: xShare.h1, h2: xShare.h2 },\n          bitgoToUserPaillierChallenge\n        );\n        const userSignShare = await ECDSAMethods.createUserSignShare(xShare, yShare);\n        userSignShare.should.have.properties(['wShare', 'kShare']);\n        const { wShare, kShare } = userSignShare;\n        wShare.should.have.property('gamma').and.be.a.String();\n        wShare.should.have.property('w').and.be.a.String();\n        wShare.should.have.property('k').and.be.a.String();\n        wShare.should.have.property('ck').and.be.a.String();\n        wShare.should.have.property('h2').and.be.a.String();\n        wShare.should.have.property('h1').and.be.a.String();\n        wShare.should.have.property('ntilde').and.be.a.String();\n        wShare.should.have.property('y').and.be.a.String();\n        wShare.should.have.property('n').and.be.a.String();\n        wShare.should.have.property('m').and.be.a.String();\n        wShare.should.have.property('l').and.be.a.String();\n        wShare.should.have.property('i').and.be.a.Number();\n        kShare['i'].should.equal(3);\n        kShare['j'].should.equal(1);\n        kShare.should.have.property('n').and.be.a.String();\n        kShare.should.have.property('k').and.be.a.String();\n        kShare.should.have.property('ntilde').and.be.a.String();\n        kShare.should.have.property('h1').and.be.a.String();\n        kShare.should.have.property('h2').and.be.a.String();\n      });\n\n      it('should fail if the Xshare doesnt belong to the User', async function () {\n        let xShare = mpc.appendChallenge(\n          userKey.xShare,\n          mockSerializedChallengeWithProofs,\n          userToBitGoPaillierChallenge\n        );\n        xShare = { ...xShare, i: 3 };\n        const yShare = mpc.appendChallenge(\n          userKey.yShares[3],\n          {\n            ntilde: xShare.ntilde,\n            h1: xShare.h1,\n            h2: xShare.h2,\n          },\n          bitgoToUserPaillierChallenge\n        );\n        await ECDSAMethods.createUserSignShare(xShare, yShare).should.be.rejectedWith(\n          `Invalid XShare, XShare doesn't belong to the User`\n        );\n      });\n    });\n\n    describe('createUserGammaAndMuShare:', async function () {\n      it('should succeed to create User Gamma Share and MuShare', async function () {\n        const userShare = await ECDSAMethods.createUserGammaAndMuShare(\n          gammaAndMuShareCreationParams.wShare,\n          gammaAndMuShareCreationParams.aShare\n        );\n        userShare.should.have.properties(['muShare', 'gShare']);\n        const { muShare, gShare } = userShare;\n        muShare?.i?.should.equal(3);\n        muShare?.j?.should.equal(1);\n        muShare?.should.have.property('alpha').and.be.a.String();\n        muShare?.should.have.property('mu').and.be.a.String();\n        gShare?.should.have.property('beta').and.be.a.String();\n        gShare?.should.have.property('nu').and.be.a.String();\n      });\n\n      it('should fail if the Wshare / AShare doesnt belong to the User', async function () {\n        const invalidWShare = { ...gammaAndMuShareCreationParams.wShare, i: 3 };\n        const invalidAShare = { ...gammaAndMuShareCreationParams.aShare, i: 3 };\n        await ECDSAMethods.createUserGammaAndMuShare(\n          invalidWShare,\n          gammaAndMuShareCreationParams.aShare\n        ).should.be.rejectedWith(`Invalid WShare, doesn't belong to the User`);\n        await ECDSAMethods.createUserGammaAndMuShare(\n          gammaAndMuShareCreationParams.wShare,\n          invalidAShare\n        ).should.be.rejectedWith(`Invalid AShare, is not from Bitgo to User`);\n      });\n    });\n\n    describe('createUserOmicronAndDeltaShare:', async function () {\n      it('should succeed to create User Omicron and Mu Shares', async function () {\n        const userShare = await ECDSAMethods.createUserOmicronAndDeltaShare(omicronAndDeltaShareCreationParams.gShare);\n        userShare.should.have.properties(['dShare', 'oShare']);\n        const { dShare, oShare } = userShare;\n        dShare?.i?.should.equal(3);\n        dShare?.j?.should.equal(1);\n        dShare?.should.have.property('delta').and.be.a.String();\n        dShare?.should.have.property('Gamma').and.be.a.String();\n        oShare?.should.have.property('omicron').and.be.a.String();\n        oShare?.should.have.property('delta').and.be.a.String();\n      });\n\n      it(`should fail if the gShare doesn't belong to the User`, async function () {\n        const invalidGShare = { ...omicronAndDeltaShareCreationParams.gShare, i: 3 };\n        await ECDSAMethods.createUserOmicronAndDeltaShare(invalidGShare).should.be.rejectedWith(\n          `Invalid GShare, doesn't belong to the User`\n        );\n      });\n    });\n\n    describe('createUserSignatureShare:', async function () {\n      afterEach(function () {\n        nock.cleanAll();\n      });\n\n      it('should succeed to create User Signature Share', async function () {\n        const userSignatureShare = await ECDSAMethods.createUserSignatureShare(\n          createUserSignatureParams.oShare,\n          createUserSignatureParams.dShare,\n          signablePayload\n        );\n        const { R, s, y, i } = userSignatureShare;\n        i.should.be.Number();\n        R.should.be.a.String();\n        s.should.be.a.String();\n        y.should.be.a.String();\n      });\n\n      it(`should fail if the OShare / dShare doesn't belong to the User`, async function () {\n        const invalidOShare = { ...createUserSignatureParams.oShare, i: 3 };\n        await ECDSAMethods.createUserSignatureShare(\n          invalidOShare,\n          createUserSignatureParams.dShare,\n          signablePayload\n        ).should.be.rejectedWith(`Invalid OShare, doesn't belong to the User`);\n        const invalidDShare = { ...createUserSignatureParams.dShare, i: 3 };\n        await ECDSAMethods.createUserSignatureShare(\n          createUserSignatureParams.oShare,\n          invalidDShare,\n          signablePayload\n        ).should.be.rejectedWith(`Invalid DShare, doesn't seem to be from BitGo`);\n      });\n    });\n\n    describe('sendSignatureShare Tests', async function () {\n      afterEach(function () {\n        nock.cleanAll();\n      });\n\n      const mockAShareString = ECDSAMethods.convertAShare(mockAShare).share;\n      const mockDShareString = ECDSAMethods.convertDShare(mockDShare).share;\n      const config = [\n        {\n          shareToSend: 'KShare',\n          mockShareToSend: mockSignRT.kShare,\n          mockShareToSendString: ECDSAMethods.convertKShare(mockSignRT.kShare).share,\n          sendType: ECDSAMethodTypes.SendShareType.KShare,\n          mockShareAsResponse: mockAShare,\n          mockShareAsResponseString: mockAShareString,\n          shareReceived: 'AShare',\n          incorrectReceivedShareString: mockAShare.k,\n          signerShare: 'a valid signer share',\n        },\n        {\n          shareToSend: 'MUShare',\n          mockShareToSend: { muShare: mockMuShare, dShare: mockDShareToBitgo, i: mockMuShare.i },\n          mockShareToSendString: `${ECDSAMethods.convertMuShare(mockMuShare).share}${ECDSAMethods.secondaryDelimeter}${\n            ECDSAMethods.convertDShare(mockDShareToBitgo).share\n          }`,\n          sendType: ECDSAMethodTypes.SendShareType.MUShare,\n          mockShareAsResponse: mockDShare,\n          mockShareAsResponseString: mockDShareString,\n          shareReceived: 'DShare',\n          incorrectReceivedShareString: mockDShare.Gamma,\n        },\n      ];\n\n      for (let index = 0; index < config.length; index++) {\n        describe(`sendSignatureShare: ${config[index].shareToSend}`, async function () {\n          it(`should succeed to send ${config[index].shareToSend}`, async function () {\n            const mockSendReq = {\n              from: 'user',\n              to: 'bitgo',\n              share: config[index].mockShareToSendString,\n            } as SignatureShareRecord;\n            const shareRecord = {\n              from: 'bitgo',\n              to: 'user',\n              share: config[index].mockShareAsResponseString,\n            } as SignatureShareRecord;\n            await nockSendSignatureShare({\n              walletId: wallet.id(),\n              txRequestId: txRequest.txRequestId,\n              signatureShare: mockSendReq,\n              response: shareRecord,\n              tssType: 'ecdsa',\n              signerShare: config[index].signerShare,\n            });\n            txRequest.signatureShares = [shareRecord];\n            const response = { txRequests: [{ transactions: [{ ...txRequest }] }] };\n            await nockGetTxRequest({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response: response });\n            const responseAShare = await ECDSAMethods.sendShareToBitgo(\n              bitgo,\n              wallet.id(),\n              txRequest.txRequestId,\n              RequestType.tx,\n              config[index].sendType,\n              config[index].mockShareToSend,\n              config[index].signerShare\n            );\n            responseAShare.should.deepEqual(config[index].mockShareAsResponse);\n          });\n\n          it(`should fail if we get an invalid ${config[index].shareReceived} as response`, async function () {\n            const mockSendReq = {\n              from: 'user',\n              to: 'bitgo',\n              share: config[index].mockShareToSendString,\n            } as SignatureShareRecord;\n            const invalidSignatureShare = {\n              from: 'bitgo',\n              to: 'user',\n              share: JSON.stringify(config[index].incorrectReceivedShareString),\n            } as SignatureShareRecord;\n            const nock = await nockSendSignatureShare(\n              {\n                walletId: wallet.id(),\n                txRequestId: txRequest.txRequestId,\n                signatureShare: mockSendReq,\n                response: invalidSignatureShare,\n                tssType: 'ecdsa',\n                signerShare: config[index].signerShare,\n              },\n              200\n            );\n            txRequest.signatureShares = [invalidSignatureShare];\n            const response = { txRequests: [{ transactions: [{ ...txRequest }] }] };\n            await nockGetTxRequest({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response: response });\n            await ECDSAMethods.sendShareToBitgo(\n              bitgo,\n              wallet.id(),\n              txRequest.txRequestId,\n              RequestType.tx,\n              config[index].sendType,\n              config[index].mockShareToSend,\n              config[index].signerShare\n            ).should.be.rejectedWith(/Invalid .* share/g); // `Invalid ${shareName} share`\n            nock.isDone().should.equal(true);\n          });\n        });\n      }\n    });\n\n    describe('getTxRequest:', async function () {\n      afterEach(function () {\n        nock.cleanAll();\n      });\n\n      it('should succeed to get txRequest by id', async function () {\n        const response = { txRequests: [txRequest] };\n        const nock = await nockGetTxRequest({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response });\n        const txReq = await getTxRequest(bitgo, wallet.id(), txRequest.txRequestId);\n        txReq.should.deepEqual(txRequest);\n        nock.isDone().should.equal(true);\n      });\n\n      it('should fail if there are no txRequests', async function () {\n        const response = { txRequests: [] };\n        const nock = await nockGetTxRequest({ walletId: wallet.id(), txRequestId: txRequest.txRequestId, response });\n        await getTxRequest(bitgo, wallet.id(), txRequest.txRequestId).should.be.rejectedWith(\n          'Unable to find TxRequest with id randomId'\n        );\n        nock.isDone().should.equal(true);\n      });\n    });\n\n    describe('signing share parsers and converters', function () {\n      afterEach(function () {\n        nock.cleanAll();\n      });\n\n      it('should successfully parse K share', function () {\n        const bitgoKShare = mockSignWithPaillierChallengeRT.kShare;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: ECDSAMethods.convertKShare(mockSignWithPaillierChallengeRT.kShare).share,\n        } as SignatureShareRecord;\n        const kShare = ECDSAMethods.parseKShare(share);\n        kShare.should.deepEqual(bitgoKShare);\n      });\n\n      it('should successfully convert K share to signature share record', function () {\n        const bitgoKShare = mockSignWithPaillierChallengeRT.kShare;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockSignRT.kShare.k}${ECDSAMethods.delimeter}${mockSignRT.kShare.n}${ECDSAMethods.delimeter}${\n            mockSignRT.kShare.ntilde\n          }${ECDSAMethods.delimeter}${mockSignRT.kShare.h1}${ECDSAMethods.delimeter}${mockSignRT.kShare.h2}${\n            ECDSAMethods.delimeter\n          }${mockSignRT.kShare.proof?.z || ''}${ECDSAMethods.delimeter}${mockSignRT.kShare.proof?.u || ''}${\n            ECDSAMethods.delimeter\n          }${mockSignRT.kShare.proof?.w || ''}${ECDSAMethods.delimeter}${mockSignRT.kShare.proof?.s || ''}${\n            ECDSAMethods.delimeter\n          }${mockSignRT.kShare.proof?.s1 || ''}${ECDSAMethods.delimeter}${mockSignRT.kShare.proof?.s2 || ''}${\n            ECDSAMethods.delimeter\n          }${bitgoKShare.p.join(ECDSAMethods.delimeter)}${ECDSAMethods.delimeter}${bitgoKShare.sigma.join(\n            ECDSAMethods.delimeter\n          )}`,\n        } as SignatureShareRecord;\n\n        const kshare = ECDSAMethods.convertKShare(bitgoKShare);\n        kshare.from.should.equal(share.from);\n        kshare.to.should.equal(share.to);\n        kshare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse A share without paillier challenge', function () {\n        const share = {\n          to: SignatureShareType.USER,\n          from: SignatureShareType.BITGO,\n          share: ECDSAMethods.convertAShare(mockAShare).share,\n        } as SignatureShareRecord;\n        const aShare = ECDSAMethods.parseAShare(share);\n        should.exist(aShare);\n        aShare.should.deepEqual(mockAShare);\n      });\n\n      it('should successfully parse A share', function () {\n        const share = {\n          to: SignatureShareType.USER,\n          from: SignatureShareType.BITGO,\n          share: ECDSAMethods.convertAShare(mockAShare).share,\n        } as SignatureShareRecord;\n        const aShare = ECDSAMethods.parseAShare(share);\n        should.exist(aShare);\n        aShare.should.deepEqual(mockAShare);\n      });\n\n      it('should successfully convert A share to signature share record', function () {\n        const mockShare = mockAShare;\n        const share = {\n          to: SignatureShareType.USER,\n          from: SignatureShareType.BITGO,\n          share: `${mockShare.k}${ECDSAMethods.delimeter}${mockShare.alpha}${ECDSAMethods.delimeter}${mockShare.mu}${\n            ECDSAMethods.delimeter\n          }${mockShare.n}${ECDSAMethods.delimeter}${mockShare.ntilde}${ECDSAMethods.delimeter}${mockShare.h1}${\n            ECDSAMethods.delimeter\n          }${mockShare.h2}${ECDSAMethods.delimeter}${mockShare.proof?.z || ''}${ECDSAMethods.delimeter}${\n            mockShare.proof?.u || ''\n          }${ECDSAMethods.delimeter}${mockShare.proof?.w || ''}${ECDSAMethods.delimeter}${mockShare.proof?.s || ''}${\n            ECDSAMethods.delimeter\n          }${mockShare.proof?.s1 || ''}${ECDSAMethods.delimeter}${mockShare.proof?.s2 || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.z || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.zprm || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.t || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.v || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.w || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.s || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.s1 || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.s2 || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.t1 || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.t2 || ''}${ECDSAMethods.delimeter}${\n            mockShare.gammaProof?.u || ''\n          }${ECDSAMethods.delimeter}${mockShare.gammaProof?.x || ''}${ECDSAMethods.delimeter}${\n            mockShare.wProof?.z || ''\n          }${ECDSAMethods.delimeter}${mockShare.wProof?.zprm || ''}${ECDSAMethods.delimeter}${\n            mockShare.wProof?.t || ''\n          }${ECDSAMethods.delimeter}${mockShare.wProof?.v || ''}${ECDSAMethods.delimeter}${mockShare.wProof?.w || ''}${\n            ECDSAMethods.delimeter\n          }${mockShare.wProof?.s || ''}${ECDSAMethods.delimeter}${mockShare.wProof?.s1 || ''}${ECDSAMethods.delimeter}${\n            mockShare.wProof?.s2 || ''\n          }${ECDSAMethods.delimeter}${mockShare.wProof?.t1 || ''}${ECDSAMethods.delimeter}${\n            mockShare.wProof?.t2 || ''\n          }${ECDSAMethods.delimeter}${mockShare.wProof?.u || ''}${ECDSAMethods.delimeter}${mockShare.wProof?.x || ''}${\n            ECDSAMethods.delimeter\n          }${mockShare.sigma!.join(ECDSAMethods.delimeter)}`,\n        } as SignatureShareRecord;\n\n        const aShare = ECDSAMethods.convertAShare(mockShare);\n        aShare.from.should.equal(share.from);\n        aShare.to.should.equal(share.to);\n        aShare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse Mu share', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: ECDSAMethods.convertMuShare(mockMuShare).share,\n        } as SignatureShareRecord;\n        const muShare = ECDSAMethods.parseMuShare(share);\n        muShare.i.should.equal(mockMuShare.i);\n        muShare.j.should.equal(mockMuShare.j);\n        muShare.alpha.should.equal(mockMuShare.alpha);\n        muShare.mu.should.equal(mockMuShare.mu);\n      });\n\n      it('should successfully convert Mu share to signature share record', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockMuShare.alpha}${ECDSAMethods.delimeter}${mockMuShare.mu}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.z || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.zprm || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.t || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.v || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.w || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.s || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.s1 || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.s2 || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.t1 || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.t2 || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.gammaProof?.u || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.gammaProof?.x || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.z || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.zprm || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.t || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.v || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.w || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.s || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.s1 || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.s2 || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.t1 || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.t2 || ''}${ECDSAMethods.delimeter}${\n            mockMuShare.wProof?.u || ''\n          }${ECDSAMethods.delimeter}${mockMuShare.wProof?.x || ''}`,\n        } as SignatureShareRecord;\n        const muShare = ECDSAMethods.convertMuShare(mockMuShare);\n        muShare.from.should.equal(share.from);\n        muShare.to.should.equal(share.to);\n        muShare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse D share', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: ECDSAMethods.convertDShare(mockDShareToBitgo).share,\n        } as SignatureShareRecord;\n        const dShare = ECDSAMethods.parseDShare(share);\n        dShare.i.should.equal(mockDShareToBitgo.i);\n        dShare.j.should.equal(mockDShareToBitgo.j);\n        dShare.delta.should.equal(mockDShareToBitgo.delta);\n        dShare.Gamma.should.equal(mockDShareToBitgo.Gamma);\n      });\n\n      it('should successfully convert D share to signature share record', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockDShareToBitgo.delta}${ECDSAMethods.delimeter}${mockDShareToBitgo.Gamma}`,\n        } as SignatureShareRecord;\n        const dShare = ECDSAMethods.convertDShare(mockDShareToBitgo);\n        dShare.from.should.equal(share.from);\n        dShare.to.should.equal(share.to);\n        dShare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse S and D share', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockSShareFromUser.R}${ECDSAMethods.delimeter}${mockSShareFromUser.s}${ECDSAMethods.delimeter}${mockSShareFromUser.y}${ECDSAMethods.secondaryDelimeter}${mockDShareToBitgo.delta}${ECDSAMethods.delimeter}${mockDShareToBitgo.Gamma}`,\n        } as SignatureShareRecord;\n        const { sShare, dShare } = ECDSAMethods.parseSDShare(share);\n        sShare.i.should.equal(3);\n        sShare.R.should.equal(mockSShareFromUser.R);\n        sShare.s.should.equal(mockSShareFromUser.s);\n        sShare.y.should.equal(mockSShareFromUser.y);\n        dShare.i.should.equal(mockDShareToBitgo.i);\n        dShare.j.should.equal(mockDShareToBitgo.j);\n        dShare.delta.should.equal(mockDShareToBitgo.delta);\n        dShare.Gamma.should.equal(mockDShareToBitgo.Gamma);\n      });\n\n      it('should successfully convert S and D share to signature share record', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockSShareFromUser.R}${ECDSAMethods.delimeter}${mockSShareFromUser.s}${ECDSAMethods.delimeter}${mockSShareFromUser.y}${ECDSAMethods.secondaryDelimeter}${mockDShareToBitgo.delta}${ECDSAMethods.delimeter}${mockDShareToBitgo.Gamma}`,\n        } as SignatureShareRecord;\n        const sdShare = ECDSAMethods.convertSDShare({ sShare: mockSShareFromUser, dShare: mockDShareToBitgo });\n        sdShare.from.should.equal(share.from);\n        sdShare.to.should.equal(share.to);\n        sdShare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse signature share', function () {\n        const share = {\n          to: SignatureShareType.USER,\n          from: SignatureShareType.BITGO,\n          share: `${mockSShareFromUser.R}${ECDSAMethods.delimeter}${mockSShareFromUser.s}${ECDSAMethods.delimeter}${mockSShareFromUser.y}`,\n        } as SignatureShareRecord;\n        const signature = ECDSAMethods.parseSignatureShare(share);\n        signature.i.should.equal(1);\n        signature.R.should.equal(mockSShareFromUser.R);\n        signature.s.should.equal(mockSShareFromUser.s);\n        signature.y.should.equal(mockSShareFromUser.y);\n      });\n\n      it('should succuesfully parse combined signature', function () {\n        const mockCombinedSignature = mpc.constructSignature([mockSShareFromUser, mockSShare]);\n        const share = {\n          to: SignatureShareType.USER,\n          from: SignatureShareType.BITGO,\n          share: `${mockCombinedSignature.recid}${ECDSAMethods.delimeter}${mockCombinedSignature.r}${ECDSAMethods.delimeter}${mockCombinedSignature.s}${ECDSAMethods.delimeter}${mockCombinedSignature.y}`,\n        } as SignatureShareRecord;\n        const signature = ECDSAMethods.parseCombinedSignature(share);\n        signature.recid.should.equal(mockCombinedSignature.recid);\n        signature.r.should.equal(mockCombinedSignature.r);\n        signature.s.should.equal(mockCombinedSignature.s);\n        signature.y.should.equal(mockCombinedSignature.y);\n      });\n\n      it('should successfully convert signature share to signature share record', function () {\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.USER,\n          share: `${mockSShareFromUser.R}${ECDSAMethods.delimeter}${mockSShareFromUser.s}${ECDSAMethods.delimeter}${mockSShareFromUser.y}`,\n        } as SignatureShareRecord;\n        const signatureShare = ECDSAMethods.convertSignatureShare(\n          mockSShareFromUser,\n          ECDSAMethods.getParticipantIndex('user'),\n          ECDSAMethods.getParticipantIndex('bitgo')\n        );\n        signatureShare.from.should.equal(share.from);\n        signatureShare.to.should.equal(share.to);\n        signatureShare.share.should.equal(share.share);\n      });\n\n      it('should successfully convert B share to signature share record', function () {\n        const bShare = mockedBitgoBShare.bShare;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.BITGO,\n          share: `${bShare.beta}${ECDSAMethods.delimeter}${bShare.gamma}${ECDSAMethods.delimeter}${bShare.k}${\n            ECDSAMethods.delimeter\n          }${bShare.nu}${ECDSAMethods.delimeter}${bShare.w}${ECDSAMethods.delimeter}${bShare.y}${\n            ECDSAMethods.delimeter\n          }${bShare.l}${ECDSAMethods.delimeter}${bShare.m}${ECDSAMethods.delimeter}${bShare.n}${\n            ECDSAMethods.delimeter\n          }${bShare.ntilde}${ECDSAMethods.delimeter}${bShare.h1}${ECDSAMethods.delimeter}${bShare.h2}${\n            ECDSAMethods.delimeter\n          }${bShare.ck}${ECDSAMethods.delimeter}${bShare.p!.join(ECDSAMethods.delimeter)}`,\n        } as SignatureShareRecord;\n        const signatureShare = ECDSAMethods.convertBShare(bShare);\n        signatureShare.from.should.equal(share.from);\n        signatureShare.to.should.equal(share.to);\n        signatureShare.share.should.equal(share.share);\n      });\n\n      it('should successfully parse B share', function () {\n        const bShare = mockedBitgoBShare.bShare;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.BITGO,\n          share: ECDSAMethods.convertBShare(mockedBitgoBShare.bShare).share,\n        } as SignatureShareRecord;\n        const parsedBShare = ECDSAMethods.parseBShare(share);\n        parsedBShare.should.deepEqual(bShare);\n      });\n\n      it('should successfully convert O share to signature share record', function () {\n        const oShare = mockedBitgoOAndDShare.oShare;\n        const delimeter = ECDSAMethods.delimeter;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.BITGO,\n          share: `${oShare.Gamma}${delimeter}${oShare.delta}${delimeter}${oShare.k}${delimeter}${oShare.omicron}${delimeter}${oShare.y}`,\n        } as SignatureShareRecord;\n        const oShareSigRecord = ECDSAMethods.convertOShare(oShare);\n        oShareSigRecord.from.should.equal(share.from);\n        oShareSigRecord.to.should.equal(share.to);\n        oShareSigRecord.share.should.equal(share.share);\n      });\n\n      it('should successfully parse O share', function () {\n        const oShare = mockedBitgoOAndDShare.oShare;\n        const delimeter = ECDSAMethods.delimeter;\n        const share = {\n          to: SignatureShareType.BITGO,\n          from: SignatureShareType.BITGO,\n          share: `${oShare.Gamma}${delimeter}${oShare.delta}${delimeter}${oShare.k}${delimeter}${oShare.omicron}${delimeter}${oShare.y}`,\n        } as SignatureShareRecord;\n        const parsedOShare = ECDSAMethods.parseOShare(share);\n        parsedOShare.i.should.equal(oShare.i);\n        parsedOShare.y.should.equal(oShare.y);\n        parsedOShare.k.should.equal(oShare.k);\n        parsedOShare.omicron.should.equal(oShare.omicron);\n        parsedOShare.delta.should.equal(oShare.delta);\n        parsedOShare.Gamma.should.equal(oShare.Gamma);\n      });\n    });\n  });\n});\n"]}

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


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