PHP WebShell

Текущая директория: /opt/BitGoJS/modules/unspents/dist/test/signedTx

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

"use strict";
/* eslint-disable @typescript-eslint/ban-ts-comment */
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.runSignedTransactions = exports.runCombinations = exports.Histogram = exports.TxCombo = exports.createScriptPubKey = void 0;
const utxolib = __importStar(require("@bitgo/utxo-lib"));
const utxo_lib_1 = require("@bitgo/utxo-lib");
const lodash_1 = __importDefault(require("lodash"));
require("lodash.combinations");
const src_1 = require("../../src");
const testutils_1 = require("../testutils");
function createUnspent(pubkeys, inputType, value) {
    let spendableScript;
    const scriptType = inputType === 'taprootKeyPathSpend' ? 'p2trMusig2' : inputType;
    if (scriptType === testutils_1.UnspentTypeP2shP2pk) {
        spendableScript = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(pubkeys[0]);
    }
    else if (utxolib.bitgo.outputScripts.isScriptType2Of3(scriptType)) {
        spendableScript = utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType);
    }
    else {
        throw new Error(`unexpected inputType ${scriptType}`);
    }
    return {
        ...spendableScript,
        value,
        inputType: scriptType,
    };
}
/**
 *
 * @param keys - Pubkeys to use for generating the address.
 *               If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.
 * @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash
 * @return {String} address
 */
