PHP WebShell
Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/test/integration_local_rpc/generate
Просмотр файла: outputScripts.util.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.scriptTypes = exports.scriptTypesSingleSig = void 0;
exports.isSupportedDepositType = isSupportedDepositType;
exports.isSupportedSpendType = isSupportedSpendType;
exports.createScriptPubKey = createScriptPubKey;
exports.createSpendTransactionFromPrevOutputs = createSpendTransactionFromPrevOutputs;
exports.createSpendTransaction = createSpendTransaction;
exports.createPsbtSpendTransactionFromPrevTx = createPsbtSpendTransactionFromPrevTx;
exports.createPsbtSpendTransaction = createPsbtSpendTransaction;
exports.getP2trMusig2Index = getP2trMusig2Index;
const utxolib = require("../../../src");
const outputScripts_1 = require("../../../src/bitgo/outputScripts");
const testutil_1 = require("../../../src/testutil");
const bitgo_1 = require("../../../src/bitgo");
const bitgo_2 = require("../../../src/bitgo");
exports.scriptTypesSingleSig = ['p2pkh', 'p2wkh'];
exports.scriptTypes = [...exports.scriptTypesSingleSig, ...outputScripts_1.scriptTypes2Of3];
function isSupportedDepositType(network, scriptType) {
if (scriptType === 'p2pkh') {
return true;
}
if (scriptType === 'p2wkh') {
return utxolib.supportsSegwit(network);
}
return (0, outputScripts_1.isSupportedScriptType)(network, scriptType);
}
function isSupportedSpendType(network, scriptType) {
return (0, outputScripts_1.isScriptType2Of3)(scriptType) && (0, outputScripts_1.isSupportedScriptType)(network, scriptType);
}
/**
*
* @param keys - Pubkeys to use for generating the address.
* If scriptType is single-sig, the first key will be used.
* @param scriptType
* @param network
* @return {Buffer} scriptPubKey
*/
function createScriptPubKey(keys, scriptType, network) {
const pubkeys = keys.map((k) => k.publicKey);
switch (scriptType) {
case 'p2sh':
case 'p2shP2wsh':
case 'p2wsh':
case 'p2tr':
case 'p2trMusig2':
return (0, outputScripts_1.createOutputScript2of3)(pubkeys, scriptType).scriptPubKey;
case 'p2pkh':
return utxolib.payments.p2pkh({ pubkey: keys[0].publicKey }).output;
case 'p2wkh':
return utxolib.payments.p2wpkh({ pubkey: keys[0].publicKey }).output;
default:
throw new Error(`unsupported output type ${scriptType}`);
}
}
function createSpendTransactionFromPrevOutputs(keys, scriptType, prevOutputs, recipientScript, network, { signKeys = [keys[0], keys[2]], version, amountType, } = {}) {
if (signKeys.length !== 1 && signKeys.length !== 2) {
throw new Error(`signKeys length must be 1 or 2`);
}
const txBuilder = (0, bitgo_1.createTransactionBuilderForNetwork)(network, { version });
prevOutputs.forEach(({ txid, vout, script, value }, i) => {
txBuilder.addInput(txid, vout, undefined, script, value);
});
const inputSum = prevOutputs.reduce((sum, { value }) => sum + BigInt(value), BigInt(0));
const fee = network === utxolib.networks.dogecoinTest ? BigInt(1000000) : BigInt(1000);
const outputValue = inputSum - fee;
txBuilder.addOutput(recipientScript, (amountType === 'number' ? Number(outputValue) : outputValue));
const publicKeys = keys.map((k) => k.publicKey);
if (!(0, bitgo_1.isTriple)(publicKeys)) {
throw new Error();
}
prevOutputs.forEach(({ value }, vin) => {
signKeys.forEach((key) => {
(0, bitgo_1.signInput2Of3)(txBuilder, vin, scriptType, publicKeys, key, (0, testutil_1.getDefaultCosigner)(publicKeys, key.publicKey), value);
});
});
if (signKeys.length === 1) {
return txBuilder.buildIncomplete();
}
return txBuilder.build();
}
function createSpendTransaction(keys, scriptType, inputTxs, recipientScript, network, version, amountType) {
const matches = inputTxs
.map((inputTxBuffer) => {
const inputTx = (0, bitgo_1.createTransactionFromBuffer)(inputTxBuffer, network, { amountType });
const { scriptPubKey } = (0, outputScripts_1.createOutputScript2of3)(keys.map((k) => k.publicKey), scriptType);
return inputTx.outs
.map((o, vout) => {
if (!scriptPubKey.equals(o.script)) {
return;
}
return {
txid: inputTx.getId(),
vout,
value: o.value,
script: o.script,
};
})
.filter((v) => v !== undefined);
})
.reduce((all, matches) => [...all, ...matches]);
if (!matches.length) {
throw new Error(`could not find matching outputs in funding transaction`);
}
return createSpendTransactionFromPrevOutputs(keys, scriptType, matches, recipientScript, network, {
version,
amountType,
});
}
function createPsbtSpendTransactionFromPrevTx(rootWalletKeys, unspents, network, signers = ['user', 'bitgo'], version) {
const psbt = (0, bitgo_1.createPsbtForNetwork)({ network }, { version });
unspents.forEach((u, index) => {
(0, bitgo_1.addWalletUnspentToPsbt)(psbt, u, rootWalletKeys, signers[0], signers[1]);
});
const inputSum = unspents.reduce((sum, { value }) => sum + BigInt(value), BigInt(0));
const fee = network === utxolib.networks.dogecoinTest ? BigInt(1000000) : BigInt(1000);
const outputValue = inputSum - fee;
(0, bitgo_1.addWalletOutputToPsbt)(psbt, rootWalletKeys, unspents[0].chain, unspents[0].index, outputValue);
signers.forEach((keyName) => {
psbt.setAllInputsMusig2NonceHD(rootWalletKeys[keyName]);
});
signers.forEach((keyName) => {
psbt.signAllInputsHD(rootWalletKeys[keyName]);
});
if (!psbt.validateSignaturesOfAllInputs()) {
throw new Error('psbt sig validation fails');
}
psbt.finalizeAllInputs();
return psbt.extractTransaction();
}
function createPsbtSpendTransaction({ rootWalletKeys, signers, chain, index, inputTxs, network, version, amountType, }) {
const walletKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);
const { scriptPubKey } = (0, outputScripts_1.createOutputScript2of3)(walletKeys.publicKeys, (0, bitgo_2.scriptTypeForChain)(chain));
const matches = inputTxs
.map((inputTxBuffer) => {
const inputTx = (0, bitgo_1.createTransactionFromBuffer)(inputTxBuffer, network, { amountType: 'bigint' });
return inputTx.outs
.map((o, vout) => {
if (!scriptPubKey.equals(o.script)) {
return;
}
return { chain, index, ...(0, bitgo_1.fromOutputWithPrevTx)(inputTx, vout) };
})
.filter((v) => v !== undefined);
})
.reduce((all, matches) => [...all, ...matches]);
if (!matches.length) {
throw new Error(`could not find matching outputs in funding transaction`);
}
const tx = createPsbtSpendTransactionFromPrevTx(rootWalletKeys, matches, network, signers, version);
return tx.clone(amountType);
}
/**
* @returns BIP32 hardcoded index for p2trMusig2 spend type. 0 for key path and 100 for script path.
* For same fixture key triple and script type (p2trMusig2),
* we need 2 different deposit and spend tx fixtures.
*/
function getP2trMusig2Index(spendType) {
return spendType === 'keyPath' ? 0 : 100;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputScripts.util.js","sourceRoot":"","sources":["../../../../test/integration_local_rpc/generate/outputScripts.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { BIP32Interface } from 'bip32';\nimport { Transaction, TxOutput } from 'bitcoinjs-lib';\nimport * as utxolib from '../../../src';\nimport {\n  createOutputScript2of3,\n  isScriptType2Of3,\n  isSupportedScriptType,\n  ScriptType2Of3,\n  scriptTypes2Of3,\n} from '../../../src/bitgo/outputScripts';\nimport { getDefaultCosigner, KeyTriple } from '../../../src/testutil';\n\nimport {\n  isTriple,\n  createTransactionBuilderForNetwork,\n  createTransactionFromBuffer,\n  signInput2Of3,\n  TxOutPoint,\n  UtxoTransaction,\n  createPsbtForNetwork,\n  ChainCode,\n  RootWalletKeys,\n  addWalletUnspentToPsbt,\n  fromOutputWithPrevTx,\n  WalletUnspent,\n  KeyName,\n  addWalletOutputToPsbt,\n  Tuple,\n} from '../../../src/bitgo';\nimport { scriptTypeForChain } from '../../../src/bitgo';\n\nexport const scriptTypesSingleSig = ['p2pkh', 'p2wkh'] as const;\nexport type ScriptTypeSingleSig = (typeof scriptTypesSingleSig)[number];\n\nexport const scriptTypes = [...scriptTypesSingleSig, ...scriptTypes2Of3];\nexport type ScriptType = ScriptType2Of3 | ScriptTypeSingleSig;\n\ntype Network = utxolib.Network;\n\nexport function isSupportedDepositType(network: Network, scriptType: ScriptType): boolean {\n  if (scriptType === 'p2pkh') {\n    return true;\n  }\n\n  if (scriptType === 'p2wkh') {\n    return utxolib.supportsSegwit(network);\n  }\n\n  return isSupportedScriptType(network, scriptType);\n}\n\nexport function isSupportedSpendType(network: Network, scriptType: ScriptType): boolean {\n  return isScriptType2Of3(scriptType) && isSupportedScriptType(network, scriptType);\n}\n\n/**\n *\n * @param keys - Pubkeys to use for generating the address.\n *               If scriptType is single-sig, the first key will be used.\n * @param scriptType\n * @param network\n * @return {Buffer} scriptPubKey\n */\nexport function createScriptPubKey(keys: KeyTriple, scriptType: ScriptType, network: Network): Buffer {\n  const pubkeys = keys.map((k) => k.publicKey);\n\n  switch (scriptType) {\n    case 'p2sh':\n    case 'p2shP2wsh':\n    case 'p2wsh':\n    case 'p2tr':\n    case 'p2trMusig2':\n      return createOutputScript2of3(pubkeys, scriptType).scriptPubKey;\n    case 'p2pkh':\n      return utxolib.payments.p2pkh({ pubkey: keys[0].publicKey }).output as Buffer;\n    case 'p2wkh':\n      return utxolib.payments.p2wpkh({ pubkey: keys[0].publicKey }).output as Buffer;\n    default:\n      throw new Error(`unsupported output type ${scriptType}`);\n  }\n}\n\nexport function createSpendTransactionFromPrevOutputs<TNumber extends number | bigint>(\n  keys: KeyTriple,\n  scriptType: ScriptType2Of3,\n  prevOutputs: (TxOutPoint & TxOutput<TNumber>)[],\n  recipientScript: Buffer,\n  network: Network,\n  {\n    signKeys = [keys[0], keys[2]],\n    version,\n    amountType,\n  }: { signKeys?: BIP32Interface[]; version?: number; amountType?: 'number' | 'bigint' } = {}\n): UtxoTransaction<TNumber> {\n  if (signKeys.length !== 1 && signKeys.length !== 2) {\n    throw new Error(`signKeys length must be 1 or 2`);\n  }\n\n  const txBuilder = createTransactionBuilderForNetwork<TNumber>(network, { version });\n\n  prevOutputs.forEach(({ txid, vout, script, value }, i) => {\n    txBuilder.addInput(txid, vout, undefined, script, value);\n  });\n\n  const inputSum = prevOutputs.reduce((sum, { value }) => sum + BigInt(value), BigInt(0));\n  const fee = network === utxolib.networks.dogecoinTest ? BigInt(1_000_000) : BigInt(1_000);\n  const outputValue = inputSum - fee;\n\n  txBuilder.addOutput(recipientScript, (amountType === 'number' ? Number(outputValue) : outputValue) as TNumber);\n\n  const publicKeys = keys.map((k) => k.publicKey);\n  if (!isTriple(publicKeys)) {\n    throw new Error();\n  }\n\n  prevOutputs.forEach(({ value }, vin) => {\n    signKeys.forEach((key) => {\n      signInput2Of3(txBuilder, vin, scriptType, publicKeys, key, getDefaultCosigner(publicKeys, key.publicKey), value);\n    });\n  });\n\n  if (signKeys.length === 1) {\n    return txBuilder.buildIncomplete() as UtxoTransaction<TNumber>;\n  }\n  return txBuilder.build() as UtxoTransaction<TNumber>;\n}\n\nexport function createSpendTransaction<TNumber extends number | bigint = number>(\n  keys: KeyTriple,\n  scriptType: ScriptType2Of3,\n  inputTxs: Buffer[],\n  recipientScript: Buffer,\n  network: Network,\n  version?: number,\n  amountType?: 'number' | 'bigint'\n): Transaction<TNumber> {\n  const matches: (TxOutPoint & TxOutput<TNumber>)[] = inputTxs\n    .map((inputTxBuffer): (TxOutPoint & TxOutput<TNumber>)[] => {\n      const inputTx = createTransactionFromBuffer<TNumber>(inputTxBuffer, network, { amountType });\n\n      const { scriptPubKey } = createOutputScript2of3(\n        keys.map((k) => k.publicKey),\n        scriptType as ScriptType2Of3\n      );\n\n      return inputTx.outs\n        .map((o, vout): (TxOutPoint & TxOutput<TNumber>) | undefined => {\n          if (!scriptPubKey.equals(o.script)) {\n            return;\n          }\n          return {\n            txid: inputTx.getId(),\n            vout,\n            value: o.value,\n            script: o.script,\n          };\n        })\n        .filter((v): v is TxOutPoint & TxOutput<TNumber> => v !== undefined);\n    })\n    .reduce((all, matches) => [...all, ...matches]);\n\n  if (!matches.length) {\n    throw new Error(`could not find matching outputs in funding transaction`);\n  }\n\n  return createSpendTransactionFromPrevOutputs<TNumber>(keys, scriptType, matches, recipientScript, network, {\n    version,\n    amountType,\n  });\n}\n\nexport function createPsbtSpendTransactionFromPrevTx(\n  rootWalletKeys: RootWalletKeys,\n  unspents: WalletUnspent<bigint>[],\n  network: Network,\n  signers: Tuple<KeyName> = ['user', 'bitgo'],\n  version?: number\n): UtxoTransaction<bigint> {\n  const psbt = createPsbtForNetwork({ network }, { version });\n\n  unspents.forEach((u, index) => {\n    addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signers[0], signers[1]);\n  });\n\n  const inputSum = unspents.reduce((sum, { value }) => sum + BigInt(value), BigInt(0));\n  const fee = network === utxolib.networks.dogecoinTest ? BigInt(1_000_000) : BigInt(1_000);\n  const outputValue = inputSum - fee;\n\n  addWalletOutputToPsbt(psbt, rootWalletKeys, unspents[0].chain, unspents[0].index, outputValue);\n\n  signers.forEach((keyName) => {\n    psbt.setAllInputsMusig2NonceHD(rootWalletKeys[keyName]);\n  });\n\n  signers.forEach((keyName) => {\n    psbt.signAllInputsHD(rootWalletKeys[keyName]);\n  });\n\n  if (!psbt.validateSignaturesOfAllInputs()) {\n    throw new Error('psbt sig validation fails');\n  }\n\n  psbt.finalizeAllInputs();\n  return psbt.extractTransaction();\n}\n\nexport function createPsbtSpendTransaction<TNumber extends number | bigint = number>({\n  rootWalletKeys,\n  signers,\n  chain,\n  index,\n  inputTxs,\n  network,\n  version,\n  amountType,\n}: {\n  rootWalletKeys: RootWalletKeys;\n  signers: Tuple<KeyName>;\n  chain: ChainCode;\n  index: number;\n  inputTxs: Buffer[];\n  network: Network;\n  version?: number;\n  amountType?: 'number' | 'bigint';\n}): Transaction<TNumber> {\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);\n  const { scriptPubKey } = createOutputScript2of3(walletKeys.publicKeys, scriptTypeForChain(chain));\n\n  const matches = inputTxs\n    .map((inputTxBuffer): WalletUnspent<bigint>[] => {\n      const inputTx = createTransactionFromBuffer<bigint>(inputTxBuffer, network, { amountType: 'bigint' });\n\n      return inputTx.outs\n        .map((o, vout): WalletUnspent<bigint> | undefined => {\n          if (!scriptPubKey.equals(o.script)) {\n            return;\n          }\n          return { chain, index, ...fromOutputWithPrevTx<bigint>(inputTx, vout) };\n        })\n        .filter((v): v is WalletUnspent<bigint> => v !== undefined);\n    })\n    .reduce((all, matches) => [...all, ...matches]);\n\n  if (!matches.length) {\n    throw new Error(`could not find matching outputs in funding transaction`);\n  }\n\n  const tx = createPsbtSpendTransactionFromPrevTx(rootWalletKeys, matches, network, signers, version);\n  return tx.clone(amountType) as Transaction<TNumber>;\n}\n\n/**\n * @returns BIP32 hardcoded index for p2trMusig2 spend type. 0 for key path and 100 for script path.\n * For same fixture key triple and script type (p2trMusig2),\n * we need 2 different deposit and spend tx fixtures.\n */\nexport function getP2trMusig2Index(spendType: 'keyPath' | 'scriptPath'): number {\n  return spendType === 'keyPath' ? 0 : 100;\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!