PHP WebShell
Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/test/bitgo/psbt
Просмотр файла: SignVerifyPsbtAndTx.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const bitgo_1 = require("../../../src/bitgo");
const testutil_1 = require("../../../src/testutil");
const src_1 = require("../../../src");
const outputScripts_1 = require("../../../src/bitgo/outputScripts");
const rootWalletKeys = (0, testutil_1.getDefaultWalletKeys)();
const signs = ['unsigned', 'halfsigned', 'fullsigned'];
const neutratedRootWalletKeys = new bitgo_1.RootWalletKeys(rootWalletKeys.triple.map((bip32) => bip32.neutered()), rootWalletKeys.derivationPrefixes);
const psbtInputs = testutil_1.inputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(1000) }));
const psbtOutputs = testutil_1.outputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(900) }));
const txInputs = testutil_1.txnInputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(1000) }));
const txOutputs = testutil_1.txnOutputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(900) }));
function getSigValidArray(scriptType, sign) {
if (scriptType === 'p2shP2pk' || sign === 'unsigned') {
return [false, false, false];
}
if (sign === 'halfsigned') {
return [true, false, false];
}
return scriptType === 'p2trMusig2' ? [true, true, false] : [true, false, true];
}
function signCount(sign) {
return sign === 'unsigned' ? 0 : sign === 'halfsigned' ? 1 : 2;
}
function runPsbt(network, sign, inputs, outputs) {
const coin = (0, src_1.getNetworkName)(network);
const signatureCount = signCount(sign);
describe(`psbt build, sign and verify for ${coin} ${sign}`, function () {
it(`getSignatureValidationArray with globalXpub ${coin} ${sign}`, function () {
const psbt = (0, testutil_1.constructPsbt)(inputs, outputs, network, rootWalletKeys, sign);
(0, bitgo_1.addXpubsToPsbt)(psbt, neutratedRootWalletKeys);
psbt.data.inputs.forEach((input, inputIndex) => {
const isP2shP2pk = inputs[inputIndex].scriptType === 'p2shP2pk';
const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);
psbt.getSignatureValidationArray(inputIndex, { rootNodes: rootWalletKeys.triple }).forEach((sv, i) => {
if (isP2shP2pk && sign !== 'unsigned' && i === 0) {
assert.strictEqual(sv, true);
}
else {
assert.strictEqual(sv, expectedSigValid[i]);
}
});
});
});
it(`getSignatureValidationArray with rootNodes ${coin} ${sign}`, function () {
const psbt = (0, testutil_1.constructPsbt)(inputs, outputs, network, rootWalletKeys, sign);
(0, bitgo_1.addXpubsToPsbt)(psbt, neutratedRootWalletKeys);
psbt.data.inputs.forEach((input, inputIndex) => {
const isP2shP2pk = inputs[inputIndex].scriptType === 'p2shP2pk';
const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);
psbt.getSignatureValidationArray(inputIndex, { rootNodes: neutratedRootWalletKeys.triple }).forEach((sv, i) => {
if (isP2shP2pk && sign !== 'unsigned' && i === 0) {
assert.strictEqual(sv, true);
}
else {
assert.strictEqual(sv, expectedSigValid[i]);
}
});
});
});
it(`getSignatureValidationArrayPsbt ${coin} ${sign}`, function () {
const psbt = (0, testutil_1.constructPsbt)(inputs, outputs, network, rootWalletKeys, sign);
const sigValidations = (0, bitgo_1.getSignatureValidationArrayPsbt)(psbt, neutratedRootWalletKeys);
psbt.data.inputs.forEach((input, inputIndex) => {
const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);
const sigValid = sigValidations.find((sv) => sv[0] === inputIndex);
assert.ok(sigValid);
sigValid[1].forEach((sv, i) => assert.strictEqual(sv, expectedSigValid[i]));
});
});
it(`psbt signature counts ${coin} ${sign}`, function () {
const psbt = (0, testutil_1.constructPsbt)(inputs, outputs, network, rootWalletKeys, sign);
const counts = (0, bitgo_1.getStrictSignatureCounts)(psbt);
const countsFromInputs = (0, bitgo_1.getStrictSignatureCounts)(psbt.data.inputs);
assert.strictEqual(counts.length, psbt.data.inputs.length);
assert.strictEqual(countsFromInputs.length, psbt.data.inputs.length);
psbt.data.inputs.forEach((input, inputIndex) => {
const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' && signatureCount > 0 ? 1 : signatureCount;
assert.strictEqual((0, bitgo_1.getPsbtInputSignatureCount)(input), expectedCount);
assert.strictEqual((0, bitgo_1.getStrictSignatureCount)(input), expectedCount);
assert.strictEqual(counts[inputIndex], expectedCount);
assert.strictEqual(countsFromInputs[inputIndex], expectedCount);
});
if (sign === 'fullsigned') {
const tx = psbt.finalizeAllInputs().extractTransaction();
const counts = (0, bitgo_1.getStrictSignatureCounts)(tx);
const countsFromIns = (0, bitgo_1.getStrictSignatureCounts)(tx.ins);
tx.ins.forEach((input, inputIndex) => {
const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' ? 1 : signatureCount;
assert.strictEqual((0, bitgo_1.getStrictSignatureCount)(input), expectedCount);
assert.strictEqual(counts[inputIndex], expectedCount);
assert.strictEqual(countsFromIns[inputIndex], expectedCount);
});
}
});
});
}
function runTx(network, sign, inputs, outputs) {
const coin = (0, src_1.getNetworkName)(network);
const signatureCount = signCount(sign);
describe(`tx build, sign and verify for ${coin} ${sign}`, function () {
it(`tx signature counts ${coin} ${sign}`, function () {
const txb = (0, testutil_1.constructTxnBuilder)(inputs, outputs, network, rootWalletKeys, sign);
const tx = sign === 'fullsigned' ? txb.build() : txb.buildIncomplete();
const counts = (0, bitgo_1.getStrictSignatureCounts)(tx);
const countsFromIns = (0, bitgo_1.getStrictSignatureCounts)(tx.ins);
assert.strictEqual(counts.length, tx.ins.length);
assert.strictEqual(countsFromIns.length, tx.ins.length);
tx.ins.forEach((input, inputIndex) => {
const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' && signatureCount > 0 ? 1 : signatureCount;
assert.strictEqual((0, bitgo_1.getStrictSignatureCount)(input), expectedCount);
assert.strictEqual(counts[inputIndex], expectedCount);
assert.strictEqual(countsFromIns[inputIndex], expectedCount);
});
});
});
}
signs.forEach((sign) => {
(0, src_1.getNetworkList)()
.filter((v) => (0, src_1.isMainnet)(v) && v !== src_1.networks.bitcoinsv)
.forEach((network) => {
const supportedPsbtInputs = psbtInputs.filter((input) => (0, outputScripts_1.isSupportedScriptType)(network, input.scriptType === 'taprootKeyPathSpend' ? 'p2trMusig2' : input.scriptType));
const supportedPsbtOutputs = psbtOutputs.filter((output) => (0, outputScripts_1.isSupportedScriptType)(network, output.scriptType));
runPsbt(network, sign, supportedPsbtInputs, supportedPsbtOutputs);
const supportedTxInputs = txInputs.filter((input) => (0, outputScripts_1.isSupportedScriptType)(network, input.scriptType));
const supportedTxOutputs = txOutputs.filter((output) => (0, outputScripts_1.isSupportedScriptType)(network, output.scriptType));
runTx(network, sign, supportedTxInputs, supportedTxOutputs);
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SignVerifyPsbtAndTx.js","sourceRoot":"","sources":["../../../../test/bitgo/psbt/SignVerifyPsbtAndTx.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport {\n  addXpubsToPsbt,\n  getPsbtInputSignatureCount,\n  getSignatureValidationArrayPsbt,\n  getStrictSignatureCount,\n  getStrictSignatureCounts,\n  RootWalletKeys,\n  Triple,\n  UtxoTransaction,\n} from '../../../src/bitgo';\nimport { BIP32Interface } from 'bip32';\nimport {\n  constructPsbt,\n  constructTxnBuilder,\n  getDefaultWalletKeys,\n  Input,\n  InputScriptType,\n  inputScriptTypes,\n  Output,\n  outputScriptTypes,\n  TxnInput,\n  txnInputScriptTypes,\n  TxnOutput,\n  txnOutputScriptTypes,\n} from '../../../src/testutil';\nimport { getNetworkList, getNetworkName, isMainnet, Network, networks } from '../../../src';\nimport { isSupportedScriptType } from '../../../src/bitgo/outputScripts';\nimport { SignatureTargetType } from './Psbt';\n\nconst rootWalletKeys = getDefaultWalletKeys();\nconst signs = ['unsigned', 'halfsigned', 'fullsigned'] as const;\n\nconst neutratedRootWalletKeys = new RootWalletKeys(\n  rootWalletKeys.triple.map((bip32) => bip32.neutered()) as Triple<BIP32Interface>,\n  rootWalletKeys.derivationPrefixes\n);\n\nconst psbtInputs = inputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(1000) }));\nconst psbtOutputs = outputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(900) }));\n\nconst txInputs = txnInputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(1000) }));\nconst txOutputs = txnOutputScriptTypes.map((scriptType) => ({ scriptType, value: BigInt(900) }));\n\nfunction getSigValidArray(scriptType: InputScriptType, sign: SignatureTargetType): Triple<boolean> {\n  if (scriptType === 'p2shP2pk' || sign === 'unsigned') {\n    return [false, false, false];\n  }\n  if (sign === 'halfsigned') {\n    return [true, false, false];\n  }\n  return scriptType === 'p2trMusig2' ? [true, true, false] : [true, false, true];\n}\n\nfunction signCount(sign: SignatureTargetType) {\n  return sign === 'unsigned' ? 0 : sign === 'halfsigned' ? 1 : 2;\n}\n\nfunction runPsbt(network: Network, sign: SignatureTargetType, inputs: Input[], outputs: Output[]) {\n  const coin = getNetworkName(network);\n  const signatureCount = signCount(sign);\n\n  describe(`psbt build, sign and verify for ${coin} ${sign}`, function () {\n    it(`getSignatureValidationArray with globalXpub ${coin} ${sign}`, function () {\n      const psbt = constructPsbt(inputs, outputs, network, rootWalletKeys, sign);\n      addXpubsToPsbt(psbt, neutratedRootWalletKeys);\n      psbt.data.inputs.forEach((input, inputIndex) => {\n        const isP2shP2pk = inputs[inputIndex].scriptType === 'p2shP2pk';\n        const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);\n        psbt.getSignatureValidationArray(inputIndex, { rootNodes: rootWalletKeys.triple }).forEach((sv, i) => {\n          if (isP2shP2pk && sign !== 'unsigned' && i === 0) {\n            assert.strictEqual(sv, true);\n          } else {\n            assert.strictEqual(sv, expectedSigValid[i]);\n          }\n        });\n      });\n    });\n\n    it(`getSignatureValidationArray with rootNodes ${coin} ${sign}`, function () {\n      const psbt = constructPsbt(inputs, outputs, network, rootWalletKeys, sign);\n      addXpubsToPsbt(psbt, neutratedRootWalletKeys);\n      psbt.data.inputs.forEach((input, inputIndex) => {\n        const isP2shP2pk = inputs[inputIndex].scriptType === 'p2shP2pk';\n        const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);\n        psbt.getSignatureValidationArray(inputIndex, { rootNodes: neutratedRootWalletKeys.triple }).forEach((sv, i) => {\n          if (isP2shP2pk && sign !== 'unsigned' && i === 0) {\n            assert.strictEqual(sv, true);\n          } else {\n            assert.strictEqual(sv, expectedSigValid[i]);\n          }\n        });\n      });\n    });\n\n    it(`getSignatureValidationArrayPsbt  ${coin} ${sign}`, function () {\n      const psbt = constructPsbt(inputs, outputs, network, rootWalletKeys, sign);\n      const sigValidations = getSignatureValidationArrayPsbt(psbt, neutratedRootWalletKeys);\n      psbt.data.inputs.forEach((input, inputIndex) => {\n        const expectedSigValid = getSigValidArray(inputs[inputIndex].scriptType, sign);\n        const sigValid = sigValidations.find((sv) => sv[0] === inputIndex);\n        assert.ok(sigValid);\n        sigValid[1].forEach((sv, i) => assert.strictEqual(sv, expectedSigValid[i]));\n      });\n    });\n\n    it(`psbt signature counts ${coin} ${sign}`, function () {\n      const psbt = constructPsbt(inputs, outputs, network, rootWalletKeys, sign);\n      const counts = getStrictSignatureCounts(psbt);\n      const countsFromInputs = getStrictSignatureCounts(psbt.data.inputs);\n\n      assert.strictEqual(counts.length, psbt.data.inputs.length);\n      assert.strictEqual(countsFromInputs.length, psbt.data.inputs.length);\n      psbt.data.inputs.forEach((input, inputIndex) => {\n        const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' && signatureCount > 0 ? 1 : signatureCount;\n        assert.strictEqual(getPsbtInputSignatureCount(input), expectedCount);\n        assert.strictEqual(getStrictSignatureCount(input), expectedCount);\n        assert.strictEqual(counts[inputIndex], expectedCount);\n        assert.strictEqual(countsFromInputs[inputIndex], expectedCount);\n      });\n\n      if (sign === 'fullsigned') {\n        const tx = psbt.finalizeAllInputs().extractTransaction() as UtxoTransaction<bigint>;\n        const counts = getStrictSignatureCounts(tx);\n        const countsFromIns = getStrictSignatureCounts(tx.ins);\n\n        tx.ins.forEach((input, inputIndex) => {\n          const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' ? 1 : signatureCount;\n          assert.strictEqual(getStrictSignatureCount(input), expectedCount);\n          assert.strictEqual(counts[inputIndex], expectedCount);\n          assert.strictEqual(countsFromIns[inputIndex], expectedCount);\n        });\n      }\n    });\n  });\n}\n\nfunction runTx<TNumber extends number | bigint>(\n  network: Network,\n  sign: SignatureTargetType,\n  inputs: TxnInput<TNumber>[],\n  outputs: TxnOutput<TNumber>[]\n) {\n  const coin = getNetworkName(network);\n  const signatureCount = signCount(sign);\n  describe(`tx build, sign and verify for ${coin} ${sign}`, function () {\n    it(`tx signature counts ${coin} ${sign}`, function () {\n      const txb = constructTxnBuilder(inputs, outputs, network, rootWalletKeys, sign);\n      const tx = sign === 'fullsigned' ? txb.build() : txb.buildIncomplete();\n\n      const counts = getStrictSignatureCounts(tx);\n      const countsFromIns = getStrictSignatureCounts(tx.ins);\n\n      assert.strictEqual(counts.length, tx.ins.length);\n      assert.strictEqual(countsFromIns.length, tx.ins.length);\n      tx.ins.forEach((input, inputIndex) => {\n        const expectedCount = inputs[inputIndex].scriptType === 'p2shP2pk' && signatureCount > 0 ? 1 : signatureCount;\n        assert.strictEqual(getStrictSignatureCount(input), expectedCount);\n        assert.strictEqual(counts[inputIndex], expectedCount);\n        assert.strictEqual(countsFromIns[inputIndex], expectedCount);\n      });\n    });\n  });\n}\n\nsigns.forEach((sign) => {\n  getNetworkList()\n    .filter((v) => isMainnet(v) && v !== networks.bitcoinsv)\n    .forEach((network) => {\n      const supportedPsbtInputs = psbtInputs.filter((input) =>\n        isSupportedScriptType(network, input.scriptType === 'taprootKeyPathSpend' ? 'p2trMusig2' : input.scriptType)\n      );\n      const supportedPsbtOutputs = psbtOutputs.filter((output) => isSupportedScriptType(network, output.scriptType));\n      runPsbt(network, sign, supportedPsbtInputs, supportedPsbtOutputs);\n\n      const supportedTxInputs = txInputs.filter((input) => isSupportedScriptType(network, input.scriptType));\n      const supportedTxOutputs = txOutputs.filter((output) => isSupportedScriptType(network, output.scriptType));\n      runTx(network, sign, supportedTxInputs, supportedTxOutputs);\n    });\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!