const createScriptPubKey = (keys, unspentType) => {
    const pubkeys = keys.map((key) => key.publicKey);
    if (typeof unspentType === 'string' && unspentType in testutils_1.UnspentTypeScript2of3) {
        return createUnspent(pubkeys, unspentType, 0).scriptPubKey;
    }
    const pkHash = utxolib.crypto.hash160(pubkeys[0]);
    switch (unspentType) {
        case testutils_1.UnspentTypePubKeyHash.p2pkh:
            return utxolib.payments.p2pkh({ hash: pkHash }).output;
        case testutils_1.UnspentTypePubKeyHash.p2wpkh:
            return utxolib.payments.p2wpkh({ hash: pkHash }).output;
    }
    if (unspentType instanceof testutils_1.UnspentTypeOpReturn) {
        const payload = Buffer.alloc(unspentType.size).fill(pubkeys[0]);
        return utxolib.script.compile([0x6a, payload]);
    }
    throw new Error(`unsupported output type ${unspentType}`);
};
exports.createScriptPubKey = createScriptPubKey;
const createInputTx = (unspents, inputValue) => {
    const txInputBuilder = new utxolib.bitgo.UtxoTransactionBuilder(utxolib.networks.bitcoin);
    txInputBuilder.addInput(Array(32).fill('01').join(''), 0);
    unspents.forEach(({ scriptPubKey }) => txInputBuilder.addOutput(scriptPubKey, inputValue));
    return txInputBuilder.buildIncomplete();
};
function signInput(txBuilder, index, walletKeys, unspent, signKeys = unspent.inputType === 'p2shP2pk' ? [walletKeys[0]] : [walletKeys[0], walletKeys[2]]) {
    signKeys.forEach((keyPair) => {
        if (unspent.inputType === 'p2shP2pk') {
            utxolib.bitgo.signInputP2shP2pk(txBuilder, index, keyPair);
        }
        else {
            if (signKeys.length !== 2) {
                throw new Error(`invalid signKeys length`);
            }
            const cosigner = keyPair === signKeys[0] ? signKeys[1] : signKeys[0];
            utxolib.bitgo.signInput2Of3(txBuilder, index, unspent.inputType, walletKeys.map((k) => k.publicKey), keyPair, cosigner.publicKey, unspent.value);
        }
    });
}
class TxCombo {
    constructor(walletKeys, inputTypes, outputTypes, expectedDims = src_1.Dimensions.ZERO, signKeys, inputValue = 10) {
        this.walletKeys = walletKeys;
        this.inputTypes = inputTypes;
        this.outputTypes = outputTypes;
        this.expectedDims = expectedDims;
        this.signKeys = signKeys;
        this.inputValue = inputValue;
        this.unspents = inputTypes.map((inputType) => createUnspent(walletKeys.map((key) => key.publicKey), inputType, this.inputValue));
        this.inputTx = createInputTx(this.unspents, inputValue);
    }
    getBuilderWithUnsignedTx() {
        const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
        this.inputTx.outs.forEach(({}, i) => txBuilder.addInput(this.inputTx, i));
        this.outputTypes.forEach((unspentType) => txBuilder.addOutput((0, exports.createScriptPubKey)(this.walletKeys, unspentType), this.inputValue));
        return txBuilder;
    }
    getUnsignedTx() {
        return this.getBuilderWithUnsignedTx().buildIncomplete();
    }
    getSignedTx() {
        const txBuilder = this.getBuilderWithUnsignedTx();
        this.unspents.forEach((unspent, i) => {
            signInput(txBuilder, i, this.walletKeys, unspent, this.signKeys);
        });
        return txBuilder.build();
    }
}
exports.TxCombo = TxCombo;
const runCombinations = ({ inputTypes, maxNInputs, outputTypes, maxNOutputs, }, callback) => {
    // Create combinations of different input and output types. Length between 1 and 3.
    const inputCombinations = lodash_1.default.flatten(
    // @ts-ignore
    [...Array(maxNInputs)].map((__, i) => lodash_1.default.combinations(inputTypes, i + 1)));
    const outputCombinations = lodash_1.default.flatten(
    // @ts-ignore
    [...Array(maxNOutputs)].map((__, i) => lodash_1.default.combinations(outputTypes, i + 1)));
    inputCombinations.forEach((inputTypeCombo) => outputCombinations.forEach((outputTypeCombo) => {
        callback(inputTypeCombo, outputTypeCombo);
    }));
};
exports.runCombinations = runCombinations;
class Histogram {
    constructor(map = new Map()) {
        this.map = map;
        this.total = 0;
    }
    add(size) {
        this.map.set(size, (this.map.get(size) || 0) + 1);
        this.total++;
    }
    asSortedArray() {
        return [...this.map.entries()].sort(([a], [b]) => a - b);
    }
    asFullSortedArray() {
        return lodash_1.default.range(this.getPercentile(0), this.getPercentile(1)).map((v) => [v, this.map.get(v) || 0]);
    }
    getPercentile(p) {
        if (0 > p || p > 1) {
            throw new Error(`p must be between 0 and 1`);
        }
        let sum = 0;
        for (const [k, v] of this.asSortedArray()) {
            sum += v;
            if (sum / this.total >= p) {
                return k;
            }
        }
        throw new Error('could not find percentile');
    }
    toString() {
        const keys = [...this.map.keys()].sort((a, b) => a - b);
        return `[${keys.map((k) => `[${k}, ${this.map.get(k)}]`).join(' ')}]`;
    }
}
exports.Histogram = Histogram;
const getKeyTriplets = (prefix, count) => [...Array(count)].map((v, i) => [1, 2, 3].map((j) => utxo_lib_1.bip32.fromSeed(Buffer.alloc(16, `${prefix}/${i}/${j}`), utxolib.networks.bitcoin)));
/**
 *
 * Calls `callback` with a variety of signed txs, based on input parameters
 * Callback arguments are
 *   inputType, inputCount, outputType, txs
 *  where `txs` implements `forEach()`
 *
 * @param inputTypes - input types to test
 * @param nInputKeyTriplets - number of different input key triples to cycle through
 * @param outputTypes - output types to test
 * @param nOutputKeyTriplets - number of different output key triplets to cycle through
 * @param callback
 */
