Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Socket
Sign inDemoInstall

@bitgo/utxo-lib

Package Overview
Dependencies
Maintainers
4
Versions
171
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bitgo/utxo-lib - npm Package Compare versions

Comparing version 2.2.0-rc.6 to 2.2.0-rc.7

6

dist/src/bitgo/dash/DashTransactionBuilder.d.ts
/// <reference types="node" />
import * as bitcoinjs from 'bitcoinjs-lib';
import { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';
import { Network } from '../../networkTypes';
import { DashTransaction } from './DashTransaction';
import { Transaction } from 'bitcoinjs-lib';
export declare class DashTransactionBuilder extends UtxoTransactionBuilder<DashTransaction> {
constructor(network: Network, txb?: UtxoTransactionBuilder);
createInitialTransaction(network: Network, tx?: Transaction): DashTransaction;
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction): DashTransaction;
setType(type: number): void;
setExtraPayload(extraPayload?: Buffer): void;
static fromTransaction(tx: DashTransaction): DashTransactionBuilder;
static fromTransaction(tx: DashTransaction, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput[]): DashTransactionBuilder;
}
//# sourceMappingURL=DashTransactionBuilder.d.ts.map

@@ -19,4 +19,4 @@ "use strict";

}
static fromTransaction(tx) {
const txb = new DashTransactionBuilder(tx.network, UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx));
static fromTransaction(tx, network, prevOutput) {
const txb = new DashTransactionBuilder(tx.network, UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx, network, prevOutput));
txb.setType(tx.type);

@@ -28,2 +28,2 @@ txb.setExtraPayload(tx.extraPayload);

exports.DashTransactionBuilder = DashTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFzaFRyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby9kYXNoL0Rhc2hUcmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsc0VBQW1FO0FBRW5FLHVEQUFvRDtBQUlwRCxNQUFhLHNCQUF1QixTQUFRLCtDQUF1QztJQUNqRixZQUFZLE9BQWdCLEVBQUUsR0FBNEI7UUFDeEQsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QixDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBZ0IsRUFBRSxFQUFnQjtRQUN6RCxPQUFPLElBQUksaUNBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBcUIsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxPQUFPLENBQUMsSUFBWTtRQUNsQixJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7SUFDdEIsQ0FBQztJQUVELGVBQWUsQ0FBQyxZQUFxQjtRQUNuQyxJQUFJLENBQUMsRUFBRSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDdEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxlQUFlLENBQUMsRUFBbUI7UUFDeEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxzQkFBc0IsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLCtDQUFzQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQy9GLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLEdBQUcsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztDQUNGO0FBdkJELHdEQXVCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuLi9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLi9uZXR3b3JrVHlwZXMnO1xuaW1wb3J0IHsgRGFzaFRyYW5zYWN0aW9uIH0gZnJvbSAnLi9EYXNoVHJhbnNhY3Rpb24nO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICdiaXRjb2luanMtbGliJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4uL1V0eG9UcmFuc2FjdGlvbic7XG5cbmV4cG9ydCBjbGFzcyBEYXNoVHJhbnNhY3Rpb25CdWlsZGVyIGV4dGVuZHMgVXR4b1RyYW5zYWN0aW9uQnVpbGRlcjxEYXNoVHJhbnNhY3Rpb24+IHtcbiAgY29uc3RydWN0b3IobmV0d29yazogTmV0d29yaywgdHhiPzogVXR4b1RyYW5zYWN0aW9uQnVpbGRlcikge1xuICAgIHN1cGVyKG5ldHdvcmssIHR4Yik7XG4gIH1cblxuICBjcmVhdGVJbml0aWFsVHJhbnNhY3Rpb24obmV0d29yazogTmV0d29yaywgdHg/OiBUcmFuc2FjdGlvbik6IERhc2hUcmFuc2FjdGlvbiB7XG4gICAgcmV0dXJuIG5ldyBEYXNoVHJhbnNhY3Rpb24obmV0d29yaywgdHggYXMgVXR4b1RyYW5zYWN0aW9uKTtcbiAgfVxuXG4gIHNldFR5cGUodHlwZTogbnVtYmVyKTogdm9pZCB7XG4gICAgdGhpcy50eC50eXBlID0gdHlwZTtcbiAgfVxuXG4gIHNldEV4dHJhUGF5bG9hZChleHRyYVBheWxvYWQ/OiBCdWZmZXIpOiB2b2lkIHtcbiAgICB0aGlzLnR4LmV4dHJhUGF5bG9hZCA9IGV4dHJhUGF5bG9hZDtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tVHJhbnNhY3Rpb24odHg6IERhc2hUcmFuc2FjdGlvbik6IERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICAgIGNvbnN0IHR4YiA9IG5ldyBEYXNoVHJhbnNhY3Rpb25CdWlsZGVyKHR4Lm5ldHdvcmssIFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4KSk7XG4gICAgdHhiLnNldFR5cGUodHgudHlwZSk7XG4gICAgdHhiLnNldEV4dHJhUGF5bG9hZCh0eC5leHRyYVBheWxvYWQpO1xuICAgIHJldHVybiB0eGI7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFzaFRyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby9kYXNoL0Rhc2hUcmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0Esc0VBQW1FO0FBRW5FLHVEQUFvRDtBQUdwRCxNQUFhLHNCQUF1QixTQUFRLCtDQUF1QztJQUNqRixZQUFZLE9BQWdCLEVBQUUsR0FBNEI7UUFDeEQsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QixDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBZ0IsRUFBRSxFQUEwQjtRQUNuRSxPQUFPLElBQUksaUNBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBcUIsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxPQUFPLENBQUMsSUFBWTtRQUNsQixJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7SUFDdEIsQ0FBQztJQUVELGVBQWUsQ0FBQyxZQUFxQjtRQUNuQyxJQUFJLENBQUMsRUFBRSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDdEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxlQUFlLENBQ3BCLEVBQW1CLEVBQ25CLE9BQTJCLEVBQzNCLFVBQWlDO1FBRWpDLE1BQU0sR0FBRyxHQUFHLElBQUksc0JBQXNCLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSwrQ0FBc0IsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ3BILEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLEdBQUcsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztDQUNGO0FBM0JELHdEQTJCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGJpdGNvaW5qcyBmcm9tICdiaXRjb2luanMtbGliJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuLi9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLi9uZXR3b3JrVHlwZXMnO1xuaW1wb3J0IHsgRGFzaFRyYW5zYWN0aW9uIH0gZnJvbSAnLi9EYXNoVHJhbnNhY3Rpb24nO1xuaW1wb3J0IHsgVXR4b1RyYW5zYWN0aW9uIH0gZnJvbSAnLi4vVXR4b1RyYW5zYWN0aW9uJztcblxuZXhwb3J0IGNsYXNzIERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIgZXh0ZW5kcyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyPERhc2hUcmFuc2FjdGlvbj4ge1xuICBjb25zdHJ1Y3RvcihuZXR3b3JrOiBOZXR3b3JrLCB0eGI/OiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyKSB7XG4gICAgc3VwZXIobmV0d29yaywgdHhiKTtcbiAgfVxuXG4gIGNyZWF0ZUluaXRpYWxUcmFuc2FjdGlvbihuZXR3b3JrOiBOZXR3b3JrLCB0eD86IGJpdGNvaW5qcy5UcmFuc2FjdGlvbik6IERhc2hUcmFuc2FjdGlvbiB7XG4gICAgcmV0dXJuIG5ldyBEYXNoVHJhbnNhY3Rpb24obmV0d29yaywgdHggYXMgVXR4b1RyYW5zYWN0aW9uKTtcbiAgfVxuXG4gIHNldFR5cGUodHlwZTogbnVtYmVyKTogdm9pZCB7XG4gICAgdGhpcy50eC50eXBlID0gdHlwZTtcbiAgfVxuXG4gIHNldEV4dHJhUGF5bG9hZChleHRyYVBheWxvYWQ/OiBCdWZmZXIpOiB2b2lkIHtcbiAgICB0aGlzLnR4LmV4dHJhUGF5bG9hZCA9IGV4dHJhUGF5bG9hZDtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tVHJhbnNhY3Rpb24oXG4gICAgdHg6IERhc2hUcmFuc2FjdGlvbixcbiAgICBuZXR3b3JrPzogYml0Y29pbmpzLk5ldHdvcmssXG4gICAgcHJldk91dHB1dD86IGJpdGNvaW5qcy5UeE91dHB1dFtdXG4gICk6IERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICAgIGNvbnN0IHR4YiA9IG5ldyBEYXNoVHJhbnNhY3Rpb25CdWlsZGVyKHR4Lm5ldHdvcmssIFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4LCBuZXR3b3JrLCBwcmV2T3V0cHV0KSk7XG4gICAgdHhiLnNldFR5cGUodHgudHlwZSk7XG4gICAgdHhiLnNldEV4dHJhUGF5bG9hZCh0eC5leHRyYVBheWxvYWQpO1xuICAgIHJldHVybiB0eGI7XG4gIH1cbn1cbiJdfQ==
/// <reference types="node" />
import * as bip32 from 'bip32';
import { TxInput } from 'bitcoinjs-lib';
import { TxInput, TxOutput } from 'bitcoinjs-lib';
import { Network } from '../networkTypes';

@@ -67,6 +67,2 @@ import { UtxoTransaction } from './UtxoTransaction';

};
export interface PrevOutput {
prevOutScript: Buffer;
value: number;
}
/**

@@ -81,3 +77,3 @@ * Get signature verifications for multsig transaction

*/
export declare function getSignatureVerifications(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: PrevOutput[]): SignatureVerification[];
export declare function getSignatureVerifications(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput[]): SignatureVerification[];
/**

@@ -90,3 +86,3 @@ * @param transaction

*/
export declare function verifySignature(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: PrevOutput[]): boolean;
export declare function verifySignature(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput[]): boolean;
export declare function signInputP2shP2pk(txBuilder: UtxoTransactionBuilder, vin: number, keyPair: bip32.BIP32Interface): void;

@@ -93,0 +89,0 @@ export declare function signInput2Of3(txBuilder: UtxoTransactionBuilder, vin: number, scriptType: ScriptType2Of3, pubkeys: Triple<Buffer>, keyPair: bip32.BIP32Interface, cosigner: Buffer, amount: number): void;

@@ -283,3 +283,3 @@ "use strict";

const leafHash = bitcoinjs_lib_1.taproot.getTapleafHash(controlBlock, pubScript);
const signatureHash = transaction.hashForWitnessV1(inputIndex, prevOutputs.map(({ prevOutScript }) => prevOutScript), prevOutputs.map(({ value }) => value), hashType, leafHash);
const signatureHash = transaction.hashForWitnessV1(inputIndex, prevOutputs.map(({ script }) => script), prevOutputs.map(({ value }) => value), hashType, leafHash);
const signedBy = publicKeys.filter((k) => Buffer.isBuffer(signatureBuffer) && bitcoinjs_lib_1.schnorrBip340.verifySchnorr(signatureHash, k, signatureBuffer));

