PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.replayProtectionKeyPair = void 0;
exports.mockPrevTx = mockPrevTx;
exports.isReplayProtectionUnspent = isReplayProtectionUnspent;
exports.mockReplayProtectionUnspent = mockReplayProtectionUnspent;
exports.mockWalletUnspent = mockWalletUnspent;
exports.mockUnspents = mockUnspents;
const assert = require("assert");
const noble = require("@noble/secp256k1");
const utxolib = require("..");
const networks_1 = require("../networks");
const bitgo_1 = require("../bitgo");
const address_1 = require("../address");
const outputScripts_1 = require("../bitgo/outputScripts");
const keys_1 = require("./keys");
function mockPrevTx(vout, outputScript, value, network) {
    const psbtFromNetwork = (0, bitgo_1.createPsbtForNetwork)({ network });
    const keypair = (0, keys_1.getKey)('mock-prev-tx');
    const pubkey = keypair.publicKey;
    assert(keypair.privateKey);
    const payment = utxolib.payments.p2wpkh({ pubkey });
    const destOutput = payment.output;
    if (!destOutput)
        throw new Error('Impossible, payment we just constructed has no output');
    for (let index = 0; index <= vout; index++) {
        if (index === vout) {
            psbtFromNetwork.addOutput({ script: outputScript, value });
        }
        else {
            psbtFromNetwork.addOutput({ script: destOutput, value });
        }
    }
    psbtFromNetwork.addInput({
        hash: Buffer.alloc(32, 0x01),
        index: 0,
        witnessUtxo: { script: destOutput, value: value * (BigInt(vout) + BigInt(1)) + BigInt(1000) },
    });
    psbtFromNetwork.signInput(0, {
        publicKey: pubkey,
        sign: (hash, lowR) => Buffer.from(noble.signSync(hash, keypair.privateKey, { canonical: !lowR, der: false })),
    });
    psbtFromNetwork.validateSignaturesOfAllInputs();
    psbtFromNetwork.finalizeAllInputs();
    return psbtFromNetwork.extractTransaction();
}
exports.replayProtectionKeyPair = (0, keys_1.getKey)('replay-protection');
const replayProtectionScriptPubKey = (0, outputScripts_1.createOutputScriptP2shP2pk)(exports.replayProtectionKeyPair.publicKey).scriptPubKey;
function isReplayProtectionUnspent(u, network) {
    return u.address === (0, address_1.fromOutputScript)(replayProtectionScriptPubKey, network);
}
function mockReplayProtectionUnspent(network, value, { key = exports.replayProtectionKeyPair, vout = 0 } = {}) {
    const outputScript = (0, outputScripts_1.createOutputScriptP2shP2pk)(key.publicKey).scriptPubKey;
    const prevTransaction = mockPrevTx(vout, outputScript, BigInt(value), network);
    return { ...(0, bitgo_1.fromOutputWithPrevTx)(prevTransaction, vout), value };
}
function mockWalletUnspent(network, value, { chain = 0, index = 0, keys = (0, keys_1.getDefaultWalletKeys)(), vout = 0, id, } = {}) {
    const derivedKeys = keys.deriveForChainAndIndex(chain, index);
    const address = (0, address_1.fromOutputScript)((0, outputScripts_1.createOutputScript2of3)(derivedKeys.publicKeys, (0, bitgo_1.scriptTypeForChain)(chain)).scriptPubKey, network);
    if (id && typeof id === 'string') {
        return { id, address, chain, index, value };
    }
    else {
        const prevTransaction = mockPrevTx(vout, (0, outputScripts_1.createOutputScript2of3)(derivedKeys.publicKeys, (0, bitgo_1.scriptTypeForChain)(chain), network).scriptPubKey, BigInt(value), network);
        const unspent = (0, bitgo_1.isSegwit)(chain) || (0, networks_1.getMainnet)(network) === networks_1.networks.zcash
            ? (0, bitgo_1.fromOutput)(prevTransaction, vout)
            : (0, bitgo_1.fromOutputWithPrevTx)(prevTransaction, vout);
        return {
            ...unspent,
            chain,
            index,
            value,
        };
    }
}
function mockUnspents(rootWalletKeys, inputScriptTypes, testOutputAmount, network) {
    return inputScriptTypes.map((t, i) => {
        if (bitgo_1.outputScripts.isScriptType2Of3(t)) {
            return mockWalletUnspent(network, testOutputAmount, {
                keys: rootWalletKeys,
                chain: (0, bitgo_1.getExternalChainCode)(t),
                vout: i,
            });
        }
        else if (t === bitgo_1.outputScripts.scriptTypeP2shP2pk) {
            return mockReplayProtectionUnspent(network, testOutputAmount, {
                key: exports.replayProtectionKeyPair,
                vout: i,
            });
        }
        throw new Error(`invalid input type ${t}`);
    });
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mock.js","sourceRoot":"","sources":["../../../src/testutil/mock.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport { BIP32Interface } from 'bip32';\nimport * as noble from '@noble/secp256k1';\nimport * as utxolib from '..';\nimport { getMainnet, Network, networks } from '../networks';\n\nimport {\n  ChainCode,\n  createPsbtForNetwork,\n  fromOutput,\n  fromOutputWithPrevTx,\n  getExternalChainCode,\n  isSegwit,\n  NonWitnessWalletUnspent,\n  outputScripts,\n  RootWalletKeys,\n  scriptTypeForChain,\n  Unspent,\n  UnspentWithPrevTx,\n  UtxoTransaction,\n  WalletUnspent,\n} from '../bitgo';\nimport { fromOutputScript } from '../address';\nimport { createOutputScript2of3, createOutputScriptP2shP2pk } from '../bitgo/outputScripts';\n\nimport { getDefaultWalletKeys, getKey } from './keys';\n\nexport type InputType = outputScripts.ScriptType2Of3;\n\nexport function mockPrevTx(\n  vout: number,\n  outputScript: Buffer,\n  value: bigint,\n  network: Network\n): UtxoTransaction<bigint> {\n  const psbtFromNetwork = createPsbtForNetwork({ network });\n\n  const keypair = getKey('mock-prev-tx');\n  const pubkey = keypair.publicKey;\n  assert(keypair.privateKey);\n  const payment = utxolib.payments.p2wpkh({ pubkey });\n  const destOutput = payment.output;\n  if (!destOutput) throw new Error('Impossible, payment we just constructed has no output');\n\n  for (let index = 0; index <= vout; index++) {\n    if (index === vout) {\n      psbtFromNetwork.addOutput({ script: outputScript, value });\n    } else {\n      psbtFromNetwork.addOutput({ script: destOutput, value });\n    }\n  }\n  psbtFromNetwork.addInput({\n    hash: Buffer.alloc(32, 0x01),\n    index: 0,\n    witnessUtxo: { script: destOutput, value: value * (BigInt(vout) + BigInt(1)) + BigInt(1000) },\n  });\n  psbtFromNetwork.signInput(0, {\n    publicKey: pubkey,\n    sign: (hash: Buffer, lowR?: boolean) =>\n      Buffer.from(noble.signSync(hash, keypair.privateKey as Buffer, { canonical: !lowR, der: false })),\n  });\n  psbtFromNetwork.validateSignaturesOfAllInputs();\n  psbtFromNetwork.finalizeAllInputs();\n  return psbtFromNetwork.extractTransaction();\n}\n\nexport const replayProtectionKeyPair = getKey('replay-protection');\nconst replayProtectionScriptPubKey = createOutputScriptP2shP2pk(replayProtectionKeyPair.publicKey).scriptPubKey;\n\nexport function isReplayProtectionUnspent<TNumber extends bigint | number>(\n  u: Unspent<TNumber>,\n  network: Network\n): boolean {\n  return u.address === fromOutputScript(replayProtectionScriptPubKey, network);\n}\n\nexport function mockReplayProtectionUnspent<TNumber extends number | bigint>(\n  network: Network,\n  value: TNumber,\n  { key = replayProtectionKeyPair, vout = 0 }: { key?: BIP32Interface; vout?: number } = {}\n): UnspentWithPrevTx<TNumber> {\n  const outputScript = createOutputScriptP2shP2pk(key.publicKey).scriptPubKey;\n  const prevTransaction = mockPrevTx(vout, outputScript, BigInt(value), network);\n  return { ...fromOutputWithPrevTx(prevTransaction, vout), value };\n}\n\nexport function mockWalletUnspent<TNumber extends number | bigint>(\n  network: Network,\n  value: TNumber,\n  {\n    chain = 0,\n    index = 0,\n    keys = getDefaultWalletKeys(),\n    vout = 0,\n    id,\n  }: { chain?: ChainCode; index?: number; keys?: RootWalletKeys; vout?: number; id?: string } = {}\n): WalletUnspent<TNumber> | NonWitnessWalletUnspent<TNumber> {\n  const derivedKeys = keys.deriveForChainAndIndex(chain, index);\n  const address = fromOutputScript(\n    createOutputScript2of3(derivedKeys.publicKeys, scriptTypeForChain(chain)).scriptPubKey,\n    network\n  );\n  if (id && typeof id === 'string') {\n    return { id, address, chain, index, value };\n  } else {\n    const prevTransaction = mockPrevTx(\n      vout,\n      createOutputScript2of3(derivedKeys.publicKeys, scriptTypeForChain(chain), network).scriptPubKey,\n      BigInt(value),\n      network\n    );\n    const unspent =\n      isSegwit(chain) || getMainnet(network) === networks.zcash\n        ? fromOutput(prevTransaction, vout)\n        : fromOutputWithPrevTx(prevTransaction, vout);\n    return {\n      ...unspent,\n      chain,\n      index,\n      value,\n    };\n  }\n}\n\nexport function mockUnspents<TNumber extends number | bigint>(\n  rootWalletKeys: RootWalletKeys,\n  inputScriptTypes: (InputType | outputScripts.ScriptTypeP2shP2pk)[],\n  testOutputAmount: TNumber,\n  network: Network\n): (Unspent<TNumber> | WalletUnspent<TNumber>)[] {\n  return inputScriptTypes.map((t, i): Unspent<TNumber> => {\n    if (outputScripts.isScriptType2Of3(t)) {\n      return mockWalletUnspent(network, testOutputAmount, {\n        keys: rootWalletKeys,\n        chain: getExternalChainCode(t),\n        vout: i,\n      });\n    } else if (t === outputScripts.scriptTypeP2shP2pk) {\n      return mockReplayProtectionUnspent(network, testOutputAmount, {\n        key: replayProtectionKeyPair,\n        vout: i,\n      });\n    }\n    throw new Error(`invalid input type ${t}`);\n  });\n}\n"]}

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


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