PHP WebShell
Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/test/bitgo/psbt
Просмотр файла: signingAndValidation.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const mocha_1 = require("mocha");
const bs58check = require("bs58check");
const testutil_1 = require("../../../src/testutil");
const bitgo_1 = require("../../../src/bitgo");
const src_1 = require("../../../src");
const outputScripts_1 = require("../../../src/bitgo/outputScripts");
function getScriptTypes() {
return [...bitgo_1.outputScripts.scriptTypes2Of3, 'p2shP2pk'];
}
const walletKeys = (0, testutil_1.getDefaultWalletKeys)();
function runTest(scriptType, signerName, cosignerName, network) {
const signer = walletKeys[signerName];
const cosigner = walletKeys[cosignerName];
const networkName = (0, src_1.getNetworkName)(network);
const signingKeys = [
signerName === 'user' || (cosignerName === 'user' && scriptType !== 'p2shP2pk'),
signerName === 'backup' || (cosignerName === 'backup' && scriptType !== 'p2shP2pk'),
signerName === 'bitgo' || (cosignerName === 'bitgo' && scriptType !== 'p2shP2pk'),
];
(0, mocha_1.describe)(`UtxoPsbt ${[
`scriptType=${scriptType}`,
`network=${networkName}`,
`signer=${signerName}`,
`cosigner=${cosignerName}`,
].join(',')}`, function () {
let psbt;
before('create transaction', async function () {
// Build a fully hydrated UtxoPsbt
psbt = (0, bitgo_1.createPsbtForNetwork)({ network });
psbt.updateGlobal({
globalXpub: walletKeys.triple.map((bip32) => {
const extendedPubkey = bip32.neutered().toBase58();
return {
extendedPubkey: bs58check.decode(extendedPubkey),
masterFingerprint: bip32.fingerprint,
path: 'm',
};
}),
});
// Add the inputs
if (scriptType === 'p2shP2pk') {
const unspent = (0, testutil_1.mockReplayProtectionUnspent)(network, BigInt(1e8), { key: signer });
const { redeemScript } = (0, outputScripts_1.createOutputScriptP2shP2pk)(signer.publicKey);
assert(redeemScript);
(0, bitgo_1.addReplayProtectionUnspentToPsbt)(psbt, unspent, redeemScript);
}
else {
const unspents = (0, testutil_1.mockUnspents)(walletKeys, [scriptType], BigInt(1e8), network);
unspents.forEach((unspent) => (0, bitgo_1.addWalletUnspentToPsbt)(psbt, unspent, walletKeys, signerName, cosignerName, {
isReplaceableByFee: true,
}));
}
// Add the outputs
(0, bitgo_1.addWalletOutputToPsbt)(psbt, walletKeys, (0, bitgo_1.getInternalChainCode)('p2sh'), 0, BigInt(1e8 - 10000));
});
(0, mocha_1.it)('can go from unsigned to fully signed', async function () {
if (scriptType === 'p2trMusig2' && signerName === 'user' && cosignerName === 'bitgo') {
psbt.setAllInputsMusig2NonceHD(signer);
psbt.setAllInputsMusig2NonceHD(cosigner);
}
assert.ok(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }).every((res) => !res));
if (scriptType === 'p2shP2pk') {
psbt.signAllInputs(signer);
}
else {
psbt.signAllInputsHD(signer);
psbt.signAllInputsHD(cosigner);
}
assert(psbt.validateSignaturesOfAllInputs());
assert.deepStrictEqual(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }), signingKeys);
psbt.finalizeAllInputs();
const tx = psbt.extractTransaction();
assert(tx);
if (scriptType === 'p2shP2pk') {
tx.ins.forEach((input) => assert.strictEqual(input.sequence, bitgo_1.TX_INPUT_SEQUENCE_NUMBER_FINAL));
}
else {
tx.ins.forEach((input) => assert.strictEqual(input.sequence, bitgo_1.MAX_BIP125_RBF_SEQUENCE));
}
});
});
}
getScriptTypes().forEach((t) => {
runTest(t, 'user', 'bitgo', src_1.networks.bitcoin);
runTest(t, 'backup', 'user', src_1.networks.bitcoin);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signingAndValidation.js","sourceRoot":"","sources":["../../../../test/bitgo/psbt/signingAndValidation.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport { describe, it } from 'mocha';\nimport * as bs58check from 'bs58check';\n\nimport { getDefaultWalletKeys, mockReplayProtectionUnspent, mockUnspents } from '../../../src/testutil';\nimport {\n  addReplayProtectionUnspentToPsbt,\n  addWalletOutputToPsbt,\n  addWalletUnspentToPsbt,\n  createPsbtForNetwork,\n  MAX_BIP125_RBF_SEQUENCE,\n  TX_INPUT_SEQUENCE_NUMBER_FINAL,\n  getInternalChainCode,\n  KeyName,\n  outputScripts,\n  UtxoPsbt,\n  WalletUnspent,\n} from '../../../src/bitgo';\nimport { getNetworkName, Network, networks } from '../../../src';\nimport { createOutputScriptP2shP2pk } from '../../../src/bitgo/outputScripts';\n\nfunction getScriptTypes(): outputScripts.ScriptType[] {\n  return [...outputScripts.scriptTypes2Of3, 'p2shP2pk'];\n}\n\nconst walletKeys = getDefaultWalletKeys();\nfunction runTest(scriptType: outputScripts.ScriptType, signerName: KeyName, cosignerName: KeyName, network: Network) {\n  const signer = walletKeys[signerName];\n  const cosigner = walletKeys[cosignerName];\n\n  const networkName = getNetworkName(network);\n  const signingKeys = [\n    signerName === 'user' || (cosignerName === 'user' && scriptType !== 'p2shP2pk'),\n    signerName === 'backup' || (cosignerName === 'backup' && scriptType !== 'p2shP2pk'),\n    signerName === 'bitgo' || (cosignerName === 'bitgo' && scriptType !== 'p2shP2pk'),\n  ];\n\n  describe(`UtxoPsbt ${[\n    `scriptType=${scriptType}`,\n    `network=${networkName}`,\n    `signer=${signerName}`,\n    `cosigner=${cosignerName}`,\n  ].join(',')}`, function () {\n    let psbt: UtxoPsbt;\n    before('create transaction', async function () {\n      // Build a fully hydrated UtxoPsbt\n      psbt = createPsbtForNetwork({ network });\n      psbt.updateGlobal({\n        globalXpub: walletKeys.triple.map((bip32) => {\n          const extendedPubkey = bip32.neutered().toBase58();\n          return {\n            extendedPubkey: bs58check.decode(extendedPubkey),\n            masterFingerprint: bip32.fingerprint,\n            path: 'm',\n          };\n        }),\n      });\n\n      // Add the inputs\n      if (scriptType === 'p2shP2pk') {\n        const unspent = mockReplayProtectionUnspent(network, BigInt(1e8), { key: signer });\n        const { redeemScript } = createOutputScriptP2shP2pk(signer.publicKey);\n        assert(redeemScript);\n        addReplayProtectionUnspentToPsbt(psbt, unspent, redeemScript);\n      } else {\n        const unspents = mockUnspents(walletKeys, [scriptType], BigInt(1e8), network) as WalletUnspent<bigint>[];\n        unspents.forEach((unspent) =>\n          addWalletUnspentToPsbt(psbt, unspent, walletKeys, signerName, cosignerName, {\n            isReplaceableByFee: true,\n          })\n        );\n      }\n\n      // Add the outputs\n      addWalletOutputToPsbt(psbt, walletKeys, getInternalChainCode('p2sh'), 0, BigInt(1e8 - 10000));\n    });\n\n    it('can go from unsigned to fully signed', async function () {\n      if (scriptType === 'p2trMusig2' && signerName === 'user' && cosignerName === 'bitgo') {\n        psbt.setAllInputsMusig2NonceHD(signer);\n        psbt.setAllInputsMusig2NonceHD(cosigner);\n      }\n      assert.ok(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }).every((res) => !res));\n      if (scriptType === 'p2shP2pk') {\n        psbt.signAllInputs(signer);\n      } else {\n        psbt.signAllInputsHD(signer);\n        psbt.signAllInputsHD(cosigner);\n      }\n      assert(psbt.validateSignaturesOfAllInputs());\n      assert.deepStrictEqual(psbt.getSignatureValidationArray(0, { rootNodes: walletKeys.triple }), signingKeys);\n      psbt.finalizeAllInputs();\n      const tx = psbt.extractTransaction();\n      assert(tx);\n      if (scriptType === 'p2shP2pk') {\n        tx.ins.forEach((input) => assert.strictEqual(input.sequence, TX_INPUT_SEQUENCE_NUMBER_FINAL));\n      } else {\n        tx.ins.forEach((input) => assert.strictEqual(input.sequence, MAX_BIP125_RBF_SEQUENCE));\n      }\n    });\n  });\n}\n\ngetScriptTypes().forEach((t) => {\n  runTest(t, 'user', 'bitgo', networks.bitcoin);\n  runTest(t, 'backup', 'user', networks.bitcoin);\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!