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

@bitgo/utxo-lib

Package Overview
Dependencies
Maintainers
7
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 3.0.0-rc.0 to 3.0.0-rc.1

10

dist/src/bitgo/dash/DashTransaction.d.ts
/// <reference types="node" />
import { UtxoTransaction } from '../UtxoTransaction';
import { Network } from '../../networks';
export declare class DashTransaction<TNumber extends number | bigint = number> extends UtxoTransaction<TNumber> {
export declare class DashTransaction extends UtxoTransaction {
static DASH_NORMAL: number;

@@ -14,6 +14,6 @@ static DASH_PROVIDER_REGISTER: number;

extraPayload?: Buffer;
constructor(network: Network, tx?: UtxoTransaction<TNumber> | DashTransaction<TNumber>);
static fromTransaction<TNumber extends number | bigint = number>(tx: DashTransaction<TNumber>): DashTransaction<TNumber>;
static fromBuffer<TNumber extends number | bigint = number>(buffer: Buffer, noStrict: boolean, amountType: "number" | "bigint" | undefined, network: Network): DashTransaction<TNumber>;
clone(): DashTransaction<TNumber>;
constructor(network: Network, tx?: UtxoTransaction | DashTransaction);
static fromTransaction(tx: DashTransaction): DashTransaction;
static fromBuffer(buffer: Buffer, noStrict: boolean, network: Network): DashTransaction;
clone(): DashTransaction;
byteLength(_ALLOW_WITNESS?: boolean): number;

@@ -20,0 +20,0 @@ /**

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

}
static fromBuffer(buffer, noStrict, amountType = 'number', network) {
const baseTx = UtxoTransaction_1.UtxoTransaction.fromBuffer(buffer, true, amountType, network);
static fromBuffer(buffer, noStrict, network) {
const baseTx = UtxoTransaction_1.UtxoTransaction.fromBuffer(buffer, true, network);
const tx = new DashTransaction(network, baseTx);

@@ -111,2 +111,2 @@ tx.version = baseTx.version & 0xffff;

DashTransaction.DASH_QUORUM_COMMITMENT = 6;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DashTransaction.js","sourceRoot":"","sources":["../../../../src/bitgo/dash/DashTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\nimport { crypto as bcrypto, Transaction } from 'bitcoinjs-lib';\n\nimport { UtxoTransaction, varSliceSize } from '../UtxoTransaction';\nimport { isDash, Network } from '../../networks';\n\nexport class DashTransaction<TNumber extends number | bigint = number> extends UtxoTransaction<TNumber> {\n  static DASH_NORMAL = 0;\n  static DASH_PROVIDER_REGISTER = 1;\n  static DASH_PROVIDER_UPDATE_SERVICE = 2;\n  static DASH_PROVIDER_UPDATE_REGISTRAR = 3;\n  static DASH_PROVIDER_UPDATE_REVOKE = 4;\n  static DASH_COINBASE = 5;\n  static DASH_QUORUM_COMMITMENT = 6;\n\n  public type = 0;\n  public extraPayload?: Buffer;\n\n  constructor(network: Network, tx?: UtxoTransaction<TNumber> | DashTransaction<TNumber>) {\n    super(network, tx);\n\n    if (!isDash(network)) {\n      throw new Error(`invalid network`);\n    }\n\n    if (tx) {\n      this.version = tx.version;\n\n      if (tx instanceof DashTransaction) {\n        this.type = tx.type;\n        this.extraPayload = tx.extraPayload;\n      }\n    }\n\n    // since `__toBuffer` is private we have to do a little hack here\n    (this as any).__toBuffer = this.toBufferWithExtraPayload;\n  }\n\n  static fromTransaction<TNumber extends number | bigint = number>(\n    tx: DashTransaction<TNumber>\n  ): DashTransaction<TNumber> {\n    return new DashTransaction(tx.network, tx);\n  }\n\n  static fromBuffer<TNumber extends number | bigint = number>(\n    buffer: Buffer,\n    noStrict: boolean,\n    amountType: 'number' | 'bigint' = 'number',\n    network: Network\n  ): DashTransaction<TNumber> {\n    const baseTx = UtxoTransaction.fromBuffer<TNumber>(buffer, true, amountType, network);\n    const tx = new DashTransaction(network, baseTx);\n    tx.version = baseTx.version & 0xffff;\n    tx.type = baseTx.version >> 16;\n    if (baseTx.byteLength() !== buffer.length) {\n      const bufferReader = new BufferReader(buffer, baseTx.byteLength());\n      tx.extraPayload = bufferReader.readVarSlice();\n    }\n    return tx;\n  }\n\n  clone(): DashTransaction<TNumber> {\n    return new DashTransaction(this.network, this);\n  }\n\n  byteLength(_ALLOW_WITNESS?: boolean): number {\n    return super.byteLength(_ALLOW_WITNESS) + (this.extraPayload ? varSliceSize(this.extraPayload) : 0);\n  }\n\n  /**\n   * Helper to override `__toBuffer()` of bitcoinjs.Transaction.\n   * Since the method is private, we use a hack in the constructor to make it work.\n   *\n   * TODO: remove `private` modifier in bitcoinjs `__toBuffer()` or find some other solution\n   *\n   * @param buffer - optional target buffer\n   * @param initialOffset - can only be undefined or 0. Other values are only used for serialization in blocks.\n   * @param _ALLOW_WITNESS - ignored\n   */\n  private toBufferWithExtraPayload(buffer?: Buffer, initialOffset?: number, _ALLOW_WITNESS = false): Buffer {\n    // We can ignore the `_ALLOW_WITNESS` parameter here since it has no effect.\n    if (!buffer) {\n      buffer = Buffer.allocUnsafe(this.byteLength(false));\n    }\n\n    if (initialOffset !== undefined && initialOffset !== 0) {\n      throw new Error(`not supported`);\n    }\n\n    // Start out with regular bitcoin byte sequence.\n    // This buffer will have excess size because it uses `byteLength()` to allocate.\n    const baseBuffer = (Transaction.prototype as any).__toBuffer.call(this);\n    baseBuffer.copy(buffer);\n\n    // overwrite leading version bytes (uint16 version, uint16 type)\n    const bufferWriter = new BufferWriter(buffer, 0);\n    bufferWriter.writeUInt32((this.version & 0xffff) | (this.type << 16));\n\n    // Seek to end of original byte sequence and add extraPayload.\n    // We must use the byteLength as calculated by the bitcoinjs implementation since\n    // `baseBuffer` has an excess size.\n    if (this.extraPayload) {\n      bufferWriter.offset = Transaction.prototype.byteLength.call(this);\n      bufferWriter.writeVarSlice(this.extraPayload);\n    }\n\n    return buffer;\n  }\n\n  getHash(forWitness?: boolean): Buffer {\n    if (forWitness) {\n      throw new Error(`invalid argument`);\n    }\n    return bcrypto.hash256(this.toBuffer());\n  }\n\n  /**\n   * Build a hash for all or none of the transaction inputs depending on the hashtype\n   * @param hashType\n   * @returns Buffer\n   */\n  getPrevoutHash(hashType: number): Buffer {\n    if (!(hashType & UtxoTransaction.SIGHASH_ANYONECANPAY)) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeSlice(txIn.hash);\n        bufferWriter.writeUInt32(txIn.index);\n      });\n\n      return bcrypto.hash256(bufferWriter.buffer);\n    }\n\n    return Buffer.alloc(32, 0);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DashTransaction.js","sourceRoot":"","sources":["../../../../src/bitgo/dash/DashTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\nimport { crypto as bcrypto, Transaction } from 'bitcoinjs-lib';\n\nimport { UtxoTransaction, varSliceSize } from '../UtxoTransaction';\nimport { isDash, Network } from '../../networks';\n\nexport class DashTransaction extends UtxoTransaction {\n  static DASH_NORMAL = 0;\n  static DASH_PROVIDER_REGISTER = 1;\n  static DASH_PROVIDER_UPDATE_SERVICE = 2;\n  static DASH_PROVIDER_UPDATE_REGISTRAR = 3;\n  static DASH_PROVIDER_UPDATE_REVOKE = 4;\n  static DASH_COINBASE = 5;\n  static DASH_QUORUM_COMMITMENT = 6;\n\n  public type = 0;\n  public extraPayload?: Buffer;\n\n  constructor(network: Network, tx?: UtxoTransaction | DashTransaction) {\n    super(network, tx);\n\n    if (!isDash(network)) {\n      throw new Error(`invalid network`);\n    }\n\n    if (tx) {\n      this.version = tx.version;\n\n      if (tx instanceof DashTransaction) {\n        this.type = tx.type;\n        this.extraPayload = tx.extraPayload;\n      }\n    }\n\n    // since `__toBuffer` is private we have to do a little hack here\n    (this as any).__toBuffer = this.toBufferWithExtraPayload;\n  }\n\n  static fromTransaction(tx: DashTransaction): DashTransaction {\n    return new DashTransaction(tx.network, tx);\n  }\n\n  static fromBuffer(buffer: Buffer, noStrict: boolean, network: Network): DashTransaction {\n    const baseTx = UtxoTransaction.fromBuffer(buffer, true, network);\n    const tx = new DashTransaction(network, baseTx);\n    tx.version = baseTx.version & 0xffff;\n    tx.type = baseTx.version >> 16;\n    if (baseTx.byteLength() !== buffer.length) {\n      const bufferReader = new BufferReader(buffer, baseTx.byteLength());\n      tx.extraPayload = bufferReader.readVarSlice();\n    }\n    return tx;\n  }\n\n  clone(): DashTransaction {\n    return new DashTransaction(this.network, this);\n  }\n\n  byteLength(_ALLOW_WITNESS?: boolean): number {\n    return super.byteLength(_ALLOW_WITNESS) + (this.extraPayload ? varSliceSize(this.extraPayload) : 0);\n  }\n\n  /**\n   * Helper to override `__toBuffer()` of bitcoinjs.Transaction.\n   * Since the method is private, we use a hack in the constructor to make it work.\n   *\n   * TODO: remove `private` modifier in bitcoinjs `__toBuffer()` or find some other solution\n   *\n   * @param buffer - optional target buffer\n   * @param initialOffset - can only be undefined or 0. Other values are only used for serialization in blocks.\n   * @param _ALLOW_WITNESS - ignored\n   */\n  private toBufferWithExtraPayload(buffer?: Buffer, initialOffset?: number, _ALLOW_WITNESS = false): Buffer {\n    // We can ignore the `_ALLOW_WITNESS` parameter here since it has no effect.\n    if (!buffer) {\n      buffer = Buffer.allocUnsafe(this.byteLength(false));\n    }\n\n    if (initialOffset !== undefined && initialOffset !== 0) {\n      throw new Error(`not supported`);\n    }\n\n    // Start out with regular bitcoin byte sequence.\n    // This buffer will have excess size because it uses `byteLength()` to allocate.\n    const baseBuffer = (Transaction.prototype as any).__toBuffer.call(this);\n    baseBuffer.copy(buffer);\n\n    // overwrite leading version bytes (uint16 version, uint16 type)\n    const bufferWriter = new BufferWriter(buffer, 0);\n    bufferWriter.writeUInt32((this.version & 0xffff) | (this.type << 16));\n\n    // Seek to end of original byte sequence and add extraPayload.\n    // We must use the byteLength as calculated by the bitcoinjs implementation since\n    // `baseBuffer` has an excess size.\n    if (this.extraPayload) {\n      bufferWriter.offset = Transaction.prototype.byteLength.call(this);\n      bufferWriter.writeVarSlice(this.extraPayload);\n    }\n\n    return buffer;\n  }\n\n  getHash(forWitness?: boolean): Buffer {\n    if (forWitness) {\n      throw new Error(`invalid argument`);\n    }\n    return bcrypto.hash256(this.toBuffer());\n  }\n\n  /**\n   * Build a hash for all or none of the transaction inputs depending on the hashtype\n   * @param hashType\n   * @returns Buffer\n   */\n  getPrevoutHash(hashType: number): Buffer {\n    if (!(hashType & UtxoTransaction.SIGHASH_ANYONECANPAY)) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeSlice(txIn.hash);\n        bufferWriter.writeUInt32(txIn.index);\n      });\n\n      return bcrypto.hash256(bufferWriter.buffer);\n    }\n\n    return Buffer.alloc(32, 0);\n  }\n}\n"]}

@@ -6,9 +6,9 @@ /// <reference types="node" />

import { DashTransaction } from './DashTransaction';
export declare class DashTransactionBuilder<TNumber extends number | bigint = number> extends UtxoTransactionBuilder<TNumber, DashTransaction<TNumber>> {
constructor(network: Network, txb?: UtxoTransactionBuilder<TNumber>);
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction<TNumber>): DashTransaction<TNumber>;
export declare class DashTransactionBuilder extends UtxoTransactionBuilder<DashTransaction> {
constructor(network: Network, txb?: UtxoTransactionBuilder);
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction): DashTransaction;
setType(type: number): void;
setExtraPayload(extraPayload?: Buffer): void;
static fromTransaction<TNumber extends number | bigint>(tx: DashTransaction<TNumber>, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput<TNumber>[]): DashTransactionBuilder<TNumber>;
static fromTransaction(tx: DashTransaction, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput[]): DashTransactionBuilder;
}
//# sourceMappingURL=DashTransactionBuilder.d.ts.map

@@ -27,2 +27,2 @@ "use strict";

exports.DashTransactionBuilder = DashTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFzaFRyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby9kYXNoL0Rhc2hUcmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsc0VBQW1FO0FBQ25FLHVEQUFvRDtBQUdwRCxNQUFhLHNCQUFpRSxTQUFRLCtDQUdyRjtJQUNDLFlBQVksT0FBZ0IsRUFBRSxHQUFxQztRQUNqRSxLQUFLLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxPQUFnQixFQUFFLEVBQW1DO1FBQzVFLE9BQU8sSUFBSSxpQ0FBZSxDQUFVLE9BQU8sRUFBRSxFQUE4QixDQUFDLENBQUM7SUFDL0UsQ0FBQztJQUVELE9BQU8sQ0FBQyxJQUFZO1FBQ2xCLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUN0QixDQUFDO0lBRUQsZUFBZSxDQUFDLFlBQXFCO1FBQ25DLElBQUksQ0FBQyxFQUFFLENBQUMsWUFBWSxHQUFHLFlBQVksQ0FBQztJQUN0QyxDQUFDO0lBRUQsTUFBTSxDQUFDLGVBQWUsQ0FDcEIsRUFBNEIsRUFDNUIsT0FBMkIsRUFDM0IsVUFBMEM7UUFFMUMsTUFBTSxHQUFHLEdBQUcsSUFBSSxzQkFBc0IsQ0FDcEMsRUFBRSxDQUFDLE9BQU8sRUFDViwrQ0FBc0IsQ0FBQyxlQUFlLENBQVUsRUFBRSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FDekUsQ0FBQztRQUNGLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLEdBQUcsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztDQUNGO0FBakNELHdEQWlDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGJpdGNvaW5qcyBmcm9tICdiaXRjb2luanMtbGliJztcbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLi9uZXR3b3Jrcyc7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi4vVXR4b1RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBEYXNoVHJhbnNhY3Rpb24gfSBmcm9tICcuL0Rhc2hUcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb24gfSBmcm9tICcuLi9VdHhvVHJhbnNhY3Rpb24nO1xuXG5leHBvcnQgY2xhc3MgRGFzaFRyYW5zYWN0aW9uQnVpbGRlcjxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiBleHRlbmRzIFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8XG4gIFROdW1iZXIsXG4gIERhc2hUcmFuc2FjdGlvbjxUTnVtYmVyPlxuPiB7XG4gIGNvbnN0cnVjdG9yKG5ldHdvcms6IE5ldHdvcmssIHR4Yj86IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8VE51bWJlcj4pIHtcbiAgICBzdXBlcihuZXR3b3JrLCB0eGIpO1xuICB9XG5cbiAgY3JlYXRlSW5pdGlhbFRyYW5zYWN0aW9uKG5ldHdvcms6IE5ldHdvcmssIHR4PzogYml0Y29pbmpzLlRyYW5zYWN0aW9uPFROdW1iZXI+KTogRGFzaFRyYW5zYWN0aW9uPFROdW1iZXI+IHtcbiAgICByZXR1cm4gbmV3IERhc2hUcmFuc2FjdGlvbjxUTnVtYmVyPihuZXR3b3JrLCB0eCBhcyBVdHhvVHJhbnNhY3Rpb248VE51bWJlcj4pO1xuICB9XG5cbiAgc2V0VHlwZSh0eXBlOiBudW1iZXIpOiB2b2lkIHtcbiAgICB0aGlzLnR4LnR5cGUgPSB0eXBlO1xuICB9XG5cbiAgc2V0RXh0cmFQYXlsb2FkKGV4dHJhUGF5bG9hZD86IEJ1ZmZlcik6IHZvaWQge1xuICAgIHRoaXMudHguZXh0cmFQYXlsb2FkID0gZXh0cmFQYXlsb2FkO1xuICB9XG5cbiAgc3RhdGljIGZyb21UcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50PihcbiAgICB0eDogRGFzaFRyYW5zYWN0aW9uPFROdW1iZXI+LFxuICAgIG5ldHdvcms/OiBiaXRjb2luanMuTmV0d29yayxcbiAgICBwcmV2T3V0cHV0PzogYml0Y29pbmpzLlR4T3V0cHV0PFROdW1iZXI+W11cbiAgKTogRGFzaFRyYW5zYWN0aW9uQnVpbGRlcjxUTnVtYmVyPiB7XG4gICAgY29uc3QgdHhiID0gbmV3IERhc2hUcmFuc2FjdGlvbkJ1aWxkZXI8VE51bWJlcj4oXG4gICAgICB0eC5uZXR3b3JrLFxuICAgICAgVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5mcm9tVHJhbnNhY3Rpb248VE51bWJlcj4odHgsIG5ldHdvcmssIHByZXZPdXRwdXQpXG4gICAgKTtcbiAgICB0eGIuc2V0VHlwZSh0eC50eXBlKTtcbiAgICB0eGIuc2V0RXh0cmFQYXlsb2FkKHR4LmV4dHJhUGF5bG9hZCk7XG4gICAgcmV0dXJuIHR4YjtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGFzaFRyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby9kYXNoL0Rhc2hUcmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsc0VBQW1FO0FBQ25FLHVEQUFvRDtBQUdwRCxNQUFhLHNCQUF1QixTQUFRLCtDQUF1QztJQUNqRixZQUFZLE9BQWdCLEVBQUUsR0FBNEI7UUFDeEQsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQztJQUN0QixDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBZ0IsRUFBRSxFQUEwQjtRQUNuRSxPQUFPLElBQUksaUNBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBcUIsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxPQUFPLENBQUMsSUFBWTtRQUNsQixJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7SUFDdEIsQ0FBQztJQUVELGVBQWUsQ0FBQyxZQUFxQjtRQUNuQyxJQUFJLENBQUMsRUFBRSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDdEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxlQUFlLENBQ3BCLEVBQW1CLEVBQ25CLE9BQTJCLEVBQzNCLFVBQWlDO1FBRWpDLE1BQU0sR0FBRyxHQUFHLElBQUksc0JBQXNCLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSwrQ0FBc0IsQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ3BILEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLEdBQUcsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sR0FBRyxDQUFDO0lBQ2IsQ0FBQztDQUNGO0FBM0JELHdEQTJCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGJpdGNvaW5qcyBmcm9tICdiaXRjb2luanMtbGliJztcbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLi9uZXR3b3Jrcyc7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi4vVXR4b1RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBEYXNoVHJhbnNhY3Rpb24gfSBmcm9tICcuL0Rhc2hUcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb24gfSBmcm9tICcuLi9VdHhvVHJhbnNhY3Rpb24nO1xuXG5leHBvcnQgY2xhc3MgRGFzaFRyYW5zYWN0aW9uQnVpbGRlciBleHRlbmRzIFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8RGFzaFRyYW5zYWN0aW9uPiB7XG4gIGNvbnN0cnVjdG9yKG5ldHdvcms6IE5ldHdvcmssIHR4Yj86IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIpIHtcbiAgICBzdXBlcihuZXR3b3JrLCB0eGIpO1xuICB9XG5cbiAgY3JlYXRlSW5pdGlhbFRyYW5zYWN0aW9uKG5ldHdvcms6IE5ldHdvcmssIHR4PzogYml0Y29pbmpzLlRyYW5zYWN0aW9uKTogRGFzaFRyYW5zYWN0aW9uIHtcbiAgICByZXR1cm4gbmV3IERhc2hUcmFuc2FjdGlvbihuZXR3b3JrLCB0eCBhcyBVdHhvVHJhbnNhY3Rpb24pO1xuICB9XG5cbiAgc2V0VHlwZSh0eXBlOiBudW1iZXIpOiB2b2lkIHtcbiAgICB0aGlzLnR4LnR5cGUgPSB0eXBlO1xuICB9XG5cbiAgc2V0RXh0cmFQYXlsb2FkKGV4dHJhUGF5bG9hZD86IEJ1ZmZlcik6IHZvaWQge1xuICAgIHRoaXMudHguZXh0cmFQYXlsb2FkID0gZXh0cmFQYXlsb2FkO1xuICB9XG5cbiAgc3RhdGljIGZyb21UcmFuc2FjdGlvbihcbiAgICB0eDogRGFzaFRyYW5zYWN0aW9uLFxuICAgIG5ldHdvcms/OiBiaXRjb2luanMuTmV0d29yayxcbiAgICBwcmV2T3V0cHV0PzogYml0Y29pbmpzLlR4T3V0cHV0W11cbiAgKTogRGFzaFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgY29uc3QgdHhiID0gbmV3IERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIodHgubmV0d29yaywgVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5mcm9tVHJhbnNhY3Rpb24odHgsIG5ldHdvcmssIHByZXZPdXRwdXQpKTtcbiAgICB0eGIuc2V0VHlwZSh0eC50eXBlKTtcbiAgICB0eGIuc2V0RXh0cmFQYXlsb2FkKHR4LmV4dHJhUGF5bG9hZCk7XG4gICAgcmV0dXJuIHR4YjtcbiAgfVxufVxuIl19

@@ -14,3 +14,2 @@ export * as bcashAddress from './bitcoincash';

export * from './zcash';
export * from './tnumber';
//# sourceMappingURL=index.d.ts.map

@@ -27,3 +27,2 @@ "use strict";

__exportStar(require("./zcash"), exports);
__exportStar(require("./tnumber"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUE4QztBQUM5Qyx1Q0FBcUM7QUFDckMsbUVBQWlFO0FBQ2pFLG1EQUFpRDtBQUNqRCx5Q0FBdUI7QUFDdkIsOENBQTRCO0FBQzVCLGdEQUE4QjtBQUM5QiwwQ0FBd0I7QUFDeEIsNENBQTBCO0FBQzFCLG9EQUFrQztBQUNsQywyREFBeUM7QUFDekMsMkNBQXlCO0FBQ3pCLDBDQUF3QjtBQUN4Qiw0Q0FBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBhcyBiY2FzaEFkZHJlc3MgZnJvbSAnLi9iaXRjb2luY2FzaCc7XG5leHBvcnQgKiBhcyBrZXl1dGlsIGZyb20gJy4va2V5dXRpbCc7XG5leHBvcnQgKiBhcyBub25TdGFuZGFyZEhhbGZTaWduZWQgZnJvbSAnLi9ub25TdGFuZGFyZEhhbGZTaWduZWQnO1xuZXhwb3J0ICogYXMgb3V0cHV0U2NyaXB0cyBmcm9tICcuL291dHB1dFNjcmlwdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9kYXNoJztcbmV4cG9ydCAqIGZyb20gJy4vc2lnbmF0dXJlJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL1Vuc3BlbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9VdHhvVHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vd2FsbGV0JztcbmV4cG9ydCAqIGZyb20gJy4vemNhc2gnO1xuZXhwb3J0ICogZnJvbSAnLi90bnVtYmVyJztcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUE4QztBQUM5Qyx1Q0FBcUM7QUFDckMsbUVBQWlFO0FBQ2pFLG1EQUFpRDtBQUNqRCx5Q0FBdUI7QUFDdkIsOENBQTRCO0FBQzVCLGdEQUE4QjtBQUM5QiwwQ0FBd0I7QUFDeEIsNENBQTBCO0FBQzFCLG9EQUFrQztBQUNsQywyREFBeUM7QUFDekMsMkNBQXlCO0FBQ3pCLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGFzIGJjYXNoQWRkcmVzcyBmcm9tICcuL2JpdGNvaW5jYXNoJztcbmV4cG9ydCAqIGFzIGtleXV0aWwgZnJvbSAnLi9rZXl1dGlsJztcbmV4cG9ydCAqIGFzIG5vblN0YW5kYXJkSGFsZlNpZ25lZCBmcm9tICcuL25vblN0YW5kYXJkSGFsZlNpZ25lZCc7XG5leHBvcnQgKiBhcyBvdXRwdXRTY3JpcHRzIGZyb20gJy4vb3V0cHV0U2NyaXB0cyc7XG5leHBvcnQgKiBmcm9tICcuL2Rhc2gnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWduYXR1cmUnO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vVW5zcGVudCc7XG5leHBvcnQgKiBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbkJ1aWxkZXInO1xuZXhwb3J0ICogZnJvbSAnLi93YWxsZXQnO1xuZXhwb3J0ICogZnJvbSAnLi96Y2FzaCc7XG4iXX0=

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

*/
export declare function getSignatureVerifications<TNumber extends number | bigint>(transaction: UtxoTransaction<TNumber>, inputIndex: number, amount: TNumber, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput<TNumber>[]): SignatureVerification[];
export declare function getSignatureVerifications(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput[]): SignatureVerification[];
/**

@@ -102,3 +102,3 @@ * @deprecated use {@see verifySignatureWithPublicKeys} instead

*/
export declare function verifySignature<TNumber extends number | bigint>(transaction: UtxoTransaction<TNumber>, inputIndex: number, amount: TNumber, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput<TNumber>[]): boolean;
export declare function verifySignature(transaction: UtxoTransaction, inputIndex: number, amount: number, verificationSettings?: VerificationSettings, prevOutputs?: TxOutput[]): boolean;
/**

@@ -111,3 +111,3 @@ * @param transaction

*/
export declare function verifySignatureWithPublicKeys<TNumber extends number | bigint>(transaction: UtxoTransaction<TNumber>, inputIndex: number, prevOutputs: TxOutput<TNumber>[], publicKeys: Buffer[]): boolean[];
export declare function verifySignatureWithPublicKeys(transaction: UtxoTransaction, inputIndex: number, prevOutputs: TxOutput[], publicKeys: Buffer[]): boolean[];
/**

@@ -121,6 +121,6 @@ * Wrapper for {@see verifySignatureWithPublicKeys} for single pubkey

*/
export declare function verifySignatureWithPublicKey<TNumber extends number | bigint>(transaction: UtxoTransaction<TNumber>, inputIndex: number, prevOutputs: TxOutput<TNumber>[], publicKey: Buffer): boolean;
export declare function signInputP2shP2pk<TNumber extends number | bigint>(txBuilder: UtxoTransactionBuilder<TNumber>, vin: number, keyPair: bip32.BIP32Interface): void;
export declare function signInput2Of3<TNumber extends number | bigint>(txBuilder: UtxoTransactionBuilder<TNumber>, vin: number, scriptType: ScriptType2Of3, pubkeys: Triple<Buffer>, keyPair: bip32.BIP32Interface, cosigner: Buffer, amount: TNumber): void;
export declare function verifySignatureWithPublicKey(transaction: UtxoTransaction, inputIndex: number, prevOutputs: TxOutput[], publicKey: Buffer): boolean;
export declare function signInputP2shP2pk(txBuilder: UtxoTransactionBuilder, vin: number, keyPair: bip32.BIP32Interface): void;
export declare function signInput2Of3(txBuilder: UtxoTransactionBuilder, vin: number, scriptType: ScriptType2Of3, pubkeys: Triple<Buffer>, keyPair: bip32.BIP32Interface, cosigner: Buffer, amount: number): void;
export {};
//# sourceMappingURL=signature.d.ts.map

@@ -6,14 +6,14 @@ /// <reference types="node" />

import { UtxoTransactionBuilder } from './UtxoTransactionBuilder';
export declare function createTransactionFromBuffer<TNumber extends number | bigint = number>(buf: Buffer, network: Network, { version }?: {
export declare function createTransactionFromBuffer(buf: Buffer, network: Network, { version }?: {
version?: number;
}, amountType?: 'number' | 'bigint'): UtxoTransaction<TNumber>;
export declare function createTransactionFromHex<TNumber extends number | bigint = number>(hex: string, network: Network, amountType?: 'number' | 'bigint'): UtxoTransaction<TNumber>;
}): UtxoTransaction;
export declare function createTransactionFromHex(hex: string, network: Network): UtxoTransaction;
export declare function getDefaultTransactionVersion(network: Network): number;
export declare function setTransactionBuilderDefaults<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, network: Network, { version }?: {
export declare function setTransactionBuilderDefaults(txb: UtxoTransactionBuilder, network: Network, { version }?: {
version?: number;
}): void;
export declare function createTransactionBuilderForNetwork<TNumber extends number | bigint = number>(network: Network, { version }?: {
export declare function createTransactionBuilderForNetwork(network: Network, { version }?: {
version?: number;
}): UtxoTransactionBuilder<TNumber>;
export declare function createTransactionBuilderFromTransaction<TNumber extends number | bigint>(tx: UtxoTransaction<TNumber>, prevOutputs?: TxOutput<TNumber>[]): UtxoTransactionBuilder<TNumber>;
}): UtxoTransactionBuilder;
export declare function createTransactionBuilderFromTransaction(tx: UtxoTransaction, prevOutputs?: TxOutput[]): UtxoTransactionBuilder;
//# sourceMappingURL=transaction.d.ts.map

@@ -11,6 +11,3 @@ "use strict";

const ZcashTransaction_1 = require("./zcash/ZcashTransaction");
function createTransactionFromBuffer(buf, network, { version } = {}, amountType = 'number') {
if (amountType !== 'number' && (networks_1.getMainnet(network) === networks_1.networks.dash || networks_1.getMainnet(network) === networks_1.networks.zcash)) {
throw new Error('dash and zcash must use number amount type; bigint amount type is recommended for doge only');
}
function createTransactionFromBuffer(buf, network, { version } = {}) {
switch (networks_1.getMainnet(network)) {

@@ -21,9 +18,9 @@ case networks_1.networks.bitcoin:

case networks_1.networks.bitcoingold:
case networks_1.networks.litecoin:
case networks_1.networks.dogecoin:
case networks_1.networks.litecoin:
return UtxoTransaction_1.UtxoTransaction.fromBuffer(buf, false, amountType, network);
return UtxoTransaction_1.UtxoTransaction.fromBuffer(buf, false, network);
case networks_1.networks.dash:
return DashTransaction_1.DashTransaction.fromBuffer(buf, false, amountType, network);
return DashTransaction_1.DashTransaction.fromBuffer(buf, false, network);
case networks_1.networks.zcash:
return ZcashTransaction_1.ZcashTransaction.fromBufferWithVersion(buf, network, version, amountType);
return ZcashTransaction_1.ZcashTransaction.fromBufferWithVersion(buf, network, version);
}

@@ -35,4 +32,4 @@ /* istanbul ignore next */

/* istanbul ignore next */
function createTransactionFromHex(hex, network, amountType = 'number') {
return createTransactionFromBuffer(Buffer.from(hex, 'hex'), network, {}, amountType);
function createTransactionFromHex(hex, network) {
return createTransactionFromBuffer(Buffer.from(hex, 'hex'), network);
}

@@ -80,4 +77,4 @@ exports.createTransactionFromHex = createTransactionFromHex;

case networks_1.networks.bitcoingold:
case networks_1.networks.dogecoin:
case networks_1.networks.litecoin: {
case networks_1.networks.litecoin:
case networks_1.networks.dogecoin: {
txb = new UtxoTransactionBuilder_1.UtxoTransactionBuilder(network);

@@ -106,4 +103,4 @@ break;

case networks_1.networks.bitcoingold:
case networks_1.networks.litecoin:
case networks_1.networks.dogecoin:
case networks_1.networks.litecoin:
return UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx, undefined, prevOutputs);

@@ -118,2 +115,2 @@ case networks_1.networks.dash:

exports.createTransactionBuilderFromTransaction = createTransactionBuilderFromTransaction;
//# 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 { networks, Network, getMainnet } from '../networks';\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 { ZcashNetwork, ZcashTransaction } from './zcash/ZcashTransaction';\n\nexport function createTransactionFromBuffer<TNumber extends number | bigint = number>(\n  buf: Buffer,\n  network: Network,\n  { version }: { version?: number } = {},\n  amountType: 'number' | 'bigint' = 'number'\n): UtxoTransaction<TNumber> {\n  if (amountType !== 'number' && (getMainnet(network) === networks.dash || getMainnet(network) === networks.zcash)) {\n    throw new Error('dash and zcash must use number amount type; bigint amount type is recommended for doge only');\n  }\n  switch (getMainnet(network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.dogecoin:\n    case networks.litecoin:\n      return UtxoTransaction.fromBuffer<TNumber>(buf, false, amountType, network);\n    case networks.dash:\n      return DashTransaction.fromBuffer<TNumber>(buf, false, amountType, network);\n    case networks.zcash:\n      return ZcashTransaction.fromBufferWithVersion<TNumber>(buf, network as ZcashNetwork, version, amountType);\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`invalid network`);\n}\n\n/* istanbul ignore next */\nexport function createTransactionFromHex<TNumber extends number | bigint = number>(\n  hex: string,\n  network: Network,\n  amountType: 'number' | 'bigint' = 'number'\n): UtxoTransaction<TNumber> {\n  return createTransactionFromBuffer<TNumber>(Buffer.from(hex, 'hex'), network, {}, amountType);\n}\n\nexport function getDefaultTransactionVersion(network: Network): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return 2;\n    case networks.zcash:\n      return ZcashTransaction.VERSION4_BRANCH_NU5;\n    default:\n      return 1;\n  }\n}\n\nexport function setTransactionBuilderDefaults<TNumber extends number | bigint>(\n  txb: UtxoTransactionBuilder<TNumber>,\n  network: Network,\n  { version = getDefaultTransactionVersion(network) }: { version?: number } = {}\n): void {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      if (version !== 2) {\n        throw new Error(`invalid version`);\n      }\n      txb.setVersion(version);\n      break;\n    case networks.zcash:\n      (txb as ZcashTransactionBuilder<TNumber>).setDefaultsForVersion(network, version);\n      break;\n    default:\n      if (version !== 1) {\n        throw new Error(`invalid version`);\n      }\n  }\n}\n\nexport function createTransactionBuilderForNetwork<TNumber extends number | bigint = number>(\n  network: Network,\n  { version }: { version?: number } = {}\n): UtxoTransactionBuilder<TNumber> {\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.dogecoin:\n    case networks.litecoin: {\n      txb = new UtxoTransactionBuilder<TNumber>(network);\n      break;\n    }\n    case networks.dash:\n      txb = new DashTransactionBuilder<TNumber>(network);\n      break;\n    case networks.zcash: {\n      txb = new ZcashTransactionBuilder<TNumber>(network as ZcashNetwork);\n      break;\n    }\n    default:\n      throw new Error(`unsupported network`);\n  }\n\n  setTransactionBuilderDefaults<TNumber>(txb, network, { version });\n\n  return txb;\n}\n\nexport function createTransactionBuilderFromTransaction<TNumber extends number | bigint>(\n  tx: UtxoTransaction<TNumber>,\n  prevOutputs?: TxOutput<TNumber>[]\n): UtxoTransactionBuilder<TNumber> {\n  switch (getMainnet(tx.network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.dogecoin:\n    case networks.litecoin:\n      return UtxoTransactionBuilder.fromTransaction<TNumber>(tx, undefined, prevOutputs);\n    case networks.dash:\n      return DashTransactionBuilder.fromTransaction<TNumber>(\n        tx as DashTransaction<TNumber>,\n        undefined,\n        prevOutputs as TxOutput<TNumber>[]\n      );\n    case networks.zcash:\n      return ZcashTransactionBuilder.fromTransaction<TNumber>(\n        tx as ZcashTransaction<TNumber>,\n        undefined,\n        prevOutputs as TxOutput<TNumber>[]\n      );\n  }\n\n  throw new Error(`invalid network`);\n}\n"]}
//# 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 { networks, Network, getMainnet } from '../networks';\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 { ZcashNetwork, ZcashTransaction } from './zcash/ZcashTransaction';\n\nexport function createTransactionFromBuffer(\n  buf: Buffer,\n  network: Network,\n  { version }: { version?: number } = {}\n): 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    case networks.dogecoin:\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.fromBufferWithVersion(buf, network as ZcashNetwork, version);\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 getDefaultTransactionVersion(network: Network): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return 2;\n    case networks.zcash:\n      return ZcashTransaction.VERSION4_BRANCH_NU5;\n    default:\n      return 1;\n  }\n}\n\nexport function setTransactionBuilderDefaults(\n  txb: UtxoTransactionBuilder,\n  network: Network,\n  { version = getDefaultTransactionVersion(network) }: { version?: number } = {}\n): void {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      if (version !== 2) {\n        throw new Error(`invalid version`);\n      }\n      txb.setVersion(version);\n      break;\n    case networks.zcash:\n      (txb as ZcashTransactionBuilder).setDefaultsForVersion(network, version);\n      break;\n    default:\n      if (version !== 1) {\n        throw new Error(`invalid version`);\n      }\n  }\n}\n\nexport function createTransactionBuilderForNetwork(\n  network: Network,\n  { version }: { version?: number } = {}\n): 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    case networks.dogecoin: {\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, { version });\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    case networks.dogecoin:\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"]}
/// <reference types="node" />
import { TxOutput } from 'bitcoinjs-lib';
import { Network } from '..';
import { TxOutput, Network } from '..';
import { UtxoTransactionBuilder } from './UtxoTransactionBuilder';

@@ -8,3 +7,3 @@ /**

*/
export interface Unspent<TNumber extends number | bigint = number> {
export interface Unspent {
/**

@@ -23,3 +22,3 @@ * Format: ${txid}:${vout}.

*/
value: TNumber;
value: number;
}

@@ -29,3 +28,3 @@ /**

*/
export declare function toOutput<TNumber extends number | bigint>(u: Unspent<TNumber>, network: Network): TxOutput<TNumber>;
export declare function toOutput(u: Unspent, network: Network): TxOutput;
/**

@@ -57,7 +56,7 @@ * @param outputId

*/
export declare type PrevOutput<TNumber extends number | bigint = number> = TxOutPoint & TxOutput<TNumber>;
export declare type PrevOutput = TxOutPoint & TxOutput;
/**
* @return PrevOutput from Unspent
*/
export declare function toPrevOutput<TNumber extends number | bigint>(u: Unspent<TNumber>, network: Network): PrevOutput<TNumber>;
export declare function toPrevOutput(u: Unspent, network: Network): PrevOutput;
/**

@@ -68,11 +67,4 @@ * @param txb

*/
export declare function addToTransactionBuilder<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, u: Unspent<TNumber>, sequence?: number): void;
/**
* Sum the values of the unspents.
* Throws error if sum is not a safe integer value, or if unspent amount types do not match `amountType`
* @param unspents - array of unspents to sum
* @param amountType - expected value type of unspents
* @return unspentSum - type matches amountType
*/
export declare function unspentSum<TNumber extends number | bigint>(unspents: Unspent<TNumber>[], amountType?: 'number' | 'bigint'): TNumber;
export declare function addToTransactionBuilder(txb: UtxoTransactionBuilder, u: Unspent, sequence?: number): void;
export declare function unspentSum(unspents: Unspent[]): number;
//# sourceMappingURL=Unspent.d.ts.map

@@ -71,22 +71,6 @@ "use strict";

exports.addToTransactionBuilder = addToTransactionBuilder;
/**
* Sum the values of the unspents.
* Throws error if sum is not a safe integer value, or if unspent amount types do not match `amountType`
* @param unspents - array of unspents to sum
* @param amountType - expected value type of unspents
* @return unspentSum - type matches amountType
*/
function unspentSum(unspents, amountType = 'number') {
if (amountType === 'bigint') {
return unspents.reduce((sum, u) => sum + u.value, BigInt(0));
}
else {
const sum = unspents.reduce((sum, u) => sum + u.value, Number(0));
if (!Number.isSafeInteger(sum)) {
throw new Error('unspent sum is not a safe integer number, consider using bigint');
}
return sum;
}
function unspentSum(unspents) {
return unspents.reduce((sum, u) => sum + u.value, 0);
}
exports.unspentSum = unspentSum;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVW5zcGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VbnNwZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLHdDQUE0QztBQXVCNUM7O0dBRUc7QUFDSCxTQUFnQixRQUFRLENBQWtDLENBQW1CLEVBQUUsT0FBZ0I7SUFDN0YsT0FBTztRQUNMLE1BQU0sRUFBRSx3QkFBYyxDQUFDLENBQUMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDO1FBQzFDLEtBQUssRUFBRSxDQUFDLENBQUMsS0FBSztLQUNmLENBQUM7QUFDSixDQUFDO0FBTEQsNEJBS0M7QUFFRDs7O0dBR0c7QUFDSCxTQUFnQixhQUFhLENBQUMsUUFBZ0I7SUFDNUMsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsOENBQThDLENBQUMsQ0FBQztLQUNqRTtJQUNELE1BQU0sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLEdBQUcsS0FBSyxDQUFDO0lBQzlCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM3QixJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0JBQWdCLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztLQUN4RDtJQUNELElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNqRSxNQUFNLElBQUksS0FBSyxDQUFDLG9DQUFvQyxDQUFDLENBQUM7S0FDdkQ7SUFDRCxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDO0FBQ3hCLENBQUM7QUFkRCxzQ0FjQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixjQUFjLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFjO0lBQ3ZELE9BQU8sR0FBRyxJQUFJLElBQUksSUFBSSxFQUFFLENBQUM7QUFDM0IsQ0FBQztBQUZELHdDQUVDO0FBRUQsU0FBZ0IsbUJBQW1CLENBQUMsQ0FBa0M7SUFDcEUsT0FBTztRQUNMLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO1FBQ25ELElBQUksRUFBRSxDQUFDLENBQUMsS0FBSztLQUNkLENBQUM7QUFDSixDQUFDO0FBTEQsa0RBS0M7QUFnQkQ7O0dBRUc7QUFDSCxTQUFnQixZQUFZLENBQzFCLENBQW1CLEVBQ25CLE9BQWdCO0lBRWhCLE9BQU87UUFDTCxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3RCLEdBQUcsUUFBUSxDQUFDLENBQUMsRUFBRSxPQUFPLENBQUM7S0FDeEIsQ0FBQztBQUNKLENBQUM7QUFSRCxvQ0FRQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQix1QkFBdUIsQ0FDckMsR0FBb0MsRUFDcEMsQ0FBbUIsRUFDbkIsUUFBaUI7SUFFakIsTUFBTSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxHQUFHLFlBQVksQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLE9BQWtCLENBQUMsQ0FBQztJQUM5RSxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztBQUNwRCxDQUFDO0FBUEQsMERBT0M7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixVQUFVLENBQ3hCLFFBQTRCLEVBQzVCLGFBQWtDLFFBQVE7SUFFMUMsSUFBSSxVQUFVLEtBQUssUUFBUSxFQUFFO1FBQzNCLE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBSSxDQUFDLENBQUMsS0FBZ0IsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQVksQ0FBQztLQUNyRjtTQUFNO1FBQ0wsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBSSxDQUFDLENBQUMsS0FBZ0IsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM5RSxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUM5QixNQUFNLElBQUksS0FBSyxDQUFDLGlFQUFpRSxDQUFDLENBQUM7U0FDcEY7UUFDRCxPQUFPLEdBQWMsQ0FBQztLQUN2QjtBQUNILENBQUM7QUFiRCxnQ0FhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR4T3V0cHV0IH0gZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSAnLi4nO1xuaW1wb3J0IHsgdG9PdXRwdXRTY3JpcHQgfSBmcm9tICcuLi9hZGRyZXNzJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbkJ1aWxkZXInO1xuXG4vKipcbiAqIFB1YmxpYyB1bnNwZW50IGRhdGEgaW4gQml0R28tc3BlY2lmaWMgcmVwcmVzZW50YXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVW5zcGVudDxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiB7XG4gIC8qKlxuICAgKiBGb3JtYXQ6ICR7dHhpZH06JHt2b3V0fS5cbiAgICogVXNlIGBwYXJzZU91dHB1dElkKGlkKWAgdG8gcGFyc2UuXG4gICAqL1xuICBpZDogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIG5ldHdvcmstc3BlY2lmaWMgZW5jb2RlZCBhZGRyZXNzLlxuICAgKiBVc2UgYHRvT3V0cHV0U2NyaXB0KGFkZHJlc3MsIG5ldHdvcmspYCB0byBvYnRhaW4gc2NyaXB0UHViS2V5LlxuICAgKi9cbiAgYWRkcmVzczogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIGFtb3VudCBpbiBzYXRvc2hpLlxuICAgKi9cbiAgdmFsdWU6IFROdW1iZXI7XG59XG5cbi8qKlxuICogQHJldHVybiBUeE91dHB1dCBmcm9tIFVuc3BlbnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvT3V0cHV0PFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KHU6IFVuc3BlbnQ8VE51bWJlcj4sIG5ldHdvcms6IE5ldHdvcmspOiBUeE91dHB1dDxUTnVtYmVyPiB7XG4gIHJldHVybiB7XG4gICAgc2NyaXB0OiB0b091dHB1dFNjcmlwdCh1LmFkZHJlc3MsIG5ldHdvcmspLFxuICAgIHZhbHVlOiB1LnZhbHVlLFxuICB9O1xufVxuXG4vKipcbiAqIEBwYXJhbSBvdXRwdXRJZFxuICogQHJldHVybiBUeE91dFBvaW50XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZU91dHB1dElkKG91dHB1dElkOiBzdHJpbmcpOiBUeE91dFBvaW50IHtcbiAgY29uc3QgcGFydHMgPSBvdXRwdXRJZC5zcGxpdCgnOicpO1xuICBpZiAocGFydHMubGVuZ3RoICE9PSAyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIG91dHB1dElkLCBtdXN0IGhhdmUgZm9ybWF0IHR4aWQ6dm91dGApO1xuICB9XG4gIGNvbnN0IFt0eGlkLCB2b3V0U3RyXSA9IHBhcnRzO1xuICBjb25zdCB2b3V0ID0gTnVtYmVyKHZvdXRTdHIpO1xuICBpZiAodHhpZC5sZW5ndGggIT09IDY0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIHR4aWQgJHt0eGlkfSAke3R4aWQubGVuZ3RofWApO1xuICB9XG4gIGlmIChOdW1iZXIuaXNOYU4odm91dCkgfHwgdm91dCA8IDAgfHwgIU51bWJlci5pc1NhZmVJbnRlZ2VyKHZvdXQpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIHZvdXQ6IG11c3QgYmUgaW50ZWdlciA+PSAwYCk7XG4gIH1cbiAgcmV0dXJuIHsgdHhpZCwgdm91dCB9O1xufVxuXG4vKipcbiAqIEBwYXJhbSB0eGlkXG4gKiBAcGFyYW0gdm91dFxuICogQHJldHVybiBvdXRwdXRJZFxuICovXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0T3V0cHV0SWQoeyB0eGlkLCB2b3V0IH06IFR4T3V0UG9pbnQpOiBzdHJpbmcge1xuICByZXR1cm4gYCR7dHhpZH06JHt2b3V0fWA7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRPdXRwdXRJZEZvcklucHV0KGk6IHsgaGFzaDogQnVmZmVyOyBpbmRleDogbnVtYmVyIH0pOiBUeE91dFBvaW50IHtcbiAgcmV0dXJuIHtcbiAgICB0eGlkOiBCdWZmZXIuZnJvbShpLmhhc2gpLnJldmVyc2UoKS50b1N0cmluZygnaGV4JyksXG4gICAgdm91dDogaS5pbmRleCxcbiAgfTtcbn1cblxuLyoqXG4gKiBSZWZlcmVuY2UgdG8gb3V0cHV0IG9mIGFuIGV4aXN0aW5nIHRyYW5zYWN0aW9uXG4gKi9cbmV4cG9ydCB0eXBlIFR4T3V0UG9pbnQgPSB7XG4gIHR4aWQ6IHN0cmluZztcbiAgdm91dDogbnVtYmVyO1xufTtcblxuLyoqXG4gKiBPdXRwdXQgcmVmZXJlbmNlIGFuZCBzY3JpcHQgZGF0YS5cbiAqIFN1aXRhYmxlIGZvciB1c2UgZm9yIGB0eGIuYWRkSW5wdXQoKWBcbiAqL1xuZXhwb3J0IHR5cGUgUHJldk91dHB1dDxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiA9IFR4T3V0UG9pbnQgJiBUeE91dHB1dDxUTnVtYmVyPjtcblxuLyoqXG4gKiBAcmV0dXJuIFByZXZPdXRwdXQgZnJvbSBVbnNwZW50XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0b1ByZXZPdXRwdXQ8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIHU6IFVuc3BlbnQ8VE51bWJlcj4sXG4gIG5ldHdvcms6IE5ldHdvcmtcbik6IFByZXZPdXRwdXQ8VE51bWJlcj4ge1xuICByZXR1cm4ge1xuICAgIC4uLnBhcnNlT3V0cHV0SWQodS5pZCksXG4gICAgLi4udG9PdXRwdXQodSwgbmV0d29yayksXG4gIH07XG59XG5cbi8qKlxuICogQHBhcmFtIHR4YlxuICogQHBhcmFtIHVcbiAqIEBwYXJhbSBzZXF1ZW5jZSAtIHNlcXVlbmNlSWRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFkZFRvVHJhbnNhY3Rpb25CdWlsZGVyPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KFxuICB0eGI6IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8VE51bWJlcj4sXG4gIHU6IFVuc3BlbnQ8VE51bWJlcj4sXG4gIHNlcXVlbmNlPzogbnVtYmVyXG4pOiB2b2lkIHtcbiAgY29uc3QgeyB0eGlkLCB2b3V0LCBzY3JpcHQsIHZhbHVlIH0gPSB0b1ByZXZPdXRwdXQodSwgdHhiLm5ldHdvcmsgYXMgTmV0d29yayk7XG4gIHR4Yi5hZGRJbnB1dCh0eGlkLCB2b3V0LCBzZXF1ZW5jZSwgc2NyaXB0LCB2YWx1ZSk7XG59XG5cbi8qKlxuICogU3VtIHRoZSB2YWx1ZXMgb2YgdGhlIHVuc3BlbnRzLlxuICogVGhyb3dzIGVycm9yIGlmIHN1bSBpcyBub3QgYSBzYWZlIGludGVnZXIgdmFsdWUsIG9yIGlmIHVuc3BlbnQgYW1vdW50IHR5cGVzIGRvIG5vdCBtYXRjaCBgYW1vdW50VHlwZWBcbiAqIEBwYXJhbSB1bnNwZW50cyAtIGFycmF5IG9mIHVuc3BlbnRzIHRvIHN1bVxuICogQHBhcmFtIGFtb3VudFR5cGUgLSBleHBlY3RlZCB2YWx1ZSB0eXBlIG9mIHVuc3BlbnRzXG4gKiBAcmV0dXJuIHVuc3BlbnRTdW0gLSB0eXBlIG1hdGNoZXMgYW1vdW50VHlwZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdW5zcGVudFN1bTxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50PihcbiAgdW5zcGVudHM6IFVuc3BlbnQ8VE51bWJlcj5bXSxcbiAgYW1vdW50VHlwZTogJ251bWJlcicgfCAnYmlnaW50JyA9ICdudW1iZXInXG4pOiBUTnVtYmVyIHtcbiAgaWYgKGFtb3VudFR5cGUgPT09ICdiaWdpbnQnKSB7XG4gICAgcmV0dXJuIHVuc3BlbnRzLnJlZHVjZSgoc3VtLCB1KSA9PiBzdW0gKyAodS52YWx1ZSBhcyBiaWdpbnQpLCBCaWdJbnQoMCkpIGFzIFROdW1iZXI7XG4gIH0gZWxzZSB7XG4gICAgY29uc3Qgc3VtID0gdW5zcGVudHMucmVkdWNlKChzdW0sIHUpID0+IHN1bSArICh1LnZhbHVlIGFzIG51bWJlciksIE51bWJlcigwKSk7XG4gICAgaWYgKCFOdW1iZXIuaXNTYWZlSW50ZWdlcihzdW0pKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3Vuc3BlbnQgc3VtIGlzIG5vdCBhIHNhZmUgaW50ZWdlciBudW1iZXIsIGNvbnNpZGVyIHVzaW5nIGJpZ2ludCcpO1xuICAgIH1cbiAgICByZXR1cm4gc3VtIGFzIFROdW1iZXI7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVW5zcGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VbnNwZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHdDQUE0QztBQXVCNUM7O0dBRUc7QUFDSCxTQUFnQixRQUFRLENBQUMsQ0FBVSxFQUFFLE9BQWdCO0lBQ25ELE9BQU87UUFDTCxNQUFNLEVBQUUsd0JBQWMsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQztRQUMxQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEtBQUs7S0FDZixDQUFDO0FBQ0osQ0FBQztBQUxELDRCQUtDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBZ0IsYUFBYSxDQUFDLFFBQWdCO0lBQzVDLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbEMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLDhDQUE4QyxDQUFDLENBQUM7S0FDakU7SUFDRCxNQUFNLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUM5QixNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0IsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLEVBQUUsRUFBRTtRQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLGdCQUFnQixJQUFJLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7S0FDeEQ7SUFDRCxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDakUsTUFBTSxJQUFJLEtBQUssQ0FBQyxvQ0FBb0MsQ0FBQyxDQUFDO0tBQ3ZEO0lBQ0QsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQztBQUN4QixDQUFDO0FBZEQsc0NBY0M7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsY0FBYyxDQUFDLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBYztJQUN2RCxPQUFPLEdBQUcsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDO0FBQzNCLENBQUM7QUFGRCx3Q0FFQztBQUVELFNBQWdCLG1CQUFtQixDQUFDLENBQWtDO0lBQ3BFLE9BQU87UUFDTCxJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQztRQUNuRCxJQUFJLEVBQUUsQ0FBQyxDQUFDLEtBQUs7S0FDZCxDQUFDO0FBQ0osQ0FBQztBQUxELGtEQUtDO0FBZ0JEOztHQUVHO0FBQ0gsU0FBZ0IsWUFBWSxDQUFDLENBQVUsRUFBRSxPQUFnQjtJQUN2RCxPQUFPO1FBQ0wsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN0QixHQUFHLFFBQVEsQ0FBQyxDQUFDLEVBQUUsT0FBTyxDQUFDO0tBQ3hCLENBQUM7QUFDSixDQUFDO0FBTEQsb0NBS0M7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQUMsR0FBMkIsRUFBRSxDQUFVLEVBQUUsUUFBaUI7SUFDaEcsTUFBTSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxHQUFHLFlBQVksQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLE9BQWtCLENBQUMsQ0FBQztJQUM5RSxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztBQUNwRCxDQUFDO0FBSEQsMERBR0M7QUFFRCxTQUFnQixVQUFVLENBQUMsUUFBbUI7SUFDNUMsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDdkQsQ0FBQztBQUZELGdDQUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHhPdXRwdXQsIE5ldHdvcmsgfSBmcm9tICcuLic7XG5pbXBvcnQgeyB0b091dHB1dFNjcmlwdCB9IGZyb20gJy4uL2FkZHJlc3MnO1xuaW1wb3J0IHsgVXR4b1RyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vVXR4b1RyYW5zYWN0aW9uQnVpbGRlcic7XG5cbi8qKlxuICogUHVibGljIHVuc3BlbnQgZGF0YSBpbiBCaXRHby1zcGVjaWZpYyByZXByZXNlbnRhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBVbnNwZW50IHtcbiAgLyoqXG4gICAqIEZvcm1hdDogJHt0eGlkfToke3ZvdXR9LlxuICAgKiBVc2UgYHBhcnNlT3V0cHV0SWQoaWQpYCB0byBwYXJzZS5cbiAgICovXG4gIGlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgbmV0d29yay1zcGVjaWZpYyBlbmNvZGVkIGFkZHJlc3MuXG4gICAqIFVzZSBgdG9PdXRwdXRTY3JpcHQoYWRkcmVzcywgbmV0d29yaylgIHRvIG9idGFpbiBzY3JpcHRQdWJLZXkuXG4gICAqL1xuICBhZGRyZXNzOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgYW1vdW50IGluIHNhdG9zaGkuXG4gICAqL1xuICB2YWx1ZTogbnVtYmVyO1xufVxuXG4vKipcbiAqIEByZXR1cm4gVHhPdXRwdXQgZnJvbSBVbnNwZW50XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB0b091dHB1dCh1OiBVbnNwZW50LCBuZXR3b3JrOiBOZXR3b3JrKTogVHhPdXRwdXQge1xuICByZXR1cm4ge1xuICAgIHNjcmlwdDogdG9PdXRwdXRTY3JpcHQodS5hZGRyZXNzLCBuZXR3b3JrKSxcbiAgICB2YWx1ZTogdS52YWx1ZSxcbiAgfTtcbn1cblxuLyoqXG4gKiBAcGFyYW0gb3V0cHV0SWRcbiAqIEByZXR1cm4gVHhPdXRQb2ludFxuICovXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VPdXRwdXRJZChvdXRwdXRJZDogc3RyaW5nKTogVHhPdXRQb2ludCB7XG4gIGNvbnN0IHBhcnRzID0gb3V0cHV0SWQuc3BsaXQoJzonKTtcbiAgaWYgKHBhcnRzLmxlbmd0aCAhPT0gMikge1xuICAgIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBvdXRwdXRJZCwgbXVzdCBoYXZlIGZvcm1hdCB0eGlkOnZvdXRgKTtcbiAgfVxuICBjb25zdCBbdHhpZCwgdm91dFN0cl0gPSBwYXJ0cztcbiAgY29uc3Qgdm91dCA9IE51bWJlcih2b3V0U3RyKTtcbiAgaWYgKHR4aWQubGVuZ3RoICE9PSA2NCkge1xuICAgIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCB0eGlkICR7dHhpZH0gJHt0eGlkLmxlbmd0aH1gKTtcbiAgfVxuICBpZiAoTnVtYmVyLmlzTmFOKHZvdXQpIHx8IHZvdXQgPCAwIHx8ICFOdW1iZXIuaXNTYWZlSW50ZWdlcih2b3V0KSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCB2b3V0OiBtdXN0IGJlIGludGVnZXIgPj0gMGApO1xuICB9XG4gIHJldHVybiB7IHR4aWQsIHZvdXQgfTtcbn1cblxuLyoqXG4gKiBAcGFyYW0gdHhpZFxuICogQHBhcmFtIHZvdXRcbiAqIEByZXR1cm4gb3V0cHV0SWRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdE91dHB1dElkKHsgdHhpZCwgdm91dCB9OiBUeE91dFBvaW50KTogc3RyaW5nIHtcbiAgcmV0dXJuIGAke3R4aWR9OiR7dm91dH1gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0T3V0cHV0SWRGb3JJbnB1dChpOiB7IGhhc2g6IEJ1ZmZlcjsgaW5kZXg6IG51bWJlciB9KTogVHhPdXRQb2ludCB7XG4gIHJldHVybiB7XG4gICAgdHhpZDogQnVmZmVyLmZyb20oaS5oYXNoKS5yZXZlcnNlKCkudG9TdHJpbmcoJ2hleCcpLFxuICAgIHZvdXQ6IGkuaW5kZXgsXG4gIH07XG59XG5cbi8qKlxuICogUmVmZXJlbmNlIHRvIG91dHB1dCBvZiBhbiBleGlzdGluZyB0cmFuc2FjdGlvblxuICovXG5leHBvcnQgdHlwZSBUeE91dFBvaW50ID0ge1xuICB0eGlkOiBzdHJpbmc7XG4gIHZvdXQ6IG51bWJlcjtcbn07XG5cbi8qKlxuICogT3V0cHV0IHJlZmVyZW5jZSBhbmQgc2NyaXB0IGRhdGEuXG4gKiBTdWl0YWJsZSBmb3IgdXNlIGZvciBgdHhiLmFkZElucHV0KClgXG4gKi9cbmV4cG9ydCB0eXBlIFByZXZPdXRwdXQgPSBUeE91dFBvaW50ICYgVHhPdXRwdXQ7XG5cbi8qKlxuICogQHJldHVybiBQcmV2T3V0cHV0IGZyb20gVW5zcGVudFxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9QcmV2T3V0cHV0KHU6IFVuc3BlbnQsIG5ldHdvcms6IE5ldHdvcmspOiBQcmV2T3V0cHV0IHtcbiAgcmV0dXJuIHtcbiAgICAuLi5wYXJzZU91dHB1dElkKHUuaWQpLFxuICAgIC4uLnRvT3V0cHV0KHUsIG5ldHdvcmspLFxuICB9O1xufVxuXG4vKipcbiAqIEBwYXJhbSB0eGJcbiAqIEBwYXJhbSB1XG4gKiBAcGFyYW0gc2VxdWVuY2UgLSBzZXF1ZW5jZUlkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhZGRUb1RyYW5zYWN0aW9uQnVpbGRlcih0eGI6IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIsIHU6IFVuc3BlbnQsIHNlcXVlbmNlPzogbnVtYmVyKTogdm9pZCB7XG4gIGNvbnN0IHsgdHhpZCwgdm91dCwgc2NyaXB0LCB2YWx1ZSB9ID0gdG9QcmV2T3V0cHV0KHUsIHR4Yi5uZXR3b3JrIGFzIE5ldHdvcmspO1xuICB0eGIuYWRkSW5wdXQodHhpZCwgdm91dCwgc2VxdWVuY2UsIHNjcmlwdCwgdmFsdWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdW5zcGVudFN1bSh1bnNwZW50czogVW5zcGVudFtdKTogbnVtYmVyIHtcbiAgcmV0dXJuIHVuc3BlbnRzLnJlZHVjZSgoc3VtLCB1KSA9PiBzdW0gKyB1LnZhbHVlLCAwKTtcbn1cbiJdfQ==

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

export declare function varSliceSize(slice: Buffer): number;
export declare class UtxoTransaction<TNumber extends number | bigint = number> extends bitcoinjs.Transaction<TNumber> {
export declare class UtxoTransaction extends bitcoinjs.Transaction {
network: Network;

@@ -11,13 +11,13 @@ static SIGHASH_FORKID: number;

static SIGHASH_BITCOINCASHBIP143: number;
constructor(network: Network, transaction?: bitcoinjs.Transaction<TNumber>);
static fromBuffer<TNumber extends number | bigint = number>(buf: Buffer, noStrict: boolean, amountType?: 'number' | 'bigint', network?: Network, prevOutput?: bitcoinjs.TxOutput<TNumber>[]): UtxoTransaction<TNumber>;
constructor(network: Network, transaction?: bitcoinjs.Transaction);
static fromBuffer(buf: Buffer, noStrict: boolean, network?: Network, prevOutput?: bitcoinjs.TxOutput[]): UtxoTransaction;
addForkId(hashType: number): number;
hashForWitnessV0(inIndex: number, prevOutScript: Buffer, value: TNumber, hashType: number): Buffer;
hashForWitnessV0(inIndex: number, prevOutScript: Buffer, value: number, hashType: number): Buffer;
/**
* Calculate the hash to verify the signature against
*/
hashForSignatureByNetwork(inIndex: number, prevoutScript: Buffer, value: TNumber | undefined, hashType: number): Buffer;
hashForSignatureByNetwork(inIndex: number, prevoutScript: Buffer, value: number | undefined, hashType: number): Buffer;
hashForSignature(inIndex: number, prevOutScript: Buffer, hashType: number): Buffer;
clone(): UtxoTransaction<TNumber>;
clone(): UtxoTransaction;
}
//# sourceMappingURL=UtxoTransaction.d.ts.map

@@ -21,10 +21,7 @@ "use strict";

}
static fromBuffer(buf, noStrict, amountType = 'number', network, prevOutput) {
static fromBuffer(buf, noStrict, network, prevOutput) {
if (!network) {
throw new Error(`must provide network`);
}
if (amountType !== 'number' && (networks_1.getMainnet(network) === networks_1.networks.dash || networks_1.getMainnet(network) === networks_1.networks.zcash)) {
throw new Error('dash and zcash must use number amount type; bigint amount type is recommended for doge only');
}
return new UtxoTransaction(network, bitcoinjs.Transaction.fromBuffer(buf, noStrict, amountType));
return new UtxoTransaction(network, bitcoinjs.Transaction.fromBuffer(buf, noStrict));
}

@@ -85,2 +82,2 @@ addForkId(hashType) {

UtxoTransaction.SIGHASH_BITCOINCASHBIP143 = UtxoTransaction.SIGHASH_FORKID;
//# 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 { networks, Network, getMainnet, isBitcoinGold } 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<TNumber extends number | bigint = number> extends bitcoinjs.Transaction<TNumber> {\n  static SIGHASH_FORKID = 0x40;\n  /** @deprecated use SIGHASH_FORKID */\n  static SIGHASH_BITCOINCASHBIP143 = UtxoTransaction.SIGHASH_FORKID;\n\n  constructor(\n    public network: Network,\n    transaction: bitcoinjs.Transaction<TNumber> = new bitcoinjs.Transaction<TNumber>()\n  ) {\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<TNumber extends number | bigint = number>(\n    buf: Buffer,\n    noStrict: boolean,\n    amountType: 'number' | 'bigint' = 'number',\n    network?: Network,\n    prevOutput?: bitcoinjs.TxOutput<TNumber>[]\n  ): UtxoTransaction<TNumber> {\n    if (!network) {\n      throw new Error(`must provide network`);\n    }\n    if (amountType !== 'number' && (getMainnet(network) === networks.dash || getMainnet(network) === networks.zcash)) {\n      throw new Error('dash and zcash must use number amount type; bigint amount type is recommended for doge only');\n    }\n    return new UtxoTransaction<TNumber>(network, bitcoinjs.Transaction.fromBuffer<TNumber>(buf, noStrict, amountType));\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: TNumber, 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: TNumber | 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<TNumber> {\n    return new UtxoTransaction<TNumber>(this.network, super.clone());\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL1V0eG9UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBMkM7QUFDM0MsMkNBQTJDO0FBRTNDLDBDQUEyRTtBQUUzRSxTQUFnQixZQUFZLENBQUMsS0FBYTtJQUN4QyxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO0lBQzVCLE9BQU8sT0FBTyxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUM7QUFDakQsQ0FBQztBQUhELG9DQUdDO0FBRUQsTUFBYSxlQUFnQixTQUFRLFNBQVMsQ0FBQyxXQUFXO0lBS3hELFlBQW1CLE9BQWdCLEVBQUUsY0FBcUMsSUFBSSxTQUFTLENBQUMsV0FBVyxFQUFFO1FBQ25HLEtBQUssRUFBRSxDQUFDO1FBRFMsWUFBTyxHQUFQLE9BQU8sQ0FBUztRQUVqQyxJQUFJLENBQUMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFDbkMsSUFBSSxDQUFDLFFBQVEsR0FBRyxXQUFXLENBQUMsUUFBUSxDQUFDO1FBQ3JDLElBQUksQ0FBQyxHQUFHLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsSUFBSSxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELE1BQU0sQ0FBQyxVQUFVLENBQ2YsR0FBVyxFQUNYLFFBQWlCLEVBQ2pCLE9BQWlCLEVBQ2pCLFVBQWlDO1FBRWpDLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDWixNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLENBQUM7U0FDekM7UUFDRCxPQUFPLElBQUksZUFBZSxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRUQsU0FBUyxDQUFDLFFBQWdCO1FBQ3hCLElBQUksUUFBUSxHQUFHLGVBQWUsQ0FBQyxjQUFjLEVBQUU7WUFDN0MsTUFBTSxNQUFNLEdBQUcsd0JBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3BELE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDekM7UUFFRCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsT0FBZSxFQUFFLGFBQXFCLEVBQUUsS0FBYSxFQUFFLFFBQWdCO1FBQ3RGLE9BQU8sS0FBSyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUN6RixDQUFDO0lBRUQ7O09BRUc7SUFDSCx5QkFBeUIsQ0FDdkIsT0FBZSxFQUNmLGFBQXFCLEVBQ3JCLEtBQXlCLEVBQ3pCLFFBQWdCO1FBRWhCLFFBQVEscUJBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDaEMsS0FBSyxtQkFBUSxDQUFDLEtBQUs7Z0JBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7WUFDbkMsS0FBSyxtQkFBUSxDQUFDLFdBQVcsQ0FBQztZQUMxQixLQUFLLG1CQUFRLENBQUMsU0FBUyxDQUFDO1lBQ3hCLEtBQUssbUJBQVEsQ0FBQyxXQUFXO2dCQUN2Qjs7Ozs7OzttQkFPRztnQkFDSCxNQUFNLFNBQVMsR0FBRyxDQUFDLFFBQVEsR0FBRyxlQUFlLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUVsRSxJQUFJLFNBQVMsRUFBRTtvQkFDYjs7Ozt1QkFJRztvQkFDSCxJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7d0JBQ3ZCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztxQkFDdkM7b0JBQ0QsT0FBTyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO2lCQUN4RjtTQUNKO1FBRUQsT0FBTyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsT0FBZSxFQUFFLGFBQXFCLEVBQUUsUUFBZ0I7UUFDdkUsT0FBTyxJQUFJLENBQUMseUJBQXlCLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBUyxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztJQUM1RyxDQUFDO0lBRUQsS0FBSztRQUNILE9BQU8sSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUMxRCxDQUFDOztBQXJGSCwwQ0FzRkM7QUFyRlEsOEJBQWMsR0FBRyxJQUFJLENBQUM7QUFDN0IscUNBQXFDO0FBQzlCLHlDQUF5QixHQUFHLGVBQWUsQ0FBQyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBiaXRjb2luanMgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgKiBhcyB2YXJ1aW50IGZyb20gJ3ZhcnVpbnQtYml0Y29pbic7XG5cbmltcG9ydCB7IG5ldHdvcmtzLCBOZXR3b3JrLCBnZXRNYWlubmV0LCBpc0JpdGNvaW5Hb2xkIH0gZnJvbSAnLi4vbmV0d29ya3MnO1xuXG5leHBvcnQgZnVuY3Rpb24gdmFyU2xpY2VTaXplKHNsaWNlOiBCdWZmZXIpOiBudW1iZXIge1xuICBjb25zdCBsZW5ndGggPSBzbGljZS5sZW5ndGg7XG4gIHJldHVybiB2YXJ1aW50LmVuY29kaW5nTGVuZ3RoKGxlbmd0aCkgKyBsZW5ndGg7XG59XG5cbmV4cG9ydCBjbGFzcyBVdHhvVHJhbnNhY3Rpb24gZXh0ZW5kcyBiaXRjb2luanMuVHJhbnNhY3Rpb24ge1xuICBzdGF0aWMgU0lHSEFTSF9GT1JLSUQgPSAweDQwO1xuICAvKiogQGRlcHJlY2F0ZWQgdXNlIFNJR0hBU0hfRk9SS0lEICovXG4gIHN0YXRpYyBTSUdIQVNIX0JJVENPSU5DQVNIQklQMTQzID0gVXR4b1RyYW5zYWN0aW9uLlNJR0hBU0hfRk9SS0lEO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBuZXR3b3JrOiBOZXR3b3JrLCB0cmFuc2FjdGlvbjogYml0Y29pbmpzLlRyYW5zYWN0aW9uID0gbmV3IGJpdGNvaW5qcy5UcmFuc2FjdGlvbigpKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLnZlcnNpb24gPSB0cmFuc2FjdGlvbi52ZXJzaW9uO1xuICAgIHRoaXMubG9ja3RpbWUgPSB0cmFuc2FjdGlvbi5sb2NrdGltZTtcbiAgICB0aGlzLmlucyA9IHRyYW5zYWN0aW9uLmlucy5tYXAoKHYpID0+ICh7IC4uLnYgfSkpO1xuICAgIHRoaXMub3V0cyA9IHRyYW5zYWN0aW9uLm91dHMubWFwKCh2KSA9PiAoeyAuLi52IH0pKTtcbiAgfVxuXG4gIHN0YXRpYyBmcm9tQnVmZmVyKFxuICAgIGJ1ZjogQnVmZmVyLFxuICAgIG5vU3RyaWN0OiBib29sZWFuLFxuICAgIG5ldHdvcms/OiBOZXR3b3JrLFxuICAgIHByZXZPdXRwdXQ/OiBiaXRjb2luanMuVHhPdXRwdXRbXVxuICApOiBVdHhvVHJhbnNhY3Rpb24ge1xuICAgIGlmICghbmV0d29yaykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBtdXN0IHByb3ZpZGUgbmV0d29ya2ApO1xuICAgIH1cbiAgICByZXR1cm4gbmV3IFV0eG9UcmFuc2FjdGlvbihuZXR3b3JrLCBiaXRjb2luanMuVHJhbnNhY3Rpb24uZnJvbUJ1ZmZlcihidWYsIG5vU3RyaWN0KSk7XG4gIH1cblxuICBhZGRGb3JrSWQoaGFzaFR5cGU6IG51bWJlcik6IG51bWJlciB7XG4gICAgaWYgKGhhc2hUeXBlICYgVXR4b1RyYW5zYWN0aW9uLlNJR0hBU0hfRk9SS0lEKSB7XG4gICAgICBjb25zdCBmb3JrSWQgPSBpc0JpdGNvaW5Hb2xkKHRoaXMubmV0d29yaykgPyA3OSA6IDA7XG4gICAgICByZXR1cm4gKGhhc2hUeXBlIHwgKGZvcmtJZCA8PCA4KSkgPj4+IDA7XG4gICAgfVxuXG4gICAgcmV0dXJuIGhhc2hUeXBlO1xuICB9XG5cbiAgaGFzaEZvcldpdG5lc3NWMChpbkluZGV4OiBudW1iZXIsIHByZXZPdXRTY3JpcHQ6IEJ1ZmZlciwgdmFsdWU6IG51bWJlciwgaGFzaFR5cGU6IG51bWJlcik6IEJ1ZmZlciB7XG4gICAgcmV0dXJuIHN1cGVyLmhhc2hGb3JXaXRuZXNzVjAoaW5JbmRleCwgcHJldk91dFNjcmlwdCwgdmFsdWUsIHRoaXMuYWRkRm9ya0lkKGhhc2hUeXBlKSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FsY3VsYXRlIHRoZSBoYXNoIHRvIHZlcmlmeSB0aGUgc2lnbmF0dXJlIGFnYWluc3RcbiAgICovXG4gIGhhc2hGb3JTaWduYXR1cmVCeU5ldHdvcmsoXG4gICAgaW5JbmRleDogbnVtYmVyLFxuICAgIHByZXZvdXRTY3JpcHQ6IEJ1ZmZlcixcbiAgICB2YWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkLFxuICAgIGhhc2hUeXBlOiBudW1iZXJcbiAgKTogQnVmZmVyIHtcbiAgICBzd2l0Y2ggKGdldE1haW5uZXQodGhpcy5uZXR3b3JrKSkge1xuICAgICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBpbGxlZ2FsIHN0YXRlYCk7XG4gICAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5nb2xkOlxuICAgICAgICAvKlxuICAgICAgICAgIEJpdGNvaW4gQ2FzaCBzdXBwb3J0cyBhIEZPUktJRCBmbGFnLiBXaGVuIHNldCwgd2UgaGFzaCB1c2luZyBoYXNoaW5nIGFsZ29yaXRobVxuICAgICAgICAgICB0aGF0IGlzIHVzZWQgZm9yIHNlZ3JlZ2F0ZWQgd2l0bmVzcyB0cmFuc2FjdGlvbnMgKGRlZmluZWQgaW4gQklQMTQzKS5cblxuICAgICAgICAgIFRoZSBmbGFnIGlzIGFsc28gdXNlZCBieSBCaXRjb2luU1YgYW5kIEJpdGNvaW5Hb2xkXG5cbiAgICAgICAgICBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbmNhc2hvcmcvYml0Y29pbmNhc2gub3JnL2Jsb2IvbWFzdGVyL3NwZWMvcmVwbGF5LXByb3RlY3RlZC1zaWdoYXNoLm1kXG4gICAgICAgICAqL1xuICAgICAgICBjb25zdCBhZGRGb3JrSWQgPSAoaGFzaFR5cGUgJiBVdHhvVHJhbnNhY3Rpb24uU0lHSEFTSF9GT1JLSUQpID4gMDtcblxuICAgICAgICBpZiAoYWRkRm9ya0lkKSB7XG4gICAgICAgICAgLypcbiAgICAgICAgICAgIGBgVGhlIHNpZ2hhc2ggdHlwZSBpcyBhbHRlcmVkIHRvIGluY2x1ZGUgYSAyNC1iaXQgZm9yayBpZCBpbiBpdHMgbW9zdCBzaWduaWZpY2FudCBiaXRzLicnXG4gICAgICAgICAgICBXZSBhbHNvIHVzZSB1bnNpZ25lZCByaWdodCBzaGlmdCBvcGVyYXRvciBgPj4+YCB0byBjYXN0IHRvIFVJbnQzMlxuICAgICAgICAgICAgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSmF2YVNjcmlwdC9SZWZlcmVuY2UvT3BlcmF0b3JzL1Vuc2lnbmVkX3JpZ2h0X3NoaWZ0XG4gICAgICAgICAgICovXG4gICAgICAgICAgaWYgKHZhbHVlID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgbXVzdCBwcm92aWRlIHZhbHVlYCk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiBzdXBlci5oYXNoRm9yV2l0bmVzc1YwKGluSW5kZXgsIHByZXZvdXRTY3JpcHQsIHZhbHVlLCB0aGlzLmFkZEZvcmtJZChoYXNoVHlwZSkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHN1cGVyLmhhc2hGb3JTaWduYXR1cmUoaW5JbmRleCwgcHJldm91dFNjcmlwdCwgaGFzaFR5cGUpO1xuICB9XG5cbiAgaGFzaEZvclNpZ25hdHVyZShpbkluZGV4OiBudW1iZXIsIHByZXZPdXRTY3JpcHQ6IEJ1ZmZlciwgaGFzaFR5cGU6IG51bWJlcik6IEJ1ZmZlciB7XG4gICAgcmV0dXJuIHRoaXMuaGFzaEZvclNpZ25hdHVyZUJ5TmV0d29yayhpbkluZGV4LCBwcmV2T3V0U2NyaXB0LCAodGhpcy5pbnNbaW5JbmRleF0gYXMgYW55KS52YWx1ZSwgaGFzaFR5cGUpO1xuICB9XG5cbiAgY2xvbmUoKTogVXR4b1RyYW5zYWN0aW9uIHtcbiAgICByZXR1cm4gbmV3IFV0eG9UcmFuc2FjdGlvbih0aGlzLm5ldHdvcmssIHN1cGVyLmNsb25lKCkpO1xuICB9XG59XG4iXX0=

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

import { UtxoTransaction } from './UtxoTransaction';
export interface TxbSignArg<TNumber extends number | bigint = number> {
export interface TxbSignArg {
prevOutScriptType: string;

@@ -13,15 +13,15 @@ vin: number;

hashType?: number;
witnessValue?: TNumber;
witnessValue?: number;
witnessScript?: Buffer;
controlBlock?: Buffer;
}
export declare class UtxoTransactionBuilder<TNumber extends number | bigint = number, T extends UtxoTransaction<TNumber> = UtxoTransaction<TNumber>> extends TransactionBuilder<TNumber> {
constructor(network: Network, txb?: TransactionBuilder<TNumber>, prevOutputs?: TxOutput<TNumber>[]);
createInitialTransaction(network: Network, tx?: Transaction<TNumber>): UtxoTransaction<TNumber>;
static fromTransaction<TNumber extends number | bigint = number>(tx: UtxoTransaction<TNumber>, network?: bitcoinjs.Network, prevOutputs?: TxOutput<TNumber>[]): UtxoTransactionBuilder<TNumber>;
export declare class UtxoTransactionBuilder<T extends UtxoTransaction = UtxoTransaction> extends TransactionBuilder {
constructor(network: Network, txb?: TransactionBuilder, prevOutputs?: TxOutput[]);
createInitialTransaction(network: Network, tx?: Transaction): UtxoTransaction;
static fromTransaction(tx: UtxoTransaction, network?: bitcoinjs.Network, prevOutputs?: TxOutput[]): UtxoTransactionBuilder;
get tx(): T;
build(): T;
buildIncomplete(): T;
sign(signParams: number | TxbSignArg<TNumber>, keyPair?: bitcoinjs.ECPair.Signer, redeemScript?: Buffer, hashType?: number, witnessValue?: TNumber, witnessScript?: Buffer): void;
sign(signParams: number | TxbSignArg, keyPair?: bitcoinjs.ECPair.Signer, redeemScript?: Buffer, hashType?: number, witnessValue?: number, witnessScript?: Buffer): void;
}
//# sourceMappingURL=UtxoTransactionBuilder.d.ts.map

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

if (typeof signParams === 'number') {
if (typeof witnessValue === 'number' || typeof witnessValue === 'bigint') {
if (typeof witnessValue === 'number') {
this.tx.ins[signParams].value = witnessValue;

@@ -66,2 +66,2 @@ }

exports.UtxoTransactionBuilder = UtxoTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlEQUEwRTtBQUkxRSx1REFBb0Q7QUFhcEQsTUFBYSxzQkFHWCxTQUFRLGtDQUEyQjtJQUNuQyxZQUFZLE9BQWdCLEVBQUUsR0FBaUMsRUFBRSxXQUFpQzs7UUFDaEcsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQTRCLENBQUM7UUFFM0MsSUFBWSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsT0FBTyxFQUFFLE1BQUMsR0FBVywwQ0FBRSxJQUFJLENBQUMsQ0FBQztRQUVoRixJQUFJLEdBQUcsRUFBRTtZQUNOLElBQVksQ0FBQyxRQUFRLEdBQUksR0FBVyxDQUFDLFFBQVEsQ0FBQztTQUNoRDtRQUVELElBQUksV0FBVyxFQUFFO1lBQ2YsTUFBTSxTQUFTLEdBQUksSUFBWSxDQUFDLFFBQVEsQ0FBQztZQUN6QyxJQUFJLFdBQVcsQ0FBQyxNQUFNLEtBQUssU0FBUyxDQUFDLE1BQU0sRUFBRTtnQkFDM0MsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDO2FBQ3hEO1lBQ0QsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDM0IsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDO2dCQUM3QixTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7WUFDeEMsQ0FBQyxDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxPQUFnQixFQUFFLEVBQXlCO1FBQ2xFLE9BQU8sSUFBSSxpQ0FBZSxDQUFVLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRUQsTUFBTSxDQUFDLGVBQWUsQ0FDcEIsRUFBNEIsRUFDNUIsT0FBMkIsRUFDM0IsV0FBaUM7UUFFakMsT0FBTyxJQUFJLHNCQUFzQixDQUMvQixFQUFFLENBQUMsT0FBTyxFQUNWLGtDQUFrQixDQUFDLGVBQWUsQ0FBVSxFQUFFLENBQUMsRUFDL0MsV0FBVyxDQUNaLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxFQUFFO1FBQ0osT0FBUSxJQUFZLENBQUMsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLO1FBQ0gsT0FBTyxLQUFLLENBQUMsS0FBSyxFQUFPLENBQUM7SUFDNUIsQ0FBQztJQUVELGVBQWU7UUFDYixPQUFPLEtBQUssQ0FBQyxlQUFlLEVBQU8sQ0FBQztJQUN0QyxDQUFDO0lBRUQsSUFBSSxDQUNGLFVBQXdDLEVBQ3hDLE9BQWlDLEVBQ2pDLFlBQXFCLEVBQ3JCLFFBQWlCLEVBQ2pCLFlBQXNCLEVBQ3RCLGFBQXNCO1FBRXRCLGdHQUFnRztRQUNoRyx1REFBdUQ7UUFDdkQsNkZBQTZGO1FBQzdGLDJGQUEyRjtRQUMzRixtQ0FBbUM7UUFFbkMsSUFBSSxPQUFPLFVBQVUsS0FBSyxRQUFRLEVBQUU7WUFDbEMsSUFBSSxPQUFPLFlBQVksS0FBSyxRQUFRLElBQUksT0FBTyxZQUFZLEtBQUssUUFBUSxFQUFFO2dCQUN2RSxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQVMsQ0FBQyxLQUFLLEdBQUcsWUFBWSxDQUFDO2FBQ3ZEO1lBRUQsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsYUFBYSxDQUFDLENBQUM7U0FDN0Y7UUFFRCxJQUFJLFVBQVUsQ0FBQyxZQUFZLEtBQUssU0FBUyxFQUFFO1lBQ3hDLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQVMsQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDLFlBQVksQ0FBQztTQUN0RTtRQUNELCtGQUErRjtRQUMvRix3Q0FBd0M7UUFDeEMsSUFBSSxVQUFVLENBQUMsaUJBQWlCLEtBQUssV0FBVyxFQUFFO1lBQ2hELE9BQU8sVUFBVSxDQUFDLFlBQVksQ0FBQztTQUNoQztRQUNELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNoQyxDQUFDO0NBQ0Y7QUF0RkQsd0RBc0ZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHhPdXRwdXQsIFRyYW5zYWN0aW9uLCBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICdiaXRjb2luanMtbGliJztcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuaW1wb3J0ICogYXMgYml0Y29pbmpzIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuaW1wb3J0IHsgTmV0d29yayB9IGZyb20gJy4uJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4vVXR4b1RyYW5zYWN0aW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBUeGJTaWduQXJnPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQgPSBudW1iZXI+IHtcbiAgcHJldk91dFNjcmlwdFR5cGU6IHN0cmluZztcbiAgdmluOiBudW1iZXI7XG4gIGtleVBhaXI6IGJpdGNvaW5qcy5FQ1BhaXIuU2lnbmVyO1xuICByZWRlZW1TY3JpcHQ/OiBCdWZmZXI7XG4gIGhhc2hUeXBlPzogbnVtYmVyO1xuICB3aXRuZXNzVmFsdWU/OiBUTnVtYmVyO1xuICB3aXRuZXNzU2NyaXB0PzogQnVmZmVyO1xuICBjb250cm9sQmxvY2s/OiBCdWZmZXI7XG59XG5cbmV4cG9ydCBjbGFzcyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyPFxuICBUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyLFxuICBUIGV4dGVuZHMgVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+ID0gVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+XG4+IGV4dGVuZHMgVHJhbnNhY3Rpb25CdWlsZGVyPFROdW1iZXI+IHtcbiAgY29uc3RydWN0b3IobmV0d29yazogTmV0d29yaywgdHhiPzogVHJhbnNhY3Rpb25CdWlsZGVyPFROdW1iZXI+LCBwcmV2T3V0cHV0cz86IFR4T3V0cHV0PFROdW1iZXI+W10pIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMubmV0d29yayA9IG5ldHdvcmsgYXMgYml0Y29pbmpzLk5ldHdvcms7XG5cbiAgICAodGhpcyBhcyBhbnkpLl9fVFggPSB0aGlzLmNyZWF0ZUluaXRpYWxUcmFuc2FjdGlvbihuZXR3b3JrLCAodHhiIGFzIGFueSk/Ll9fVFgpO1xuXG4gICAgaWYgKHR4Yikge1xuICAgICAgKHRoaXMgYXMgYW55KS5fX0lOUFVUUyA9ICh0eGIgYXMgYW55KS5fX0lOUFVUUztcbiAgICB9XG5cbiAgICBpZiAocHJldk91dHB1dHMpIHtcbiAgICAgIGNvbnN0IHR4YklucHV0cyA9ICh0aGlzIGFzIGFueSkuX19JTlBVVFM7XG4gICAgICBpZiAocHJldk91dHB1dHMubGVuZ3RoICE9PSB0eGJJbnB1dHMubGVuZ3RoKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgcHJldk91dHMgbXVzdCBtYXRjaCB0eGJJbnB1dCBsZW5ndGhgKTtcbiAgICAgIH1cbiAgICAgIHByZXZPdXRwdXRzLmZvckVhY2goKG8sIGkpID0+IHtcbiAgICAgICAgdHhiSW5wdXRzW2ldLnZhbHVlID0gby52YWx1ZTtcbiAgICAgICAgdHhiSW5wdXRzW2ldLnByZXZPdXRTY3JpcHQgPSBvLnNjcmlwdDtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIGNyZWF0ZUluaXRpYWxUcmFuc2FjdGlvbihuZXR3b3JrOiBOZXR3b3JrLCB0eD86IFRyYW5zYWN0aW9uPFROdW1iZXI+KTogVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+IHtcbiAgICByZXR1cm4gbmV3IFV0eG9UcmFuc2FjdGlvbjxUTnVtYmVyPihuZXR3b3JrLCB0eCk7XG4gIH1cblxuICBzdGF0aWMgZnJvbVRyYW5zYWN0aW9uPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQgPSBudW1iZXI+KFxuICAgIHR4OiBVdHhvVHJhbnNhY3Rpb248VE51bWJlcj4sXG4gICAgbmV0d29yaz86IGJpdGNvaW5qcy5OZXR3b3JrLFxuICAgIHByZXZPdXRwdXRzPzogVHhPdXRwdXQ8VE51bWJlcj5bXVxuICApOiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyPFROdW1iZXI+IHtcbiAgICByZXR1cm4gbmV3IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8VE51bWJlcj4oXG4gICAgICB0eC5uZXR3b3JrLFxuICAgICAgVHJhbnNhY3Rpb25CdWlsZGVyLmZyb21UcmFuc2FjdGlvbjxUTnVtYmVyPih0eCksXG4gICAgICBwcmV2T3V0cHV0c1xuICAgICk7XG4gIH1cblxuICBnZXQgdHgoKTogVCB7XG4gICAgcmV0dXJuICh0aGlzIGFzIGFueSkuX19UWDtcbiAgfVxuXG4gIGJ1aWxkKCk6IFQge1xuICAgIHJldHVybiBzdXBlci5idWlsZCgpIGFzIFQ7XG4gIH1cblxuICBidWlsZEluY29tcGxldGUoKTogVCB7XG4gICAgcmV0dXJuIHN1cGVyLmJ1aWxkSW5jb21wbGV0ZSgpIGFzIFQ7XG4gIH1cblxuICBzaWduKFxuICAgIHNpZ25QYXJhbXM6IG51bWJlciB8IFR4YlNpZ25Bcmc8VE51bWJlcj4sXG4gICAga2V5UGFpcj86IGJpdGNvaW5qcy5FQ1BhaXIuU2lnbmVyLFxuICAgIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcixcbiAgICBoYXNoVHlwZT86IG51bWJlcixcbiAgICB3aXRuZXNzVmFsdWU/OiBUTnVtYmVyLFxuICAgIHdpdG5lc3NTY3JpcHQ/OiBCdWZmZXJcbiAgKTogdm9pZCB7XG4gICAgLy8gUmVndWxhciBiaXRjb2luIHAyc2gtcDJtcyBpbnB1dHMgZG8gbm90IGluY2x1ZGUgdGhlIGlucHV0IGFtb3VudCAodmFsdWUpIGluIHRoZSBzaWduYXR1cmUgYW5kXG4gICAgLy8gdGh1cyBkbyBub3QgcmVxdWlyZSB0aGUgcGFyYW1ldGVyIGB2YWx1ZWAgdG8gYmUgc2V0LlxuICAgIC8vIEZvciBiaXRjb2luY2FzaCBhbmQgYml0Y29pbnN2IHAyc2gtcDJtcyBpbnB1dHMsIHRoZSB2YWx1ZSBwYXJhbWV0ZXIgKmlzKiByZXF1aXJlZCBob3dldmVyLlxuICAgIC8vIFNpbmNlIHRoZSBgdmFsdWVgIHBhcmFtZXRlciBpcyBub3QgcGFzc2VkIHRvIHRoZSBsZWdhY3kgaGFzaGluZyBtZXRob2QsIHdlIG11c3Qgc3RvcmUgaXRcbiAgICAvLyBvbiB0aGUgdHJhbnNhY3Rpb24gaW5wdXQgb2JqZWN0LlxuXG4gICAgaWYgKHR5cGVvZiBzaWduUGFyYW1zID09PSAnbnVtYmVyJykge1xuICAgICAgaWYgKHR5cGVvZiB3aXRuZXNzVmFsdWUgPT09ICdudW1iZXInIHx8IHR5cGVvZiB3aXRuZXNzVmFsdWUgPT09ICdiaWdpbnQnKSB7XG4gICAgICAgICh0aGlzLnR4Lmluc1tzaWduUGFyYW1zXSBhcyBhbnkpLnZhbHVlID0gd2l0bmVzc1ZhbHVlO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gc3VwZXIuc2lnbihzaWduUGFyYW1zLCBrZXlQYWlyLCByZWRlZW1TY3JpcHQsIGhhc2hUeXBlLCB3aXRuZXNzVmFsdWUsIHdpdG5lc3NTY3JpcHQpO1xuICAgIH1cblxuICAgIGlmIChzaWduUGFyYW1zLndpdG5lc3NWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAodGhpcy50eC5pbnNbc2lnblBhcmFtcy52aW5dIGFzIGFueSkudmFsdWUgPSBzaWduUGFyYW1zLndpdG5lc3NWYWx1ZTtcbiAgICB9XG4gICAgLy8gV2hlbiBjYWxsaW5nIHRoZSBzaWduIG1ldGhvZCB2aWEgVHhiU2lnbkFyZywgdGhlIGB2YWx1ZWAgcGFyYW1ldGVyIGlzIGFjdHVhbGx5IG5vdCBwZXJtaXR0ZWRcbiAgICAvLyB0byBiZSBzZXQgZm9yIHAyc2gtcDJtcyB0cmFuc2FjdGlvbnMuXG4gICAgaWYgKHNpZ25QYXJhbXMucHJldk91dFNjcmlwdFR5cGUgPT09ICdwMnNoLXAybXMnKSB7XG4gICAgICBkZWxldGUgc2lnblBhcmFtcy53aXRuZXNzVmFsdWU7XG4gICAgfVxuICAgIHJldHVybiBzdXBlci5zaWduKHNpZ25QYXJhbXMpO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVXR4b1RyYW5zYWN0aW9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlEQUEwRTtBQUkxRSx1REFBb0Q7QUFhcEQsTUFBYSxzQkFBb0UsU0FBUSxrQ0FBa0I7SUFDekcsWUFBWSxPQUFnQixFQUFFLEdBQXdCLEVBQUUsV0FBd0I7O1FBQzlFLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUE0QixDQUFDO1FBRTNDLElBQVksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUFDLE9BQU8sRUFBRSxNQUFDLEdBQVcsMENBQUUsSUFBSSxDQUFDLENBQUM7UUFFaEYsSUFBSSxHQUFHLEVBQUU7WUFDTixJQUFZLENBQUMsUUFBUSxHQUFJLEdBQVcsQ0FBQyxRQUFRLENBQUM7U0FDaEQ7UUFFRCxJQUFJLFdBQVcsRUFBRTtZQUNmLE1BQU0sU0FBUyxHQUFJLElBQVksQ0FBQyxRQUFRLENBQUM7WUFDekMsSUFBSSxXQUFXLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQyxNQUFNLEVBQUU7Z0JBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLENBQUMsQ0FBQzthQUN4RDtZQUNELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQzNCLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQztnQkFDN0IsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO1lBQ3hDLENBQUMsQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDO0lBRUQsd0JBQXdCLENBQUMsT0FBZ0IsRUFBRSxFQUFnQjtRQUN6RCxPQUFPLElBQUksaUNBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELE1BQU0sQ0FBQyxlQUFlLENBQ3BCLEVBQW1CLEVBQ25CLE9BQTJCLEVBQzNCLFdBQXdCO1FBRXhCLE9BQU8sSUFBSSxzQkFBc0IsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLGtDQUFrQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyRyxDQUFDO0lBRUQsSUFBSSxFQUFFO1FBQ0osT0FBUSxJQUFZLENBQUMsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLO1FBQ0gsT0FBTyxLQUFLLENBQUMsS0FBSyxFQUFPLENBQUM7SUFDNUIsQ0FBQztJQUVELGVBQWU7UUFDYixPQUFPLEtBQUssQ0FBQyxlQUFlLEVBQU8sQ0FBQztJQUN0QyxDQUFDO0lBRUQsSUFBSSxDQUNGLFVBQStCLEVBQy9CLE9BQWlDLEVBQ2pDLFlBQXFCLEVBQ3JCLFFBQWlCLEVBQ2pCLFlBQXFCLEVBQ3JCLGFBQXNCO1FBRXRCLGdHQUFnRztRQUNoRyx1REFBdUQ7UUFDdkQsNkZBQTZGO1FBQzdGLDJGQUEyRjtRQUMzRixtQ0FBbUM7UUFFbkMsSUFBSSxPQUFPLFVBQVUsS0FBSyxRQUFRLEVBQUU7WUFDbEMsSUFBSSxPQUFPLFlBQVksS0FBSyxRQUFRLEVBQUU7Z0JBQ25DLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBUyxDQUFDLEtBQUssR0FBRyxZQUFZLENBQUM7YUFDdkQ7WUFFRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBRSxhQUFhLENBQUMsQ0FBQztTQUM3RjtRQUVELElBQUksVUFBVSxDQUFDLFlBQVksS0FBSyxTQUFTLEVBQUU7WUFDeEMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBUyxDQUFDLEtBQUssR0FBRyxVQUFVLENBQUMsWUFBWSxDQUFDO1NBQ3RFO1FBQ0QsK0ZBQStGO1FBQy9GLHdDQUF3QztRQUN4QyxJQUFJLFVBQVUsQ0FBQyxpQkFBaUIsS0FBSyxXQUFXLEVBQUU7WUFDaEQsT0FBTyxVQUFVLENBQUMsWUFBWSxDQUFDO1NBQ2hDO1FBQ0QsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDRjtBQS9FRCx3REErRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeE91dHB1dCwgVHJhbnNhY3Rpb24sIFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJ2JpdGNvaW5qcy1saWInO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lXG5pbXBvcnQgKiBhcyBiaXRjb2luanMgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSAnLi4nO1xuaW1wb3J0IHsgVXR4b1RyYW5zYWN0aW9uIH0gZnJvbSAnLi9VdHhvVHJhbnNhY3Rpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR4YlNpZ25Bcmcge1xuICBwcmV2T3V0U2NyaXB0VHlwZTogc3RyaW5nO1xuICB2aW46IG51bWJlcjtcbiAga2V5UGFpcjogYml0Y29pbmpzLkVDUGFpci5TaWduZXI7XG4gIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcjtcbiAgaGFzaFR5cGU/OiBudW1iZXI7XG4gIHdpdG5lc3NWYWx1ZT86IG51bWJlcjtcbiAgd2l0bmVzc1NjcmlwdD86IEJ1ZmZlcjtcbiAgY29udHJvbEJsb2NrPzogQnVmZmVyO1xufVxuXG5leHBvcnQgY2xhc3MgVXR4b1RyYW5zYWN0aW9uQnVpbGRlcjxUIGV4dGVuZHMgVXR4b1RyYW5zYWN0aW9uID0gVXR4b1RyYW5zYWN0aW9uPiBleHRlbmRzIFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gIGNvbnN0cnVjdG9yKG5ldHdvcms6IE5ldHdvcmssIHR4Yj86IFRyYW5zYWN0aW9uQnVpbGRlciwgcHJldk91dHB1dHM/OiBUeE91dHB1dFtdKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLm5ldHdvcmsgPSBuZXR3b3JrIGFzIGJpdGNvaW5qcy5OZXR3b3JrO1xuXG4gICAgKHRoaXMgYXMgYW55KS5fX1RYID0gdGhpcy5jcmVhdGVJbml0aWFsVHJhbnNhY3Rpb24obmV0d29yaywgKHR4YiBhcyBhbnkpPy5fX1RYKTtcblxuICAgIGlmICh0eGIpIHtcbiAgICAgICh0aGlzIGFzIGFueSkuX19JTlBVVFMgPSAodHhiIGFzIGFueSkuX19JTlBVVFM7XG4gICAgfVxuXG4gICAgaWYgKHByZXZPdXRwdXRzKSB7XG4gICAgICBjb25zdCB0eGJJbnB1dHMgPSAodGhpcyBhcyBhbnkpLl9fSU5QVVRTO1xuICAgICAgaWYgKHByZXZPdXRwdXRzLmxlbmd0aCAhPT0gdHhiSW5wdXRzLmxlbmd0aCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHByZXZPdXRzIG11c3QgbWF0Y2ggdHhiSW5wdXQgbGVuZ3RoYCk7XG4gICAgICB9XG4gICAgICBwcmV2T3V0cHV0cy5mb3JFYWNoKChvLCBpKSA9PiB7XG4gICAgICAgIHR4YklucHV0c1tpXS52YWx1ZSA9IG8udmFsdWU7XG4gICAgICAgIHR4YklucHV0c1tpXS5wcmV2T3V0U2NyaXB0ID0gby5zY3JpcHQ7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBjcmVhdGVJbml0aWFsVHJhbnNhY3Rpb24obmV0d29yazogTmV0d29yaywgdHg/OiBUcmFuc2FjdGlvbik6IFV0eG9UcmFuc2FjdGlvbiB7XG4gICAgcmV0dXJuIG5ldyBVdHhvVHJhbnNhY3Rpb24obmV0d29yaywgdHgpO1xuICB9XG5cbiAgc3RhdGljIGZyb21UcmFuc2FjdGlvbihcbiAgICB0eDogVXR4b1RyYW5zYWN0aW9uLFxuICAgIG5ldHdvcms/OiBiaXRjb2luanMuTmV0d29yayxcbiAgICBwcmV2T3V0cHV0cz86IFR4T3V0cHV0W11cbiAgKTogVXR4b1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgcmV0dXJuIG5ldyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyKHR4Lm5ldHdvcmssIFRyYW5zYWN0aW9uQnVpbGRlci5mcm9tVHJhbnNhY3Rpb24odHgpLCBwcmV2T3V0cHV0cyk7XG4gIH1cblxuICBnZXQgdHgoKTogVCB7XG4gICAgcmV0dXJuICh0aGlzIGFzIGFueSkuX19UWDtcbiAgfVxuXG4gIGJ1aWxkKCk6IFQge1xuICAgIHJldHVybiBzdXBlci5idWlsZCgpIGFzIFQ7XG4gIH1cblxuICBidWlsZEluY29tcGxldGUoKTogVCB7XG4gICAgcmV0dXJuIHN1cGVyLmJ1aWxkSW5jb21wbGV0ZSgpIGFzIFQ7XG4gIH1cblxuICBzaWduKFxuICAgIHNpZ25QYXJhbXM6IG51bWJlciB8IFR4YlNpZ25BcmcsXG4gICAga2V5UGFpcj86IGJpdGNvaW5qcy5FQ1BhaXIuU2lnbmVyLFxuICAgIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcixcbiAgICBoYXNoVHlwZT86IG51bWJlcixcbiAgICB3aXRuZXNzVmFsdWU/OiBudW1iZXIsXG4gICAgd2l0bmVzc1NjcmlwdD86IEJ1ZmZlclxuICApOiB2b2lkIHtcbiAgICAvLyBSZWd1bGFyIGJpdGNvaW4gcDJzaC1wMm1zIGlucHV0cyBkbyBub3QgaW5jbHVkZSB0aGUgaW5wdXQgYW1vdW50ICh2YWx1ZSkgaW4gdGhlIHNpZ25hdHVyZSBhbmRcbiAgICAvLyB0aHVzIGRvIG5vdCByZXF1aXJlIHRoZSBwYXJhbWV0ZXIgYHZhbHVlYCB0byBiZSBzZXQuXG4gICAgLy8gRm9yIGJpdGNvaW5jYXNoIGFuZCBiaXRjb2luc3YgcDJzaC1wMm1zIGlucHV0cywgdGhlIHZhbHVlIHBhcmFtZXRlciAqaXMqIHJlcXVpcmVkIGhvd2V2ZXIuXG4gICAgLy8gU2luY2UgdGhlIGB2YWx1ZWAgcGFyYW1ldGVyIGlzIG5vdCBwYXNzZWQgdG8gdGhlIGxlZ2FjeSBoYXNoaW5nIG1ldGhvZCwgd2UgbXVzdCBzdG9yZSBpdFxuICAgIC8vIG9uIHRoZSB0cmFuc2FjdGlvbiBpbnB1dCBvYmplY3QuXG5cbiAgICBpZiAodHlwZW9mIHNpZ25QYXJhbXMgPT09ICdudW1iZXInKSB7XG4gICAgICBpZiAodHlwZW9mIHdpdG5lc3NWYWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgKHRoaXMudHguaW5zW3NpZ25QYXJhbXNdIGFzIGFueSkudmFsdWUgPSB3aXRuZXNzVmFsdWU7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBzdXBlci5zaWduKHNpZ25QYXJhbXMsIGtleVBhaXIsIHJlZGVlbVNjcmlwdCwgaGFzaFR5cGUsIHdpdG5lc3NWYWx1ZSwgd2l0bmVzc1NjcmlwdCk7XG4gICAgfVxuXG4gICAgaWYgKHNpZ25QYXJhbXMud2l0bmVzc1ZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICh0aGlzLnR4Lmluc1tzaWduUGFyYW1zLnZpbl0gYXMgYW55KS52YWx1ZSA9IHNpZ25QYXJhbXMud2l0bmVzc1ZhbHVlO1xuICAgIH1cbiAgICAvLyBXaGVuIGNhbGxpbmcgdGhlIHNpZ24gbWV0aG9kIHZpYSBUeGJTaWduQXJnLCB0aGUgYHZhbHVlYCBwYXJhbWV0ZXIgaXMgYWN0dWFsbHkgbm90IHBlcm1pdHRlZFxuICAgIC8vIHRvIGJlIHNldCBmb3IgcDJzaC1wMm1zIHRyYW5zYWN0aW9ucy5cbiAgICBpZiAoc2lnblBhcmFtcy5wcmV2T3V0U2NyaXB0VHlwZSA9PT0gJ3Ayc2gtcDJtcycpIHtcbiAgICAgIGRlbGV0ZSBzaWduUGFyYW1zLndpdG5lc3NWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHN1cGVyLnNpZ24oc2lnblBhcmFtcyk7XG4gIH1cbn1cbiJdfQ==

@@ -20,3 +20,3 @@ /**

export declare const chainCodesP2tr: readonly [30, 31];
export declare const chainCodes: (0 | 1 | 10 | 11 | 20 | 21 | 30 | 31)[];
export declare const chainCodes: (0 | 30 | 1 | 10 | 11 | 20 | 21 | 31)[];
export declare type ChainCode = typeof chainCodes[number];

@@ -23,0 +23,0 @@ export declare function isChainCode(n: unknown): n is ChainCode;

@@ -8,8 +8,8 @@ import { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';

import { ChainCode } from './chains';
export interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {
export interface WalletUnspent extends Unspent {
chain: ChainCode;
index: number;
}
export declare function isWalletUnspent<TNumber extends number | bigint>(u: Unspent<TNumber>): u is WalletUnspent<TNumber>;
export declare function signInputWithUnspent<TNumber extends number | bigint>(txBuilder: UtxoTransactionBuilder<TNumber>, inputIndex: number, unspent: WalletUnspent<TNumber>, unspentSigner: WalletUnspentSigner<RootWalletKeys>): void;
export declare function isWalletUnspent(u: Unspent): u is WalletUnspent;
export declare function signInputWithUnspent(txBuilder: UtxoTransactionBuilder, inputIndex: number, unspent: WalletUnspent, unspentSigner: WalletUnspentSigner<RootWalletKeys>): void;
/**

@@ -22,3 +22,3 @@ * @param tx

*/
export declare function verifySignatureWithUnspent<TNumber extends number | bigint>(tx: UtxoTransaction<TNumber>, inputIndex: number, unspents: Unspent<TNumber>[], walletKeys: RootWalletKeys): Triple<boolean>;
export declare function verifySignatureWithUnspent(tx: UtxoTransaction, inputIndex: number, unspents: Unspent[], walletKeys: RootWalletKeys): Triple<boolean>;
/**

@@ -28,3 +28,3 @@ * @deprecated

*/
export interface WalletUnspentLegacy<TNumber extends number | bigint = number> extends WalletUnspent<TNumber> {
export interface WalletUnspentLegacy extends WalletUnspent {
/** @deprecated - obviated by signWithUnspent */

@@ -31,0 +31,0 @@ redeemScript?: string;

@@ -41,2 +41,2 @@ "use strict";

exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVW5zcGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby93YWxsZXQvVW5zcGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxvREFBOEU7QUFDOUUsMkNBQStDO0FBQy9DLDRDQUE0RTtBQUs1RSx3Q0FBK0M7QUFRL0MsU0FBZ0IsZUFBZSxDQUFrQyxDQUFtQjtJQUNsRixPQUFRLENBQTRCLENBQUMsS0FBSyxLQUFLLFNBQVMsQ0FBQztBQUMzRCxDQUFDO0FBRkQsMENBRUM7QUFFRCxTQUFnQixvQkFBb0IsQ0FDbEMsU0FBMEMsRUFDMUMsVUFBa0IsRUFDbEIsT0FBK0IsRUFDL0IsYUFBa0Q7SUFFbEQsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsYUFBYSxDQUFDLHNCQUFzQixDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVHLE1BQU0sVUFBVSxHQUFHLGtDQUFrQixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyRCxNQUFNLFNBQVMsR0FBRyxzQ0FBc0IsQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDLFlBQVksQ0FBQztJQUN6RixNQUFNLGlCQUFpQixHQUFHLHdCQUFjLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUMsT0FBa0IsQ0FBQyxDQUFDO0lBQ3hGLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLEVBQUU7UUFDeEMsTUFBTSxJQUFJLEtBQUssQ0FDYixnQ0FBZ0MsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxRQUFRLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FDckcsQ0FBQztLQUNIO0lBQ0QseUJBQWEsQ0FDWCxTQUFTLEVBQ1QsVUFBVSxFQUNWLFVBQVUsRUFDVixVQUFVLENBQUMsVUFBVSxFQUNyQixNQUFNLEVBQ04sUUFBUSxDQUFDLFNBQVMsRUFDbEIsT0FBTyxDQUFDLEtBQUssQ0FDZCxDQUFDO0FBQ0osQ0FBQztBQXhCRCxvREF3QkM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQiwwQkFBMEIsQ0FDeEMsRUFBNEIsRUFDNUIsVUFBa0IsRUFDbEIsUUFBNEIsRUFDNUIsVUFBMEI7SUFFMUIsSUFBSSxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxRQUFRLENBQUMsTUFBTSxFQUFFO1FBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMseUNBQXlDLENBQUMsQ0FBQztLQUM1RDtJQUNELE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzdCLE9BQU8sQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0tBQzlCO0lBQ0QsT0FBTyx5Q0FBNkIsQ0FDbEMsRUFBRSxFQUNGLFVBQVUsRUFDVixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxrQkFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsRUFDNUMsVUFBVSxDQUFDLHNCQUFzQixDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FDeEQsQ0FBQztBQUN2QixDQUFDO0FBbkJELGdFQW1CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLic7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi4vVXR4b1RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBjcmVhdGVPdXRwdXRTY3JpcHQyb2YzLCBzY3JpcHRUeXBlRm9yQ2hhaW4gfSBmcm9tICcuLi9vdXRwdXRTY3JpcHRzJztcbmltcG9ydCB7IHRvT3V0cHV0U2NyaXB0IH0gZnJvbSAnLi4vLi4vYWRkcmVzcyc7XG5pbXBvcnQgeyBzaWduSW5wdXQyT2YzLCB2ZXJpZnlTaWduYXR1cmVXaXRoUHVibGljS2V5cyB9IGZyb20gJy4uL3NpZ25hdHVyZSc7XG5pbXBvcnQgeyBXYWxsZXRVbnNwZW50U2lnbmVyIH0gZnJvbSAnLi9XYWxsZXRVbnNwZW50U2lnbmVyJztcbmltcG9ydCB7IFJvb3RXYWxsZXRLZXlzIH0gZnJvbSAnLi9XYWxsZXRLZXlzJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4uL1V0eG9UcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBUcmlwbGUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyB0b091dHB1dCwgVW5zcGVudCB9IGZyb20gJy4uL1Vuc3BlbnQnO1xuaW1wb3J0IHsgQ2hhaW5Db2RlIH0gZnJvbSAnLi9jaGFpbnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFdhbGxldFVuc3BlbnQ8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludCA9IG51bWJlcj4gZXh0ZW5kcyBVbnNwZW50PFROdW1iZXI+IHtcbiAgY2hhaW46IENoYWluQ29kZTtcbiAgaW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzV2FsbGV0VW5zcGVudDxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50Pih1OiBVbnNwZW50PFROdW1iZXI+KTogdSBpcyBXYWxsZXRVbnNwZW50PFROdW1iZXI+IHtcbiAgcmV0dXJuICh1IGFzIFdhbGxldFVuc3BlbnQ8VE51bWJlcj4pLmNoYWluICE9PSB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzaWduSW5wdXRXaXRoVW5zcGVudDxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50PihcbiAgdHhCdWlsZGVyOiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyPFROdW1iZXI+LFxuICBpbnB1dEluZGV4OiBudW1iZXIsXG4gIHVuc3BlbnQ6IFdhbGxldFVuc3BlbnQ8VE51bWJlcj4sXG4gIHVuc3BlbnRTaWduZXI6IFdhbGxldFVuc3BlbnRTaWduZXI8Um9vdFdhbGxldEtleXM+XG4pOiB2b2lkIHtcbiAgY29uc3QgeyB3YWxsZXRLZXlzLCBzaWduZXIsIGNvc2lnbmVyIH0gPSB1bnNwZW50U2lnbmVyLmRlcml2ZUZvckNoYWluQW5kSW5kZXgodW5zcGVudC5jaGFpbiwgdW5zcGVudC5pbmRleCk7XG4gIGNvbnN0IHNjcmlwdFR5cGUgPSBzY3JpcHRUeXBlRm9yQ2hhaW4odW5zcGVudC5jaGFpbik7XG4gIGNvbnN0IHB1YlNjcmlwdCA9IGNyZWF0ZU91dHB1dFNjcmlwdDJvZjMod2FsbGV0S2V5cy5wdWJsaWNLZXlzLCBzY3JpcHRUeXBlKS5zY3JpcHRQdWJLZXk7XG4gIGNvbnN0IHB1YlNjcmlwdEV4cGVjdGVkID0gdG9PdXRwdXRTY3JpcHQodW5zcGVudC5hZGRyZXNzLCB0eEJ1aWxkZXIubmV0d29yayBhcyBOZXR3b3JrKTtcbiAgaWYgKCFwdWJTY3JpcHQuZXF1YWxzKHB1YlNjcmlwdEV4cGVjdGVkKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIGBwdWJzY3JpcHQgbWlzbWF0Y2g6IGV4cGVjdGVkICR7cHViU2NyaXB0RXhwZWN0ZWQudG9TdHJpbmcoJ2hleCcpfSBnb3QgJHtwdWJTY3JpcHQudG9TdHJpbmcoJ2hleCcpfWBcbiAgICApO1xuICB9XG4gIHNpZ25JbnB1dDJPZjM8VE51bWJlcj4oXG4gICAgdHhCdWlsZGVyLFxuICAgIGlucHV0SW5kZXgsXG4gICAgc2NyaXB0VHlwZSxcbiAgICB3YWxsZXRLZXlzLnB1YmxpY0tleXMsXG4gICAgc2lnbmVyLFxuICAgIGNvc2lnbmVyLnB1YmxpY0tleSxcbiAgICB1bnNwZW50LnZhbHVlXG4gICk7XG59XG5cbi8qKlxuICogQHBhcmFtIHR4XG4gKiBAcGFyYW0gaW5wdXRJbmRleFxuICogQHBhcmFtIHVuc3BlbnRzXG4gKiBAcGFyYW0gd2FsbGV0S2V5c1xuICogQHJldHVybiB0cmlwbGUgb2YgYm9vbGVhbnMgaW5kaWNhdGluZyBhIHZhbGlkIHNpZ25hdHVyZSBmb3IgZWFjaCBwdWJrZXlcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeVNpZ25hdHVyZVdpdGhVbnNwZW50PFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KFxuICB0eDogVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+LFxuICBpbnB1dEluZGV4OiBudW1iZXIsXG4gIHVuc3BlbnRzOiBVbnNwZW50PFROdW1iZXI+W10sXG4gIHdhbGxldEtleXM6IFJvb3RXYWxsZXRLZXlzXG4pOiBUcmlwbGU8Ym9vbGVhbj4ge1xuICBpZiAodHguaW5zLmxlbmd0aCAhPT0gdW5zcGVudHMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnB1dCBsZW5ndGggbXVzdCBtYXRjaCB1bnNwZW50cyBsZW5ndGhgKTtcbiAgfVxuICBjb25zdCB1bnNwZW50ID0gdW5zcGVudHNbaW5wdXRJbmRleF07XG4gIGlmICghaXNXYWxsZXRVbnNwZW50KHVuc3BlbnQpKSB7XG4gICAgcmV0dXJuIFtmYWxzZSwgZmFsc2UsIGZhbHNlXTtcbiAgfVxuICByZXR1cm4gdmVyaWZ5U2lnbmF0dXJlV2l0aFB1YmxpY0tleXMoXG4gICAgdHgsXG4gICAgaW5wdXRJbmRleCxcbiAgICB1bnNwZW50cy5tYXAoKHUpID0+IHRvT3V0cHV0KHUsIHR4Lm5ldHdvcmspKSxcbiAgICB3YWxsZXRLZXlzLmRlcml2ZUZvckNoYWluQW5kSW5kZXgodW5zcGVudC5jaGFpbiwgdW5zcGVudC5pbmRleCkucHVibGljS2V5c1xuICApIGFzIFRyaXBsZTxib29sZWFuPjtcbn1cblxuLyoqXG4gKiBAZGVwcmVjYXRlZFxuICogVXNlZCBpbiBjZXJ0YWluIGxlZ2FjeSBzaWduaW5nIG1ldGhvZHMgdGhhdCBkbyBub3QgZGVyaXZlIHNpZ25pbmcgZGF0YSBmcm9tIGluZGV4L2NoYWluXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgV2FsbGV0VW5zcGVudExlZ2FjeTxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiBleHRlbmRzIFdhbGxldFVuc3BlbnQ8VE51bWJlcj4ge1xuICAvKiogQGRlcHJlY2F0ZWQgLSBvYnZpYXRlZCBieSBzaWduV2l0aFVuc3BlbnQgKi9cbiAgcmVkZWVtU2NyaXB0Pzogc3RyaW5nO1xuICAvKiogQGRlcHJlY2F0ZWQgLSBvYnZpYXRlZCBieSB2ZXJpZnlXaXRoVW5zcGVudCAqL1xuICB3aXRuZXNzU2NyaXB0Pzogc3RyaW5nO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVW5zcGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby93YWxsZXQvVW5zcGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSxvREFBOEU7QUFDOUUsMkNBQStDO0FBQy9DLDRDQUE0RTtBQUs1RSx3Q0FBK0M7QUFRL0MsU0FBZ0IsZUFBZSxDQUFDLENBQVU7SUFDeEMsT0FBUSxDQUFtQixDQUFDLEtBQUssS0FBSyxTQUFTLENBQUM7QUFDbEQsQ0FBQztBQUZELDBDQUVDO0FBRUQsU0FBZ0Isb0JBQW9CLENBQ2xDLFNBQWlDLEVBQ2pDLFVBQWtCLEVBQ2xCLE9BQXNCLEVBQ3RCLGFBQWtEO0lBRWxELE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1RyxNQUFNLFVBQVUsR0FBRyxrQ0FBa0IsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckQsTUFBTSxTQUFTLEdBQUcsc0NBQXNCLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQyxZQUFZLENBQUM7SUFDekYsTUFBTSxpQkFBaUIsR0FBRyx3QkFBYyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLE9BQWtCLENBQUMsQ0FBQztJQUN4RixJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFO1FBQ3hDLE1BQU0sSUFBSSxLQUFLLENBQ2IsZ0NBQWdDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsUUFBUSxTQUFTLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQ3JHLENBQUM7S0FDSDtJQUNELHlCQUFhLENBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsVUFBVSxDQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDckgsQ0FBQztBQWhCRCxvREFnQkM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQiwwQkFBMEIsQ0FDeEMsRUFBbUIsRUFDbkIsVUFBa0IsRUFDbEIsUUFBbUIsRUFDbkIsVUFBMEI7SUFFMUIsSUFBSSxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sS0FBSyxRQUFRLENBQUMsTUFBTSxFQUFFO1FBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMseUNBQXlDLENBQUMsQ0FBQztLQUM1RDtJQUNELE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzdCLE9BQU8sQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0tBQzlCO0lBQ0QsT0FBTyx5Q0FBNkIsQ0FDbEMsRUFBRSxFQUNGLFVBQVUsRUFDVixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxrQkFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsRUFDNUMsVUFBVSxDQUFDLHNCQUFzQixDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FDeEQsQ0FBQztBQUN2QixDQUFDO0FBbkJELGdFQW1CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLic7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi4vVXR4b1RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBjcmVhdGVPdXRwdXRTY3JpcHQyb2YzLCBzY3JpcHRUeXBlRm9yQ2hhaW4gfSBmcm9tICcuLi9vdXRwdXRTY3JpcHRzJztcbmltcG9ydCB7IHRvT3V0cHV0U2NyaXB0IH0gZnJvbSAnLi4vLi4vYWRkcmVzcyc7XG5pbXBvcnQgeyBzaWduSW5wdXQyT2YzLCB2ZXJpZnlTaWduYXR1cmVXaXRoUHVibGljS2V5cyB9IGZyb20gJy4uL3NpZ25hdHVyZSc7XG5pbXBvcnQgeyBXYWxsZXRVbnNwZW50U2lnbmVyIH0gZnJvbSAnLi9XYWxsZXRVbnNwZW50U2lnbmVyJztcbmltcG9ydCB7IFJvb3RXYWxsZXRLZXlzIH0gZnJvbSAnLi9XYWxsZXRLZXlzJztcbmltcG9ydCB7IFV0eG9UcmFuc2FjdGlvbiB9IGZyb20gJy4uL1V0eG9UcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBUcmlwbGUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyB0b091dHB1dCwgVW5zcGVudCB9IGZyb20gJy4uL1Vuc3BlbnQnO1xuaW1wb3J0IHsgQ2hhaW5Db2RlIH0gZnJvbSAnLi9jaGFpbnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFdhbGxldFVuc3BlbnQgZXh0ZW5kcyBVbnNwZW50IHtcbiAgY2hhaW46IENoYWluQ29kZTtcbiAgaW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzV2FsbGV0VW5zcGVudCh1OiBVbnNwZW50KTogdSBpcyBXYWxsZXRVbnNwZW50IHtcbiAgcmV0dXJuICh1IGFzIFdhbGxldFVuc3BlbnQpLmNoYWluICE9PSB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzaWduSW5wdXRXaXRoVW5zcGVudChcbiAgdHhCdWlsZGVyOiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyLFxuICBpbnB1dEluZGV4OiBudW1iZXIsXG4gIHVuc3BlbnQ6IFdhbGxldFVuc3BlbnQsXG4gIHVuc3BlbnRTaWduZXI6IFdhbGxldFVuc3BlbnRTaWduZXI8Um9vdFdhbGxldEtleXM+XG4pOiB2b2lkIHtcbiAgY29uc3QgeyB3YWxsZXRLZXlzLCBzaWduZXIsIGNvc2lnbmVyIH0gPSB1bnNwZW50U2lnbmVyLmRlcml2ZUZvckNoYWluQW5kSW5kZXgodW5zcGVudC5jaGFpbiwgdW5zcGVudC5pbmRleCk7XG4gIGNvbnN0IHNjcmlwdFR5cGUgPSBzY3JpcHRUeXBlRm9yQ2hhaW4odW5zcGVudC5jaGFpbik7XG4gIGNvbnN0IHB1YlNjcmlwdCA9IGNyZWF0ZU91dHB1dFNjcmlwdDJvZjMod2FsbGV0S2V5cy5wdWJsaWNLZXlzLCBzY3JpcHRUeXBlKS5zY3JpcHRQdWJLZXk7XG4gIGNvbnN0IHB1YlNjcmlwdEV4cGVjdGVkID0gdG9PdXRwdXRTY3JpcHQodW5zcGVudC5hZGRyZXNzLCB0eEJ1aWxkZXIubmV0d29yayBhcyBOZXR3b3JrKTtcbiAgaWYgKCFwdWJTY3JpcHQuZXF1YWxzKHB1YlNjcmlwdEV4cGVjdGVkKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIGBwdWJzY3JpcHQgbWlzbWF0Y2g6IGV4cGVjdGVkICR7cHViU2NyaXB0RXhwZWN0ZWQudG9TdHJpbmcoJ2hleCcpfSBnb3QgJHtwdWJTY3JpcHQudG9TdHJpbmcoJ2hleCcpfWBcbiAgICApO1xuICB9XG4gIHNpZ25JbnB1dDJPZjModHhCdWlsZGVyLCBpbnB1dEluZGV4LCBzY3JpcHRUeXBlLCB3YWxsZXRLZXlzLnB1YmxpY0tleXMsIHNpZ25lciwgY29zaWduZXIucHVibGljS2V5LCB1bnNwZW50LnZhbHVlKTtcbn1cblxuLyoqXG4gKiBAcGFyYW0gdHhcbiAqIEBwYXJhbSBpbnB1dEluZGV4XG4gKiBAcGFyYW0gdW5zcGVudHNcbiAqIEBwYXJhbSB3YWxsZXRLZXlzXG4gKiBAcmV0dXJuIHRyaXBsZSBvZiBib29sZWFucyBpbmRpY2F0aW5nIGEgdmFsaWQgc2lnbmF0dXJlIGZvciBlYWNoIHB1YmtleVxuICovXG5leHBvcnQgZnVuY3Rpb24gdmVyaWZ5U2lnbmF0dXJlV2l0aFVuc3BlbnQoXG4gIHR4OiBVdHhvVHJhbnNhY3Rpb24sXG4gIGlucHV0SW5kZXg6IG51bWJlcixcbiAgdW5zcGVudHM6IFVuc3BlbnRbXSxcbiAgd2FsbGV0S2V5czogUm9vdFdhbGxldEtleXNcbik6IFRyaXBsZTxib29sZWFuPiB7XG4gIGlmICh0eC5pbnMubGVuZ3RoICE9PSB1bnNwZW50cy5sZW5ndGgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGlucHV0IGxlbmd0aCBtdXN0IG1hdGNoIHVuc3BlbnRzIGxlbmd0aGApO1xuICB9XG4gIGNvbnN0IHVuc3BlbnQgPSB1bnNwZW50c1tpbnB1dEluZGV4XTtcbiAgaWYgKCFpc1dhbGxldFVuc3BlbnQodW5zcGVudCkpIHtcbiAgICByZXR1cm4gW2ZhbHNlLCBmYWxzZSwgZmFsc2VdO1xuICB9XG4gIHJldHVybiB2ZXJpZnlTaWduYXR1cmVXaXRoUHVibGljS2V5cyhcbiAgICB0eCxcbiAgICBpbnB1dEluZGV4LFxuICAgIHVuc3BlbnRzLm1hcCgodSkgPT4gdG9PdXRwdXQodSwgdHgubmV0d29yaykpLFxuICAgIHdhbGxldEtleXMuZGVyaXZlRm9yQ2hhaW5BbmRJbmRleCh1bnNwZW50LmNoYWluLCB1bnNwZW50LmluZGV4KS5wdWJsaWNLZXlzXG4gICkgYXMgVHJpcGxlPGJvb2xlYW4+O1xufVxuXG4vKipcbiAqIEBkZXByZWNhdGVkXG4gKiBVc2VkIGluIGNlcnRhaW4gbGVnYWN5IHNpZ25pbmcgbWV0aG9kcyB0aGF0IGRvIG5vdCBkZXJpdmUgc2lnbmluZyBkYXRhIGZyb20gaW5kZXgvY2hhaW5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYWxsZXRVbnNwZW50TGVnYWN5IGV4dGVuZHMgV2FsbGV0VW5zcGVudCB7XG4gIC8qKiBAZGVwcmVjYXRlZCAtIG9idmlhdGVkIGJ5IHNpZ25XaXRoVW5zcGVudCAqL1xuICByZWRlZW1TY3JpcHQ/OiBzdHJpbmc7XG4gIC8qKiBAZGVwcmVjYXRlZCAtIG9idmlhdGVkIGJ5IHZlcmlmeVdpdGhVbnNwZW50ICovXG4gIHdpdG5lc3NTY3JpcHQ/OiBzdHJpbmc7XG59XG4iXX0=

@@ -8,6 +8,6 @@ /// <reference types="node" />

import { ZcashTransaction } from './ZcashTransaction';
declare type SignatureParams<TNumber extends number | bigint = number> = {
declare type SignatureParams = {
inIndex?: number;
prevOutScript: Buffer;
value: TNumber;
value: number;
hashType: number;

@@ -22,8 +22,8 @@ };

export declare function getBlake2bHash(buffer: Buffer, personalization: string | Buffer): Buffer;
export declare function getPrevoutsDigest<TNumber extends number | bigint>(ins: TxInput[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
export declare function getSequenceDigest<TNumber extends number | bigint>(ins: TxInput[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
export declare function getOutputsDigest<TNumber extends number | bigint>(outs: TxOutput<TNumber>[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
export declare function getTxidDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer;
export declare function getSignatureDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>, inIndex: number | undefined, prevOutScript: Buffer, value: TNumber, hashType: number): Buffer;
export declare function getPrevoutsDigest(ins: TxInput[], tag?: string, sigParams?: SignatureParams): Buffer;
export declare function getSequenceDigest(ins: TxInput[], tag?: string, sigParams?: SignatureParams): Buffer;
export declare function getOutputsDigest(outs: TxOutput[], tag?: string, sigParams?: SignatureParams): Buffer;
export declare function getTxidDigest(tx: ZcashTransaction): Buffer;
export declare function getSignatureDigest(tx: ZcashTransaction, inIndex: number | undefined, prevOutScript: Buffer, value: number, hashType: number): Buffer;
export {};
//# sourceMappingURL=hashZip0244.d.ts.map

@@ -184,2 +184,2 @@ "use strict";

exports.getSignatureDigest = getSignatureDigest;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hashZip0244.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/hashZip0244.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Implements hashing methods described in https://zips.z.cash/zip-0244.\n * Only supports full transparent transactions without shielded inputs or outputs.\n */\nimport { Transaction, TxInput, TxOutput } from 'bitcoinjs-lib';\nimport { BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nconst blake2b = require('@bitgo/blake2b');\n\nimport { ZcashTransaction } from './ZcashTransaction';\nimport { varSliceSize } from '../UtxoTransaction';\n\ntype SignatureParams<TNumber extends number | bigint = number> = {\n  inIndex?: number;\n  prevOutScript: Buffer;\n  value: TNumber;\n  hashType: number;\n};\n\n/**\n * Blake2b hashing algorithm for Zcash\n * @param buffer\n * @param personalization\n * @returns 256-bit BLAKE2b hash\n */\nexport function getBlake2bHash(buffer: Buffer, personalization: string | Buffer): Buffer {\n  const out = Buffer.allocUnsafe(32);\n  personalization = Buffer.from(personalization);\n  return blake2b(out.length, null, null, personalization).update(buffer).digest(out);\n}\n\nfunction getHeaderDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-1-header-digest\n  const mask = tx.overwintered ? 1 : 0;\n  const writer = BufferWriter.withCapacity(4 * 5);\n  writer.writeInt32(tx.version | (mask << 31)); // Set overwinter bit\n  writer.writeUInt32(tx.versionGroupId);\n  writer.writeUInt32(tx.consensusBranchId);\n  writer.writeUInt32(tx.locktime);\n  writer.writeUInt32(tx.expiryHeight);\n  return getBlake2bHash(writer.end(), 'ZTxIdHeadersHash');\n}\n\nexport function getPrevoutsDigest<TNumber extends number | bigint>(\n  ins: TxInput[],\n  tag = 'ZTxIdPrevoutHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  if (sigParams) {\n    if (sigParams.hashType & Transaction.SIGHASH_ANYONECANPAY) {\n      return getPrevoutsDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * ins.length));\n  ins.forEach(function (txIn) {\n    bufferWriter.writeSlice(txIn.hash);\n    bufferWriter.writeUInt32(txIn.index);\n  });\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getSequenceDigest<TNumber extends number | bigint>(\n  ins: TxInput[],\n  tag = 'ZTxIdSequencHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2b-sequence-digest\n  // sig: https://zips.z.cash/zip-0244#s-2b-sequence-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L263\n  if (sigParams) {\n    const { hashType } = sigParams;\n    if (\n      hashType & Transaction.SIGHASH_ANYONECANPAY ||\n      (hashType & 0x1f) === Transaction.SIGHASH_SINGLE ||\n      (hashType & 0x1f) === Transaction.SIGHASH_NONE\n    ) {\n      return getSequenceDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(4 * ins.length));\n\n  ins.forEach(function (txIn) {\n    bufferWriter.writeUInt32(txIn.sequence);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getOutputsDigest<TNumber extends number | bigint>(\n  outs: TxOutput<TNumber>[],\n  tag = 'ZTxIdOutputsHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2c-outputs-digest\n  // sig: https://zips.z.cash/zip-0244#s-2c-outputs-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L275\n  if (sigParams) {\n    let { hashType } = sigParams;\n    hashType = hashType & 0x1f;\n\n    if (hashType === Transaction.SIGHASH_SINGLE) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      if (outs[sigParams.inIndex] === undefined) {\n        return getOutputsDigest(outs);\n      }\n      return getOutputsDigest([outs[sigParams.inIndex]]);\n    }\n\n    if (hashType === Transaction.SIGHASH_NONE) {\n      return getOutputsDigest([]);\n    }\n\n    return getOutputsDigest(outs, tag);\n  }\n\n  // Find out the size of the outputs and write them\n  const txOutsSize = outs.reduce(function (sum, output) {\n    return sum + 8 + varSliceSize(output.script);\n  }, 0);\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(txOutsSize));\n\n  outs.forEach(function (out) {\n    bufferWriter.writeUInt64(out.value);\n    bufferWriter.writeVarSlice(out.script);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nfunction getTxinDigest<TNumber extends number | bigint>(input: TxInput, sigParams: SignatureParams<TNumber>) {\n  // https://zips.z.cash/zip-0244#s-2d-txin-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L291\n  const writer = BufferWriter.withCapacity(\n    32 /* prevout hash */ +\n      4 /* prevout vin */ +\n      varSliceSize(sigParams.prevOutScript) +\n      8 /* value */ +\n      4 /* sequence */\n  );\n  writer.writeSlice(input.hash);\n  writer.writeUInt32(input.index);\n  writer.writeVarSlice(sigParams.prevOutScript);\n  writer.writeUInt64(sigParams.value);\n  writer.writeUInt32(input.sequence);\n  return getBlake2bHash(writer.end(), 'Zcash___TxInHash');\n}\n\nfunction getTransparentDigest<TNumber extends number | bigint>(\n  tx: { ins: TxInput[]; outs: TxOutput<TNumber>[] },\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2-transparent-digest\n  // sig: https://zips.z.cash/zip-0244#s-2a-prevouts-sig-digest\n  if (sigParams) {\n    if (sigParams.inIndex === undefined) {\n      return getTransparentDigest(tx);\n    }\n  }\n\n  let buffer;\n  if (tx.ins.length || tx.outs.length) {\n    const writer = BufferWriter.withCapacity(32 * (sigParams ? 4 : 3));\n    writer.writeSlice(getPrevoutsDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getSequenceDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getOutputsDigest(tx.outs, undefined, sigParams));\n    if (sigParams) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      writer.writeSlice(getTxinDigest(tx.ins[sigParams.inIndex], sigParams));\n    }\n    buffer = writer.end();\n  } else {\n    buffer = Buffer.of();\n  }\n  return getBlake2bHash(buffer, 'ZTxIdTranspaHash');\n}\n\nfunction getSaplingDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-3-sapling-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdSaplingHash');\n}\n\nfunction getOrchardDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-4-orchard-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdOrchardHash');\n}\n\n/**\n * @param tx\n * @param signatureParams - calculates txid when undefined\n */\nfunction getDigest<TNumber extends number | bigint>(\n  tx: ZcashTransaction<TNumber>,\n  signatureParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#id4\n  // sig: https://zips.z.cash/zip-0244#id13\n  const writer = BufferWriter.withCapacity(32 * 4);\n  writer.writeSlice(getHeaderDigest(tx));\n  writer.writeSlice(getTransparentDigest(tx, signatureParams));\n  writer.writeSlice(getSaplingDigest(tx));\n  writer.writeSlice(getOrchardDigest(tx));\n\n  const tag = 'ZcashTxHash_';\n  const personalization = BufferWriter.withCapacity(tag.length + 4 /* UInt32 */);\n  personalization.writeSlice(Buffer.from(tag));\n  personalization.writeUInt32(tx.consensusBranchId);\n  return getBlake2bHash(writer.end(), personalization.end());\n}\n\nexport function getTxidDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#id4\n  return getDigest(tx);\n}\n\nexport function getSignatureDigest<TNumber extends number | bigint>(\n  tx: ZcashTransaction<TNumber>,\n  inIndex: number | undefined,\n  prevOutScript: Buffer,\n  value: TNumber,\n  hashType: number\n): Buffer {\n  // https://zips.z.cash/zip-0244#id13\n  return getDigest(tx, {\n    inIndex,\n    prevOutScript,\n    value,\n    hashType,\n  });\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hashZip0244.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/hashZip0244.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Implements hashing methods described in https://zips.z.cash/zip-0244.\n * Only supports full transparent transactions without shielded inputs or outputs.\n */\nimport { Transaction, TxInput, TxOutput } from 'bitcoinjs-lib';\nimport { BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nconst blake2b = require('@bitgo/blake2b');\n\nimport { ZcashTransaction } from './ZcashTransaction';\nimport { varSliceSize } from '../UtxoTransaction';\n\ntype SignatureParams = {\n  inIndex?: number;\n  prevOutScript: Buffer;\n  value: number;\n  hashType: number;\n};\n\n/**\n * Blake2b hashing algorithm for Zcash\n * @param buffer\n * @param personalization\n * @returns 256-bit BLAKE2b hash\n */\nexport function getBlake2bHash(buffer: Buffer, personalization: string | Buffer): Buffer {\n  const out = Buffer.allocUnsafe(32);\n  personalization = Buffer.from(personalization);\n  return blake2b(out.length, null, null, personalization).update(buffer).digest(out);\n}\n\nfunction getHeaderDigest(tx: ZcashTransaction): Buffer {\n  // https://zips.z.cash/zip-0244#t-1-header-digest\n  const mask = tx.overwintered ? 1 : 0;\n  const writer = BufferWriter.withCapacity(4 * 5);\n  writer.writeInt32(tx.version | (mask << 31)); // Set overwinter bit\n  writer.writeUInt32(tx.versionGroupId);\n  writer.writeUInt32(tx.consensusBranchId);\n  writer.writeUInt32(tx.locktime);\n  writer.writeUInt32(tx.expiryHeight);\n  return getBlake2bHash(writer.end(), 'ZTxIdHeadersHash');\n}\n\nexport function getPrevoutsDigest(ins: TxInput[], tag = 'ZTxIdPrevoutHash', sigParams?: SignatureParams): Buffer {\n  if (sigParams) {\n    if (sigParams.hashType & Transaction.SIGHASH_ANYONECANPAY) {\n      return getPrevoutsDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * ins.length));\n  ins.forEach(function (txIn) {\n    bufferWriter.writeSlice(txIn.hash);\n    bufferWriter.writeUInt32(txIn.index);\n  });\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getSequenceDigest(ins: TxInput[], tag = 'ZTxIdSequencHash', sigParams?: SignatureParams): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2b-sequence-digest\n  // sig: https://zips.z.cash/zip-0244#s-2b-sequence-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L263\n  if (sigParams) {\n    const { hashType } = sigParams;\n    if (\n      hashType & Transaction.SIGHASH_ANYONECANPAY ||\n      (hashType & 0x1f) === Transaction.SIGHASH_SINGLE ||\n      (hashType & 0x1f) === Transaction.SIGHASH_NONE\n    ) {\n      return getSequenceDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(4 * ins.length));\n\n  ins.forEach(function (txIn) {\n    bufferWriter.writeUInt32(txIn.sequence);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getOutputsDigest(outs: TxOutput[], tag = 'ZTxIdOutputsHash', sigParams?: SignatureParams): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2c-outputs-digest\n  // sig: https://zips.z.cash/zip-0244#s-2c-outputs-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L275\n  if (sigParams) {\n    let { hashType } = sigParams;\n    hashType = hashType & 0x1f;\n\n    if (hashType === Transaction.SIGHASH_SINGLE) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      if (outs[sigParams.inIndex] === undefined) {\n        return getOutputsDigest(outs);\n      }\n      return getOutputsDigest([outs[sigParams.inIndex]]);\n    }\n\n    if (hashType === Transaction.SIGHASH_NONE) {\n      return getOutputsDigest([]);\n    }\n\n    return getOutputsDigest(outs, tag);\n  }\n\n  // Find out the size of the outputs and write them\n  const txOutsSize = outs.reduce(function (sum, output) {\n    return sum + 8 + varSliceSize(output.script);\n  }, 0);\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(txOutsSize));\n\n  outs.forEach(function (out) {\n    bufferWriter.writeUInt64(out.value);\n    bufferWriter.writeVarSlice(out.script);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nfunction getTxinDigest(input: TxInput, sigParams: SignatureParams) {\n  // https://zips.z.cash/zip-0244#s-2d-txin-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L291\n  const writer = BufferWriter.withCapacity(\n    32 /* prevout hash */ +\n      4 /* prevout vin */ +\n      varSliceSize(sigParams.prevOutScript) +\n      8 /* value */ +\n      4 /* sequence */\n  );\n  writer.writeSlice(input.hash);\n  writer.writeUInt32(input.index);\n  writer.writeVarSlice(sigParams.prevOutScript);\n  writer.writeUInt64(sigParams.value);\n  writer.writeUInt32(input.sequence);\n  return getBlake2bHash(writer.end(), 'Zcash___TxInHash');\n}\n\nfunction getTransparentDigest(tx: { ins: TxInput[]; outs: TxOutput[] }, sigParams?: SignatureParams): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2-transparent-digest\n  // sig: https://zips.z.cash/zip-0244#s-2a-prevouts-sig-digest\n  if (sigParams) {\n    if (sigParams.inIndex === undefined) {\n      return getTransparentDigest(tx);\n    }\n  }\n\n  let buffer;\n  if (tx.ins.length || tx.outs.length) {\n    const writer = BufferWriter.withCapacity(32 * (sigParams ? 4 : 3));\n    writer.writeSlice(getPrevoutsDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getSequenceDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getOutputsDigest(tx.outs, undefined, sigParams));\n    if (sigParams) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      writer.writeSlice(getTxinDigest(tx.ins[sigParams.inIndex], sigParams));\n    }\n    buffer = writer.end();\n  } else {\n    buffer = Buffer.of();\n  }\n  return getBlake2bHash(buffer, 'ZTxIdTranspaHash');\n}\n\nfunction getSaplingDigest(tx: ZcashTransaction): Buffer {\n  // https://zips.z.cash/zip-0244#t-3-sapling-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdSaplingHash');\n}\n\nfunction getOrchardDigest(tx: ZcashTransaction): Buffer {\n  // https://zips.z.cash/zip-0244#t-4-orchard-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdOrchardHash');\n}\n\n/**\n * @param tx\n * @param signatureParams - calculates txid when undefined\n */\nfunction getDigest(tx: ZcashTransaction, signatureParams?: SignatureParams): Buffer {\n  // txid: https://zips.z.cash/zip-0244#id4\n  // sig: https://zips.z.cash/zip-0244#id13\n  const writer = BufferWriter.withCapacity(32 * 4);\n  writer.writeSlice(getHeaderDigest(tx));\n  writer.writeSlice(getTransparentDigest(tx, signatureParams));\n  writer.writeSlice(getSaplingDigest(tx));\n  writer.writeSlice(getOrchardDigest(tx));\n\n  const tag = 'ZcashTxHash_';\n  const personalization = BufferWriter.withCapacity(tag.length + 4 /* UInt32 */);\n  personalization.writeSlice(Buffer.from(tag));\n  personalization.writeUInt32(tx.consensusBranchId);\n  return getBlake2bHash(writer.end(), personalization.end());\n}\n\nexport function getTxidDigest(tx: ZcashTransaction): Buffer {\n  // https://zips.z.cash/zip-0244#id4\n  return getDigest(tx);\n}\n\nexport function getSignatureDigest(\n  tx: ZcashTransaction,\n  inIndex: number | undefined,\n  prevOutScript: Buffer,\n  value: number,\n  hashType: number\n): Buffer {\n  // https://zips.z.cash/zip-0244#id13\n  return getDigest(tx, {\n    inIndex,\n    prevOutScript,\n    value,\n    hashType,\n  });\n}\n"]}

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

export declare function readInputs(bufferReader: BufferReader): TxInput[];
export declare function readOutputs<TNumber extends number | bigint>(bufferReader: BufferReader, amountType?: 'number' | 'bigint'): TxOutput<TNumber>[];
export declare function readOutputs(bufferReader: BufferReader): TxOutput[];
export declare function readEmptyVector(bufferReader: BufferReader): void;

@@ -21,8 +21,8 @@ export declare function readEmptyOrchardBundle(bufferReader: BufferReader): void;

export declare function writeEmptySamplingBundle(bufferWriter: BufferWriter): void;
export declare function fromBufferV4<TNumber extends number | bigint>(bufferReader: BufferReader, tx: ZcashTransaction<TNumber>, amountType?: 'number' | 'bigint'): void;
export declare function fromBufferV5<TNumber extends number | bigint>(bufferReader: BufferReader, tx: ZcashTransaction<TNumber>, amountType?: 'number' | 'bigint'): void;
export declare function fromBufferV4(bufferReader: BufferReader, tx: ZcashTransaction): void;
export declare function fromBufferV5(bufferReader: BufferReader, tx: ZcashTransaction): void;
export declare function writeInputs(bufferWriter: BufferWriter, ins: TxInput[]): void;
export declare function writeOutputs<TNumber extends number | bigint>(bufferWriter: BufferWriter, outs: TxOutput<TNumber>[]): void;
export declare function toBufferV4<TNumber extends number | bigint>(bufferWriter: BufferWriter, tx: ZcashTransaction<TNumber>): void;
export declare function toBufferV5<TNumber extends number | bigint>(bufferWriter: BufferWriter, tx: ZcashTransaction<TNumber>): void;
export declare function writeOutputs(bufferWriter: BufferWriter, outs: TxOutput[]): void;
export declare function toBufferV4(bufferWriter: BufferWriter, tx: ZcashTransaction): void;
export declare function toBufferV5(bufferWriter: BufferWriter, tx: ZcashTransaction): void;
//# sourceMappingURL=ZcashBufferutils.d.ts.map

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

exports.readInputs = readInputs;
function readOutputs(bufferReader, amountType = 'number') {
function readOutputs(bufferReader) {
const voutLen = bufferReader.readVarInt();

@@ -27,3 +27,3 @@ const outs = [];

outs.push({
value: (amountType === 'bigint' ? bufferReader.readUInt64BigInt() : bufferReader.readUInt64()),
value: bufferReader.readUInt64(),
script: bufferReader.readVarSlice(),

@@ -69,6 +69,6 @@ });

exports.writeEmptySamplingBundle = writeEmptySamplingBundle;
function fromBufferV4(bufferReader, tx, amountType = 'number') {
function fromBufferV4(bufferReader, tx) {
// https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L855-L857
tx.ins = readInputs(bufferReader);
tx.outs = readOutputs(bufferReader, amountType);
tx.outs = readOutputs(bufferReader);
tx.locktime = bufferReader.readUInt32();

@@ -93,3 +93,3 @@ if (tx.isOverwinterCompatible()) {

exports.fromBufferV4 = fromBufferV4;
function fromBufferV5(bufferReader, tx, amountType = 'number') {
function fromBufferV5(bufferReader, tx) {
// https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L815

@@ -101,3 +101,3 @@ tx.consensusBranchId = bufferReader.readUInt32();

tx.ins = readInputs(bufferReader);
tx.outs = readOutputs(bufferReader, amountType);
tx.outs = readOutputs(bufferReader);
// https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L835

@@ -162,2 +162,2 @@ readEmptySaplingBundle(bufferReader);

exports.toBufferV5 = toBufferV5;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashBufferutils.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashBufferutils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Transaction (de)serialization helpers.\n * Only supports full transparent transactions without shielded inputs or outputs.\n *\n * References:\n * - https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L771\n */\nimport { TxInput, TxOutput } from 'bitcoinjs-lib';\nimport { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nimport { UnsupportedTransactionError, ZcashTransaction } from './ZcashTransaction';\n\nexport const VALUE_INT64_ZERO = Buffer.from('0000000000000000', 'hex');\n\nexport function readInputs(bufferReader: BufferReader): TxInput[] {\n  const vinLen = bufferReader.readVarInt();\n  const ins: TxInput[] = [];\n  for (let i = 0; i < vinLen; ++i) {\n    ins.push({\n      hash: bufferReader.readSlice(32),\n      index: bufferReader.readUInt32(),\n      script: bufferReader.readVarSlice(),\n      sequence: bufferReader.readUInt32(),\n      witness: [],\n    });\n  }\n  return ins;\n}\n\nexport function readOutputs<TNumber extends number | bigint>(\n  bufferReader: BufferReader,\n  amountType: 'number' | 'bigint' = 'number'\n): TxOutput<TNumber>[] {\n  const voutLen = bufferReader.readVarInt();\n  const outs: TxOutput<TNumber>[] = [];\n  for (let i = 0; i < voutLen; ++i) {\n    outs.push({\n      value: (amountType === 'bigint' ? bufferReader.readUInt64BigInt() : bufferReader.readUInt64()) as TNumber,\n      script: bufferReader.readVarSlice(),\n    });\n  }\n  return outs;\n}\n\nexport function readEmptyVector(bufferReader: BufferReader): void {\n  const n = bufferReader.readVarInt();\n  if (n !== 0) {\n    throw new UnsupportedTransactionError(`expected empty vector`);\n  }\n}\n\nexport function readEmptyOrchardBundle(bufferReader: BufferReader): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/orchard.h#L66\n  // https://github.com/zcash/librustzcash/blob/edcde252de221d4851f1e5145306c2caf95453bc/zcash_primitives/src/transaction/components/orchard.rs#L36\n  const v = bufferReader.readUInt8();\n  if (v !== 0x00) {\n    throw new UnsupportedTransactionError(`expected byte 0x00`);\n  }\n}\n\nexport function writeEmptyOrchardBundle(bufferWriter: BufferWriter): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/orchard.h#L66\n  // https://github.com/zcash/librustzcash/blob/edcde252de221d4851f1e5145306c2caf95453bc/zcash_primitives/src/transaction/components/orchard.rs#L201\n  bufferWriter.writeUInt8(0);\n}\n\nexport function readEmptySaplingBundle(bufferReader: BufferReader): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L283\n  readEmptyVector(bufferReader) /* vSpendsSapling */;\n  readEmptyVector(bufferReader) /* vOutputsSapling */;\n}\n\nexport function writeEmptySamplingBundle(bufferWriter: BufferWriter): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L283\n  bufferWriter.writeVarInt(0) /* vSpendsSapling */;\n  bufferWriter.writeVarInt(0) /* vOutputsSapling */;\n}\n\nexport function fromBufferV4<TNumber extends number | bigint>(\n  bufferReader: BufferReader,\n  tx: ZcashTransaction<TNumber>,\n  amountType: 'number' | 'bigint' = 'number'\n): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L855-L857\n  tx.ins = readInputs(bufferReader);\n  tx.outs = readOutputs<TNumber>(bufferReader, amountType);\n  tx.locktime = bufferReader.readUInt32();\n\n  if (tx.isOverwinterCompatible()) {\n    tx.expiryHeight = bufferReader.readUInt32();\n  }\n\n  if (tx.isSaplingCompatible()) {\n    const valueBalance = bufferReader.readSlice(8);\n    if (!valueBalance.equals(VALUE_INT64_ZERO)) {\n      /* istanbul ignore next */\n      throw new UnsupportedTransactionError(`valueBalance must be zero`);\n    }\n\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L863\n    readEmptySaplingBundle(bufferReader);\n  }\n\n  if (tx.supportsJoinSplits()) {\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L869\n    readEmptyVector(bufferReader) /* vJoinSplit */;\n  }\n}\n\nexport function fromBufferV5<TNumber extends number | bigint>(\n  bufferReader: BufferReader,\n  tx: ZcashTransaction<TNumber>,\n  amountType: 'number' | 'bigint' = 'number'\n): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L815\n  tx.consensusBranchId = bufferReader.readUInt32();\n  tx.locktime = bufferReader.readUInt32();\n  tx.expiryHeight = bufferReader.readUInt32();\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L828\n  tx.ins = readInputs(bufferReader);\n  tx.outs = readOutputs<TNumber>(bufferReader, amountType);\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L835\n  readEmptySaplingBundle(bufferReader);\n  readEmptyOrchardBundle(bufferReader);\n}\n\nexport function writeInputs(bufferWriter: BufferWriter, ins: TxInput[]): void {\n  bufferWriter.writeVarInt(ins.length);\n  ins.forEach(function (txIn) {\n    bufferWriter.writeSlice(txIn.hash);\n    bufferWriter.writeUInt32(txIn.index);\n    bufferWriter.writeVarSlice(txIn.script);\n    bufferWriter.writeUInt32(txIn.sequence);\n  });\n}\n\nexport function writeOutputs<TNumber extends number | bigint>(\n  bufferWriter: BufferWriter,\n  outs: TxOutput<TNumber>[]\n): void {\n  bufferWriter.writeVarInt(outs.length);\n  outs.forEach(function (txOut) {\n    if ((txOut as any).valueBuffer) {\n      bufferWriter.writeSlice((txOut as any).valueBuffer);\n    } else {\n      bufferWriter.writeUInt64(txOut.value);\n    }\n\n    bufferWriter.writeVarSlice(txOut.script);\n  });\n}\n\nexport function toBufferV4<TNumber extends number | bigint>(\n  bufferWriter: BufferWriter,\n  tx: ZcashTransaction<TNumber>\n): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1083\n  writeInputs(bufferWriter, tx.ins);\n  writeOutputs<TNumber>(bufferWriter, tx.outs);\n\n  bufferWriter.writeUInt32(tx.locktime);\n\n  if (tx.isOverwinterCompatible()) {\n    bufferWriter.writeUInt32(tx.expiryHeight);\n  }\n\n  if (tx.isSaplingCompatible()) {\n    bufferWriter.writeSlice(VALUE_INT64_ZERO);\n    bufferWriter.writeVarInt(0); // vShieldedSpendLength\n    bufferWriter.writeVarInt(0); // vShieldedOutputLength\n  }\n\n  if (tx.supportsJoinSplits()) {\n    bufferWriter.writeVarInt(0); // joinsSplits length\n  }\n}\n\nexport function toBufferV5<TNumber extends number | bigint>(\n  bufferWriter: BufferWriter,\n  tx: ZcashTransaction<TNumber>\n): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L825-L826\n  bufferWriter.writeUInt32(tx.consensusBranchId);\n  bufferWriter.writeUInt32(tx.locktime);\n  bufferWriter.writeUInt32(tx.expiryHeight);\n  writeInputs(bufferWriter, tx.ins);\n  writeOutputs<TNumber>(bufferWriter, tx.outs);\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1063\n  writeEmptySamplingBundle(bufferWriter);\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1081\n  writeEmptyOrchardBundle(bufferWriter);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashBufferutils.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashBufferutils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Transaction (de)serialization helpers.\n * Only supports full transparent transactions without shielded inputs or outputs.\n *\n * References:\n * - https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L771\n */\nimport { TxInput, TxOutput } from 'bitcoinjs-lib';\nimport { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nimport { UnsupportedTransactionError, ZcashTransaction } from './ZcashTransaction';\n\nexport const VALUE_INT64_ZERO = Buffer.from('0000000000000000', 'hex');\n\nexport function readInputs(bufferReader: BufferReader): TxInput[] {\n  const vinLen = bufferReader.readVarInt();\n  const ins: TxInput[] = [];\n  for (let i = 0; i < vinLen; ++i) {\n    ins.push({\n      hash: bufferReader.readSlice(32),\n      index: bufferReader.readUInt32(),\n      script: bufferReader.readVarSlice(),\n      sequence: bufferReader.readUInt32(),\n      witness: [],\n    });\n  }\n  return ins;\n}\n\nexport function readOutputs(bufferReader: BufferReader): TxOutput[] {\n  const voutLen = bufferReader.readVarInt();\n  const outs: TxOutput[] = [];\n  for (let i = 0; i < voutLen; ++i) {\n    outs.push({\n      value: bufferReader.readUInt64(),\n      script: bufferReader.readVarSlice(),\n    });\n  }\n  return outs;\n}\n\nexport function readEmptyVector(bufferReader: BufferReader): void {\n  const n = bufferReader.readVarInt();\n  if (n !== 0) {\n    throw new UnsupportedTransactionError(`expected empty vector`);\n  }\n}\n\nexport function readEmptyOrchardBundle(bufferReader: BufferReader): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/orchard.h#L66\n  // https://github.com/zcash/librustzcash/blob/edcde252de221d4851f1e5145306c2caf95453bc/zcash_primitives/src/transaction/components/orchard.rs#L36\n  const v = bufferReader.readUInt8();\n  if (v !== 0x00) {\n    throw new UnsupportedTransactionError(`expected byte 0x00`);\n  }\n}\n\nexport function writeEmptyOrchardBundle(bufferWriter: BufferWriter): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/orchard.h#L66\n  // https://github.com/zcash/librustzcash/blob/edcde252de221d4851f1e5145306c2caf95453bc/zcash_primitives/src/transaction/components/orchard.rs#L201\n  bufferWriter.writeUInt8(0);\n}\n\nexport function readEmptySaplingBundle(bufferReader: BufferReader): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L283\n  readEmptyVector(bufferReader) /* vSpendsSapling */;\n  readEmptyVector(bufferReader) /* vOutputsSapling */;\n}\n\nexport function writeEmptySamplingBundle(bufferWriter: BufferWriter): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L283\n  bufferWriter.writeVarInt(0) /* vSpendsSapling */;\n  bufferWriter.writeVarInt(0) /* vOutputsSapling */;\n}\n\nexport function fromBufferV4(bufferReader: BufferReader, tx: ZcashTransaction): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L855-L857\n  tx.ins = readInputs(bufferReader);\n  tx.outs = readOutputs(bufferReader);\n  tx.locktime = bufferReader.readUInt32();\n\n  if (tx.isOverwinterCompatible()) {\n    tx.expiryHeight = bufferReader.readUInt32();\n  }\n\n  if (tx.isSaplingCompatible()) {\n    const valueBalance = bufferReader.readSlice(8);\n    if (!valueBalance.equals(VALUE_INT64_ZERO)) {\n      /* istanbul ignore next */\n      throw new UnsupportedTransactionError(`valueBalance must be zero`);\n    }\n\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L863\n    readEmptySaplingBundle(bufferReader);\n  }\n\n  if (tx.supportsJoinSplits()) {\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L869\n    readEmptyVector(bufferReader) /* vJoinSplit */;\n  }\n}\n\nexport function fromBufferV5(bufferReader: BufferReader, tx: ZcashTransaction): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L815\n  tx.consensusBranchId = bufferReader.readUInt32();\n  tx.locktime = bufferReader.readUInt32();\n  tx.expiryHeight = bufferReader.readUInt32();\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L828\n  tx.ins = readInputs(bufferReader);\n  tx.outs = readOutputs(bufferReader);\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L835\n  readEmptySaplingBundle(bufferReader);\n  readEmptyOrchardBundle(bufferReader);\n}\n\nexport function writeInputs(bufferWriter: BufferWriter, ins: TxInput[]): void {\n  bufferWriter.writeVarInt(ins.length);\n  ins.forEach(function (txIn) {\n    bufferWriter.writeSlice(txIn.hash);\n    bufferWriter.writeUInt32(txIn.index);\n    bufferWriter.writeVarSlice(txIn.script);\n    bufferWriter.writeUInt32(txIn.sequence);\n  });\n}\n\nexport function writeOutputs(bufferWriter: BufferWriter, outs: TxOutput[]): void {\n  bufferWriter.writeVarInt(outs.length);\n  outs.forEach(function (txOut) {\n    if ((txOut as any).valueBuffer) {\n      bufferWriter.writeSlice((txOut as any).valueBuffer);\n    } else {\n      bufferWriter.writeUInt64(txOut.value);\n    }\n\n    bufferWriter.writeVarSlice(txOut.script);\n  });\n}\n\nexport function toBufferV4(bufferWriter: BufferWriter, tx: ZcashTransaction): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1083\n  writeInputs(bufferWriter, tx.ins);\n  writeOutputs(bufferWriter, tx.outs);\n\n  bufferWriter.writeUInt32(tx.locktime);\n\n  if (tx.isOverwinterCompatible()) {\n    bufferWriter.writeUInt32(tx.expiryHeight);\n  }\n\n  if (tx.isSaplingCompatible()) {\n    bufferWriter.writeSlice(VALUE_INT64_ZERO);\n    bufferWriter.writeVarInt(0); // vShieldedSpendLength\n    bufferWriter.writeVarInt(0); // vShieldedOutputLength\n  }\n\n  if (tx.supportsJoinSplits()) {\n    bufferWriter.writeVarInt(0); // joinsSplits length\n  }\n}\n\nexport function toBufferV5(bufferWriter: BufferWriter, tx: ZcashTransaction): void {\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L825-L826\n  bufferWriter.writeUInt32(tx.consensusBranchId);\n  bufferWriter.writeUInt32(tx.locktime);\n  bufferWriter.writeUInt32(tx.expiryHeight);\n  writeInputs(bufferWriter, tx.ins);\n  writeOutputs(bufferWriter, tx.outs);\n\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1063\n  writeEmptySamplingBundle(bufferWriter);\n  // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L1081\n  writeEmptyOrchardBundle(bufferWriter);\n}\n"]}

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

export declare function getDefaultConsensusBranchIdForVersion(network: ZcashNetwork, version: number): number;
export declare class ZcashTransaction<TNumber extends number | bigint = number> extends UtxoTransaction<TNumber> {
export declare class ZcashTransaction extends UtxoTransaction {
network: ZcashNetwork;

@@ -23,5 +23,5 @@ static VERSION_JOINSPLITS_SUPPORT: number;

consensusBranchId: number;
constructor(network: ZcashNetwork, tx?: ZcashTransaction<TNumber>);
static fromBuffer<TNumber extends number | bigint = number>(buffer: Buffer, __noStrict: boolean, amountType?: 'number' | 'bigint', network?: ZcashNetwork): ZcashTransaction<TNumber>;
static fromBufferWithVersion<TNumber extends number | bigint>(buf: Buffer, network: ZcashNetwork, version?: number, amountType?: 'number' | 'bigint'): ZcashTransaction<TNumber>;
constructor(network: ZcashNetwork, tx?: ZcashTransaction);
static fromBuffer(buffer: Buffer, __noStrict: boolean, network?: ZcashNetwork): ZcashTransaction;
static fromBufferWithVersion(buf: Buffer, network: ZcashNetwork, version?: number): ZcashTransaction;
byteLength(): number;

@@ -58,7 +58,7 @@ isSaplingCompatible(): boolean;

*/
hashForSignatureByNetwork(inIndex: number | undefined, prevOutScript: Buffer, value: TNumber | undefined, hashType: number): Buffer;
hashForSignatureByNetwork(inIndex: number | undefined, prevOutScript: Buffer, value: number, hashType: number): Buffer;
toBuffer(buffer?: Buffer, initialOffset?: number): Buffer;
getHash(forWitness?: boolean): Buffer;
clone(): ZcashTransaction<TNumber>;
clone(): ZcashTransaction;
}
//# sourceMappingURL=ZcashTransaction.d.ts.map

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

}
static fromBuffer(buffer, __noStrict, amountType = 'number', network) {
static fromBuffer(buffer, __noStrict, network) {
/* istanbul ignore next */

@@ -97,6 +97,6 @@ if (!network) {

if (tx.version === 5) {
ZcashBufferutils_1.fromBufferV5(bufferReader, tx, amountType);
ZcashBufferutils_1.fromBufferV5(bufferReader, tx);
}
else {
ZcashBufferutils_1.fromBufferV4(bufferReader, tx, amountType);
ZcashBufferutils_1.fromBufferV4(bufferReader, tx);
}

@@ -111,4 +111,4 @@ if (__noStrict)

}
static fromBufferWithVersion(buf, network, version, amountType = 'number') {
const tx = ZcashTransaction.fromBuffer(buf, false, amountType, network);
static fromBufferWithVersion(buf, network, version) {
const tx = ZcashTransaction.fromBuffer(buf, false, network);
if (version) {

@@ -229,5 +229,2 @@ tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, version);

hashForSignatureByNetwork(inIndex, prevOutScript, value, hashType) {
if (value === undefined) {
throw new Error(`must provide value`);
}
// https://github.com/zcash/zcash/blob/v4.5.1/src/script/interpreter.cpp#L1175

@@ -343,2 +340,2 @@ if (this.version === 5) {

ZcashTransaction.VERSION5_BRANCH_NU5 = 500;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashTransaction.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transaction, crypto } from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nimport { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nconst varuint = require('varuint-bitcoin');\nconst typeforce = require('typeforce');\n\nimport { networks } from '../../networks';\nimport { UtxoTransaction, varSliceSize } from '../UtxoTransaction';\nimport { fromBufferV4, fromBufferV5, toBufferV4, toBufferV5, VALUE_INT64_ZERO } from './ZcashBufferutils';\nimport { getBlake2bHash, getSignatureDigest, getTxidDigest } from './hashZip0244';\n\nconst ZERO = Buffer.from('0000000000000000000000000000000000000000000000000000000000000000', 'hex');\n\nexport type ZcashNetwork = typeof networks.zcash | typeof networks.zcashTest;\n\n// https://github.com/zcash/zcash/blob/v4.7.0/src/primitives/transaction.h#L40\nconst SAPLING_VERSION_GROUP_ID = 0x892f2085;\n// https://github.com/zcash/zcash/blob/v4.7.0/src/primitives/transaction.h#L52\nconst ZIP225_VERSION_GROUP_ID = 0x26a7270a;\n\n// https://github.com/zcash/zcash/blob/v4.7.0/src/consensus/upgrades.cpp#L11\nconst OVERWINTER_BRANCH_ID = 0x5ba81b19;\nconst CANOPY_BRANCH_ID = 0xe9ff75a6;\nconst NU5_BRANCH_ID = 0xc2d6d0b4;\n\nexport class UnsupportedTransactionError extends Error {\n  constructor(message: string) {\n    super(message);\n  }\n}\n\nexport function getDefaultVersionGroupIdForVersion(version: number): number {\n  switch (version) {\n    case 400:\n    case 450:\n      return SAPLING_VERSION_GROUP_ID;\n    case 500:\n      return ZIP225_VERSION_GROUP_ID;\n  }\n  throw new Error(`no value for version ${version}`);\n}\n\nexport function getDefaultConsensusBranchIdForVersion(network: ZcashNetwork, version: number): number {\n  switch (version) {\n    case 1:\n    case 2:\n      return 0;\n    case 3:\n      return OVERWINTER_BRANCH_ID;\n    case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      // https://zips.z.cash/zip-0251\n      return CANOPY_BRANCH_ID;\n    case 4:\n    case 5:\n    case ZcashTransaction.VERSION4_BRANCH_NU5:\n    case ZcashTransaction.VERSION5_BRANCH_NU5:\n      // https://zips.z.cash/zip-0252\n      return NU5_BRANCH_ID;\n  }\n  throw new Error(`no value for version ${version}`);\n}\n\nexport class ZcashTransaction<TNumber extends number | bigint = number> extends UtxoTransaction<TNumber> {\n  static VERSION_JOINSPLITS_SUPPORT = 2;\n  static VERSION_OVERWINTER = 3;\n  static VERSION_SAPLING = 4;\n\n  static VERSION4_BRANCH_CANOPY = 400;\n  static VERSION4_BRANCH_NU5 = 450;\n  static VERSION5_BRANCH_NU5 = 500;\n\n  // 1 if the transaction is post overwinter upgrade, 0 otherwise\n  overwintered = 0;\n  // 0x03C48270 (63210096) for overwinter and 0x892F2085 (2301567109) for sapling\n  versionGroupId = 0;\n  // Block height after which this transactions will expire, or 0 to disable expiry\n  expiryHeight = 0;\n  consensusBranchId: number;\n\n  constructor(public network: ZcashNetwork, tx?: ZcashTransaction<TNumber>) {\n    super(network, tx);\n\n    let consensusBranchId;\n    if (tx) {\n      this.overwintered = tx.overwintered;\n      this.versionGroupId = tx.versionGroupId;\n      this.expiryHeight = tx.expiryHeight;\n\n      if (tx.consensusBranchId !== undefined) {\n        consensusBranchId = tx.consensusBranchId;\n      }\n    }\n    this.consensusBranchId = consensusBranchId ?? getDefaultConsensusBranchIdForVersion(network, this.version);\n  }\n\n  static fromBuffer<TNumber extends number | bigint = number>(\n    buffer: Buffer,\n    __noStrict: boolean,\n    amountType: 'number' | 'bigint' = 'number',\n    network?: ZcashNetwork\n  ): ZcashTransaction<TNumber> {\n    /* istanbul ignore next */\n    if (!network) {\n      throw new Error(`must provide network`);\n    }\n\n    const bufferReader = new BufferReader(buffer);\n    const tx = new ZcashTransaction<TNumber>(network);\n    tx.version = bufferReader.readInt32();\n\n    // Split the header into fOverwintered and nVersion\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L772\n    tx.overwintered = tx.version >>> 31; // Must be 1 for version 3 and up\n    tx.version = tx.version & 0x07fffffff; // 3 for overwinter\n    tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, tx.version);\n\n    if (tx.isOverwinterCompatible()) {\n      tx.versionGroupId = bufferReader.readUInt32();\n    }\n\n    if (tx.version === 5) {\n      fromBufferV5(bufferReader, tx, amountType);\n    } else {\n      fromBufferV4(bufferReader, tx, amountType);\n    }\n\n    if (__noStrict) return tx;\n    if (bufferReader.offset !== buffer.length) {\n      const trailing = buffer.slice(bufferReader.offset);\n      throw new Error(`Unexpected trailing bytes: ${trailing.toString('hex')}`);\n    }\n\n    return tx;\n  }\n\n  static fromBufferWithVersion<TNumber extends number | bigint>(\n    buf: Buffer,\n    network: ZcashNetwork,\n    version?: number,\n    amountType: 'number' | 'bigint' = 'number'\n  ): ZcashTransaction<TNumber> {\n    const tx = ZcashTransaction.fromBuffer<TNumber>(buf, false, amountType, network);\n    if (version) {\n      tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, version);\n    }\n    return tx;\n  }\n\n  byteLength(): number {\n    let byteLength = super.byteLength();\n    if (this.isOverwinterCompatible()) {\n      byteLength += 4; // nVersionGroupId\n    }\n    if (this.isOverwinterCompatible()) {\n      byteLength += 4; // nExpiryHeight\n    }\n    const emptyVectorLength = varuint.encodingLength(0);\n    if (this.version === 5) {\n      // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L822\n      byteLength += 4; // consensusBranchId\n      byteLength += emptyVectorLength; // saplingBundle inputs\n      byteLength += emptyVectorLength; // saplingBundle outputs\n      byteLength += 1; // orchardBundle (empty)\n    } else {\n      if (this.isSaplingCompatible()) {\n        // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L862\n        byteLength += 8; // valueBalance (uint64)\n        byteLength += emptyVectorLength; // inputs\n        byteLength += emptyVectorLength; // outputs\n      }\n      if (this.supportsJoinSplits()) {\n        //\n        byteLength += emptyVectorLength; // joinsplits\n      }\n    }\n    return byteLength;\n  }\n\n  isSaplingCompatible(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_SAPLING;\n  }\n\n  isOverwinterCompatible(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_OVERWINTER;\n  }\n\n  supportsJoinSplits(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_JOINSPLITS_SUPPORT;\n  }\n\n  /**\n   * Build a hash for all or none of the transaction inputs depending on the hashtype\n   * @param hashType\n   * @returns Buffer - BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getPrevoutHash(hashType: number): Buffer {\n    if (!(hashType & Transaction.SIGHASH_ANYONECANPAY)) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeSlice(txIn.hash);\n        bufferWriter.writeUInt32(txIn.index);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashPrevoutHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Build a hash for all or none of the transactions inputs sequence numbers depending on the hashtype\n   * @param hashType\n   * @returns Buffer BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getSequenceHash(hashType: number): Buffer {\n    if (\n      !(hashType & Transaction.SIGHASH_ANYONECANPAY) &&\n      (hashType & 0x1f) !== Transaction.SIGHASH_SINGLE &&\n      (hashType & 0x1f) !== Transaction.SIGHASH_NONE\n    ) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(4 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeUInt32(txIn.sequence);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashSequencHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Build a hash for one, all or none of the transaction outputs depending on the hashtype\n   * @param hashType\n   * @param inIndex\n   * @returns Buffer BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getOutputsHash(hashType: number, inIndex: number): Buffer {\n    if ((hashType & 0x1f) !== Transaction.SIGHASH_SINGLE && (hashType & 0x1f) !== Transaction.SIGHASH_NONE) {\n      // Find out the size of the outputs and write them\n      const txOutsSize = this.outs.reduce(function (sum, output) {\n        return sum + 8 + varSliceSize(output.script);\n      }, 0);\n\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(txOutsSize));\n\n      this.outs.forEach(function (out) {\n        bufferWriter.writeUInt64(out.value);\n        bufferWriter.writeVarSlice(out.script);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashOutputsHash');\n    } else if ((hashType & 0x1f) === Transaction.SIGHASH_SINGLE && inIndex < this.outs.length) {\n      // Write only the output specified in inIndex\n      const output = this.outs[inIndex];\n\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(8 + varSliceSize(output.script)));\n      bufferWriter.writeUInt64(output.value);\n      bufferWriter.writeVarSlice(output.script);\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashOutputsHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Hash transaction for signing a transparent transaction in Zcash. Protected transactions are not supported.\n   * @param inIndex\n   * @param prevOutScript\n   * @param value\n   * @param hashType\n   * @returns Buffer BLAKE2b hash\n   */\n  hashForSignatureByNetwork(\n    inIndex: number | undefined,\n    prevOutScript: Buffer,\n    value: TNumber | undefined,\n    hashType: number\n  ): Buffer {\n    if (value === undefined) {\n      throw new Error(`must provide value`);\n    }\n\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/script/interpreter.cpp#L1175\n    if (this.version === 5) {\n      return getSignatureDigest(this, inIndex, prevOutScript, value, hashType);\n    }\n\n    typeforce(types.tuple(types.UInt32, types.Buffer, types.Number), arguments);\n\n    if (inIndex === undefined) {\n      throw new Error(`invalid inIndex`);\n    }\n\n    /* istanbul ignore next */\n    if (inIndex >= this.ins.length) {\n      throw new Error('Input index is out of range');\n    }\n\n    /* istanbul ignore next */\n    if (!this.isOverwinterCompatible()) {\n      throw new Error(`unsupported version ${this.version}`);\n    }\n\n    const hashPrevouts = this.getPrevoutHash(hashType);\n    const hashSequence = this.getSequenceHash(hashType);\n    const hashOutputs = this.getOutputsHash(hashType, inIndex);\n    const hashJoinSplits = ZERO;\n    const hashShieldedSpends = ZERO;\n    const hashShieldedOutputs = ZERO;\n\n    let baseBufferSize = 0;\n    baseBufferSize += 4 * 5; // header, nVersionGroupId, lock_time, nExpiryHeight, hashType\n    baseBufferSize += 32 * 4; // 256 hashes: hashPrevouts, hashSequence, hashOutputs, hashJoinSplits\n    baseBufferSize += 4 * 2; // input.index, input.sequence\n    baseBufferSize += 8; // value\n    baseBufferSize += 32; // input.hash\n    baseBufferSize += varSliceSize(prevOutScript); // prevOutScript\n    if (this.isSaplingCompatible()) {\n      baseBufferSize += 32 * 2; // hashShieldedSpends and hashShieldedOutputs\n      baseBufferSize += 8; // valueBalance\n    }\n\n    const mask = this.overwintered ? 1 : 0;\n    const header = this.version | (mask << 31);\n\n    const bufferWriter = new BufferWriter(Buffer.alloc(baseBufferSize));\n    bufferWriter.writeInt32(header);\n    bufferWriter.writeUInt32(this.versionGroupId);\n    bufferWriter.writeSlice(hashPrevouts);\n    bufferWriter.writeSlice(hashSequence);\n    bufferWriter.writeSlice(hashOutputs);\n    bufferWriter.writeSlice(hashJoinSplits);\n    if (this.isSaplingCompatible()) {\n      bufferWriter.writeSlice(hashShieldedSpends);\n      bufferWriter.writeSlice(hashShieldedOutputs);\n    }\n    bufferWriter.writeUInt32(this.locktime);\n    bufferWriter.writeUInt32(this.expiryHeight);\n    if (this.isSaplingCompatible()) {\n      bufferWriter.writeSlice(VALUE_INT64_ZERO);\n    }\n    bufferWriter.writeInt32(hashType);\n\n    // The input being signed (replacing the scriptSig with scriptCode + amount)\n    // The prevout may already be contained in hashPrevout, and the nSequence\n    // may already be contained in hashSequence.\n    const input = this.ins[inIndex];\n    bufferWriter.writeSlice(input.hash);\n    bufferWriter.writeUInt32(input.index);\n    bufferWriter.writeVarSlice(prevOutScript);\n    bufferWriter.writeUInt64(value);\n    bufferWriter.writeUInt32(input.sequence);\n\n    const personalization = Buffer.alloc(16);\n    const prefix = 'ZcashSigHash';\n    personalization.write(prefix);\n    personalization.writeUInt32LE(this.consensusBranchId, prefix.length);\n\n    return getBlake2bHash(bufferWriter.buffer, personalization);\n  }\n\n  toBuffer(buffer?: Buffer, initialOffset = 0): Buffer {\n    if (!buffer) buffer = Buffer.allocUnsafe(this.byteLength());\n\n    const bufferWriter = new BufferWriter(buffer, initialOffset);\n\n    if (this.isOverwinterCompatible()) {\n      const mask = this.overwintered ? 1 : 0;\n      bufferWriter.writeInt32(this.version | (mask << 31)); // Set overwinter bit\n      bufferWriter.writeUInt32(this.versionGroupId);\n    } else {\n      bufferWriter.writeInt32(this.version);\n    }\n\n    if (this.version === 5) {\n      toBufferV5(bufferWriter, this);\n    } else {\n      toBufferV4(bufferWriter, this);\n    }\n\n    if (initialOffset !== undefined) {\n      return buffer.slice(initialOffset, bufferWriter.offset);\n    }\n    return buffer;\n  }\n\n  getHash(forWitness?: boolean): Buffer {\n    if (forWitness) {\n      throw new Error(`invalid argument`);\n    }\n    if (this.version === 5) {\n      return getTxidDigest(this);\n    }\n    return crypto.hash256(this.toBuffer());\n  }\n\n  clone(): ZcashTransaction<TNumber> {\n    return new ZcashTransaction(this.network, this);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashTransaction.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transaction, crypto } from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nimport { BufferReader, BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nconst varuint = require('varuint-bitcoin');\nconst typeforce = require('typeforce');\n\nimport { networks } from '../../networks';\nimport { UtxoTransaction, varSliceSize } from '../UtxoTransaction';\nimport { fromBufferV4, fromBufferV5, toBufferV4, toBufferV5, VALUE_INT64_ZERO } from './ZcashBufferutils';\nimport { getBlake2bHash, getSignatureDigest, getTxidDigest } from './hashZip0244';\n\nconst ZERO = Buffer.from('0000000000000000000000000000000000000000000000000000000000000000', 'hex');\n\nexport type ZcashNetwork = typeof networks.zcash | typeof networks.zcashTest;\n\n// https://github.com/zcash/zcash/blob/v4.7.0/src/primitives/transaction.h#L40\nconst SAPLING_VERSION_GROUP_ID = 0x892f2085;\n// https://github.com/zcash/zcash/blob/v4.7.0/src/primitives/transaction.h#L52\nconst ZIP225_VERSION_GROUP_ID = 0x26a7270a;\n\n// https://github.com/zcash/zcash/blob/v4.7.0/src/consensus/upgrades.cpp#L11\nconst OVERWINTER_BRANCH_ID = 0x5ba81b19;\nconst CANOPY_BRANCH_ID = 0xe9ff75a6;\nconst NU5_BRANCH_ID = 0xc2d6d0b4;\n\nexport class UnsupportedTransactionError extends Error {\n  constructor(message: string) {\n    super(message);\n  }\n}\n\nexport function getDefaultVersionGroupIdForVersion(version: number): number {\n  switch (version) {\n    case 400:\n    case 450:\n      return SAPLING_VERSION_GROUP_ID;\n    case 500:\n      return ZIP225_VERSION_GROUP_ID;\n  }\n  throw new Error(`no value for version ${version}`);\n}\n\nexport function getDefaultConsensusBranchIdForVersion(network: ZcashNetwork, version: number): number {\n  switch (version) {\n    case 1:\n    case 2:\n      return 0;\n    case 3:\n      return OVERWINTER_BRANCH_ID;\n    case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      // https://zips.z.cash/zip-0251\n      return CANOPY_BRANCH_ID;\n    case 4:\n    case 5:\n    case ZcashTransaction.VERSION4_BRANCH_NU5:\n    case ZcashTransaction.VERSION5_BRANCH_NU5:\n      // https://zips.z.cash/zip-0252\n      return NU5_BRANCH_ID;\n  }\n  throw new Error(`no value for version ${version}`);\n}\n\nexport class ZcashTransaction extends UtxoTransaction {\n  static VERSION_JOINSPLITS_SUPPORT = 2;\n  static VERSION_OVERWINTER = 3;\n  static VERSION_SAPLING = 4;\n\n  static VERSION4_BRANCH_CANOPY = 400;\n  static VERSION4_BRANCH_NU5 = 450;\n  static VERSION5_BRANCH_NU5 = 500;\n\n  // 1 if the transaction is post overwinter upgrade, 0 otherwise\n  overwintered = 0;\n  // 0x03C48270 (63210096) for overwinter and 0x892F2085 (2301567109) for sapling\n  versionGroupId = 0;\n  // Block height after which this transactions will expire, or 0 to disable expiry\n  expiryHeight = 0;\n  consensusBranchId: number;\n\n  constructor(public network: ZcashNetwork, tx?: ZcashTransaction) {\n    super(network, tx);\n\n    let consensusBranchId;\n    if (tx) {\n      this.overwintered = tx.overwintered;\n      this.versionGroupId = tx.versionGroupId;\n      this.expiryHeight = tx.expiryHeight;\n\n      if (tx.consensusBranchId !== undefined) {\n        consensusBranchId = tx.consensusBranchId;\n      }\n    }\n    this.consensusBranchId = consensusBranchId ?? getDefaultConsensusBranchIdForVersion(network, this.version);\n  }\n\n  static fromBuffer(buffer: Buffer, __noStrict: boolean, network?: ZcashNetwork): ZcashTransaction {\n    /* istanbul ignore next */\n    if (!network) {\n      throw new Error(`must provide network`);\n    }\n\n    const bufferReader = new BufferReader(buffer);\n    const tx = new ZcashTransaction(network);\n    tx.version = bufferReader.readInt32();\n\n    // Split the header into fOverwintered and nVersion\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L772\n    tx.overwintered = tx.version >>> 31; // Must be 1 for version 3 and up\n    tx.version = tx.version & 0x07fffffff; // 3 for overwinter\n    tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, tx.version);\n\n    if (tx.isOverwinterCompatible()) {\n      tx.versionGroupId = bufferReader.readUInt32();\n    }\n\n    if (tx.version === 5) {\n      fromBufferV5(bufferReader, tx);\n    } else {\n      fromBufferV4(bufferReader, tx);\n    }\n\n    if (__noStrict) return tx;\n    if (bufferReader.offset !== buffer.length) {\n      const trailing = buffer.slice(bufferReader.offset);\n      throw new Error(`Unexpected trailing bytes: ${trailing.toString('hex')}`);\n    }\n\n    return tx;\n  }\n\n  static fromBufferWithVersion(buf: Buffer, network: ZcashNetwork, version?: number): ZcashTransaction {\n    const tx = ZcashTransaction.fromBuffer(buf, false, network);\n    if (version) {\n      tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, version);\n    }\n    return tx;\n  }\n\n  byteLength(): number {\n    let byteLength = super.byteLength();\n    if (this.isOverwinterCompatible()) {\n      byteLength += 4; // nVersionGroupId\n    }\n    if (this.isOverwinterCompatible()) {\n      byteLength += 4; // nExpiryHeight\n    }\n    const emptyVectorLength = varuint.encodingLength(0);\n    if (this.version === 5) {\n      // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L822\n      byteLength += 4; // consensusBranchId\n      byteLength += emptyVectorLength; // saplingBundle inputs\n      byteLength += emptyVectorLength; // saplingBundle outputs\n      byteLength += 1; // orchardBundle (empty)\n    } else {\n      if (this.isSaplingCompatible()) {\n        // https://github.com/zcash/zcash/blob/v4.5.1/src/primitives/transaction.h#L862\n        byteLength += 8; // valueBalance (uint64)\n        byteLength += emptyVectorLength; // inputs\n        byteLength += emptyVectorLength; // outputs\n      }\n      if (this.supportsJoinSplits()) {\n        //\n        byteLength += emptyVectorLength; // joinsplits\n      }\n    }\n    return byteLength;\n  }\n\n  isSaplingCompatible(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_SAPLING;\n  }\n\n  isOverwinterCompatible(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_OVERWINTER;\n  }\n\n  supportsJoinSplits(): boolean {\n    return !!this.overwintered && this.version >= ZcashTransaction.VERSION_JOINSPLITS_SUPPORT;\n  }\n\n  /**\n   * Build a hash for all or none of the transaction inputs depending on the hashtype\n   * @param hashType\n   * @returns Buffer - BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getPrevoutHash(hashType: number): Buffer {\n    if (!(hashType & Transaction.SIGHASH_ANYONECANPAY)) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeSlice(txIn.hash);\n        bufferWriter.writeUInt32(txIn.index);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashPrevoutHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Build a hash for all or none of the transactions inputs sequence numbers depending on the hashtype\n   * @param hashType\n   * @returns Buffer BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getSequenceHash(hashType: number): Buffer {\n    if (\n      !(hashType & Transaction.SIGHASH_ANYONECANPAY) &&\n      (hashType & 0x1f) !== Transaction.SIGHASH_SINGLE &&\n      (hashType & 0x1f) !== Transaction.SIGHASH_NONE\n    ) {\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(4 * this.ins.length));\n\n      this.ins.forEach(function (txIn) {\n        bufferWriter.writeUInt32(txIn.sequence);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashSequencHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Build a hash for one, all or none of the transaction outputs depending on the hashtype\n   * @param hashType\n   * @param inIndex\n   * @returns Buffer BLAKE2b hash or 256-bit zero if doesn't apply\n   */\n  getOutputsHash(hashType: number, inIndex: number): Buffer {\n    if ((hashType & 0x1f) !== Transaction.SIGHASH_SINGLE && (hashType & 0x1f) !== Transaction.SIGHASH_NONE) {\n      // Find out the size of the outputs and write them\n      const txOutsSize = this.outs.reduce(function (sum, output) {\n        return sum + 8 + varSliceSize(output.script);\n      }, 0);\n\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(txOutsSize));\n\n      this.outs.forEach(function (out) {\n        bufferWriter.writeUInt64(out.value);\n        bufferWriter.writeVarSlice(out.script);\n      });\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashOutputsHash');\n    } else if ((hashType & 0x1f) === Transaction.SIGHASH_SINGLE && inIndex < this.outs.length) {\n      // Write only the output specified in inIndex\n      const output = this.outs[inIndex];\n\n      const bufferWriter = new BufferWriter(Buffer.allocUnsafe(8 + varSliceSize(output.script)));\n      bufferWriter.writeUInt64(output.value);\n      bufferWriter.writeVarSlice(output.script);\n\n      return getBlake2bHash(bufferWriter.buffer, 'ZcashOutputsHash');\n    }\n    return ZERO;\n  }\n\n  /**\n   * Hash transaction for signing a transparent transaction in Zcash. Protected transactions are not supported.\n   * @param inIndex\n   * @param prevOutScript\n   * @param value\n   * @param hashType\n   * @returns Buffer BLAKE2b hash\n   */\n  hashForSignatureByNetwork(\n    inIndex: number | undefined,\n    prevOutScript: Buffer,\n    value: number,\n    hashType: number\n  ): Buffer {\n    // https://github.com/zcash/zcash/blob/v4.5.1/src/script/interpreter.cpp#L1175\n    if (this.version === 5) {\n      return getSignatureDigest(this, inIndex, prevOutScript, value, hashType);\n    }\n\n    typeforce(types.tuple(types.UInt32, types.Buffer, types.Number), arguments);\n\n    if (inIndex === undefined) {\n      throw new Error(`invalid inIndex`);\n    }\n\n    /* istanbul ignore next */\n    if (inIndex >= this.ins.length) {\n      throw new Error('Input index is out of range');\n    }\n\n    /* istanbul ignore next */\n    if (!this.isOverwinterCompatible()) {\n      throw new Error(`unsupported version ${this.version}`);\n    }\n\n    const hashPrevouts = this.getPrevoutHash(hashType);\n    const hashSequence = this.getSequenceHash(hashType);\n    const hashOutputs = this.getOutputsHash(hashType, inIndex);\n    const hashJoinSplits = ZERO;\n    const hashShieldedSpends = ZERO;\n    const hashShieldedOutputs = ZERO;\n\n    let baseBufferSize = 0;\n    baseBufferSize += 4 * 5; // header, nVersionGroupId, lock_time, nExpiryHeight, hashType\n    baseBufferSize += 32 * 4; // 256 hashes: hashPrevouts, hashSequence, hashOutputs, hashJoinSplits\n    baseBufferSize += 4 * 2; // input.index, input.sequence\n    baseBufferSize += 8; // value\n    baseBufferSize += 32; // input.hash\n    baseBufferSize += varSliceSize(prevOutScript); // prevOutScript\n    if (this.isSaplingCompatible()) {\n      baseBufferSize += 32 * 2; // hashShieldedSpends and hashShieldedOutputs\n      baseBufferSize += 8; // valueBalance\n    }\n\n    const mask = this.overwintered ? 1 : 0;\n    const header = this.version | (mask << 31);\n\n    const bufferWriter = new BufferWriter(Buffer.alloc(baseBufferSize));\n    bufferWriter.writeInt32(header);\n    bufferWriter.writeUInt32(this.versionGroupId);\n    bufferWriter.writeSlice(hashPrevouts);\n    bufferWriter.writeSlice(hashSequence);\n    bufferWriter.writeSlice(hashOutputs);\n    bufferWriter.writeSlice(hashJoinSplits);\n    if (this.isSaplingCompatible()) {\n      bufferWriter.writeSlice(hashShieldedSpends);\n      bufferWriter.writeSlice(hashShieldedOutputs);\n    }\n    bufferWriter.writeUInt32(this.locktime);\n    bufferWriter.writeUInt32(this.expiryHeight);\n    if (this.isSaplingCompatible()) {\n      bufferWriter.writeSlice(VALUE_INT64_ZERO);\n    }\n    bufferWriter.writeInt32(hashType);\n\n    // The input being signed (replacing the scriptSig with scriptCode + amount)\n    // The prevout may already be contained in hashPrevout, and the nSequence\n    // may already be contained in hashSequence.\n    const input = this.ins[inIndex];\n    bufferWriter.writeSlice(input.hash);\n    bufferWriter.writeUInt32(input.index);\n    bufferWriter.writeVarSlice(prevOutScript);\n    bufferWriter.writeUInt64(value);\n    bufferWriter.writeUInt32(input.sequence);\n\n    const personalization = Buffer.alloc(16);\n    const prefix = 'ZcashSigHash';\n    personalization.write(prefix);\n    personalization.writeUInt32LE(this.consensusBranchId, prefix.length);\n\n    return getBlake2bHash(bufferWriter.buffer, personalization);\n  }\n\n  toBuffer(buffer?: Buffer, initialOffset = 0): Buffer {\n    if (!buffer) buffer = Buffer.allocUnsafe(this.byteLength());\n\n    const bufferWriter = new BufferWriter(buffer, initialOffset);\n\n    if (this.isOverwinterCompatible()) {\n      const mask = this.overwintered ? 1 : 0;\n      bufferWriter.writeInt32(this.version | (mask << 31)); // Set overwinter bit\n      bufferWriter.writeUInt32(this.versionGroupId);\n    } else {\n      bufferWriter.writeInt32(this.version);\n    }\n\n    if (this.version === 5) {\n      toBufferV5(bufferWriter, this);\n    } else {\n      toBufferV4(bufferWriter, this);\n    }\n\n    if (initialOffset !== undefined) {\n      return buffer.slice(initialOffset, bufferWriter.offset);\n    }\n    return buffer;\n  }\n\n  getHash(forWitness?: boolean): Buffer {\n    if (forWitness) {\n      throw new Error(`invalid argument`);\n    }\n    if (this.version === 5) {\n      return getTxidDigest(this);\n    }\n    return crypto.hash256(this.toBuffer());\n  }\n\n  clone(): ZcashTransaction {\n    return new ZcashTransaction(this.network, this);\n  }\n}\n"]}

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

import { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';
export declare class ZcashTransactionBuilder<TNumber extends number | bigint = number> extends UtxoTransactionBuilder<TNumber, ZcashTransaction<TNumber>> {
export declare class ZcashTransactionBuilder extends UtxoTransactionBuilder<ZcashTransaction> {
constructor(network: ZcashNetwork);
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction<TNumber>): ZcashTransaction<TNumber>;
static fromTransaction<TNumber extends number | bigint = number>(transaction: ZcashTransaction<TNumber>, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput<TNumber>[]): ZcashTransactionBuilder<TNumber>;
createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction): ZcashTransaction;
static fromTransaction(transaction: ZcashTransaction, network?: bitcoinjs.Network, prevOutput?: bitcoinjs.TxOutput[]): ZcashTransactionBuilder;
setVersion(version: number, overwinter?: boolean): void;

@@ -18,6 +18,6 @@ setDefaultsForVersion(network: Network, version: number): void;

setExpiryHeight(expiryHeight: number): void;
build(): ZcashTransaction<TNumber>;
buildIncomplete(): ZcashTransaction<TNumber>;
addOutput(scriptPubKey: string | Buffer, value: TNumber): number;
build(): ZcashTransaction;
buildIncomplete(): ZcashTransaction;
addOutput(scriptPubKey: string | Buffer, value: number): number;
}
//# sourceMappingURL=ZcashTransactionBuilder.d.ts.map

@@ -105,2 +105,2 @@ "use strict";

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 * as bitcoinjs from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nconst typeforce = require('typeforce');\n\nimport { Network } from '../..';\nimport {\n  getDefaultConsensusBranchIdForVersion,\n  getDefaultVersionGroupIdForVersion,\n  ZcashNetwork,\n  ZcashTransaction,\n} from './ZcashTransaction';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport { toOutputScript } from './address';\n\nexport class ZcashTransactionBuilder<TNumber extends number | bigint = number> extends UtxoTransactionBuilder<\n  TNumber,\n  ZcashTransaction<TNumber>\n> {\n  constructor(network: ZcashNetwork) {\n    super(network);\n  }\n\n  createInitialTransaction(network: Network, tx?: bitcoinjs.Transaction<TNumber>): ZcashTransaction<TNumber> {\n    return new ZcashTransaction<TNumber>(network as ZcashNetwork, tx as ZcashTransaction<TNumber>);\n  }\n\n  static fromTransaction<TNumber extends number | bigint = number>(\n    transaction: ZcashTransaction<TNumber>,\n    network?: bitcoinjs.Network,\n    prevOutput?: bitcoinjs.TxOutput<TNumber>[]\n  ): ZcashTransactionBuilder<TNumber> {\n    const txb = new ZcashTransactionBuilder<TNumber>(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    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.version = version;\n  }\n\n  setDefaultsForVersion(network: Network, version: number): void {\n    switch (version) {\n      case 4:\n      case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      case ZcashTransaction.VERSION4_BRANCH_NU5:\n        this.setVersion(4);\n        break;\n      case 5:\n      case ZcashTransaction.VERSION5_BRANCH_NU5:\n        this.setVersion(5);\n        break;\n      default:\n        throw new Error(`invalid version ${version}`);\n    }\n\n    this.tx.versionGroupId = getDefaultVersionGroupIdForVersion(version);\n    this.tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, 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<TNumber>, 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<TNumber> {\n    return super.build() as ZcashTransaction<TNumber>;\n  }\n\n  buildIncomplete(): ZcashTransaction<TNumber> {\n    return super.buildIncomplete() as ZcashTransaction<TNumber>;\n  }\n\n  addOutput(scriptPubKey: string | Buffer, value: TNumber): 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 { Network } from '../..';\nimport {\n  getDefaultConsensusBranchIdForVersion,\n  getDefaultVersionGroupIdForVersion,\n  ZcashNetwork,\n  ZcashTransaction,\n} from './ZcashTransaction';\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    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.version = version;\n  }\n\n  setDefaultsForVersion(network: Network, version: number): void {\n    switch (version) {\n      case 4:\n      case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      case ZcashTransaction.VERSION4_BRANCH_NU5:\n        this.setVersion(4);\n        break;\n      case 5:\n      case ZcashTransaction.VERSION5_BRANCH_NU5:\n        this.setVersion(5);\n        break;\n      default:\n        throw new Error(`invalid version ${version}`);\n    }\n\n    this.tx.versionGroupId = getDefaultVersionGroupIdForVersion(version);\n    this.tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, 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": "3.0.0-rc.0",
"version": "3.0.0-rc.1",
"description": "Client-side Bitcoin JavaScript library",

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

"bitcoin-ops": "^1.3.0",
"bitcoinjs-lib": "npm:@bitgo/bitcoinjs-lib@6.1.0-rc.4",
"bitcoinjs-lib": "npm:@bitgo/bitcoinjs-lib@6.1.0-rc.3",
"bn.js": "^5.2.1",

@@ -80,3 +80,3 @@ "bs58check": "^2.0.0",

"license": "MIT",
"gitHead": "c87c30518098b3bd892afb774b1d1530b2847757"
"gitHead": "24cf4dfcc0a52d168afd28caf5a7ae179d08eadc"
}

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 too big to display

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

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