PHP WebShell

Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/test/bitgo/psbt

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const mocha_1 = require("mocha");
const src_1 = require("../../../src");
const bitgo_1 = require("../../../src/bitgo");
const testutil_1 = require("../../../src/testutil");
const outputScripts_1 = require("../../../src/bitgo/outputScripts");
const fromHalfSigned_1 = require("../../../src/bitgo/psbt/fromHalfSigned");
const transaction_util_1 = require("../../transaction_util");
const fixture_util_1 = require("../../fixture.util");
const normalize_1 = require("../../testutil/normalize");
const bs58check = require("bs58check");
function getScriptTypes2Of3() {
    // FIXME(BG-66941): p2trMusig2 signing does not work in this test suite yet
    //  because the test suite is written with TransactionBuilder
    return bitgo_1.outputScripts.scriptTypes2Of3.filter((scriptType) => scriptType !== 'p2trMusig2');
}
function getScriptTypes() {
    return [...getScriptTypes2Of3(), 'p2shP2pk'];
}
const walletKeys = (0, testutil_1.getDefaultWalletKeys)();
function runTest(scriptType, signer, cosigner, network) {
    const signerName = (0, testutil_1.getKeyName)(walletKeys.triple, signer);
    const cosignerName = (0, testutil_1.getKeyName)(walletKeys.triple, cosigner);
    const networkName = (0, src_1.getNetworkName)(network);
    const signingKeys = [
        signerName === 'user' || cosignerName === 'user',
        signerName === 'backup' || cosignerName === 'backup',
        signerName === 'bitgo' || cosignerName === 'bitgo',
    ];
    (0, mocha_1.describe)(`UtxoPsbt ${[
        `scriptType=${scriptType}`,
        `network=${networkName}`,
        `signer=${signerName}`,
        `cosigner=${cosignerName}`,
    ].join(',')}`, function () {
        let prevOutputs;
        let unsigned;
        let halfSigned;
        let fullSigned;
        before('create transaction', function () {
            prevOutputs = (0, transaction_util_1.getPrevOutputs)(scriptType, BigInt(1e8), network, {
                keys: walletKeys.triple,
                prevTx: (scriptType === 'p2sh' || scriptType === 'p2shP2pk') && (0, src_1.getNetworkName)(network) !== 'zcash',
            });
            ({ unsigned, halfSigned, fullSigned } = (0, transaction_util_1.getTransactionStages)(walletKeys.triple, signer, cosigner, scriptType, network, {
                amountType: 'bigint',
                outputAmount: BigInt(1e8),
                prevOutputs,
            }));
        });
        function testGetInputUpdateForStage(stage) {
            (0, mocha_1.it)(`has getInputUpdate with expected value, stage=${stage}`, async function () {
                const tx = stage === 'unsigned' ? unsigned : halfSigned;
                const vin = 0;
                const inputUpdate = (0, fromHalfSigned_1.getInputUpdate)(tx, vin, prevOutputs);
                assert.deepStrictEqual((0, normalize_1.normDefault)(inputUpdate), await (0, fixture_util_1.readFixture)(`test/bitgo/fixtures/psbt/inputUpdate.${scriptType}.${stage}.${signerName}-${cosignerName}.json`, inputUpdate));
            });
        }
        testGetInputUpdateForStage('unsigned');
        testGetInputUpdateForStage('halfSigned');
        (0, mocha_1.it)('has equal unsigned tx', function () {
            assert.strictEqual(bitgo_1.UtxoPsbt.fromTransaction(unsigned, prevOutputs).getUnsignedTx().toBuffer().toString('hex'), unsigned.toBuffer().toString('hex'));
            if (scriptType !== 'p2shP2pk') {
                assert.strictEqual(bitgo_1.UtxoPsbt.fromTransaction(halfSigned, prevOutputs).getUnsignedTx().toBuffer().toString('hex'), unsigned.toBuffer().toString('hex'));
            }
        });
        function signPsbt(startTx, signers) {
            const psbt = bitgo_1.UtxoPsbt.fromTransaction(startTx, prevOutputs);
            psbt.updateGlobal({
                globalXpub: walletKeys.triple.map((bip32) => {
                    const masterFingerprint = Buffer.alloc(4);
                    masterFingerprint.writeUInt32BE(bip32.parentFingerprint);
                    const extendedPubkey = bip32.neutered().toBase58();
                    return {
                        extendedPubkey: bs58check.decode(extendedPubkey),
                        masterFingerprint,
                        path: 'm',
                    };
                }),
            });
            signers.forEach((s) => {
                if (scriptType === 'p2tr') {
                    psbt.signTaprootInput(0, s, [
                        (0, outputScripts_1.getLeafHash)({
                            publicKeys: walletKeys.publicKeys,
                            signer: signer.publicKey,
                            cosigner: cosigner.publicKey,
                        }),
                    ]);
                }
                else {
                    psbt.signAllInputs(s);
                }
            });
            assert.deepStrictEqual(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }), signingKeys);
            psbt.finalizeAllInputs();
            return psbt.extractTransaction();
        }
        (0, mocha_1.it)('can go from unsigned to full-signed', function () {
            // TODO(BG-57748): inputs lack some required information
            this.skip();
            assert.deepStrictEqual(signPsbt(unsigned, [signer, cosigner]).toBuffer().toString('hex'), fullSigned.toBuffer().toString('hex'));
        });
        (0, mocha_1.it)('can go from half-signed to full-signed', function () {
            if (scriptType === 'p2shP2pk') {
                this.skip();
            }
            assert.deepStrictEqual(signPsbt(halfSigned, [cosigner]).toBuffer().toString('hex'), fullSigned.toBuffer().toString('hex'));
        });
    });
}
getScriptTypes().forEach((t) => {
    runTest(t, walletKeys.user, walletKeys.bitgo, src_1.networks.bitcoin);
    runTest(t, walletKeys.backup, walletKeys.user, src_1.networks.bitcoin);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fromHalfSigned.js","sourceRoot":"","sources":["../../../../test/bitgo/psbt/fromHalfSigned.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport { describe, it } from 'mocha';\n\nimport { BIP32Interface, getNetworkName, Network, networks } from '../../../src';\nimport { outputScripts, PrevOutput, UtxoPsbt, UtxoTransaction } from '../../../src/bitgo';\nimport { getDefaultWalletKeys, getKeyName } from '../../../src/testutil';\nimport { getLeafHash } from '../../../src/bitgo/outputScripts';\nimport { getInputUpdate } from '../../../src/bitgo/psbt/fromHalfSigned';\n\nimport { getPrevOutputs, getTransactionStages } from '../../transaction_util';\n\nimport { readFixture } from '../../fixture.util';\nimport { normDefault } from '../../testutil/normalize';\nimport * as bs58check from 'bs58check';\n\nfunction getScriptTypes2Of3() {\n  // FIXME(BG-66941): p2trMusig2 signing does not work in this test suite yet\n  //  because the test suite is written with TransactionBuilder\n  return outputScripts.scriptTypes2Of3.filter((scriptType) => scriptType !== 'p2trMusig2');\n}\n\nfunction getScriptTypes(): outputScripts.ScriptType[] {\n  return [...getScriptTypes2Of3(), 'p2shP2pk'];\n}\n\nconst walletKeys = getDefaultWalletKeys();\n\nfunction runTest(\n  scriptType: outputScripts.ScriptType,\n  signer: BIP32Interface,\n  cosigner: BIP32Interface,\n  network: Network\n) {\n  const signerName = getKeyName(walletKeys.triple, signer);\n  const cosignerName = getKeyName(walletKeys.triple, cosigner);\n  const networkName = getNetworkName(network);\n  const signingKeys = [\n    signerName === 'user' || cosignerName === 'user',\n    signerName === 'backup' || cosignerName === 'backup',\n    signerName === 'bitgo' || cosignerName === 'bitgo',\n  ];\n  describe(`UtxoPsbt ${[\n    `scriptType=${scriptType}`,\n    `network=${networkName}`,\n    `signer=${signerName}`,\n    `cosigner=${cosignerName}`,\n  ].join(',')}`, function () {\n    let prevOutputs: PrevOutput<bigint>[];\n    let unsigned: UtxoTransaction<bigint>;\n    let halfSigned: UtxoTransaction<bigint>;\n    let fullSigned: UtxoTransaction<bigint>;\n    before('create transaction', function () {\n      prevOutputs = getPrevOutputs(scriptType, BigInt(1e8), network, {\n        keys: walletKeys.triple,\n        prevTx: (scriptType === 'p2sh' || scriptType === 'p2shP2pk') && getNetworkName(network) !== 'zcash',\n      });\n      ({ unsigned, halfSigned, fullSigned } = getTransactionStages(\n        walletKeys.triple,\n        signer,\n        cosigner,\n        scriptType,\n        network,\n        {\n          amountType: 'bigint',\n          outputAmount: BigInt(1e8),\n          prevOutputs,\n        }\n      ));\n    });\n\n    function testGetInputUpdateForStage(stage: 'unsigned' | 'halfSigned') {\n      it(`has getInputUpdate with expected value, stage=${stage}`, async function () {\n        const tx = stage === 'unsigned' ? unsigned : halfSigned;\n        const vin = 0;\n        const inputUpdate = getInputUpdate(tx, vin, prevOutputs);\n        assert.deepStrictEqual(\n          normDefault(inputUpdate),\n          await readFixture(\n            `test/bitgo/fixtures/psbt/inputUpdate.${scriptType}.${stage}.${signerName}-${cosignerName}.json`,\n            inputUpdate\n          )\n        );\n      });\n    }\n\n    testGetInputUpdateForStage('unsigned');\n    testGetInputUpdateForStage('halfSigned');\n\n    it('has equal unsigned tx', function () {\n      assert.strictEqual(\n        UtxoPsbt.fromTransaction(unsigned, prevOutputs).getUnsignedTx().toBuffer().toString('hex'),\n        unsigned.toBuffer().toString('hex')\n      );\n\n      if (scriptType !== 'p2shP2pk') {\n        assert.strictEqual(\n          UtxoPsbt.fromTransaction(halfSigned, prevOutputs).getUnsignedTx().toBuffer().toString('hex'),\n          unsigned.toBuffer().toString('hex')\n        );\n      }\n    });\n\n    function signPsbt(startTx: UtxoTransaction<bigint>, signers: BIP32Interface[]) {\n      const psbt = UtxoPsbt.fromTransaction(startTx, prevOutputs);\n      psbt.updateGlobal({\n        globalXpub: walletKeys.triple.map((bip32) => {\n          const masterFingerprint = Buffer.alloc(4);\n          masterFingerprint.writeUInt32BE(bip32.parentFingerprint);\n          const extendedPubkey = bip32.neutered().toBase58();\n          return {\n            extendedPubkey: bs58check.decode(extendedPubkey),\n            masterFingerprint,\n            path: 'm',\n          };\n        }),\n      });\n      signers.forEach((s) => {\n        if (scriptType === 'p2tr') {\n          psbt.signTaprootInput(0, s, [\n            getLeafHash({\n              publicKeys: walletKeys.publicKeys,\n              signer: signer.publicKey,\n              cosigner: cosigner.publicKey,\n            }),\n          ]);\n        } else {\n          psbt.signAllInputs(s);\n        }\n      });\n      assert.deepStrictEqual(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }), signingKeys);\n      psbt.finalizeAllInputs();\n      return psbt.extractTransaction();\n    }\n\n    it('can go from unsigned to full-signed', function () {\n      // TODO(BG-57748): inputs lack some required information\n      this.skip();\n      assert.deepStrictEqual(\n        signPsbt(unsigned, [signer, cosigner]).toBuffer().toString('hex'),\n        fullSigned.toBuffer().toString('hex')\n      );\n    });\n\n    it('can go from half-signed to full-signed', function () {\n      if (scriptType === 'p2shP2pk') {\n        this.skip();\n      }\n      assert.deepStrictEqual(\n        signPsbt(halfSigned, [cosigner]).toBuffer().toString('hex'),\n        fullSigned.toBuffer().toString('hex')\n      );\n    });\n  });\n}\n\ngetScriptTypes().forEach((t) => {\n  runTest(t, walletKeys.user, walletKeys.bitgo, networks.bitcoin);\n  runTest(t, walletKeys.backup, walletKeys.user, networks.bitcoin);\n});\n"]}

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


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