const runSignedTransactions = ({ inputTypes, nInputKeyTriplets, outputTypes, nOutputKeyTriplets, }, callback) => {
    const inputKeyTriplets = getKeyTriplets('test/input/', nInputKeyTriplets);
    const outputKeyTriplets = getKeyTriplets('test/output/', nOutputKeyTriplets);
    const outputValue = 1e8;
    inputTypes.forEach(({ inputType, count: inputCount }) => {
        const inputTxs = inputKeyTriplets.map((inputKeys) => {
            const unspents = [...Array(inputCount)].map(() => createUnspent(inputKeys.map((key) => key.publicKey), inputType, outputValue));
            const inputTx = createInputTx(unspents, outputValue);
            return { inputKeys, unspents, inputTx };
        });
        outputTypes.forEach((outputType) => {
            const outputs = outputKeyTriplets.map((outputKeys) => (0, exports.createScriptPubKey)(outputKeys, outputType));
            const txs = {
                forEach(cb) {
                    inputTxs.forEach(({ inputKeys, unspents, inputTx }) => {
                        outputs.forEach((scriptPubKey) => {
                            const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
                            inputTx.outs.forEach((v, i) => txBuilder.addInput(inputTx, i));
                            txBuilder.addOutput(scriptPubKey, outputValue);
                            unspents.forEach((unspent, i) => {
                                signInput(txBuilder, i, inputKeys, unspent);
                            });
                            cb(txBuilder.build());
                        });
                    });
                },
            };
            callback(inputType, inputCount, outputType, txs);
        });
    });
};
exports.runSignedTransactions = runSignedTransactions;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"txGen.js","sourceRoot":"","sources":["../../../test/signedTx/txGen.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as utxolib from '@bitgo/utxo-lib';\nimport { bip32, BIP32Interface } from '@bitgo/utxo-lib';\nimport _ from 'lodash';\nimport 'lodash.combinations';\nimport { Dimensions } from '../../src';\nimport {\n  InputScriptType,\n  TestUnspentType,\n  UnspentTypeOpReturn,\n  UnspentTypeP2shP2pk,\n  UnspentTypePubKeyHash,\n  UnspentTypeScript2of3,\n} from '../testutils';\n\ninterface IUnspent {\n  scriptPubKey: Buffer;\n  redeemScript?: Buffer;\n  witnessScript?: Buffer;\n  value: number;\n  inputType: utxolib.bitgo.outputScripts.ScriptType;\n}\n\nfunction createUnspent(pubkeys: Buffer[], inputType: string, value: number): IUnspent {\n  let spendableScript;\n  const scriptType = inputType === 'taprootKeyPathSpend' ? 'p2trMusig2' : inputType;\n  if (scriptType === UnspentTypeP2shP2pk) {\n    spendableScript = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(pubkeys[0]);\n  } else if (utxolib.bitgo.outputScripts.isScriptType2Of3(scriptType)) {\n    spendableScript = utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType);\n  } else {\n    throw new Error(`unexpected inputType ${scriptType}`);\n  }\n\n  return {\n    ...spendableScript,\n    value,\n    inputType: scriptType,\n  };\n}\n\n/**\n *\n * @param keys - Pubkeys to use for generating the address.\n *               If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.\n * @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash\n * @return {String} address\n */\nexport const createScriptPubKey = (keys: BIP32Interface[], unspentType: TestUnspentType): Buffer => {\n  const pubkeys = keys.map((key) => key.publicKey);\n  if (typeof unspentType === 'string' && unspentType in UnspentTypeScript2of3) {\n    return createUnspent(pubkeys, unspentType, 0).scriptPubKey;\n  }\n\n  const pkHash = utxolib.crypto.hash160(pubkeys[0]);\n  switch (unspentType) {\n    case UnspentTypePubKeyHash.p2pkh:\n      return utxolib.payments.p2pkh({ hash: pkHash }).output!;\n    case UnspentTypePubKeyHash.p2wpkh:\n      return utxolib.payments.p2wpkh({ hash: pkHash }).output!;\n  }\n\n  if (unspentType instanceof UnspentTypeOpReturn) {\n    const payload = Buffer.alloc(unspentType.size).fill(pubkeys[0]);\n    return utxolib.script.compile([0x6a, payload]);\n  }\n\n  throw new Error(`unsupported output type ${unspentType}`);\n};\n\nconst createInputTx = (unspents: any[], inputValue: number) => {\n  const txInputBuilder = new utxolib.bitgo.UtxoTransactionBuilder(utxolib.networks.bitcoin);\n  txInputBuilder.addInput(Array(32).fill('01').join(''), 0);\n  unspents.forEach(({ scriptPubKey }) => txInputBuilder.addOutput(scriptPubKey, inputValue));\n  return txInputBuilder.buildIncomplete();\n};\n\nfunction signInput(\n  txBuilder: utxolib.bitgo.UtxoTransactionBuilder,\n  index: number,\n  walletKeys: BIP32Interface[],\n  unspent: IUnspent,\n  signKeys: BIP32Interface[] = unspent.inputType === 'p2shP2pk' ? [walletKeys[0]] : [walletKeys[0], walletKeys[2]]\n) {\n  signKeys.forEach((keyPair) => {\n    if (unspent.inputType === 'p2shP2pk') {\n      utxolib.bitgo.signInputP2shP2pk(txBuilder, index, keyPair);\n    } else {\n      if (signKeys.length !== 2) {\n        throw new Error(`invalid signKeys length`);\n      }\n      const cosigner = keyPair === signKeys[0] ? signKeys[1] : signKeys[0];\n      utxolib.bitgo.signInput2Of3(\n        txBuilder,\n        index,\n        unspent.inputType,\n        walletKeys.map((k) => k.publicKey) as utxolib.bitgo.Triple<Buffer>,\n        keyPair,\n        cosigner.publicKey,\n        unspent.value\n      );\n    }\n  });\n}\n\nclass TxCombo {\n  public unspents: IUnspent[];\n  public inputTx: any;\n\n  constructor(\n    public walletKeys: BIP32Interface[],\n    public inputTypes: string[],\n    public outputTypes: TestUnspentType[],\n    public expectedDims: Readonly<Dimensions> = Dimensions.ZERO,\n    public signKeys?: BIP32Interface[],\n    public inputValue: number = 10\n  ) {\n    this.unspents = inputTypes.map((inputType) =>\n      createUnspent(\n        walletKeys.map((key) => key.publicKey),\n        inputType,\n        this.inputValue\n      )\n    );\n    this.inputTx = createInputTx(this.unspents, inputValue);\n  }\n\n  public getBuilderWithUnsignedTx(): utxolib.bitgo.UtxoTransactionBuilder {\n    const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);\n    this.inputTx.outs.forEach(({}, i: number) => txBuilder.addInput(this.inputTx, i));\n    this.outputTypes.forEach((unspentType) =>\n      txBuilder.addOutput(createScriptPubKey(this.walletKeys, unspentType), this.inputValue)\n    );\n    return txBuilder;\n  }\n\n  public getUnsignedTx(): utxolib.bitgo.UtxoTransaction {\n    return this.getBuilderWithUnsignedTx().buildIncomplete();\n  }\n\n  public getSignedTx(): utxolib.Transaction {\n    const txBuilder = this.getBuilderWithUnsignedTx();\n    this.unspents.forEach((unspent, i) => {\n      signInput(txBuilder, i, this.walletKeys, unspent, this.signKeys);\n    });\n    return txBuilder.build();\n  }\n}\n\nconst runCombinations = (\n  {\n    inputTypes,\n    maxNInputs,\n    outputTypes,\n    maxNOutputs,\n  }: {\n    inputTypes: InputScriptType[];\n    maxNInputs: number;\n    outputTypes: TestUnspentType[];\n    maxNOutputs: number;\n  },\n  callback: (inputCombo: InputScriptType[], outputCombo: TestUnspentType[]) => void\n): void => {\n  // Create combinations of different input and output types. Length between 1 and 3.\n  const inputCombinations = _.flatten(\n    // @ts-ignore\n    [...Array(maxNInputs)].map((__, i) => _.combinations(inputTypes, i + 1))\n  );\n  const outputCombinations = _.flatten(\n    // @ts-ignore\n    [...Array(maxNOutputs)].map((__, i) => _.combinations(outputTypes, i + 1))\n  );\n\n  inputCombinations.forEach((inputTypeCombo) =>\n    outputCombinations.forEach((outputTypeCombo) => {\n      callback(inputTypeCombo, outputTypeCombo);\n    })\n  );\n};\n\nclass Histogram {\n  public total = 0;\n\n  constructor(public map: Map<number, number> = new Map()) {}\n\n  public add(size: number): void {\n    this.map.set(size, (this.map.get(size) || 0) + 1);\n    this.total++;\n  }\n\n  public asSortedArray(): number[][] {\n    return [...this.map.entries()].sort(([a], [b]) => a - b);\n  }\n\n  public asFullSortedArray(): number[][] {\n    return _.range(this.getPercentile(0), this.getPercentile(1)).map((v) => [v, this.map.get(v) || 0]);\n  }\n\n  public getPercentile(p: number): number {\n    if (0 > p || p > 1) {\n      throw new Error(`p must be between 0 and 1`);\n    }\n\n    let sum = 0;\n    for (const [k, v] of this.asSortedArray()) {\n      sum += v;\n      if (sum / this.total >= p) {\n        return k;\n      }\n    }\n\n    throw new Error('could not find percentile');\n  }\n\n  public toString(): string {\n    const keys = [...this.map.keys()].sort((a, b) => a - b);\n    return `[${keys.map((k) => `[${k}, ${this.map.get(k)}]`).join(' ')}]`;\n  }\n}\n\nconst getKeyTriplets = (prefix: string, count: number) =>\n  [...Array(count)].map((v, i) =>\n    [1, 2, 3].map((j) => bip32.fromSeed(Buffer.alloc(16, `${prefix}/${i}/${j}`), utxolib.networks.bitcoin))\n  );\n\n/**\n *\n * Calls `callback` with a variety of signed txs, based on input parameters\n * Callback arguments are\n *   inputType, inputCount, outputType, txs\n *  where `txs` implements `forEach()`\n *\n * @param inputTypes - input types to test\n * @param nInputKeyTriplets - number of different input key triples to cycle through\n * @param outputTypes - output types to test\n * @param nOutputKeyTriplets - number of different output key triplets to cycle through\n * @param callback\n */\nconst runSignedTransactions = (\n  {\n    inputTypes,\n    nInputKeyTriplets,\n    outputTypes,\n    nOutputKeyTriplets,\n  }: {\n    inputTypes: Array<{ inputType: string; count: number }>;\n    nInputKeyTriplets: number;\n    outputTypes: TestUnspentType[];\n    nOutputKeyTriplets: number;\n  },\n  callback: (inputType: string, inputCount: number, outputType: TestUnspentType, txs: any) => void\n): void => {\n  const inputKeyTriplets = getKeyTriplets('test/input/', nInputKeyTriplets);\n  const outputKeyTriplets = getKeyTriplets('test/output/', nOutputKeyTriplets);\n  const outputValue = 1e8;\n\n  inputTypes.forEach(({ inputType, count: inputCount }) => {\n    const inputTxs = inputKeyTriplets.map((inputKeys) => {\n      const unspents = [...Array(inputCount)].map(() =>\n        createUnspent(\n          inputKeys.map((key) => key.publicKey),\n          inputType,\n          outputValue\n        )\n      );\n      const inputTx = createInputTx(unspents, outputValue);\n      return { inputKeys, unspents, inputTx };\n    });\n\n    outputTypes.forEach((outputType) => {\n      const outputs = outputKeyTriplets.map((outputKeys) => createScriptPubKey(outputKeys, outputType));\n\n      const txs = {\n        forEach(cb: (tx: utxolib.Transaction) => void) {\n          inputTxs.forEach(({ inputKeys, unspents, inputTx }) => {\n            outputs.forEach((scriptPubKey) => {\n              const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);\n              inputTx.outs.forEach((v: any, i: number) => txBuilder.addInput(inputTx, i));\n              txBuilder.addOutput(scriptPubKey, outputValue);\n              unspents.forEach((unspent, i) => {\n                signInput(txBuilder, i, inputKeys, unspent);\n              });\n\n              cb(txBuilder.build());\n            });\n          });\n        },\n      };\n\n      callback(inputType, inputCount, outputType, txs);\n    });\n  });\n};\n\nexport { TxCombo, Histogram, runCombinations, runSignedTransactions };\n"]}

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


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