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

@bitgo/utxo-lib

Package Overview
Dependencies
Maintainers
14
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 9.24.0 to 9.25.0

3

dist/src/bitgo/UtxoPsbt.d.ts

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

import { BIP32Interface } from 'bip32';
import { HDSigner, Psbt, TxOutput, Network } from '..';
import { HDSigner, Signer, Psbt, TxOutput, Network } from '..';
import { UtxoTransaction } from './UtxoTransaction';

@@ -169,2 +169,3 @@ import { Triple } from './types';

}): this;
signInput(inputIndex: number, keyPair: Signer, sighashTypes?: number[]): this;
signInputHD(inputIndex: number, hdKeyPair: HDTaprootSigner | HDTaprootMusig2Signer, params?: number[] | Partial<SignatureParams>): this;

@@ -171,0 +172,0 @@ private getMusig2Participants;

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

addForkId(hashType) {
/*
``The sighash type is altered to include a 24-bit fork id in its most significant bits.''
We also use unsigned right shift operator `>>>` to cast to UInt32
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Unsigned_right_shift
*/
if (hashType & UtxoTransaction.SIGHASH_FORKID) {

@@ -72,7 +77,2 @@ const forkId = networks_1.isBitcoinGold(this.network) ? 79 : 0;

if (addForkId) {
/*
``The sighash type is altered to include a 24-bit fork id in its most significant bits.''
We also use unsigned right shift operator `>>>` to cast to UInt32
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Unsigned_right_shift
*/
if (value === undefined) {

@@ -99,2 +99,2 @@ throw new Error(`must provide value`);

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 assert from 'assert';\nimport * as bitcoinjs from 'bitcoinjs-lib';\nimport * as varuint from 'varuint-bitcoin';\nimport { toTNumber } from './tnumber';\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<bigint | number>,\n    amountType?: 'bigint' | 'number'\n  ) {\n    super();\n    if (transaction) {\n      this.version = transaction.version;\n      this.locktime = transaction.locktime;\n      this.ins = transaction.ins.map((v) => ({ ...v, witness: [...v.witness] }));\n      if (transaction.outs.length) {\n        // amountType only matters if there are outs\n        const inAmountType = typeof transaction.outs[0].value;\n        assert(inAmountType === 'number' || inAmountType === 'bigint');\n        const outAmountType: 'number' | 'bigint' = amountType || inAmountType;\n        this.outs = transaction.outs.map((v) => ({ ...v, value: toTNumber(v.value, outAmountType) }));\n      }\n    }\n  }\n\n  protected static newTransaction<TNumber extends number | bigint = number>(\n    network: Network,\n    transaction?: bitcoinjs.Transaction<bigint | number>,\n    amountType?: 'number' | 'bigint'\n  ): UtxoTransaction<TNumber> {\n    return new UtxoTransaction<TNumber>(network, transaction, amountType);\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    return this.newTransaction<TNumber>(\n      network,\n      bitcoinjs.Transaction.fromBuffer<TNumber>(buf, noStrict, amountType),\n      amountType\n    );\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      case networks.ecash:\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, value?: TNumber): Buffer {\n    value = value ?? (this.ins[inIndex] as any).value;\n    return this.hashForSignatureByNetwork(inIndex, prevOutScript, value, hashType);\n  }\n\n  clone<TN2 extends bigint | number = TNumber>(amountType?: 'number' | 'bigint'): UtxoTransaction<TN2> {\n    // No need to clone. Everything is copied in the constructor.\n    return new UtxoTransaction<TN2>(this.network, this, amountType);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UtxoTransaction.js","sourceRoot":"","sources":["../../../src/bitgo/UtxoTransaction.ts"],"names":[],"mappings":";;;AAAA,iCAAiC;AACjC,2CAA2C;AAC3C,2CAA2C;AAC3C,uCAAsC;AAEtC,0CAA2E;AAE3E,SAAgB,YAAY,CAAC,KAAa;IACxC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC5B,OAAO,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC;AACjD,CAAC;AAHD,oCAGC;AAED,MAAa,eAA0D,SAAQ,SAAS,CAAC,WAAoB;IAK3G,YACS,OAAgB,EACvB,WAAoD,EACpD,UAAgC;QAEhC,KAAK,EAAE,CAAC;QAJD,YAAO,GAAP,OAAO,CAAS;QAKvB,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC;YACnC,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC;YACrC,IAAI,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3E,IAAI,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE;gBAC3B,4CAA4C;gBAC5C,MAAM,YAAY,GAAG,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBACtD,MAAM,CAAC,YAAY,KAAK,QAAQ,IAAI,YAAY,KAAK,QAAQ,CAAC,CAAC;gBAC/D,MAAM,aAAa,GAAwB,UAAU,IAAI,YAAY,CAAC;gBACtE,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,KAAK,EAAE,mBAAS,CAAC,CAAC,CAAC,KAAK,EAAE,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC;aAC/F;SACF;IACH,CAAC;IAES,MAAM,CAAC,cAAc,CAC7B,OAAgB,EAChB,WAAoD,EACpD,UAAgC;QAEhC,OAAO,IAAI,eAAe,CAAU,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;IACxE,CAAC;IAED,MAAM,CAAC,UAAU,CACf,GAAW,EACX,QAAiB,EACjB,aAAkC,QAAQ,EAC1C,OAAiB,EACjB,UAA0C;QAE1C,IAAI,CAAC,OAAO,EAAE;YACZ,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;SACzC;QACD,OAAO,IAAI,CAAC,cAAc,CACxB,OAAO,EACP,SAAS,CAAC,WAAW,CAAC,UAAU,CAAU,GAAG,EAAE,QAAQ,EAAE,UAAU,CAAC,EACpE,UAAU,CACX,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,QAAgB;QACxB;;;;WAIG;QACH,IAAI,QAAQ,GAAG,eAAe,CAAC,cAAc,EAAE;YAC7C,MAAM,MAAM,GAAG,wBAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YACpD,OAAO,CAAC,QAAQ,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;SACzC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,OAAe,EAAE,aAAqB,EAAE,KAAc,EAAE,QAAgB;QACvF,OAAO,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzF,CAAC;IAED;;OAEG;IACH,yBAAyB,CACvB,OAAe,EACf,aAAqB,EACrB,KAA0B,EAC1B,QAAgB;QAEhB,QAAQ,qBAAU,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAChC,KAAK,mBAAQ,CAAC,KAAK;gBACjB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;YACnC,KAAK,mBAAQ,CAAC,WAAW,CAAC;YAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;YACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;YAC1B,KAAK,mBAAQ,CAAC,KAAK;gBACjB;;;;;;;mBAOG;gBACH,MAAM,SAAS,GAAG,CAAC,QAAQ,GAAG,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;gBAElE,IAAI,SAAS,EAAE;oBACb,IAAI,KAAK,KAAK,SAAS,EAAE;wBACvB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;qBACvC;oBACD,OAAO,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;iBACxF;SACJ;QAED,OAAO,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;IAClE,CAAC;IAED,gBAAgB,CAAC,OAAe,EAAE,aAAqB,EAAE,QAAgB,EAAE,KAAe;QACxF,KAAK,GAAG,KAAK,aAAL,KAAK,cAAL,KAAK,GAAK,IAAI,CAAC,GAAG,CAAC,OAAO,CAAS,CAAC,KAAK,CAAC;QAClD,OAAO,IAAI,CAAC,yBAAyB,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;IACjF,CAAC;IAED,KAAK,CAAwC,UAAgC;QAC3E,6DAA6D;QAC7D,OAAO,IAAI,eAAe,CAAM,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;IAClE,CAAC;;AAjHH,0CAkHC;AAjHQ,8BAAc,GAAG,IAAI,CAAC;AAC7B,qCAAqC;AAC9B,yCAAyB,GAAG,eAAe,CAAC,cAAc,CAAC","sourcesContent":["import * as assert from 'assert';\nimport * as bitcoinjs from 'bitcoinjs-lib';\nimport * as varuint from 'varuint-bitcoin';\nimport { toTNumber } from './tnumber';\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<bigint | number>,\n    amountType?: 'bigint' | 'number'\n  ) {\n    super();\n    if (transaction) {\n      this.version = transaction.version;\n      this.locktime = transaction.locktime;\n      this.ins = transaction.ins.map((v) => ({ ...v, witness: [...v.witness] }));\n      if (transaction.outs.length) {\n        // amountType only matters if there are outs\n        const inAmountType = typeof transaction.outs[0].value;\n        assert(inAmountType === 'number' || inAmountType === 'bigint');\n        const outAmountType: 'number' | 'bigint' = amountType || inAmountType;\n        this.outs = transaction.outs.map((v) => ({ ...v, value: toTNumber(v.value, outAmountType) }));\n      }\n    }\n  }\n\n  protected static newTransaction<TNumber extends number | bigint = number>(\n    network: Network,\n    transaction?: bitcoinjs.Transaction<bigint | number>,\n    amountType?: 'number' | 'bigint'\n  ): UtxoTransaction<TNumber> {\n    return new UtxoTransaction<TNumber>(network, transaction, amountType);\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    return this.newTransaction<TNumber>(\n      network,\n      bitcoinjs.Transaction.fromBuffer<TNumber>(buf, noStrict, amountType),\n      amountType\n    );\n  }\n\n  addForkId(hashType: number): number {\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 (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      case networks.ecash:\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          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, value?: TNumber): Buffer {\n    value = value ?? (this.ins[inIndex] as any).value;\n    return this.hashForSignatureByNetwork(inIndex, prevOutScript, value, hashType);\n  }\n\n  clone<TN2 extends bigint | number = TNumber>(amountType?: 'number' | 'bigint'): UtxoTransaction<TN2> {\n    // No need to clone. Everything is copied in the constructor.\n    return new UtxoTransaction<TN2>(this.network, this, amountType);\n  }\n}\n"]}
{
"name": "@bitgo/utxo-lib",
"version": "9.24.0",
"version": "9.25.0",
"description": "Client-side Bitcoin JavaScript library",

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

"license": "MIT",
"gitHead": "38a8044e048a9b4a9fef80b15218d5df419465e2"
"gitHead": "fcc6a3464fa3c6ce3e0485fcb37b423be49d843d"
}

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

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