@@ -369,2 +369,2 @@ if (signedBy.length === 0) {

exports.signInput2Of3 = signInput2Of3;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":"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","sourcesContent":["import * as opcodes from 'bitcoin-ops';\nimport * as bip32 from 'bip32';\n\nimport {\n  ECPair,\n  payments,\n  script,\n  Transaction,\n  TxInput,\n  schnorrBip340,\n  classify,\n  taproot,\n  ScriptSignature,\n} from 'bitcoinjs-lib';\n\nimport { Network } from '../networkTypes';\nimport * as networks from '../networks';\nimport { getMainnet } from '../coins';\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport {\n  createOutputScript2of3,\n  createOutputScriptP2shP2pk,\n  createSpendScriptP2tr,\n  ScriptType2Of3,\n  scriptType2Of3AsPrevOutType,\n} from './outputScripts';\nimport { Triple } from './types';\n\nconst inputTypes = [\n  'multisig',\n  'nonstandard',\n  'nulldata',\n  'pubkey',\n  'pubkeyhash',\n  'scripthash',\n  'witnesspubkeyhash',\n  'witnessscripthash',\n  'witnesscommitment',\n] as const;\n\ntype InputType = typeof inputTypes[number];\n\nexport interface ParsedSignatureScript {\n  isSegwitInput: boolean;\n  inputClassification: InputType;\n  p2shOutputClassification?: string;\n  publicKeys?: Buffer[];\n}\n\nexport interface ParsedSignatureP2PKH extends ParsedSignatureScript {\n  signatures: [Buffer];\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    /* Partially signed transactions with placeholder signatures.\n       For p2sh, the placeholder is OP_0 (number 0) */\n    | [Buffer | 0, Buffer | 0, Buffer | 0];\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScriptTaproot extends ParsedSignatureScript {\n  // P2TR tapscript spends are for 2-of-2 multisig scripts\n  signatures: [Buffer, Buffer]; // missing signature is encoded as empty buffer\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n  controlBlock: Buffer;\n}\n\nexport function getDefaultSigHash(network: Network, scriptType?: ScriptType2Of3): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return Transaction.SIGHASH_ALL | UtxoTransaction.SIGHASH_FORKID;\n    default:\n      return scriptType === 'p2tr' ? Transaction.SIGHASH_DEFAULT : Transaction.SIGHASH_ALL;\n  }\n}\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: TxInput\n): ParsedSignatureScript | ParsedSignatureP2PKH | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const isSegwitInput = input.witness.length > 0;\n  const isNativeSegwitInput = input.script.length === 0;\n  let decompiledSigScript: Array<Buffer | number> | null;\n  let inputClassification: InputType;\n  if (isSegwitInput) {\n    // The decompiledSigScript is the script containing the signatures, public keys, and the script that was committed\n    // to (pubScript). If this is a segwit input the decompiledSigScript is in the witness, regardless of whether it\n    // is native or not. The inputClassification is determined based on whether or not the input is native to give an\n    // accurate classification. Note that p2shP2wsh inputs will be classified as p2sh and not p2wsh.\n    decompiledSigScript = input.witness;\n    if (isNativeSegwitInput) {\n      inputClassification = classify.witness(decompiledSigScript as Buffer[], true) as InputType;\n    } else {\n      inputClassification = classify.input(input.script, true) as InputType;\n    }\n  } else {\n    inputClassification = classify.input(input.script, true) as InputType;\n    decompiledSigScript = script.decompile(input.script);\n  }\n\n  if (!decompiledSigScript) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (inputClassification === classify.types.P2PKH) {\n    /* istanbul ignore next */\n    if (!decompiledSigScript || decompiledSigScript.length !== 2) {\n      throw new Error('unexpected signature for p2pkh');\n    }\n    const [signature, publicKey] = decompiledSigScript;\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(signature) || !Buffer.isBuffer(publicKey)) {\n      throw new Error('unexpected signature for p2pkh');\n    }\n    const publicKeys = [publicKey];\n    const signatures: [Buffer] = [signature];\n    const pubScript = payments.p2pkh({ pubkey: publicKey }).output;\n\n    return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n  }\n\n  if (inputClassification === classify.types.P2TR) {\n    // assumes no annex\n    if (input.witness.length !== 4) {\n      throw new Error(`unrecognized taproot input`);\n    }\n    const [sig1, sig2, tapscript, controlBlock] = input.witness;\n    const tapscriptClassification = classify.output(tapscript);\n    if (tapscriptClassification !== classify.types.P2TR_NS) {\n      throw new Error(`tapscript must be n of n multisig`);\n    }\n\n    const publicKeys = payments.p2tr_ns({ output: tapscript }).pubkeys;\n    if (!publicKeys || publicKeys.length !== 2) {\n      throw new Error('expected 2 pubkeys');\n    }\n\n    return {\n      isSegwitInput,\n      inputClassification,\n      signatures: [sig1, sig2].map((b) => {\n        if (Buffer.isBuffer(b)) {\n          return b;\n        }\n        throw new Error(`unexpected signature element ${b}`);\n      }),\n      publicKeys,\n      pubScript: tapscript,\n      controlBlock,\n    } as ParsedSignatureScriptTaproot;\n  }\n\n  // Note the assumption here that if we have a p2sh or p2wsh input it will be multisig (appropriate because the\n  // BitGo platform only supports multisig within these types of inputs, with the exception of replay protection inputs,\n  // which are single signature p2sh). Signatures are all but the last entry in the decompiledSigScript.\n  // The redeemScript/witnessScript (depending on which type of input this is) is the last entry in\n  // the decompiledSigScript (denoted here as the pubScript). The public keys are the second through\n  // antepenultimate entries in the decompiledPubScript. See below for a visual representation of the typical 2-of-3\n  // multisig setup:\n  //\n  //   decompiledSigScript = 0 <sig1> <sig2> [<sig3>] <pubScript>\n  //   decompiledPubScript = 2 <pub1> <pub2> <pub3> 3 OP_CHECKMULTISIG\n  //\n  // Transactions built with `.build()` only have two signatures `<sig1>` and `<sig2>` in _decompiledSigScript_.\n  // Transactions built with `.buildIncomplete()` have three signatures, where missing signatures are substituted with `OP_0`.\n  const expectedScriptType =\n    inputClassification === classify.types.P2SH || inputClassification === classify.types.P2WSH;\n\n  if (!expectedScriptType) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  const pubScript = decompiledSigScript[decompiledSigScript.length - 1];\n  /* istanbul ignore next */\n  if (!Buffer.isBuffer(pubScript)) {\n    throw new Error(`invalid pubScript`);\n  }\n\n  const p2shOutputClassification = classify.output(pubScript);\n\n  if (p2shOutputClassification !== 'multisig') {\n    return {\n      isSegwitInput,\n      inputClassification,\n      p2shOutputClassification,\n    };\n  }\n\n  const decompiledPubScript = script.decompile(pubScript);\n  if (decompiledPubScript === null) {\n    /* istanbul ignore next */\n    throw new Error(`could not decompile pubScript`);\n  }\n\n  const expectedScriptLength =\n    // complete transactions with 2 signatures\n    decompiledSigScript.length === 4 ||\n    // incomplete transaction with 3 signatures or signature placeholders\n    decompiledSigScript.length === 5;\n\n  if (!expectedScriptLength) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (isSegwitInput) {\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(decompiledSigScript[0])) {\n      throw new Error(`expected decompiledSigScript[0] to be a buffer for segwit inputs`);\n    }\n    /* istanbul ignore next */\n    if (decompiledSigScript[0].length !== 0) {\n      throw new Error(`witness stack expected to start with empty buffer`);\n    }\n  } else if (decompiledSigScript[0] !== opcodes.OP_0) {\n    throw new Error(`sigScript expected to start with OP_0`);\n  }\n\n  const signatures = decompiledSigScript.slice(1 /* ignore leading OP_0 */, -1 /* ignore trailing pubScript */);\n  /* istanbul ignore next */\n  if (signatures.length !== 2 && signatures.length !== 3) {\n    throw new Error(`expected 2 or 3 signatures, got ${signatures.length}`);\n  }\n\n  /* istanbul ignore next */\n  if (decompiledPubScript.length !== 6) {\n    throw new Error(`unexpected decompiledPubScript length`);\n  }\n  const publicKeys = decompiledPubScript.slice(1, -2) as Buffer[];\n  publicKeys.forEach((b) => {\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(b)) {\n      throw new Error();\n    }\n  });\n  if (publicKeys.length !== 3) {\n    /* istanbul ignore next */\n    throw new Error(`expected 3 public keys, got ${publicKeys.length}`);\n  }\n\n  // Op codes 81 through 96 represent numbers 1 through 16 (see https://en.bitcoin.it/wiki/Script#Opcodes), which is\n  // why we subtract by 80 to get the number of signatures (n) and the number of public keys (m) in an n-of-m setup.\n  const len = decompiledPubScript.length;\n  const signatureThreshold = (decompiledPubScript[0] as number) - 80;\n  /* istanbul ignore next */\n  if (signatureThreshold !== 2) {\n    throw new Error(`expected signatureThreshold 2, got ${signatureThreshold}`);\n  }\n  const nPubKeys = (decompiledPubScript[len - 2] as number) - 80;\n  /* istanbul ignore next */\n  if (nPubKeys !== 3) {\n    throw new Error(`expected nPubKeys 3, got ${nPubKeys}`);\n  }\n\n  const lastOpCode = decompiledPubScript[len - 1];\n  /* istanbul ignore next */\n  if (lastOpCode !== opcodes.OP_CHECKMULTISIG) {\n    throw new Error(`expected opcode #${opcodes.OP_CHECKMULTISIG}, got opcode #${lastOpCode}`);\n  }\n\n  return {\n    isSegwitInput,\n    inputClassification,\n    p2shOutputClassification,\n    signatures: signatures.map((b) => {\n      if (Buffer.isBuffer(b) || b === 0) {\n        return b;\n      }\n      throw new Error(`unexpected signature element ${b}`);\n    }) as [Buffer, Buffer] | [Buffer, Buffer, Buffer],\n    publicKeys,\n    pubScript,\n  };\n}\n\nexport function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input) as ParsedSignatureScript2Of3;\n\n  if (\n    ![classify.types.P2WSH, classify.types.P2SH, classify.types.P2PKH, classify.types.P2TR].includes(\n      result.inputClassification\n    )\n  ) {\n    throw new Error(`unexpected inputClassification ${result.inputClassification}`);\n  }\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (\n    result.publicKeys.length !== 3 &&\n    (result.publicKeys.length !== 2 || result.inputClassification !== classify.types.P2TR)\n  ) {\n    throw new Error(`unexpected pubkey count`);\n  }\n  if (!result.pubScript || result.pubScript.length === 0) {\n    throw new Error(`pubScript missing or empty`);\n  }\n\n  return result;\n}\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The hex of the public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification = {\n  /** Set to the public key that signed for the signature */\n  signedBy: Buffer | undefined;\n};\n\nexport interface PrevOutput {\n  prevOutScript: Buffer;\n  value: number;\n}\n\n/**\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @param prevOutputs - must be set for p2tr transactions\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: PrevOutput[]\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) =>\n      verificationSettings.publicKey === undefined ||\n      verificationSettings.publicKey.equals(buf) ||\n      verificationSettings.publicKey.slice(1).equals(buf)\n  );\n\n  return signatures.map((signatureBuffer) => {\n    if (signatureBuffer === 0 || signatureBuffer.length === 0) {\n      return { signedBy: undefined };\n    }\n\n    let hashType = Transaction.SIGHASH_DEFAULT;\n\n    if (signatureBuffer.length === 65) {\n      hashType = signatureBuffer[signatureBuffer.length - 1];\n      signatureBuffer = signatureBuffer.slice(0, -1);\n    }\n\n    if (parsedScript.inputClassification === classify.types.P2TR) {\n      if (verificationSettings.signatureIndex !== undefined) {\n        throw new Error(`signatureIndex parameter not supported for p2tr`);\n      }\n\n      if (!prevOutputs) {\n        throw new Error(`prevOutputs not set`);\n      }\n\n      if (prevOutputs.length !== transaction.ins.length) {\n        throw new Error(`prevOutputs length ${prevOutputs.length}, expected ${transaction.ins.length}`);\n      }\n\n      const { controlBlock, pubScript } = parsedScript as ParsedSignatureScriptTaproot;\n      const leafHash = taproot.getTapleafHash(controlBlock, pubScript);\n      const signatureHash = transaction.hashForWitnessV1(\n        inputIndex,\n        prevOutputs.map(({ prevOutScript }) => prevOutScript),\n        prevOutputs.map(({ value }) => value),\n        hashType,\n        leafHash\n      );\n\n      const signedBy = publicKeys.filter(\n        (k) => Buffer.isBuffer(signatureBuffer) && schnorrBip340.verifySchnorr(signatureHash, k, signatureBuffer)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0] };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    } else {\n      // slice the last byte from the signature hash input because it's the hash type\n      const { signature, hashType } = ScriptSignature.decode(signatureBuffer);\n      const transactionHash = parsedScript.isSegwitInput\n        ? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)\n        : transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);\n      const signedBy = publicKeys.filter((publicKey) =>\n        ECPair.fromPublicKey(publicKey).verify(transactionHash, signature)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0] };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    }\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n * @param prevOutputs - must be set for p2tr transactions\n */\nexport function verifySignature(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: PrevOutput[]\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings,\n    prevOutputs\n  ).filter(\n    (v) =>\n      // If no publicKey is set in verificationSettings, all signatures must be valid.\n      // Otherwise, a single valid signature by the specified pubkey is sufficient.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined &&\n        (verificationSettings.publicKey.equals(v.signedBy) ||\n          verificationSettings.publicKey.slice(1).equals(v.signedBy)))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n\nexport function signInputP2shP2pk(txBuilder: UtxoTransactionBuilder, vin: number, keyPair: bip32.BIP32Interface): void {\n  const prevOutScriptType = 'p2sh-p2pk';\n  const { redeemScript, witnessScript } = createOutputScriptP2shP2pk(keyPair.publicKey);\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network),\n    redeemScript,\n    witnessScript,\n    witnessValue: undefined,\n  });\n}\n\nexport function signInput2Of3(\n  txBuilder: UtxoTransactionBuilder,\n  vin: number,\n  scriptType: ScriptType2Of3,\n  pubkeys: Triple<Buffer>,\n  keyPair: bip32.BIP32Interface,\n  cosigner: Buffer,\n  amount: number\n): void {\n  let controlBlock;\n  let redeemScript;\n  let witnessScript;\n\n  const prevOutScriptType = scriptType2Of3AsPrevOutType(scriptType);\n  if (scriptType === 'p2tr') {\n    ({ witnessScript, controlBlock } = createSpendScriptP2tr(pubkeys, [keyPair.publicKey, cosigner]));\n  } else {\n    ({ redeemScript, witnessScript } = createOutputScript2of3(pubkeys, scriptType));\n  }\n\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network, scriptType),\n    redeemScript,\n    witnessScript,\n    witnessValue: amount,\n    controlBlock,\n  });\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":"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","sourcesContent":["import * as opcodes from 'bitcoin-ops';\nimport * as bip32 from 'bip32';\n\nimport {\n  ECPair,\n  payments,\n  script,\n  Transaction,\n  TxInput,\n  schnorrBip340,\n  classify,\n  taproot,\n  TxOutput,\n  ScriptSignature,\n} from 'bitcoinjs-lib';\n\nimport { Network } from '../networkTypes';\nimport * as networks from '../networks';\nimport { getMainnet } from '../coins';\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport {\n  createOutputScript2of3,\n  createOutputScriptP2shP2pk,\n  createSpendScriptP2tr,\n  ScriptType2Of3,\n  scriptType2Of3AsPrevOutType,\n} from './outputScripts';\nimport { Triple } from './types';\n\nconst inputTypes = [\n  'multisig',\n  'nonstandard',\n  'nulldata',\n  'pubkey',\n  'pubkeyhash',\n  'scripthash',\n  'witnesspubkeyhash',\n  'witnessscripthash',\n  'witnesscommitment',\n] as const;\n\ntype InputType = typeof inputTypes[number];\n\nexport interface ParsedSignatureScript {\n  isSegwitInput: boolean;\n  inputClassification: InputType;\n  p2shOutputClassification?: string;\n  publicKeys?: Buffer[];\n}\n\nexport interface ParsedSignatureP2PKH extends ParsedSignatureScript {\n  signatures: [Buffer];\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    /* Partially signed transactions with placeholder signatures.\n       For p2sh, the placeholder is OP_0 (number 0) */\n    | [Buffer | 0, Buffer | 0, Buffer | 0];\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScriptTaproot extends ParsedSignatureScript {\n  // P2TR tapscript spends are for 2-of-2 multisig scripts\n  signatures: [Buffer, Buffer]; // missing signature is encoded as empty buffer\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n  controlBlock: Buffer;\n}\n\nexport function getDefaultSigHash(network: Network, scriptType?: ScriptType2Of3): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return Transaction.SIGHASH_ALL | UtxoTransaction.SIGHASH_FORKID;\n    default:\n      return scriptType === 'p2tr' ? Transaction.SIGHASH_DEFAULT : Transaction.SIGHASH_ALL;\n  }\n}\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: TxInput\n): ParsedSignatureScript | ParsedSignatureP2PKH | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const isSegwitInput = input.witness.length > 0;\n  const isNativeSegwitInput = input.script.length === 0;\n  let decompiledSigScript: Array<Buffer | number> | null;\n  let inputClassification: InputType;\n  if (isSegwitInput) {\n    // The decompiledSigScript is the script containing the signatures, public keys, and the script that was committed\n    // to (pubScript). If this is a segwit input the decompiledSigScript is in the witness, regardless of whether it\n    // is native or not. The inputClassification is determined based on whether or not the input is native to give an\n    // accurate classification. Note that p2shP2wsh inputs will be classified as p2sh and not p2wsh.\n    decompiledSigScript = input.witness;\n    if (isNativeSegwitInput) {\n      inputClassification = classify.witness(decompiledSigScript as Buffer[], true) as InputType;\n    } else {\n      inputClassification = classify.input(input.script, true) as InputType;\n    }\n  } else {\n    inputClassification = classify.input(input.script, true) as InputType;\n    decompiledSigScript = script.decompile(input.script);\n  }\n\n  if (!decompiledSigScript) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (inputClassification === classify.types.P2PKH) {\n    /* istanbul ignore next */\n    if (!decompiledSigScript || decompiledSigScript.length !== 2) {\n      throw new Error('unexpected signature for p2pkh');\n    }\n    const [signature, publicKey] = decompiledSigScript;\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(signature) || !Buffer.isBuffer(publicKey)) {\n      throw new Error('unexpected signature for p2pkh');\n    }\n    const publicKeys = [publicKey];\n    const signatures: [Buffer] = [signature];\n    const pubScript = payments.p2pkh({ pubkey: publicKey }).output;\n\n    return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n  }\n\n  if (inputClassification === classify.types.P2TR) {\n    // assumes no annex\n    if (input.witness.length !== 4) {\n      throw new Error(`unrecognized taproot input`);\n    }\n    const [sig1, sig2, tapscript, controlBlock] = input.witness;\n    const tapscriptClassification = classify.output(tapscript);\n    if (tapscriptClassification !== classify.types.P2TR_NS) {\n      throw new Error(`tapscript must be n of n multisig`);\n    }\n\n    const publicKeys = payments.p2tr_ns({ output: tapscript }).pubkeys;\n    if (!publicKeys || publicKeys.length !== 2) {\n      throw new Error('expected 2 pubkeys');\n    }\n\n    return {\n      isSegwitInput,\n      inputClassification,\n      signatures: [sig1, sig2].map((b) => {\n        if (Buffer.isBuffer(b)) {\n          return b;\n        }\n        throw new Error(`unexpected signature element ${b}`);\n      }),\n      publicKeys,\n      pubScript: tapscript,\n      controlBlock,\n    } as ParsedSignatureScriptTaproot;\n  }\n\n  // Note the assumption here that if we have a p2sh or p2wsh input it will be multisig (appropriate because the\n  // BitGo platform only supports multisig within these types of inputs, with the exception of replay protection inputs,\n  // which are single signature p2sh). Signatures are all but the last entry in the decompiledSigScript.\n  // The redeemScript/witnessScript (depending on which type of input this is) is the last entry in\n  // the decompiledSigScript (denoted here as the pubScript). The public keys are the second through\n  // antepenultimate entries in the decompiledPubScript. See below for a visual representation of the typical 2-of-3\n  // multisig setup:\n  //\n  //   decompiledSigScript = 0 <sig1> <sig2> [<sig3>] <pubScript>\n  //   decompiledPubScript = 2 <pub1> <pub2> <pub3> 3 OP_CHECKMULTISIG\n  //\n  // Transactions built with `.build()` only have two signatures `<sig1>` and `<sig2>` in _decompiledSigScript_.\n  // Transactions built with `.buildIncomplete()` have three signatures, where missing signatures are substituted with `OP_0`.\n  const expectedScriptType =\n    inputClassification === classify.types.P2SH || inputClassification === classify.types.P2WSH;\n\n  if (!expectedScriptType) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  const pubScript = decompiledSigScript[decompiledSigScript.length - 1];\n  /* istanbul ignore next */\n  if (!Buffer.isBuffer(pubScript)) {\n    throw new Error(`invalid pubScript`);\n  }\n\n  const p2shOutputClassification = classify.output(pubScript);\n\n  if (p2shOutputClassification !== 'multisig') {\n    return {\n      isSegwitInput,\n      inputClassification,\n      p2shOutputClassification,\n    };\n  }\n\n  const decompiledPubScript = script.decompile(pubScript);\n  if (decompiledPubScript === null) {\n    /* istanbul ignore next */\n    throw new Error(`could not decompile pubScript`);\n  }\n\n  const expectedScriptLength =\n    // complete transactions with 2 signatures\n    decompiledSigScript.length === 4 ||\n    // incomplete transaction with 3 signatures or signature placeholders\n    decompiledSigScript.length === 5;\n\n  if (!expectedScriptLength) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (isSegwitInput) {\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(decompiledSigScript[0])) {\n      throw new Error(`expected decompiledSigScript[0] to be a buffer for segwit inputs`);\n    }\n    /* istanbul ignore next */\n    if (decompiledSigScript[0].length !== 0) {\n      throw new Error(`witness stack expected to start with empty buffer`);\n    }\n  } else if (decompiledSigScript[0] !== opcodes.OP_0) {\n    throw new Error(`sigScript expected to start with OP_0`);\n  }\n\n  const signatures = decompiledSigScript.slice(1 /* ignore leading OP_0 */, -1 /* ignore trailing pubScript */);\n  /* istanbul ignore next */\n  if (signatures.length !== 2 && signatures.length !== 3) {\n    throw new Error(`expected 2 or 3 signatures, got ${signatures.length}`);\n  }\n\n  /* istanbul ignore next */\n  if (decompiledPubScript.length !== 6) {\n    throw new Error(`unexpected decompiledPubScript length`);\n  }\n  const publicKeys = decompiledPubScript.slice(1, -2) as Buffer[];\n  publicKeys.forEach((b) => {\n    /* istanbul ignore next */\n    if (!Buffer.isBuffer(b)) {\n      throw new Error();\n    }\n  });\n  if (publicKeys.length !== 3) {\n    /* istanbul ignore next */\n    throw new Error(`expected 3 public keys, got ${publicKeys.length}`);\n  }\n\n  // Op codes 81 through 96 represent numbers 1 through 16 (see https://en.bitcoin.it/wiki/Script#Opcodes), which is\n  // why we subtract by 80 to get the number of signatures (n) and the number of public keys (m) in an n-of-m setup.\n  const len = decompiledPubScript.length;\n  const signatureThreshold = (decompiledPubScript[0] as number) - 80;\n  /* istanbul ignore next */\n  if (signatureThreshold !== 2) {\n    throw new Error(`expected signatureThreshold 2, got ${signatureThreshold}`);\n  }\n  const nPubKeys = (decompiledPubScript[len - 2] as number) - 80;\n  /* istanbul ignore next */\n  if (nPubKeys !== 3) {\n    throw new Error(`expected nPubKeys 3, got ${nPubKeys}`);\n  }\n\n  const lastOpCode = decompiledPubScript[len - 1];\n  /* istanbul ignore next */\n  if (lastOpCode !== opcodes.OP_CHECKMULTISIG) {\n    throw new Error(`expected opcode #${opcodes.OP_CHECKMULTISIG}, got opcode #${lastOpCode}`);\n  }\n\n  return {\n    isSegwitInput,\n    inputClassification,\n    p2shOutputClassification,\n    signatures: signatures.map((b) => {\n      if (Buffer.isBuffer(b) || b === 0) {\n        return b;\n      }\n      throw new Error(`unexpected signature element ${b}`);\n    }) as [Buffer, Buffer] | [Buffer, Buffer, Buffer],\n    publicKeys,\n    pubScript,\n  };\n}\n\nexport function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input) as ParsedSignatureScript2Of3;\n\n  if (\n    ![classify.types.P2WSH, classify.types.P2SH, classify.types.P2PKH, classify.types.P2TR].includes(\n      result.inputClassification\n    )\n  ) {\n    throw new Error(`unexpected inputClassification ${result.inputClassification}`);\n  }\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (\n    result.publicKeys.length !== 3 &&\n    (result.publicKeys.length !== 2 || result.inputClassification !== classify.types.P2TR)\n  ) {\n    throw new Error(`unexpected pubkey count`);\n  }\n  if (!result.pubScript || result.pubScript.length === 0) {\n    throw new Error(`pubScript missing or empty`);\n  }\n\n  return result;\n}\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The hex of the public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification = {\n  /** Set to the public key that signed for the signature */\n  signedBy: Buffer | undefined;\n};\n\n/**\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @param prevOutputs - must be set for p2tr transactions\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput[]\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) =>\n      verificationSettings.publicKey === undefined ||\n      verificationSettings.publicKey.equals(buf) ||\n      verificationSettings.publicKey.slice(1).equals(buf)\n  );\n\n  return signatures.map((signatureBuffer) => {\n    if (signatureBuffer === 0 || signatureBuffer.length === 0) {\n      return { signedBy: undefined };\n    }\n\n    let hashType = Transaction.SIGHASH_DEFAULT;\n\n    if (signatureBuffer.length === 65) {\n      hashType = signatureBuffer[signatureBuffer.length - 1];\n      signatureBuffer = signatureBuffer.slice(0, -1);\n    }\n\n    if (parsedScript.inputClassification === classify.types.P2TR) {\n      if (verificationSettings.signatureIndex !== undefined) {\n        throw new Error(`signatureIndex parameter not supported for p2tr`);\n      }\n\n      if (!prevOutputs) {\n        throw new Error(`prevOutputs not set`);\n      }\n\n      if (prevOutputs.length !== transaction.ins.length) {\n        throw new Error(`prevOutputs length ${prevOutputs.length}, expected ${transaction.ins.length}`);\n      }\n\n      const { controlBlock, pubScript } = parsedScript as ParsedSignatureScriptTaproot;\n      const leafHash = taproot.getTapleafHash(controlBlock, pubScript);\n      const signatureHash = transaction.hashForWitnessV1(\n        inputIndex,\n        prevOutputs.map(({ script }) => script),\n        prevOutputs.map(({ value }) => value),\n        hashType,\n        leafHash\n      );\n\n      const signedBy = publicKeys.filter(\n        (k) => Buffer.isBuffer(signatureBuffer) && schnorrBip340.verifySchnorr(signatureHash, k, signatureBuffer)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0] };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    } else {\n      // slice the last byte from the signature hash input because it's the hash type\n      const { signature, hashType } = ScriptSignature.decode(signatureBuffer);\n      const transactionHash = parsedScript.isSegwitInput\n        ? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)\n        : transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);\n      const signedBy = publicKeys.filter((publicKey) =>\n        ECPair.fromPublicKey(publicKey).verify(transactionHash, signature)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0] };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    }\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n * @param prevOutputs - must be set for p2tr transactions\n */\nexport function verifySignature(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput[]\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings,\n    prevOutputs\n  ).filter(\n    (v) =>\n      // If no publicKey is set in verificationSettings, all signatures must be valid.\n      // Otherwise, a single valid signature by the specified pubkey is sufficient.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined &&\n        (verificationSettings.publicKey.equals(v.signedBy) ||\n          verificationSettings.publicKey.slice(1).equals(v.signedBy)))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n\nexport function signInputP2shP2pk(txBuilder: UtxoTransactionBuilder, vin: number, keyPair: bip32.BIP32Interface): void {\n  const prevOutScriptType = 'p2sh-p2pk';\n  const { redeemScript, witnessScript } = createOutputScriptP2shP2pk(keyPair.publicKey);\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network),\n    redeemScript,\n    witnessScript,\n    witnessValue: undefined,\n  });\n}\n\nexport function signInput2Of3(\n  txBuilder: UtxoTransactionBuilder,\n  vin: number,\n  scriptType: ScriptType2Of3,\n  pubkeys: Triple<Buffer>,\n  keyPair: bip32.BIP32Interface,\n  cosigner: Buffer,\n  amount: number\n): void {\n  let controlBlock;\n  let redeemScript;\n  let witnessScript;\n\n  const prevOutScriptType = scriptType2Of3AsPrevOutType(scriptType);\n  if (scriptType === 'p2tr') {\n    ({ witnessScript, controlBlock } = createSpendScriptP2tr(pubkeys, [keyPair.publicKey, cosigner]));\n  } else {\n    ({ redeemScript, witnessScript } = createOutputScript2of3(pubkeys, scriptType));\n  }\n\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network, scriptType),\n    redeemScript,\n    witnessScript,\n    witnessValue: amount,\n    controlBlock,\n  });\n}\n"]}
/// <reference types="node" />
import { TxOutput } from 'bitcoinjs-lib';
import { Network } from '../networkTypes';

@@ -9,3 +10,3 @@ import { UtxoTransaction } from './UtxoTransaction';

export declare function createTransactionBuilderForNetwork(network: Network): UtxoTransactionBuilder;
export declare function createTransactionBuilderFromTransaction(tx: UtxoTransaction): UtxoTransactionBuilder;
export declare function createTransactionBuilderFromTransaction(tx: UtxoTransaction, prevOutputs?: TxOutput[]): UtxoTransactionBuilder;
//# sourceMappingURL=transaction.d.ts.map

@@ -75,3 +75,3 @@ "use strict";

exports.createTransactionBuilderForNetwork = createTransactionBuilderForNetwork;
function createTransactionBuilderFromTransaction(tx) {
function createTransactionBuilderFromTransaction(tx, prevOutputs) {
switch (coins_1.getMainnet(tx.network)) {

@@ -83,7 +83,7 @@ case networks.bitcoin:

case networks.litecoin:
return UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx);
return UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx, undefined, prevOutputs);
case networks.dash:
return DashTransactionBuilder_1.DashTransactionBuilder.fromTransaction(tx);
return DashTransactionBuilder_1.DashTransactionBuilder.fromTransaction(tx, undefined, prevOutputs);
case networks.zcash:
return ZcashTransactionBuilder_1.ZcashTransactionBuilder.fromTransaction(tx);
return ZcashTransactionBuilder_1.ZcashTransactionBuilder.fromTransaction(tx, undefined, prevOutputs);
}

@@ -93,2 +93,2 @@ throw new Error(`invalid network`);

exports.createTransactionBuilderFromTransaction = createTransactionBuilderFromTransaction;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsd0NBQXdDO0FBRXhDLG9DQUFzQztBQUV0Qyx1REFBb0Q7QUFDcEQscUVBQWtFO0FBQ2xFLDREQUF5RDtBQUN6RCwwRUFBdUU7QUFDdkUsNkVBQTBFO0FBQzFFLCtEQUE0RDtBQUU1RCxTQUFnQiwyQkFBMkIsQ0FBQyxHQUFXLEVBQUUsT0FBZ0I7SUFDdkUsUUFBUSxrQkFBVSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzNCLEtBQUssUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUN0QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxRQUFRO1lBQ3BCLE9BQU8saUNBQWUsQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN6RCxLQUFLLFFBQVEsQ0FBQyxJQUFJO1lBQ2hCLE9BQU8saUNBQWUsQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN6RCxLQUFLLFFBQVEsQ0FBQyxLQUFLO1lBQ2pCLE9BQU8sbUNBQWdCLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsT0FBdUIsQ0FBQyxDQUFDO0tBQzNFO0lBRUQsMEJBQTBCO0lBQzFCLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztBQUNyQyxDQUFDO0FBaEJELGtFQWdCQztBQUVELDBCQUEwQjtBQUMxQixTQUFnQix3QkFBd0IsQ0FBQyxHQUFXLEVBQUUsT0FBZ0I7SUFDcEUsT0FBTywyQkFBMkIsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FBQztBQUN2RSxDQUFDO0FBRkQsNERBRUM7QUFFRCxTQUFnQiw2QkFBNkIsQ0FBQyxHQUEyQixFQUFFLE9BQWdCO0lBQ3pGLFFBQVEsa0JBQVUsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUMzQixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVc7WUFDdkIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQixNQUFNO1FBQ1IsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNoQixHQUErQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM5QyxHQUErQixDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9ELGdFQUFnRTtZQUMvRCxHQUErQixDQUFDLG9CQUFvQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ2xFLE1BQU07S0FDVDtBQUNILENBQUM7QUFkRCxzRUFjQztBQUVELFNBQWdCLGtDQUFrQyxDQUFDLE9BQWdCO0lBQ2pFLElBQUksR0FBRyxDQUFDO0lBQ1IsUUFBUSxrQkFBVSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzNCLEtBQUssUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUN0QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUN0QixHQUFHLEdBQUcsSUFBSSwrQ0FBc0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMxQyxNQUFNO1NBQ1A7UUFDRCxLQUFLLFFBQVEsQ0FBQyxJQUFJO1lBQ2hCLEdBQUcsR0FBRyxJQUFJLCtDQUFzQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzFDLE1BQU07UUFDUixLQUFLLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNuQixHQUFHLEdBQUcsSUFBSSxpREFBdUIsQ0FBQyxPQUF1QixDQUFDLENBQUM7WUFDM0QsTUFBTTtTQUNQO1FBQ0Q7WUFDRSxNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7S0FDMUM7SUFFRCw2QkFBNkIsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFFNUMsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBekJELGdGQXlCQztBQUVELFNBQWdCLHVDQUF1QyxDQUFDLEVBQW1CO0lBQ3pFLFFBQVEsa0JBQVUsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDOUIsS0FBSyxRQUFRLENBQUMsT0FBTyxDQUFDO1FBQ3RCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLFFBQVE7WUFDcEIsT0FBTywrQ0FBc0IsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDcEQsS0FBSyxRQUFRLENBQUMsSUFBSTtZQUNoQixPQUFPLCtDQUFzQixDQUFDLGVBQWUsQ0FBQyxFQUFxQixDQUFDLENBQUM7UUFDdkUsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNqQixPQUFPLGlEQUF1QixDQUFDLGVBQWUsQ0FBQyxFQUFzQixDQUFDLENBQUM7S0FDMUU7SUFFRCxNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFDckMsQ0FBQztBQWZELDBGQWVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgbmV0d29ya3MgZnJvbSAnLi4vbmV0d29ya3MnO1xuaW1wb3J0IHsgTmV0d29yaywgWmNhc2hOZXR3b3JrIH0gZnJvbSAnLi4vbmV0d29ya1R5cGVzJztcbmltcG9ydCB7IGdldE1haW5uZXQgfSBmcm9tICcuLi9jb2lucyc7XG5cbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4vVXR4b1RyYW5zYWN0aW9uJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHsgRGFzaFRyYW5zYWN0aW9uIH0gZnJvbSAnLi9kYXNoL0Rhc2hUcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBEYXNoVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi9kYXNoL0Rhc2hUcmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHsgWmNhc2hUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL3pjYXNoL1pjYXNoVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IFpjYXNoVHJhbnNhY3Rpb24gfSBmcm9tICcuL3pjYXNoL1pjYXNoVHJhbnNhY3Rpb24nO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVHJhbnNhY3Rpb25Gcm9tQnVmZmVyKGJ1ZjogQnVmZmVyLCBuZXR3b3JrOiBOZXR3b3JrKTogVXR4b1RyYW5zYWN0aW9uIHtcbiAgc3dpdGNoIChnZXRNYWlubmV0KG5ldHdvcmspKSB7XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmNhc2g6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luZ29sZDpcbiAgICBjYXNlIG5ldHdvcmtzLmxpdGVjb2luOlxuICAgICAgcmV0dXJuIFV0eG9UcmFuc2FjdGlvbi5mcm9tQnVmZmVyKGJ1ZiwgZmFsc2UsIG5ldHdvcmspO1xuICAgIGNhc2UgbmV0d29ya3MuZGFzaDpcbiAgICAgIHJldHVybiBEYXNoVHJhbnNhY3Rpb24uZnJvbUJ1ZmZlcihidWYsIGZhbHNlLCBuZXR3b3JrKTtcbiAgICBjYXNlIG5ldHdvcmtzLnpjYXNoOlxuICAgICAgcmV0dXJuIFpjYXNoVHJhbnNhY3Rpb24uZnJvbUJ1ZmZlcihidWYsIGZhbHNlLCBuZXR3b3JrIGFzIFpjYXNoTmV0d29yayk7XG4gIH1cblxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgbmV0d29ya2ApO1xufVxuXG4vKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uRnJvbUhleChoZXg6IHN0cmluZywgbmV0d29yazogTmV0d29yayk6IFV0eG9UcmFuc2FjdGlvbiB7XG4gIHJldHVybiBjcmVhdGVUcmFuc2FjdGlvbkZyb21CdWZmZXIoQnVmZmVyLmZyb20oaGV4LCAnaGV4JyksIG5ldHdvcmspO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0VHJhbnNhY3Rpb25CdWlsZGVyRGVmYXVsdHModHhiOiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyLCBuZXR3b3JrOiBOZXR3b3JrKTogdm9pZCB7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldChuZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmNhc2g6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luZ29sZDpcbiAgICAgIHR4Yi5zZXRWZXJzaW9uKDIpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgICh0eGIgYXMgWmNhc2hUcmFuc2FjdGlvbkJ1aWxkZXIpLnNldFZlcnNpb24oNCk7XG4gICAgICAodHhiIGFzIFpjYXNoVHJhbnNhY3Rpb25CdWlsZGVyKS5zZXRWZXJzaW9uR3JvdXBJZCgweDg5MmYyMDg1KTtcbiAgICAgIC8vIFVzZSBcIkNhbm9weVwiIGNvbnNlbnN1cyBicmFuY2ggSUQgaHR0cHM6Ly96aXBzLnouY2FzaC96aXAtMDI1MVxuICAgICAgKHR4YiBhcyBaY2FzaFRyYW5zYWN0aW9uQnVpbGRlcikuc2V0Q29uc2Vuc3VzQnJhbmNoSWQoMHhlOWZmNzVhNik7XG4gICAgICBicmVhaztcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVHJhbnNhY3Rpb25CdWlsZGVyRm9yTmV0d29yayhuZXR3b3JrOiBOZXR3b3JrKTogVXR4b1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIGxldCB0eGI7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldChuZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSBuZXR3b3Jrcy5saXRlY29pbjoge1xuICAgICAgdHhiID0gbmV3IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIobmV0d29yayk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSBuZXR3b3Jrcy5kYXNoOlxuICAgICAgdHhiID0gbmV3IERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIobmV0d29yayk7XG4gICAgICBicmVhaztcbiAgICBjYXNlIG5ldHdvcmtzLnpjYXNoOiB7XG4gICAgICB0eGIgPSBuZXcgWmNhc2hUcmFuc2FjdGlvbkJ1aWxkZXIobmV0d29yayBhcyBaY2FzaE5ldHdvcmspO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVuc3VwcG9ydGVkIG5ldHdvcmtgKTtcbiAgfVxuXG4gIHNldFRyYW5zYWN0aW9uQnVpbGRlckRlZmF1bHRzKHR4YiwgbmV0d29yayk7XG5cbiAgcmV0dXJuIHR4Yjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uQnVpbGRlckZyb21UcmFuc2FjdGlvbih0eDogVXR4b1RyYW5zYWN0aW9uKTogVXR4b1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldCh0eC5uZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSBuZXR3b3Jrcy5saXRlY29pbjpcbiAgICAgIHJldHVybiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyLmZyb21UcmFuc2FjdGlvbih0eCk7XG4gICAgY2FzZSBuZXR3b3Jrcy5kYXNoOlxuICAgICAgcmV0dXJuIERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4IGFzIERhc2hUcmFuc2FjdGlvbik7XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgIHJldHVybiBaY2FzaFRyYW5zYWN0aW9uQnVpbGRlci5mcm9tVHJhbnNhY3Rpb24odHggYXMgWmNhc2hUcmFuc2FjdGlvbik7XG4gIH1cblxuICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgbmV0d29ya2ApO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/bitgo/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { TxOutput } from 'bitcoinjs-lib';\n\nimport * as networks from '../networks';\nimport { Network, ZcashNetwork } from '../networkTypes';\nimport { getMainnet } from '../coins';\n\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport { DashTransaction } from './dash/DashTransaction';\nimport { DashTransactionBuilder } from './dash/DashTransactionBuilder';\nimport { ZcashTransactionBuilder } from './zcash/ZcashTransactionBuilder';\nimport { ZcashTransaction } from './zcash/ZcashTransaction';\n\nexport function createTransactionFromBuffer(buf: Buffer, network: Network): UtxoTransaction {\n  switch (getMainnet(network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.litecoin:\n      return UtxoTransaction.fromBuffer(buf, false, network);\n    case networks.dash:\n      return DashTransaction.fromBuffer(buf, false, network);\n    case networks.zcash:\n      return ZcashTransaction.fromBuffer(buf, false, network as ZcashNetwork);\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`invalid network`);\n}\n\n/* istanbul ignore next */\nexport function createTransactionFromHex(hex: string, network: Network): UtxoTransaction {\n  return createTransactionFromBuffer(Buffer.from(hex, 'hex'), network);\n}\n\nexport function setTransactionBuilderDefaults(txb: UtxoTransactionBuilder, network: Network): void {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      txb.setVersion(2);\n      break;\n    case networks.zcash:\n      (txb as ZcashTransactionBuilder).setVersion(4);\n      (txb as ZcashTransactionBuilder).setVersionGroupId(0x892f2085);\n      // Use \"Canopy\" consensus branch ID https://zips.z.cash/zip-0251\n      (txb as ZcashTransactionBuilder).setConsensusBranchId(0xe9ff75a6);\n      break;\n  }\n}\n\nexport function createTransactionBuilderForNetwork(network: Network): UtxoTransactionBuilder {\n  let txb;\n  switch (getMainnet(network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.litecoin: {\n      txb = new UtxoTransactionBuilder(network);\n      break;\n    }\n    case networks.dash:\n      txb = new DashTransactionBuilder(network);\n      break;\n    case networks.zcash: {\n      txb = new ZcashTransactionBuilder(network as ZcashNetwork);\n      break;\n    }\n    default:\n      throw new Error(`unsupported network`);\n  }\n\n  setTransactionBuilderDefaults(txb, network);\n\n  return txb;\n}\n\nexport function createTransactionBuilderFromTransaction(\n  tx: UtxoTransaction,\n  prevOutputs?: TxOutput[]\n): UtxoTransactionBuilder {\n  switch (getMainnet(tx.network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.litecoin:\n      return UtxoTransactionBuilder.fromTransaction(tx, undefined, prevOutputs);\n    case networks.dash:\n      return DashTransactionBuilder.fromTransaction(tx as DashTransaction, undefined, prevOutputs);\n    case networks.zcash:\n      return ZcashTransactionBuilder.fromTransaction(tx as ZcashTransaction, undefined, prevOutputs);\n  }\n\n  throw new Error(`invalid network`);\n}\n"]}

@@ -11,3 +11,3 @@ /// <reference types="node" />

constructor(network: Network, transaction?: bitcoinjs.Transaction);
static fromBuffer(buf: Buffer, noStrict: boolean, network?: Network): UtxoTransaction;
static fromBuffer(buf: Buffer, noStrict: boolean, network?: Network, prevOutput?: bitcoinjs.TxOutput[]): UtxoTransaction;
addForkId(hashType: number): number;

@@ -14,0 +14,0 @@ hashForWitnessV0(inIndex: number, prevOutScript: Buffer, value: number, hashType: number): Buffer;

@@ -22,3 +22,3 @@ "use strict";

}
static fromBuffer(buf, noStrict, network) {
static fromBuffer(buf, noStrict, network, prevOutput) {
if (!network) {

@@ -83,2 +83,2 @@ throw new Error(`must provide network`);

UtxoTransaction.SIGHASH_BITCOINCASHBIP143 = UtxoTransaction.SIGHASH_FORKID;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL1V0eG9UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBMkM7QUFDM0MsMkNBQTJDO0FBRzNDLG9DQUFxRDtBQUNyRCx3Q0FBd0M7QUFFeEMsU0FBZ0IsWUFBWSxDQUFDLEtBQWE7SUFDeEMsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQztJQUM1QixPQUFPLE9BQU8sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDO0FBQ2pELENBQUM7QUFIRCxvQ0FHQztBQUVELE1BQWEsZUFBZ0IsU0FBUSxTQUFTLENBQUMsV0FBVztJQUt4RCxZQUFtQixPQUFnQixFQUFFLGNBQXFDLElBQUksU0FBUyxDQUFDLFdBQVcsRUFBRTtRQUNuRyxLQUFLLEVBQUUsQ0FBQztRQURTLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFFakMsSUFBSSxDQUFDLE9BQU8sR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDO1FBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsV0FBVyxDQUFDLFFBQVEsQ0FBQztRQUNyQyxJQUFJLENBQUMsR0FBRyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxtQkFBTSxDQUFDLEVBQUcsQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLG1CQUFNLENBQUMsRUFBRyxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBVyxFQUFFLFFBQWlCLEVBQUUsT0FBaUI7UUFDakUsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNaLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLENBQUMsQ0FBQztTQUN6QztRQUNELE9BQU8sSUFBSSxlQUFlLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7SUFFRCxTQUFTLENBQUMsUUFBZ0I7UUFDeEIsSUFBSSxRQUFRLEdBQUcsZUFBZSxDQUFDLGNBQWMsRUFBRTtZQUM3QyxNQUFNLE1BQU0sR0FBRyxxQkFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDcEQsT0FBTyxDQUFDLFFBQVEsR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUN6QztRQUVELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxPQUFlLEVBQUUsYUFBcUIsRUFBRSxLQUFhLEVBQUUsUUFBZ0I7UUFDdEYsT0FBTyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7SUFFRDs7T0FFRztJQUNILHlCQUF5QixDQUN2QixPQUFlLEVBQ2YsYUFBcUIsRUFDckIsS0FBeUIsRUFDekIsUUFBZ0I7UUFFaEIsUUFBUSxrQkFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNoQyxLQUFLLFFBQVEsQ0FBQyxLQUFLO2dCQUNqQixNQUFNLElBQUksS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQ25DLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztZQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7WUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVztnQkFDdkI7Ozs7Ozs7bUJBT0c7Z0JBQ0gsTUFBTSxTQUFTLEdBQUcsQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFFbEUsSUFBSSxTQUFTLEVBQUU7b0JBQ2I7Ozs7dUJBSUc7b0JBQ0gsSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFO3dCQUN2QixNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7cUJBQ3ZDO29CQUNELE9BQU8sS0FBSyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztpQkFDeEY7U0FDSjtRQUVELE9BQU8sS0FBSyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUVELGdCQUFnQixDQUFDLE9BQWUsRUFBRSxhQUFxQixFQUFFLFFBQWdCO1FBQ3ZFLE9BQU8sSUFBSSxDQUFDLHlCQUF5QixDQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQVMsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDNUcsQ0FBQztJQUVELEtBQUs7UUFDSCxPQUFPLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDMUQsQ0FBQzs7QUFoRkgsMENBaUZDO0FBaEZRLDhCQUFjLEdBQUcsSUFBSSxDQUFDO0FBQzdCLHFDQUFxQztBQUM5Qix5Q0FBeUIsR0FBRyxlQUFlLENBQUMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYml0Y29pbmpzIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuaW1wb3J0ICogYXMgdmFydWludCBmcm9tICd2YXJ1aW50LWJpdGNvaW4nO1xuXG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSAnLi4vbmV0d29ya1R5cGVzJztcbmltcG9ydCB7IGdldE1haW5uZXQsIGlzQml0Y29pbkdvbGQgfSBmcm9tICcuLi9jb2lucyc7XG5pbXBvcnQgKiBhcyBuZXR3b3JrcyBmcm9tICcuLi9uZXR3b3Jrcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiB2YXJTbGljZVNpemUoc2xpY2U6IEJ1ZmZlcik6IG51bWJlciB7XG4gIGNvbnN0IGxlbmd0aCA9IHNsaWNlLmxlbmd0aDtcbiAgcmV0dXJuIHZhcnVpbnQuZW5jb2RpbmdMZW5ndGgobGVuZ3RoKSArIGxlbmd0aDtcbn1cblxuZXhwb3J0IGNsYXNzIFV0eG9UcmFuc2FjdGlvbiBleHRlbmRzIGJpdGNvaW5qcy5UcmFuc2FjdGlvbiB7XG4gIHN0YXRpYyBTSUdIQVNIX0ZPUktJRCA9IDB4NDA7XG4gIC8qKiBAZGVwcmVjYXRlZCB1c2UgU0lHSEFTSF9GT1JLSUQgKi9cbiAgc3RhdGljIFNJR0hBU0hfQklUQ09JTkNBU0hCSVAxNDMgPSBVdHhvVHJhbnNhY3Rpb24uU0lHSEFTSF9GT1JLSUQ7XG5cbiAgY29uc3RydWN0b3IocHVibGljIG5ldHdvcms6IE5ldHdvcmssIHRyYW5zYWN0aW9uOiBiaXRjb2luanMuVHJhbnNhY3Rpb24gPSBuZXcgYml0Y29pbmpzLlRyYW5zYWN0aW9uKCkpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMudmVyc2lvbiA9IHRyYW5zYWN0aW9uLnZlcnNpb247XG4gICAgdGhpcy5sb2NrdGltZSA9IHRyYW5zYWN0aW9uLmxvY2t0aW1lO1xuICAgIHRoaXMuaW5zID0gdHJhbnNhY3Rpb24uaW5zLm1hcCgodikgPT4gKHsgLi4udiB9KSk7XG4gICAgdGhpcy5vdXRzID0gdHJhbnNhY3Rpb24ub3V0cy5tYXAoKHYpID0+ICh7IC4uLnYgfSkpO1xuICB9XG5cbiAgc3RhdGljIGZyb21CdWZmZXIoYnVmOiBCdWZmZXIsIG5vU3RyaWN0OiBib29sZWFuLCBuZXR3b3JrPzogTmV0d29yayk6IFV0eG9UcmFuc2FjdGlvbiB7XG4gICAgaWYgKCFuZXR3b3JrKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYG11c3QgcHJvdmlkZSBuZXR3b3JrYCk7XG4gICAgfVxuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uKG5ldHdvcmssIGJpdGNvaW5qcy5UcmFuc2FjdGlvbi5mcm9tQnVmZmVyKGJ1Ziwgbm9TdHJpY3QpKTtcbiAgfVxuXG4gIGFkZEZvcmtJZChoYXNoVHlwZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBpZiAoaGFzaFR5cGUgJiBVdHhvVHJhbnNhY3Rpb24uU0lHSEFTSF9GT1JLSUQpIHtcbiAgICAgIGNvbnN0IGZvcmtJZCA9IGlzQml0Y29pbkdvbGQodGhpcy5uZXR3b3JrKSA/IDc5IDogMDtcbiAgICAgIHJldHVybiAoaGFzaFR5cGUgfCAoZm9ya0lkIDw8IDgpKSA+Pj4gMDtcbiAgICB9XG5cbiAgICByZXR1cm4gaGFzaFR5cGU7XG4gIH1cblxuICBoYXNoRm9yV2l0bmVzc1YwKGluSW5kZXg6IG51bWJlciwgcHJldk91dFNjcmlwdDogQnVmZmVyLCB2YWx1ZTogbnVtYmVyLCBoYXNoVHlwZTogbnVtYmVyKTogQnVmZmVyIHtcbiAgICByZXR1cm4gc3VwZXIuaGFzaEZvcldpdG5lc3NWMChpbkluZGV4LCBwcmV2T3V0U2NyaXB0LCB2YWx1ZSwgdGhpcy5hZGRGb3JrSWQoaGFzaFR5cGUpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYWxjdWxhdGUgdGhlIGhhc2ggdG8gdmVyaWZ5IHRoZSBzaWduYXR1cmUgYWdhaW5zdFxuICAgKi9cbiAgaGFzaEZvclNpZ25hdHVyZUJ5TmV0d29yayhcbiAgICBpbkluZGV4OiBudW1iZXIsXG4gICAgcHJldm91dFNjcmlwdDogQnVmZmVyLFxuICAgIHZhbHVlOiBudW1iZXIgfCB1bmRlZmluZWQsXG4gICAgaGFzaFR5cGU6IG51bWJlclxuICApOiBCdWZmZXIge1xuICAgIHN3aXRjaCAoZ2V0TWFpbm5ldCh0aGlzLm5ldHdvcmspKSB7XG4gICAgICBjYXNlIG5ldHdvcmtzLnpjYXNoOlxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYGlsbGVnYWwgc3RhdGVgKTtcbiAgICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmNhc2g6XG4gICAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgICAgIC8qXG4gICAgICAgICAgQml0Y29pbiBDYXNoIHN1cHBvcnRzIGEgRk9SS0lEIGZsYWcuIFdoZW4gc2V0LCB3ZSBoYXNoIHVzaW5nIGhhc2hpbmcgYWxnb3JpdGhtXG4gICAgICAgICAgIHRoYXQgaXMgdXNlZCBmb3Igc2VncmVnYXRlZCB3aXRuZXNzIHRyYW5zYWN0aW9ucyAoZGVmaW5lZCBpbiBCSVAxNDMpLlxuXG4gICAgICAgICAgVGhlIGZsYWcgaXMgYWxzbyB1c2VkIGJ5IEJpdGNvaW5TViBhbmQgQml0Y29pbkdvbGRcblxuICAgICAgICAgIGh0dHBzOi8vZ2l0aHViLmNvbS9iaXRjb2luY2FzaG9yZy9iaXRjb2luY2FzaC5vcmcvYmxvYi9tYXN0ZXIvc3BlYy9yZXBsYXktcHJvdGVjdGVkLXNpZ2hhc2gubWRcbiAgICAgICAgICovXG4gICAgICAgIGNvbnN0IGFkZEZvcmtJZCA9IChoYXNoVHlwZSAmIFV0eG9UcmFuc2FjdGlvbi5TSUdIQVNIX0ZPUktJRCkgPiAwO1xuXG4gICAgICAgIGlmIChhZGRGb3JrSWQpIHtcbiAgICAgICAgICAvKlxuICAgICAgICAgICAgYGBUaGUgc2lnaGFzaCB0eXBlIGlzIGFsdGVyZWQgdG8gaW5jbHVkZSBhIDI0LWJpdCBmb3JrIGlkIGluIGl0cyBtb3N0IHNpZ25pZmljYW50IGJpdHMuJydcbiAgICAgICAgICAgIFdlIGFsc28gdXNlIHVuc2lnbmVkIHJpZ2h0IHNoaWZ0IG9wZXJhdG9yIGA+Pj5gIHRvIGNhc3QgdG8gVUludDMyXG4gICAgICAgICAgICBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9KYXZhU2NyaXB0L1JlZmVyZW5jZS9PcGVyYXRvcnMvVW5zaWduZWRfcmlnaHRfc2hpZnRcbiAgICAgICAgICAgKi9cbiAgICAgICAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBtdXN0IHByb3ZpZGUgdmFsdWVgKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHN1cGVyLmhhc2hGb3JXaXRuZXNzVjAoaW5JbmRleCwgcHJldm91dFNjcmlwdCwgdmFsdWUsIHRoaXMuYWRkRm9ya0lkKGhhc2hUeXBlKSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIuaGFzaEZvclNpZ25hdHVyZShpbkluZGV4LCBwcmV2b3V0U2NyaXB0LCBoYXNoVHlwZSk7XG4gIH1cblxuICBoYXNoRm9yU2lnbmF0dXJlKGluSW5kZXg6IG51bWJlciwgcHJldk91dFNjcmlwdDogQnVmZmVyLCBoYXNoVHlwZTogbnVtYmVyKTogQnVmZmVyIHtcbiAgICByZXR1cm4gdGhpcy5oYXNoRm9yU2lnbmF0dXJlQnlOZXR3b3JrKGluSW5kZXgsIHByZXZPdXRTY3JpcHQsICh0aGlzLmluc1tpbkluZGV4XSBhcyBhbnkpLnZhbHVlLCBoYXNoVHlwZSk7XG4gIH1cblxuICBjbG9uZSgpOiBVdHhvVHJhbnNhY3Rpb24ge1xuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uKHRoaXMubmV0d29yaywgc3VwZXIuY2xvbmUoKSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UtxoTransaction.js","sourceRoot":"","sources":["../../../src/bitgo/UtxoTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import * as bitcoinjs from 'bitcoinjs-lib';\nimport * as varuint from 'varuint-bitcoin';\n\nimport { Network } from '../networkTypes';\nimport { getMainnet, isBitcoinGold } from '../coins';\nimport * as networks from '../networks';\n\nexport function varSliceSize(slice: Buffer): number {\n  const length = slice.length;\n  return varuint.encodingLength(length) + length;\n}\n\nexport class UtxoTransaction extends bitcoinjs.Transaction {\n  static SIGHASH_FORKID = 0x40;\n  /** @deprecated use SIGHASH_FORKID */\n  static SIGHASH_BITCOINCASHBIP143 = UtxoTransaction.SIGHASH_FORKID;\n\n  constructor(public network: Network, transaction: bitcoinjs.Transaction = new bitcoinjs.Transaction()) {\n    super();\n    this.version = transaction.version;\n    this.locktime = transaction.locktime;\n    this.ins = transaction.ins.map((v) => ({ ...v }));\n    this.outs = transaction.outs.map((v) => ({ ...v }));\n  }\n\n  static fromBuffer(\n    buf: Buffer,\n    noStrict: boolean,\n    network?: Network,\n    prevOutput?: bitcoinjs.TxOutput[]\n  ): UtxoTransaction {\n    if (!network) {\n      throw new Error(`must provide network`);\n    }\n    return new UtxoTransaction(network, bitcoinjs.Transaction.fromBuffer(buf, noStrict));\n  }\n\n  addForkId(hashType: number): number {\n    if (hashType & UtxoTransaction.SIGHASH_FORKID) {\n      const forkId = isBitcoinGold(this.network) ? 79 : 0;\n      return (hashType | (forkId << 8)) >>> 0;\n    }\n\n    return hashType;\n  }\n\n  hashForWitnessV0(inIndex: number, prevOutScript: Buffer, value: number, hashType: number): Buffer {\n    return super.hashForWitnessV0(inIndex, prevOutScript, value, this.addForkId(hashType));\n  }\n\n  /**\n   * Calculate the hash to verify the signature against\n   */\n  hashForSignatureByNetwork(\n    inIndex: number,\n    prevoutScript: Buffer,\n    value: number | undefined,\n    hashType: number\n  ): Buffer {\n    switch (getMainnet(this.network)) {\n      case networks.zcash:\n        throw new Error(`illegal state`);\n      case networks.bitcoincash:\n      case networks.bitcoinsv:\n      case networks.bitcoingold:\n        /*\n          Bitcoin Cash supports a FORKID flag. When set, we hash using hashing algorithm\n           that is used for segregated witness transactions (defined in BIP143).\n\n          The flag is also used by BitcoinSV and BitcoinGold\n\n          https://github.com/bitcoincashorg/bitcoincash.org/blob/master/spec/replay-protected-sighash.md\n         */\n        const addForkId = (hashType & UtxoTransaction.SIGHASH_FORKID) > 0;\n\n        if (addForkId) {\n          /*\n            ``The sighash type is altered to include a 24-bit fork id in its most significant bits.''\n            We also use unsigned right shift operator `>>>` to cast to UInt32\n            https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Unsigned_right_shift\n           */\n          if (value === undefined) {\n            throw new Error(`must provide value`);\n          }\n          return super.hashForWitnessV0(inIndex, prevoutScript, value, this.addForkId(hashType));\n        }\n    }\n\n    return super.hashForSignature(inIndex, prevoutScript, hashType);\n  }\n\n  hashForSignature(inIndex: number, prevOutScript: Buffer, hashType: number): Buffer {\n    return this.hashForSignatureByNetwork(inIndex, prevOutScript, (this.ins[inIndex] as any).value, hashType);\n  }\n\n  clone(): UtxoTransaction {\n    return new UtxoTransaction(this.network, super.clone());\n  }\n}\n"]}
/// <reference types="node" />
import { Transaction, TransactionBuilder } from 'bitcoinjs-lib';
import { TxOutput, Transaction, TransactionBuilder } from 'bitcoinjs-lib';
import * as bitcoinjs from 'bitcoinjs-lib';

@@ -17,5 +17,5 @@ import { Network } from '../networkTypes';

export declare class UtxoTransactionBuilder<T extends UtxoTransaction = UtxoTransaction> extends TransactionBuilder {
constructor(network: Network, txb?: TransactionBuilder);
constructor(network: Network, txb?: TransactionBuilder, prevOutputs?: TxOutput[]);
createInitialTransaction(network: Network, tx?: Transaction): UtxoTransaction;
static fromTransaction(tx: UtxoTransaction): UtxoTransactionBuilder;
static fromTransaction(tx: UtxoTransaction, network?: bitcoinjs.Network, prevOutputs?: TxOutput[]): UtxoTransactionBuilder;
get tx(): T;

@@ -22,0 +22,0 @@ build(): T;

@@ -7,3 +7,3 @@ "use strict";

class UtxoTransactionBuilder extends bitcoinjs_lib_1.TransactionBuilder {
constructor(network, txb) {
constructor(network, txb, prevOutputs) {
var _a;

@@ -16,2 +16,12 @@ super();

}
if (prevOutputs) {
const txbInputs = this.__INPUTS;
if (prevOutputs.length !== txbInputs.length) {
throw new Error(`prevOuts must match txbInput length`);
}
prevOutputs.forEach((o, i) => {
txbInputs[i].value = o.value;
txbInputs[i].prevOutScript = o.script;
});
}
}

@@ -21,4 +31,4 @@ createInitialTransaction(network, tx) {

}
static fromTransaction(tx) {
return new UtxoTransactionBuilder(tx.network, bitcoinjs_lib_1.TransactionBuilder.fromTransaction(tx));
static fromTransaction(tx, network, prevOutputs) {
return new UtxoTransactionBuilder(tx.network, bitcoinjs_lib_1.TransactionBuilder.fromTransaction(tx), prevOutputs);
}

@@ -58,2 +68,2 @@ get tx() {

exports.UtxoTransactionBuilder = UtxoTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlEQUFnRTtBQUloRSx1REFBb0Q7QUFhcEQsTUFBYSxzQkFBb0UsU0FBUSxrQ0FBa0I7SUFDekcsWUFBWSxPQUFnQixFQUFFLEdBQXdCOztRQUNwRCxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBNEIsQ0FBQztRQUUzQyxJQUFZLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLEVBQUUsTUFBQyxHQUFXLDBDQUFFLElBQUksQ0FBQyxDQUFDO1FBRWhGLElBQUksR0FBRyxFQUFFO1lBQ04sSUFBWSxDQUFDLFFBQVEsR0FBSSxHQUFXLENBQUMsUUFBUSxDQUFDO1NBQ2hEO0lBQ0gsQ0FBQztJQUVELHdCQUF3QixDQUFDLE9BQWdCLEVBQUUsRUFBZ0I7UUFDekQsT0FBTyxJQUFJLGlDQUFlLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCxNQUFNLENBQUMsZUFBZSxDQUFDLEVBQW1CO1FBQ3hDLE9BQU8sSUFBSSxzQkFBc0IsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLGtDQUFrQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFFRCxJQUFJLEVBQUU7UUFDSixPQUFRLElBQVksQ0FBQyxJQUFJLENBQUM7SUFDNUIsQ0FBQztJQUVELEtBQUs7UUFDSCxPQUFPLEtBQUssQ0FBQyxLQUFLLEVBQU8sQ0FBQztJQUM1QixDQUFDO0lBRUQsZUFBZTtRQUNiLE9BQU8sS0FBSyxDQUFDLGVBQWUsRUFBTyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxJQUFJLENBQ0YsVUFBK0IsRUFDL0IsT0FBaUMsRUFDakMsWUFBcUIsRUFDckIsUUFBaUIsRUFDakIsWUFBcUIsRUFDckIsYUFBc0I7UUFFdEIsZ0dBQWdHO1FBQ2hHLHVEQUF1RDtRQUN2RCw2RkFBNkY7UUFDN0YsMkZBQTJGO1FBQzNGLG1DQUFtQztRQUVuQyxJQUFJLE9BQU8sVUFBVSxLQUFLLFFBQVEsRUFBRTtZQUNsQyxJQUFJLE9BQU8sWUFBWSxLQUFLLFFBQVEsRUFBRTtnQkFDbkMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFTLENBQUMsS0FBSyxHQUFHLFlBQVksQ0FBQzthQUN2RDtZQUVELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1NBQzdGO1FBRUQsSUFBSSxVQUFVLENBQUMsWUFBWSxLQUFLLFNBQVMsRUFBRTtZQUN4QyxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFTLENBQUMsS0FBSyxHQUFHLFVBQVUsQ0FBQyxZQUFZLENBQUM7U0FDdEU7UUFDRCwrRkFBK0Y7UUFDL0Ysd0NBQXdDO1FBQ3hDLElBQUksVUFBVSxDQUFDLGlCQUFpQixLQUFLLFdBQVcsRUFBRTtZQUNoRCxPQUFPLFVBQVUsQ0FBQyxZQUFZLENBQUM7U0FDaEM7UUFDRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDaEMsQ0FBQztDQUNGO0FBaEVELHdEQWdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zYWN0aW9uLCBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICdiaXRjb2luanMtbGliJztcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuaW1wb3J0ICogYXMgYml0Y29pbmpzIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuaW1wb3J0IHsgTmV0d29yayB9IGZyb20gJy4uL25ldHdvcmtUeXBlcyc7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb24gfSBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHhiU2lnbkFyZyB7XG4gIHByZXZPdXRTY3JpcHRUeXBlOiBzdHJpbmc7XG4gIHZpbjogbnVtYmVyO1xuICBrZXlQYWlyOiBiaXRjb2luanMuRUNQYWlyLlNpZ25lcjtcbiAgcmVkZWVtU2NyaXB0PzogQnVmZmVyO1xuICBoYXNoVHlwZT86IG51bWJlcjtcbiAgd2l0bmVzc1ZhbHVlPzogbnVtYmVyO1xuICB3aXRuZXNzU2NyaXB0PzogQnVmZmVyO1xuICBjb250cm9sQmxvY2s/OiBCdWZmZXI7XG59XG5cbmV4cG9ydCBjbGFzcyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyPFQgZXh0ZW5kcyBVdHhvVHJhbnNhY3Rpb24gPSBVdHhvVHJhbnNhY3Rpb24+IGV4dGVuZHMgVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgY29uc3RydWN0b3IobmV0d29yazogTmV0d29yaywgdHhiPzogVHJhbnNhY3Rpb25CdWlsZGVyKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLm5ldHdvcmsgPSBuZXR3b3JrIGFzIGJpdGNvaW5qcy5OZXR3b3JrO1xuXG4gICAgKHRoaXMgYXMgYW55KS5fX1RYID0gdGhpcy5jcmVhdGVJbml0aWFsVHJhbnNhY3Rpb24obmV0d29yaywgKHR4YiBhcyBhbnkpPy5fX1RYKTtcblxuICAgIGlmICh0eGIpIHtcbiAgICAgICh0aGlzIGFzIGFueSkuX19JTlBVVFMgPSAodHhiIGFzIGFueSkuX19JTlBVVFM7XG4gICAgfVxuICB9XG5cbiAgY3JlYXRlSW5pdGlhbFRyYW5zYWN0aW9uKG5ldHdvcms6IE5ldHdvcmssIHR4PzogVHJhbnNhY3Rpb24pOiBVdHhvVHJhbnNhY3Rpb24ge1xuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uKG5ldHdvcmssIHR4KTtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tVHJhbnNhY3Rpb24odHg6IFV0eG9UcmFuc2FjdGlvbik6IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIge1xuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uQnVpbGRlcih0eC5uZXR3b3JrLCBUcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4KSk7XG4gIH1cblxuICBnZXQgdHgoKTogVCB7XG4gICAgcmV0dXJuICh0aGlzIGFzIGFueSkuX19UWDtcbiAgfVxuXG4gIGJ1aWxkKCk6IFQge1xuICAgIHJldHVybiBzdXBlci5idWlsZCgpIGFzIFQ7XG4gIH1cblxuICBidWlsZEluY29tcGxldGUoKTogVCB7XG4gICAgcmV0dXJuIHN1cGVyLmJ1aWxkSW5jb21wbGV0ZSgpIGFzIFQ7XG4gIH1cblxuICBzaWduKFxuICAgIHNpZ25QYXJhbXM6IG51bWJlciB8IFR4YlNpZ25BcmcsXG4gICAga2V5UGFpcj86IGJpdGNvaW5qcy5FQ1BhaXIuU2lnbmVyLFxuICAgIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcixcbiAgICBoYXNoVHlwZT86IG51bWJlcixcbiAgICB3aXRuZXNzVmFsdWU/OiBudW1iZXIsXG4gICAgd2l0bmVzc1NjcmlwdD86IEJ1ZmZlclxuICApOiB2b2lkIHtcbiAgICAvLyBSZWd1bGFyIGJpdGNvaW4gcDJzaC1wMm1zIGlucHV0cyBkbyBub3QgaW5jbHVkZSB0aGUgaW5wdXQgYW1vdW50ICh2YWx1ZSkgaW4gdGhlIHNpZ25hdHVyZSBhbmRcbiAgICAvLyB0aHVzIGRvIG5vdCByZXF1aXJlIHRoZSBwYXJhbWV0ZXIgYHZhbHVlYCB0byBiZSBzZXQuXG4gICAgLy8gRm9yIGJpdGNvaW5jYXNoIGFuZCBiaXRjb2luc3YgcDJzaC1wMm1zIGlucHV0cywgdGhlIHZhbHVlIHBhcmFtZXRlciAqaXMqIHJlcXVpcmVkIGhvd2V2ZXIuXG4gICAgLy8gU2luY2UgdGhlIGB2YWx1ZWAgcGFyYW1ldGVyIGlzIG5vdCBwYXNzZWQgdG8gdGhlIGxlZ2FjeSBoYXNoaW5nIG1ldGhvZCwgd2UgbXVzdCBzdG9yZSBpdFxuICAgIC8vIG9uIHRoZSB0cmFuc2FjdGlvbiBpbnB1dCBvYmplY3QuXG5cbiAgICBpZiAodHlwZW9mIHNpZ25QYXJhbXMgPT09ICdudW1iZXInKSB7XG4gICAgICBpZiAodHlwZW9mIHdpdG5lc3NWYWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgKHRoaXMudHguaW5zW3NpZ25QYXJhbXNdIGFzIGFueSkudmFsdWUgPSB3aXRuZXNzVmFsdWU7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBzdXBlci5zaWduKHNpZ25QYXJhbXMsIGtleVBhaXIsIHJlZGVlbVNjcmlwdCwgaGFzaFR5cGUsIHdpdG5lc3NWYWx1ZSwgd2l0bmVzc1NjcmlwdCk7XG4gICAgfVxuXG4gICAgaWYgKHNpZ25QYXJhbXMud2l0bmVzc1ZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICh0aGlzLnR4Lmluc1tzaWduUGFyYW1zLnZpbl0gYXMgYW55KS52YWx1ZSA9IHNpZ25QYXJhbXMud2l0bmVzc1ZhbHVlO1xuICAgIH1cbiAgICAvLyBXaGVuIGNhbGxpbmcgdGhlIHNpZ24gbWV0aG9kIHZpYSBUeGJTaWduQXJnLCB0aGUgYHZhbHVlYCBwYXJhbWV0ZXIgaXMgYWN0dWFsbHkgbm90IHBlcm1pdHRlZFxuICAgIC8vIHRvIGJlIHNldCBmb3IgcDJzaC1wMm1zIHRyYW5zYWN0aW9ucy5cbiAgICBpZiAoc2lnblBhcmFtcy5wcmV2T3V0U2NyaXB0VHlwZSA9PT0gJ3Ayc2gtcDJtcycpIHtcbiAgICAgIGRlbGV0ZSBzaWduUGFyYW1zLndpdG5lc3NWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHN1cGVyLnNpZ24oc2lnblBhcmFtcyk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlEQUEwRTtBQUkxRSx1REFBb0Q7QUFhcEQsTUFBYSxzQkFBb0UsU0FBUSxrQ0FBa0I7SUFDekcsWUFBWSxPQUFnQixFQUFFLEdBQXdCLEVBQUUsV0FBd0I7O1FBQzlFLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUE0QixDQUFDO1FBRTNDLElBQVksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUFDLE9BQU8sRUFBRSxNQUFDLEdBQVcsMENBQUUsSUFBSSxDQUFDLENBQUM7UUFFaEYsSUFBSSxHQUFHLEVBQUU7WUFDTixJQUFZLENBQUMsUUFBUSxHQUFJLEdBQVcsQ0FBQyxRQUFRLENBQUM7U0FDaEQ7UUFFRCxJQUFJLFdBQVcsRUFBRTtZQUNmLE1BQU0sU0FBUyxHQUFJLElBQVksQ0FBQyxRQUFRLENBQUM7WUFDekMsSUFBSSxXQUFXLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQyxNQUFNLEVBQUU7Z0JBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLENBQUMsQ0FBQzthQUN4RDtZQUNELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQzNCLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQztnQkFDN0IsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO1lBQ3hDLENBQUMsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBZ0IsRUFBRSxFQUFnQjtRQUN6RCxPQUFPLElBQUksaUNBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELE1BQU0sQ0FBQyxlQUFlLENBQ3BCLEVBQW1CLEVBQ25CLE9BQTJCLEVBQzNCLFdBQXdCO1FBRXhCLE9BQU8sSUFBSSxzQkFBc0IsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLGtDQUFrQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyRyxDQUFDO0lBRUQsSUFBSSxFQUFFO1FBQ0osT0FBUSxJQUFZLENBQUMsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLO1FBQ0gsT0FBTyxLQUFLLENBQUMsS0FBSyxFQUFPLENBQUM7SUFDNUIsQ0FBQztJQUVELGVBQWU7UUFDYixPQUFPLEtBQUssQ0FBQyxlQUFlLEVBQU8sQ0FBQztJQUN0QyxDQUFDO0lBRUQsSUFBSSxDQUNGLFVBQStCLEVBQy9CLE9BQWlDLEVBQ2pDLFlBQXFCLEVBQ3JCLFFBQWlCLEVBQ2pCLFlBQXFCLEVBQ3JCLGFBQXNCO1FBRXRCLGdHQUFnRztRQUNoRyx1REFBdUQ7UUFDdkQsNkZBQTZGO1FBQzdGLDJGQUEyRjtRQUMzRixtQ0FBbUM7UUFFbkMsSUFBSSxPQUFPLFVBQVUsS0FBSyxRQUFRLEVBQUU7WUFDbEMsSUFBSSxPQUFPLFlBQVksS0FBSyxRQUFRLEVBQUU7Z0JBQ25DLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBUyxDQUFDLEtBQUssR0FBRyxZQUFZLENBQUM7YUFDdkQ7WUFFRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBRSxhQUFhLENBQUMsQ0FBQztTQUM3RjtRQUVELElBQUksVUFBVSxDQUFDLFlBQVksS0FBSyxTQUFTLEVBQUU7WUFDeEMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBUyxDQUFDLEtBQUssR0FBRyxVQUFVLENBQUMsWUFBWSxDQUFDO1NBQ3RFO1FBQ0QsK0ZBQStGO1FBQy9GLHdDQUF3QztRQUN4QyxJQUFJLFVBQVUsQ0FBQyxpQkFBaUIsS0FBSyxXQUFXLEVBQUU7WUFDaEQsT0FBTyxVQUFVLENBQUMsWUFBWSxDQUFDO1NBQ2hDO1FBQ0QsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDRjtBQS9FRCx3REErRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeE91dHB1dCwgVHJhbnNhY3Rpb24sIFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJ2JpdGNvaW5qcy1saWInO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG5pbXBvcnQgKiBhcyBiaXRjb2luanMgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSAnLi4vbmV0d29ya1R5cGVzJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4vVXR4b1RyYW5zYWN0aW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBUeGJTaWduQXJnIHtcbiAgcHJldk91dFNjcmlwdFR5cGU6IHN0cmluZztcbiAgdmluOiBudW1iZXI7XG4gIGtleVBhaXI6IGJpdGNvaW5qcy5FQ1BhaXIuU2lnbmVyO1xuICByZWRlZW1TY3JpcHQ/OiBCdWZmZXI7XG4gIGhhc2hUeXBlPzogbnVtYmVyO1xuICB3aXRuZXNzVmFsdWU/OiBudW1iZXI7XG4gIHdpdG5lc3NTY3JpcHQ/OiBCdWZmZXI7XG4gIGNvbnRyb2xCbG9jaz86IEJ1ZmZlcjtcbn1cblxuZXhwb3J0IGNsYXNzIFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8VCBleHRlbmRzIFV0eG9UcmFuc2FjdGlvbiA9IFV0eG9UcmFuc2FjdGlvbj4gZXh0ZW5kcyBUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBjb25zdHJ1Y3RvcihuZXR3b3JrOiBOZXR3b3JrLCB0eGI/OiBUcmFuc2FjdGlvbkJ1aWxkZXIsIHByZXZPdXRwdXRzPzogVHhPdXRwdXRbXSkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5uZXR3b3JrID0gbmV0d29yayBhcyBiaXRjb2luanMuTmV0d29yaztcblxuICAgICh0aGlzIGFzIGFueSkuX19UWCA9IHRoaXMuY3JlYXRlSW5pdGlhbFRyYW5zYWN0aW9uKG5ldHdvcmssICh0eGIgYXMgYW55KT8uX19UWCk7XG5cbiAgICBpZiAodHhiKSB7XG4gICAgICAodGhpcyBhcyBhbnkpLl9fSU5QVVRTID0gKHR4YiBhcyBhbnkpLl9fSU5QVVRTO1xuICAgIH1cblxuICAgIGlmIChwcmV2T3V0cHV0cykge1xuICAgICAgY29uc3QgdHhiSW5wdXRzID0gKHRoaXMgYXMgYW55KS5fX0lOUFVUUztcbiAgICAgIGlmIChwcmV2T3V0cHV0cy5sZW5ndGggIT09IHR4YklucHV0cy5sZW5ndGgpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBwcmV2T3V0cyBtdXN0IG1hdGNoIHR4YklucHV0IGxlbmd0aGApO1xuICAgICAgfVxuICAgICAgcHJldk91dHB1dHMuZm9yRWFjaCgobywgaSkgPT4ge1xuICAgICAgICB0eGJJbnB1dHNbaV0udmFsdWUgPSBvLnZhbHVlO1xuICAgICAgICB0eGJJbnB1dHNbaV0ucHJldk91dFNjcmlwdCA9IG8uc2NyaXB0O1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgY3JlYXRlSW5pdGlhbFRyYW5zYWN0aW9uKG5ldHdvcms6IE5ldHdvcmssIHR4PzogVHJhbnNhY3Rpb24pOiBVdHhvVHJhbnNhY3Rpb24ge1xuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uKG5ldHdvcmssIHR4KTtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tVHJhbnNhY3Rpb24oXG4gICAgdHg6IFV0eG9UcmFuc2FjdGlvbixcbiAgICBuZXR3b3JrPzogYml0Y29pbmpzLk5ldHdvcmssXG4gICAgcHJldk91dHB1dHM/OiBUeE91dHB1dFtdXG4gICk6IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIge1xuICAgIHJldHVybiBuZXcgVXR4b1RyYW5zYWN0aW9uQnVpbGRlcih0eC5uZXR3b3JrLCBUcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4KSwgcHJldk91dHB1dHMpO1xuICB9XG5cbiAgZ2V0IHR4KCk6IFQge1xuICAgIHJldHVybiAodGhpcyBhcyBhbnkpLl9fVFg7XG4gIH1cblxuICBidWlsZCgpOiBUIHtcbiAgICByZXR1cm4gc3VwZXIuYnVpbGQoKSBhcyBUO1xuICB9XG5cbiAgYnVpbGRJbmNvbXBsZXRlKCk6IFQge1xuICAgIHJldHVybiBzdXBlci5idWlsZEluY29tcGxldGUoKSBhcyBUO1xuICB9XG5cbiAgc2lnbihcbiAgICBzaWduUGFyYW1zOiBudW1iZXIgfCBUeGJTaWduQXJnLFxuICAgIGtleVBhaXI/OiBiaXRjb2luanMuRUNQYWlyLlNpZ25lcixcbiAgICByZWRlZW1TY3JpcHQ/OiBCdWZmZXIsXG4gICAgaGFzaFR5cGU/OiBudW1iZXIsXG4gICAgd2l0bmVzc1ZhbHVlPzogbnVtYmVyLFxuICAgIHdpdG5lc3NTY3JpcHQ/OiBCdWZmZXJcbiAgKTogdm9pZCB7XG4gICAgLy8gUmVndWxhciBiaXRjb2luIHAyc2gtcDJtcyBpbnB1dHMgZG8gbm90IGluY2x1ZGUgdGhlIGlucHV0IGFtb3VudCAodmFsdWUpIGluIHRoZSBzaWduYXR1cmUgYW5kXG4gICAgLy8gdGh1cyBkbyBub3QgcmVxdWlyZSB0aGUgcGFyYW1ldGVyIGB2YWx1ZWAgdG8gYmUgc2V0LlxuICAgIC8vIEZvciBiaXRjb2luY2FzaCBhbmQgYml0Y29pbnN2IHAyc2gtcDJtcyBpbnB1dHMsIHRoZSB2YWx1ZSBwYXJhbWV0ZXIgKmlzKiByZXF1aXJlZCBob3dldmVyLlxuICAgIC8vIFNpbmNlIHRoZSBgdmFsdWVgIHBhcmFtZXRlciBpcyBub3QgcGFzc2VkIHRvIHRoZSBsZWdhY3kgaGFzaGluZyBtZXRob2QsIHdlIG11c3Qgc3RvcmUgaXRcbiAgICAvLyBvbiB0aGUgdHJhbnNhY3Rpb24gaW5wdXQgb2JqZWN0LlxuXG4gICAgaWYgKHR5cGVvZiBzaWduUGFyYW1zID09PSAnbnVtYmVyJykge1xuICAgICAgaWYgKHR5cGVvZiB3aXRuZXNzVmFsdWUgPT09ICdudW1iZXInKSB7XG4gICAgICAgICh0aGlzLnR4Lmluc1tzaWduUGFyYW1zXSBhcyBhbnkpLnZhbHVlID0gd2l0bmVzc1ZhbHVlO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gc3VwZXIuc2lnbihzaWduUGFyYW1zLCBrZXlQYWlyLCByZWRlZW1TY3JpcHQsIGhhc2hUeXBlLCB3aXRuZXNzVmFsdWUsIHdpdG5lc3NTY3JpcHQpO1xuICAgIH1cblxuICAgIGlmIChzaWduUGFyYW1zLndpdG5lc3NWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAodGhpcy50eC5pbnNbc2lnblBhcmFtcy52aW5dIGFzIGFueSkudmFsdWUgPSBzaWduUGFyYW1zLndpdG5lc3NWYWx1ZTtcbiAgICB9XG4gICAgLy8gV2hlbiBjYWxsaW5nIHRoZSBzaWduIG1ldGhvZCB2aWEgVHhiU2lnbkFyZywgdGhlIGB2YWx1ZWAgcGFyYW1ldGVyIGlzIGFjdHVhbGx5IG5vdCBwZXJtaXR0ZWRcbiAgICAvLyB0byBiZSBzZXQgZm9yIHAyc2gtcDJtcyB0cmFuc2FjdGlvbnMuXG4gICAgaWYgKHNpZ25QYXJhbXMucHJldk91dFNjcmlwdFR5cGUgPT09ICdwMnNoLXAybXMnKSB7XG4gICAgICBkZWxldGUgc2lnblBhcmFtcy53aXRuZXNzVmFsdWU7XG4gICAgfVxuICAgIHJldHVybiBzdXBlci5zaWduKHNpZ25QYXJhbXMpO1xuICB9XG59XG4iXX0=
/// <reference types="node" />
import { Transaction } from 'bitcoinjs-lib';
import * as bitcoinjs from 'bitcoinjs-lib';
import { ZcashTransaction } from './ZcashTransaction';

@@ -8,5 +8,7 @@ import { Network, ZcashNetwork } from '../../networkTypes';

constructor(network: ZcashNetwork);
createInitialTransaction(network: Network, tx?: Transaction): ZcashTransaction;
static fromTransaction(transaction: ZcashTransaction): ZcashTransactionBuilder;
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction): ZcashTransaction;
static fromTransaction(transaction: ZcashTransaction, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput[]): ZcashTransactionBuilder;
setVersion(version: number, overwinter?: boolean): void;
private hasSignatures;
private setPropertyCheckSignatures;
setConsensusBranchId(consensusBranchId: number): void;

@@ -13,0 +15,0 @@ setVersionGroupId(versionGroupId: number): void;

@@ -17,3 +17,3 @@ "use strict";

}
static fromTransaction(transaction) {
static fromTransaction(transaction, network, prevOutput) {
const txb = new ZcashTransactionBuilder(transaction.network);

@@ -54,19 +54,27 @@ // Copy transaction fields

}
hasSignatures() {
return this.__INPUTS.some(function (input) {
return input.signatures !== undefined;
});
}
setPropertyCheckSignatures(propName, value) {
if (this.tx[propName] === value) {
return;
}
if (this.hasSignatures()) {
throw new Error(`Changing property ${propName} for a partially signed transaction would invalidate signatures`);
}
this.tx[propName] = value;
}
setConsensusBranchId(consensusBranchId) {
typeforce(types.UInt32, consensusBranchId);
/* istanbul ignore next */
if (!this.__INPUTS.every(function (input) {
return input.signatures === undefined;
})) {
throw new Error('Changing the consensusBranchId for a partially signed transaction would invalidate signatures');
}
this.tx.consensusBranchId = consensusBranchId;
this.setPropertyCheckSignatures('consensusBranchId', consensusBranchId);
}
setVersionGroupId(versionGroupId) {
typeforce(types.UInt32, versionGroupId);
this.tx.versionGroupId = versionGroupId;
this.setPropertyCheckSignatures('versionGroupId', versionGroupId);
}
setExpiryHeight(expiryHeight) {
typeforce(types.UInt32, expiryHeight);
this.tx.expiryHeight = expiryHeight;
this.setPropertyCheckSignatures('expiryHeight', expiryHeight);
}

@@ -88,2 +96,2 @@ build() {

exports.ZcashTransactionBuilder = ZcashTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transaction } from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nconst typeforce = require('typeforce');\n\nimport * as networks from '../../networks';\nimport { ZcashTransaction } from './ZcashTransaction';\nimport { Network, ZcashNetwork } from '../../networkTypes';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport { toOutputScript } from './address';\n\nexport class ZcashTransactionBuilder extends UtxoTransactionBuilder<ZcashTransaction> {\n  constructor(network: ZcashNetwork) {\n    super(network);\n  }\n\n  createInitialTransaction(network: Network, tx?: Transaction): ZcashTransaction {\n    return new ZcashTransaction(network as ZcashNetwork, tx as ZcashTransaction);\n  }\n\n  static fromTransaction(transaction: ZcashTransaction): ZcashTransactionBuilder {\n    const txb = new ZcashTransactionBuilder(transaction.network);\n\n    // Copy transaction fields\n    txb.setVersion(transaction.version, !!transaction.overwintered);\n    txb.setLockTime(transaction.locktime);\n\n    // Copy Zcash overwinter fields. Omitted if the transaction builder is not for Zcash.\n    if (txb.tx.isOverwinterCompatible()) {\n      txb.setVersionGroupId(transaction.versionGroupId);\n      txb.setExpiryHeight(transaction.expiryHeight);\n    }\n\n    txb.setConsensusBranchId(transaction.consensusBranchId);\n\n    // Copy outputs (done first to avoid signature invalidation)\n    transaction.outs.forEach(function (txOut) {\n      txb.addOutput(txOut.script, txOut.value);\n    });\n\n    // Copy inputs\n    transaction.ins.forEach(function (txIn) {\n      (txb as any).__addInputUnsafe(txIn.hash, txIn.index, {\n        sequence: txIn.sequence,\n        script: txIn.script,\n        witness: txIn.witness,\n        value: (txIn as any).value,\n      });\n    });\n\n    return txb;\n  }\n\n  setVersion(version: number, overwinter = true): void {\n    typeforce(types.UInt32, version);\n    /* istanbul ignore next */\n    if (!networks.zcash.consensusBranchId.hasOwnProperty(this.tx.version)) {\n      throw new Error('Unsupported Zcash transaction');\n    }\n    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.consensusBranchId = networks.zcash.consensusBranchId[version];\n    this.tx.version = version;\n  }\n\n  setConsensusBranchId(consensusBranchId: number): void {\n    typeforce(types.UInt32, consensusBranchId);\n    /* istanbul ignore next */\n    if (\n      !(this as any).__INPUTS.every(function (input: { signatures: unknown }) {\n        return input.signatures === undefined;\n      })\n    ) {\n      throw new Error('Changing the consensusBranchId for a partially signed transaction would invalidate signatures');\n    }\n    this.tx.consensusBranchId = consensusBranchId;\n  }\n\n  setVersionGroupId(versionGroupId: number): void {\n    typeforce(types.UInt32, versionGroupId);\n    (this as any).tx.versionGroupId = versionGroupId;\n  }\n\n  setExpiryHeight(expiryHeight: number): void {\n    typeforce(types.UInt32, expiryHeight);\n    this.tx.expiryHeight = expiryHeight;\n  }\n\n  build(): ZcashTransaction {\n    return super.build() as ZcashTransaction;\n  }\n\n  buildIncomplete(): ZcashTransaction {\n    return super.buildIncomplete() as ZcashTransaction;\n  }\n\n  addOutput(scriptPubKey: string | Buffer, value: number): number {\n    // Attempt to get a script if it's a base58 or bech32 address string\n    if (typeof scriptPubKey === 'string') {\n      scriptPubKey = toOutputScript(scriptPubKey, this.network as Network);\n    }\n\n    return super.addOutput(scriptPubKey, value);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as bitcoinjs from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nconst typeforce = require('typeforce');\n\nimport * as networks from '../../networks';\nimport { ZcashTransaction } from './ZcashTransaction';\nimport { Network, ZcashNetwork } from '../../networkTypes';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport { toOutputScript } from './address';\n\nexport class ZcashTransactionBuilder extends UtxoTransactionBuilder<ZcashTransaction> {\n  constructor(network: ZcashNetwork) {\n    super(network);\n  }\n\n  createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction): ZcashTransaction {\n    return new ZcashTransaction(network as ZcashNetwork, tx as ZcashTransaction);\n  }\n\n  static fromTransaction(\n    transaction: ZcashTransaction,\n    network?: bitcoinjs.Network,\n    prevOutput?: bitcoinjs.TxOutput[]\n  ): ZcashTransactionBuilder {\n    const txb = new ZcashTransactionBuilder(transaction.network);\n\n    // Copy transaction fields\n    txb.setVersion(transaction.version, !!transaction.overwintered);\n    txb.setLockTime(transaction.locktime);\n\n    // Copy Zcash overwinter fields. Omitted if the transaction builder is not for Zcash.\n    if (txb.tx.isOverwinterCompatible()) {\n      txb.setVersionGroupId(transaction.versionGroupId);\n      txb.setExpiryHeight(transaction.expiryHeight);\n    }\n\n    txb.setConsensusBranchId(transaction.consensusBranchId);\n\n    // Copy outputs (done first to avoid signature invalidation)\n    transaction.outs.forEach(function (txOut) {\n      txb.addOutput(txOut.script, txOut.value);\n    });\n\n    // Copy inputs\n    transaction.ins.forEach(function (txIn) {\n      (txb as any).__addInputUnsafe(txIn.hash, txIn.index, {\n        sequence: txIn.sequence,\n        script: txIn.script,\n        witness: txIn.witness,\n        value: (txIn as any).value,\n      });\n    });\n\n    return txb;\n  }\n\n  setVersion(version: number, overwinter = true): void {\n    typeforce(types.UInt32, version);\n    /* istanbul ignore next */\n    if (!networks.zcash.consensusBranchId.hasOwnProperty(this.tx.version)) {\n      throw new Error('Unsupported Zcash transaction');\n    }\n    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.consensusBranchId = networks.zcash.consensusBranchId[version];\n    this.tx.version = version;\n  }\n\n  private hasSignatures(): boolean {\n    return (this as any).__INPUTS.some(function (input: { signatures: unknown }) {\n      return input.signatures !== undefined;\n    });\n  }\n\n  private setPropertyCheckSignatures(propName: keyof ZcashTransaction, value: unknown) {\n    if (this.tx[propName] === value) {\n      return;\n    }\n    if (this.hasSignatures()) {\n      throw new Error(`Changing property ${propName} for a partially signed transaction would invalidate signatures`);\n    }\n    this.tx[propName] = value as any;\n  }\n\n  setConsensusBranchId(consensusBranchId: number): void {\n    typeforce(types.UInt32, consensusBranchId);\n    this.setPropertyCheckSignatures('consensusBranchId', consensusBranchId);\n  }\n\n  setVersionGroupId(versionGroupId: number): void {\n    typeforce(types.UInt32, versionGroupId);\n    this.setPropertyCheckSignatures('versionGroupId', versionGroupId);\n  }\n\n  setExpiryHeight(expiryHeight: number): void {\n    typeforce(types.UInt32, expiryHeight);\n    this.setPropertyCheckSignatures('expiryHeight', expiryHeight);\n  }\n\n  build(): ZcashTransaction {\n    return super.build() as ZcashTransaction;\n  }\n\n  buildIncomplete(): ZcashTransaction {\n    return super.buildIncomplete() as ZcashTransaction;\n  }\n\n  addOutput(scriptPubKey: string | Buffer, value: number): number {\n    // Attempt to get a script if it's a base58 or bech32 address string\n    if (typeof scriptPubKey === 'string') {\n      scriptPubKey = toOutputScript(scriptPubKey, this.network as Network);\n    }\n\n    return super.addOutput(scriptPubKey, value);\n  }\n}\n"]}
{
"name": "@bitgo/utxo-lib",
"version": "2.2.0-rc.6",
"version": "2.2.0-rc.7",
"description": "Client-side Bitcoin JavaScript library",

@@ -65,3 +65,3 @@ "main": "./dist/src/index.js",

"license": "MIT",
"gitHead": "333413fa8884f04734e6e41fd098be0db19f7000"
"gitHead": "1f0c062ce55fe5e7062f4e38fe0c27ded7eb0ebf"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc