@bitgo-beta/utxo-lib
Advanced tools
Comparing version 2.4.2-beta.148 to 2.4.2-beta.149
@@ -176,2 +176,3 @@ "use strict"; | ||
case networks_1.networks.bitcoingold: | ||
case networks_1.networks.ecash: | ||
return bitcoinjs_lib_1.Transaction.SIGHASH_ALL | UtxoTransaction_1.UtxoTransaction.SIGHASH_FORKID; | ||
@@ -222,2 +223,2 @@ default: | ||
exports.signInput2Of3 = signInput2Of3; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":"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","sourcesContent":["import { BIP32Interface } from 'bip32';\n\nimport { Transaction, taproot, TxOutput, ScriptSignature } from 'bitcoinjs-lib';\n\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport {\n  createOutputScript2of3,\n  createOutputScriptP2shP2pk,\n  createSpendScriptP2tr,\n  ScriptType2Of3,\n  scriptType2Of3AsPrevOutType,\n} from './outputScripts';\nimport { Triple } from './types';\nimport { getMainnet, Network, networks } from '../networks';\nimport { ecc as eccLib } from '../noble_ecc';\nimport { parseSignatureScript2Of3 } from './parseInput';\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification =\n  | {\n      /** Set to the public key that signed for the signature */\n      signedBy: Buffer;\n      /** Set to the signature buffer */\n      signature: Buffer;\n    }\n  | { signedBy: undefined; signature: undefined };\n\n/**\n * @deprecated - use {@see verifySignaturesWithPublicKeys} instead\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @param prevOutputs - must be set for p2tr transactions\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  amount: TNumber,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput<TNumber>[]\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  if ((!input.script || input.script.length === 0) && input.witness.length === 0) {\n    // Unsigned input: no signatures.\n    return [];\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) =>\n      verificationSettings.publicKey === undefined ||\n      verificationSettings.publicKey.equals(buf) ||\n      verificationSettings.publicKey.slice(1).equals(buf)\n  );\n\n  return signatures.map((signatureBuffer): SignatureVerification => {\n    if (signatureBuffer === 0 || signatureBuffer.length === 0) {\n      return { signedBy: undefined, signature: undefined };\n    }\n\n    let hashType = Transaction.SIGHASH_DEFAULT;\n\n    if (signatureBuffer.length === 65) {\n      hashType = signatureBuffer[signatureBuffer.length - 1];\n      signatureBuffer = signatureBuffer.slice(0, -1);\n    }\n\n    if (parsedScript.scriptType === 'p2tr') {\n      if (verificationSettings.signatureIndex !== undefined) {\n        throw new Error(`signatureIndex parameter not supported for p2tr`);\n      }\n\n      if (!prevOutputs) {\n        throw new Error(`prevOutputs not set`);\n      }\n\n      if (prevOutputs.length !== transaction.ins.length) {\n        throw new Error(`prevOutputs length ${prevOutputs.length}, expected ${transaction.ins.length}`);\n      }\n\n      if (!('controlBlock' in parsedScript)) {\n        throw new Error('expected controlBlock');\n      }\n      const { controlBlock, pubScript } = parsedScript;\n      const leafHash = taproot.getTapleafHash(eccLib, controlBlock, pubScript);\n      const signatureHash = transaction.hashForWitnessV1(\n        inputIndex,\n        prevOutputs.map(({ script }) => script),\n        prevOutputs.map(({ value }) => value),\n        hashType,\n        leafHash\n      );\n\n      const signedBy = publicKeys.filter(\n        (k) => Buffer.isBuffer(signatureBuffer) && eccLib.verifySchnorr(signatureHash, k, signatureBuffer)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined, signature: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0], signature: signatureBuffer };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    } else {\n      // slice the last byte from the signature hash input because it's the hash type\n      const { signature, hashType } = ScriptSignature.decode(signatureBuffer);\n      const transactionHash =\n        parsedScript.scriptType === 'p2shP2wsh' || parsedScript.scriptType === 'p2wsh'\n          ? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)\n          : transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);\n      const signedBy = publicKeys.filter((publicKey) =>\n        eccLib.verify(\n          transactionHash,\n          publicKey,\n          signature,\n          /*\n            Strict verification (require lower-S value), as required by BIP-0146\n            https://github.com/bitcoin/bips/blob/master/bip-0146.mediawiki\n            https://github.com/bitcoin-core/secp256k1/blob/ac83be33/include/secp256k1.h#L478-L508\n            https://github.com/bitcoinjs/tiny-secp256k1/blob/v1.1.6/js.js#L231-L233\n          */\n          true\n        )\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined, signature: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0], signature: signatureBuffer };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    }\n  });\n}\n\n/**\n * @deprecated use {@see verifySignatureWithPublicKeys} instead\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n * @param prevOutputs - must be set for p2tr transactions\n */\nexport function verifySignature<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  amount: TNumber,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput<TNumber>[]\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings,\n    prevOutputs\n  ).filter(\n    (v) =>\n      // If no publicKey is set in verificationSettings, all signatures must be valid.\n      // Otherwise, a single valid signature by the specified pubkey is sufficient.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined &&\n        (verificationSettings.publicKey.equals(v.signedBy) ||\n          verificationSettings.publicKey.slice(1).equals(v.signedBy)))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n\n/**\n * @param v\n * @param publicKey\n * @return true iff signature is by publicKey (or xonly variant of publicKey)\n */\nfunction isSignatureByPublicKey(v: SignatureVerification, publicKey: Buffer): boolean {\n  return (\n    !!v.signedBy &&\n    (v.signedBy.equals(publicKey) ||\n      /* for p2tr signatures, we pass the pubkey in 33-byte format recover it from the signature in 32-byte format */\n      (publicKey.length === 33 && isSignatureByPublicKey(v, publicKey.slice(1))))\n  );\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param prevOutputs\n * @param publicKeys\n * @return array with signature corresponding to n-th key, undefined if no match found\n */\nexport function getSignaturesWithPublicKeys<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKeys: Buffer[]\n): Array<Buffer | undefined> {\n  if (transaction.ins.length !== prevOutputs.length) {\n    throw new Error(`input length must match prevOutputs length`);\n  }\n\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    prevOutputs[inputIndex].value,\n    {},\n    prevOutputs\n  );\n\n  return publicKeys.map((publicKey) => {\n    const v = signatureVerifications.find((v) => isSignatureByPublicKey(v, publicKey));\n    return v ? v.signature : undefined;\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param prevOutputs - transaction outputs for inputs\n * @param publicKeys - public keys to check signatures for\n * @return array of booleans indicating a valid signature for every pubkey in _publicKeys_\n */\nexport function verifySignatureWithPublicKeys<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKeys: Buffer[]\n): boolean[] {\n  return getSignaturesWithPublicKeys(transaction, inputIndex, prevOutputs, publicKeys).map((s) => s !== undefined);\n}\n\n/**\n * Wrapper for {@see verifySignatureWithPublicKeys} for single pubkey\n * @param transaction\n * @param inputIndex\n * @param prevOutputs\n * @param publicKey\n * @return true iff signature is valid\n */\nexport function verifySignatureWithPublicKey<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKey: Buffer\n): boolean {\n  return verifySignatureWithPublicKeys(transaction, inputIndex, prevOutputs, [publicKey])[0];\n}\n\nexport function getDefaultSigHash(network: Network, scriptType?: ScriptType2Of3): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return Transaction.SIGHASH_ALL | UtxoTransaction.SIGHASH_FORKID;\n    default:\n      return scriptType === 'p2tr' ? Transaction.SIGHASH_DEFAULT : Transaction.SIGHASH_ALL;\n  }\n}\n\nexport function signInputP2shP2pk<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  vin: number,\n  keyPair: BIP32Interface\n): void {\n  const prevOutScriptType = 'p2sh-p2pk';\n  const { redeemScript, witnessScript } = createOutputScriptP2shP2pk(keyPair.publicKey);\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network),\n    redeemScript,\n    witnessScript,\n    witnessValue: undefined,\n  });\n}\n\nexport function signInput2Of3<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  vin: number,\n  scriptType: ScriptType2Of3,\n  pubkeys: Triple<Buffer>,\n  keyPair: BIP32Interface,\n  cosigner: Buffer,\n  amount: TNumber\n): void {\n  let controlBlock;\n  let redeemScript;\n  let witnessScript;\n\n  const prevOutScriptType = scriptType2Of3AsPrevOutType(scriptType);\n  if (scriptType === 'p2tr') {\n    ({ witnessScript, controlBlock } = createSpendScriptP2tr(pubkeys, [keyPair.publicKey, cosigner]));\n  } else {\n    ({ redeemScript, witnessScript } = createOutputScript2of3(pubkeys, scriptType));\n  }\n\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network, scriptType),\n    redeemScript,\n    witnessScript,\n    witnessValue: amount,\n    controlBlock,\n  });\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":";;;AAEA,iDAAgF;AAEhF,uDAAoD;AAEpD,mDAMyB;AAEzB,0CAA4D;AAC5D,4CAA6C;AAC7C,6CAAwD;AA8BxD;;;;;;;;;GASG;AACH,SAAgB,yBAAyB,CACvC,WAAqC,EACrC,UAAkB,EAClB,MAAe,EACf,uBAA6C,EAAE,EAC/C,WAAiC;IAEjC,0BAA0B;IAC1B,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE;QACpB,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;KACxC;IAED,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC1C,0BAA0B;IAC1B,IAAI,CAAC,KAAK,EAAE;QACV,MAAM,IAAI,KAAK,CAAC,qBAAqB,UAAU,EAAE,CAAC,CAAC;KACpD;IAED,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;QAC9E,iCAAiC;QACjC,OAAO,EAAE,CAAC;KACX;IAED,MAAM,YAAY,GAAG,qCAAwB,CAAC,KAAK,CAAC,CAAC;IAErD,MAAM,UAAU,GAAG,YAAY,CAAC,UAAU;SACvC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;SAC5B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,oBAAoB,CAAC,cAAc,KAAK,SAAS,IAAI,oBAAoB,CAAC,cAAc,KAAK,CAAC,CAAC,CAAC;IAEpH,MAAM,UAAU,GAAG,YAAY,CAAC,UAAU,CAAC,MAAM,CAC/C,CAAC,GAAG,EAAE,EAAE,CACN,oBAAoB,CAAC,SAAS,KAAK,SAAS;QAC5C,oBAAoB,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC;QAC1C,oBAAoB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CACtD,CAAC;IAEF,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,eAAe,EAAyB,EAAE;QAC/D,IAAI,eAAe,KAAK,CAAC,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;YACzD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;SACtD;QAED,IAAI,QAAQ,GAAG,2BAAW,CAAC,eAAe,CAAC;QAE3C,IAAI,eAAe,CAAC,MAAM,KAAK,EAAE,EAAE;YACjC,QAAQ,GAAG,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACvD,eAAe,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SAChD;QAED,IAAI,YAAY,CAAC,UAAU,KAAK,MAAM,EAAE;YACtC,IAAI,oBAAoB,CAAC,cAAc,KAAK,SAAS,EAAE;gBACrD,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;aACpE;YAED,IAAI,CAAC,WAAW,EAAE;gBAChB,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;aACxC;YAED,IAAI,WAAW,CAAC,MAAM,KAAK,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE;gBACjD,MAAM,IAAI,KAAK,CAAC,sBAAsB,WAAW,CAAC,MAAM,cAAc,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;aACjG;YAED,IAAI,CAAC,CAAC,cAAc,IAAI,YAAY,CAAC,EAAE;gBACrC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;aAC1C;YACD,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,YAAY,CAAC;YACjD,MAAM,QAAQ,GAAG,uBAAO,CAAC,cAAc,CAAC,eAAM,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC;YACzE,MAAM,aAAa,GAAG,WAAW,CAAC,gBAAgB,CAChD,UAAU,EACV,WAAW,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,EACvC,WAAW,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,EACrC,QAAQ,EACR,QAAQ,CACT,CAAC;YAEF,MAAM,QAAQ,GAAG,UAAU,CAAC,MAAM,CAChC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,eAAM,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC,EAAE,eAAe,CAAC,CACnG,CAAC;YAEF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;aACtD;YACD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC;aAC9D;YACD,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;aAAM;YACL,+EAA+E;YAC/E,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,+BAAe,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;YACxE,MAAM,eAAe,GACnB,YAAY,CAAC,UAAU,KAAK,WAAW,IAAI,YAAY,CAAC,UAAU,KAAK,OAAO;gBAC5E,CAAC,CAAC,WAAW,CAAC,gBAAgB,CAAC,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC;gBACpF,CAAC,CAAC,WAAW,CAAC,yBAAyB,CAAC,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;YAClG,MAAM,QAAQ,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAC/C,eAAM,CAAC,MAAM,CACX,eAAe,EACf,SAAS,EACT,SAAS;YACT;;;;;cAKE;YACF,IAAI,CACL,CACF,CAAC;YAEF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;aACtD;YACD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC;aAC9D;YACD,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AApHD,8DAoHC;AAED;;;;;;;GAOG;AACH,SAAgB,eAAe,CAC7B,WAAqC,EACrC,UAAkB,EAClB,MAAe,EACf,uBAA6C,EAAE,EAC/C,WAAiC;IAEjC,MAAM,sBAAsB,GAAG,yBAAyB,CACtD,WAAW,EACX,UAAU,EACV,MAAM,EACN,oBAAoB,EACpB,WAAW,CACZ,CAAC,MAAM,CACN,CAAC,CAAC,EAAE,EAAE;IACJ,gFAAgF;IAChF,6EAA6E;IAC7E,oBAAoB,CAAC,SAAS,KAAK,SAAS;QAC5C,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS;YACvB,CAAC,oBAAoB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC;gBAChD,oBAAoB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CACnE,CAAC;IAEF,OAAO,sBAAsB,CAAC,MAAM,GAAG,CAAC,IAAI,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC;AAC5G,CAAC;AAxBD,0CAwBC;AAED;;;;GAIG;AACH,SAAS,sBAAsB,CAAC,CAAwB,EAAE,SAAiB;IACzE,OAAO,CACL,CAAC,CAAC,CAAC,CAAC,QAAQ;QACZ,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC;YAC3B,+GAA+G;YAC/G,CAAC,SAAS,CAAC,MAAM,KAAK,EAAE,IAAI,sBAAsB,CAAC,CAAC,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAC9E,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,2BAA2B,CACzC,WAAqC,EACrC,UAAkB,EAClB,WAAgC,EAChC,UAAoB;IAEpB,IAAI,WAAW,CAAC,GAAG,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM,EAAE;QACjD,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;KAC/D;IAED,MAAM,sBAAsB,GAAG,yBAAyB,CACtD,WAAW,EACX,UAAU,EACV,WAAW,CAAC,UAAU,CAAC,CAAC,KAAK,EAC7B,EAAE,EACF,WAAW,CACZ,CAAC;IAEF,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;QAClC,MAAM,CAAC,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,sBAAsB,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;QACnF,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC;AAtBD,kEAsBC;AAED;;;;;;GAMG;AACH,SAAgB,6BAA6B,CAC3C,WAAqC,EACrC,UAAkB,EAClB,WAAgC,EAChC,UAAoB;IAEpB,OAAO,2BAA2B,CAAC,WAAW,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;AACnH,CAAC;AAPD,sEAOC;AAED;;;;;;;GAOG;AACH,SAAgB,4BAA4B,CAC1C,WAAqC,EACrC,UAAkB,EAClB,WAAgC,EAChC,SAAiB;IAEjB,OAAO,6BAA6B,CAAC,WAAW,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7F,CAAC;AAPD,oEAOC;AAED,SAAgB,iBAAiB,CAAC,OAAgB,EAAE,UAA2B;IAC7E,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,2BAAW,CAAC,WAAW,GAAG,iCAAe,CAAC,cAAc,CAAC;QAClE;YACE,OAAO,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,2BAAW,CAAC,eAAe,CAAC,CAAC,CAAC,2BAAW,CAAC,WAAW,CAAC;KACxF;AACH,CAAC;AAVD,8CAUC;AAED,SAAgB,iBAAiB,CAC/B,SAA0C,EAC1C,GAAW,EACX,OAAuB;IAEvB,MAAM,iBAAiB,GAAG,WAAW,CAAC;IACtC,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,0CAA0B,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACtF,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IAEpC,SAAS,CAAC,IAAI,CAAC;QACb,GAAG;QACH,iBAAiB;QACjB,OAAO;QACP,QAAQ,EAAE,iBAAiB,CAAC,SAAS,CAAC,OAAkB,CAAC;QACzD,YAAY;QACZ,aAAa;QACb,YAAY,EAAE,SAAS;KACxB,CAAC,CAAC;AACL,CAAC;AAlBD,8CAkBC;AAED,SAAgB,aAAa,CAC3B,SAA0C,EAC1C,GAAW,EACX,UAA0B,EAC1B,OAAuB,EACvB,OAAuB,EACvB,QAAgB,EAChB,MAAe;IAEf,IAAI,YAAY,CAAC;IACjB,IAAI,YAAY,CAAC;IACjB,IAAI,aAAa,CAAC;IAElB,MAAM,iBAAiB,GAAG,2CAA2B,CAAC,UAAU,CAAC,CAAC;IAClE,IAAI,UAAU,KAAK,MAAM,EAAE;QACzB,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,qCAAqB,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;KACnG;SAAM;QACL,CAAC,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,sCAAsB,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;KACjF;IAED,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IAEpC,SAAS,CAAC,IAAI,CAAC;QACb,GAAG;QACH,iBAAiB;QACjB,OAAO;QACP,QAAQ,EAAE,iBAAiB,CAAC,SAAS,CAAC,OAAkB,EAAE,UAAU,CAAC;QACrE,YAAY;QACZ,aAAa;QACb,YAAY,EAAE,MAAM;QACpB,YAAY;KACb,CAAC,CAAC;AACL,CAAC;AAhCD,sCAgCC","sourcesContent":["import { BIP32Interface } from 'bip32';\n\nimport { Transaction, taproot, TxOutput, ScriptSignature } from 'bitcoinjs-lib';\n\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport {\n  createOutputScript2of3,\n  createOutputScriptP2shP2pk,\n  createSpendScriptP2tr,\n  ScriptType2Of3,\n  scriptType2Of3AsPrevOutType,\n} from './outputScripts';\nimport { Triple } from './types';\nimport { getMainnet, Network, networks } from '../networks';\nimport { ecc as eccLib } from '../noble_ecc';\nimport { parseSignatureScript2Of3 } from './parseInput';\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification =\n  | {\n      /** Set to the public key that signed for the signature */\n      signedBy: Buffer;\n      /** Set to the signature buffer */\n      signature: Buffer;\n    }\n  | { signedBy: undefined; signature: undefined };\n\n/**\n * @deprecated - use {@see verifySignaturesWithPublicKeys} instead\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @param prevOutputs - must be set for p2tr transactions\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  amount: TNumber,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput<TNumber>[]\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  if ((!input.script || input.script.length === 0) && input.witness.length === 0) {\n    // Unsigned input: no signatures.\n    return [];\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) =>\n      verificationSettings.publicKey === undefined ||\n      verificationSettings.publicKey.equals(buf) ||\n      verificationSettings.publicKey.slice(1).equals(buf)\n  );\n\n  return signatures.map((signatureBuffer): SignatureVerification => {\n    if (signatureBuffer === 0 || signatureBuffer.length === 0) {\n      return { signedBy: undefined, signature: undefined };\n    }\n\n    let hashType = Transaction.SIGHASH_DEFAULT;\n\n    if (signatureBuffer.length === 65) {\n      hashType = signatureBuffer[signatureBuffer.length - 1];\n      signatureBuffer = signatureBuffer.slice(0, -1);\n    }\n\n    if (parsedScript.scriptType === 'p2tr') {\n      if (verificationSettings.signatureIndex !== undefined) {\n        throw new Error(`signatureIndex parameter not supported for p2tr`);\n      }\n\n      if (!prevOutputs) {\n        throw new Error(`prevOutputs not set`);\n      }\n\n      if (prevOutputs.length !== transaction.ins.length) {\n        throw new Error(`prevOutputs length ${prevOutputs.length}, expected ${transaction.ins.length}`);\n      }\n\n      if (!('controlBlock' in parsedScript)) {\n        throw new Error('expected controlBlock');\n      }\n      const { controlBlock, pubScript } = parsedScript;\n      const leafHash = taproot.getTapleafHash(eccLib, controlBlock, pubScript);\n      const signatureHash = transaction.hashForWitnessV1(\n        inputIndex,\n        prevOutputs.map(({ script }) => script),\n        prevOutputs.map(({ value }) => value),\n        hashType,\n        leafHash\n      );\n\n      const signedBy = publicKeys.filter(\n        (k) => Buffer.isBuffer(signatureBuffer) && eccLib.verifySchnorr(signatureHash, k, signatureBuffer)\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined, signature: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0], signature: signatureBuffer };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    } else {\n      // slice the last byte from the signature hash input because it's the hash type\n      const { signature, hashType } = ScriptSignature.decode(signatureBuffer);\n      const transactionHash =\n        parsedScript.scriptType === 'p2shP2wsh' || parsedScript.scriptType === 'p2wsh'\n          ? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)\n          : transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);\n      const signedBy = publicKeys.filter((publicKey) =>\n        eccLib.verify(\n          transactionHash,\n          publicKey,\n          signature,\n          /*\n            Strict verification (require lower-S value), as required by BIP-0146\n            https://github.com/bitcoin/bips/blob/master/bip-0146.mediawiki\n            https://github.com/bitcoin-core/secp256k1/blob/ac83be33/include/secp256k1.h#L478-L508\n            https://github.com/bitcoinjs/tiny-secp256k1/blob/v1.1.6/js.js#L231-L233\n          */\n          true\n        )\n      );\n\n      if (signedBy.length === 0) {\n        return { signedBy: undefined, signature: undefined };\n      }\n      if (signedBy.length === 1) {\n        return { signedBy: signedBy[0], signature: signatureBuffer };\n      }\n      throw new Error(`illegal state: signed by multiple public keys`);\n    }\n  });\n}\n\n/**\n * @deprecated use {@see verifySignatureWithPublicKeys} instead\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n * @param prevOutputs - must be set for p2tr transactions\n */\nexport function verifySignature<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  amount: TNumber,\n  verificationSettings: VerificationSettings = {},\n  prevOutputs?: TxOutput<TNumber>[]\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings,\n    prevOutputs\n  ).filter(\n    (v) =>\n      // If no publicKey is set in verificationSettings, all signatures must be valid.\n      // Otherwise, a single valid signature by the specified pubkey is sufficient.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined &&\n        (verificationSettings.publicKey.equals(v.signedBy) ||\n          verificationSettings.publicKey.slice(1).equals(v.signedBy)))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n\n/**\n * @param v\n * @param publicKey\n * @return true iff signature is by publicKey (or xonly variant of publicKey)\n */\nfunction isSignatureByPublicKey(v: SignatureVerification, publicKey: Buffer): boolean {\n  return (\n    !!v.signedBy &&\n    (v.signedBy.equals(publicKey) ||\n      /* for p2tr signatures, we pass the pubkey in 33-byte format recover it from the signature in 32-byte format */\n      (publicKey.length === 33 && isSignatureByPublicKey(v, publicKey.slice(1))))\n  );\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param prevOutputs\n * @param publicKeys\n * @return array with signature corresponding to n-th key, undefined if no match found\n */\nexport function getSignaturesWithPublicKeys<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKeys: Buffer[]\n): Array<Buffer | undefined> {\n  if (transaction.ins.length !== prevOutputs.length) {\n    throw new Error(`input length must match prevOutputs length`);\n  }\n\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    prevOutputs[inputIndex].value,\n    {},\n    prevOutputs\n  );\n\n  return publicKeys.map((publicKey) => {\n    const v = signatureVerifications.find((v) => isSignatureByPublicKey(v, publicKey));\n    return v ? v.signature : undefined;\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param prevOutputs - transaction outputs for inputs\n * @param publicKeys - public keys to check signatures for\n * @return array of booleans indicating a valid signature for every pubkey in _publicKeys_\n */\nexport function verifySignatureWithPublicKeys<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKeys: Buffer[]\n): boolean[] {\n  return getSignaturesWithPublicKeys(transaction, inputIndex, prevOutputs, publicKeys).map((s) => s !== undefined);\n}\n\n/**\n * Wrapper for {@see verifySignatureWithPublicKeys} for single pubkey\n * @param transaction\n * @param inputIndex\n * @param prevOutputs\n * @param publicKey\n * @return true iff signature is valid\n */\nexport function verifySignatureWithPublicKey<TNumber extends number | bigint>(\n  transaction: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  prevOutputs: TxOutput<TNumber>[],\n  publicKey: Buffer\n): boolean {\n  return verifySignatureWithPublicKeys(transaction, inputIndex, prevOutputs, [publicKey])[0];\n}\n\nexport function getDefaultSigHash(network: Network, scriptType?: ScriptType2Of3): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.ecash:\n      return Transaction.SIGHASH_ALL | UtxoTransaction.SIGHASH_FORKID;\n    default:\n      return scriptType === 'p2tr' ? Transaction.SIGHASH_DEFAULT : Transaction.SIGHASH_ALL;\n  }\n}\n\nexport function signInputP2shP2pk<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  vin: number,\n  keyPair: BIP32Interface\n): void {\n  const prevOutScriptType = 'p2sh-p2pk';\n  const { redeemScript, witnessScript } = createOutputScriptP2shP2pk(keyPair.publicKey);\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network),\n    redeemScript,\n    witnessScript,\n    witnessValue: undefined,\n  });\n}\n\nexport function signInput2Of3<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  vin: number,\n  scriptType: ScriptType2Of3,\n  pubkeys: Triple<Buffer>,\n  keyPair: BIP32Interface,\n  cosigner: Buffer,\n  amount: TNumber\n): void {\n  let controlBlock;\n  let redeemScript;\n  let witnessScript;\n\n  const prevOutScriptType = scriptType2Of3AsPrevOutType(scriptType);\n  if (scriptType === 'p2tr') {\n    ({ witnessScript, controlBlock } = createSpendScriptP2tr(pubkeys, [keyPair.publicKey, cosigner]));\n  } else {\n    ({ redeemScript, witnessScript } = createOutputScript2of3(pubkeys, scriptType));\n  }\n\n  keyPair.network = txBuilder.network;\n\n  txBuilder.sign({\n    vin,\n    prevOutScriptType,\n    keyPair,\n    hashType: getDefaultSigHash(txBuilder.network as Network, scriptType),\n    redeemScript,\n    witnessScript,\n    witnessValue: amount,\n    controlBlock,\n  });\n}\n"]} |
@@ -40,2 +40,3 @@ "use strict"; | ||
case networks_1.networks.dogecoin: | ||
case networks_1.networks.ecash: | ||
case networks_1.networks.litecoin: | ||
@@ -63,2 +64,3 @@ return UtxoPsbt_1.UtxoPsbt.fromBuffer(buf, { network, bip32PathsAbsolute }); | ||
case networks_1.networks.dogecoin: | ||
case networks_1.networks.ecash: | ||
case networks_1.networks.litecoin: | ||
@@ -85,2 +87,3 @@ return UtxoPsbt_1.UtxoPsbt.fromTransaction(tx, prevOuts); | ||
case networks_1.networks.bitcoingold: | ||
case networks_1.networks.ecash: | ||
return 2; | ||
@@ -99,2 +102,3 @@ case networks_1.networks.zcash: | ||
case networks_1.networks.bitcoingold: | ||
case networks_1.networks.ecash: | ||
if (version !== 2) { | ||
@@ -120,2 +124,3 @@ throw new Error(`invalid version`); | ||
case networks_1.networks.bitcoingold: | ||
case networks_1.networks.ecash: | ||
if (version !== 2) { | ||
@@ -153,2 +158,3 @@ throw new Error(`invalid version`); | ||
case networks_1.networks.dogecoin: | ||
case networks_1.networks.ecash: | ||
case networks_1.networks.litecoin: { | ||
@@ -218,2 +224,2 @@ psbt = UtxoPsbt_1.UtxoPsbt.createPsbt(psbtOpts); | ||
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 { UtxoPsbt, PsbtOpts } from './UtxoPsbt';\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport { DashPsbt } from './dash/DashPsbt';\nimport { DashTransaction } from './dash/DashTransaction';\nimport { DashTransactionBuilder } from './dash/DashTransactionBuilder';\nimport { ZcashPsbt } from './zcash/ZcashPsbt';\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  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.ecash:\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\nexport function createPsbtFromBuffer(\n  buf: Buffer,\n  network: Network,\n  bip32PathsAbsolute = false\n): UtxoPsbt<UtxoTransaction<bigint>> {\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 UtxoPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n    case networks.dash:\n      return DashPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n    case networks.zcash:\n      return ZcashPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`invalid network`);\n}\n\nexport function createPsbtFromHex(\n  hex: string,\n  network: Network,\n  bip32PathsAbsolute = false\n): UtxoPsbt<UtxoTransaction<bigint>> {\n  return createPsbtFromBuffer(Buffer.from(hex, 'hex'), network, bip32PathsAbsolute);\n}\n\nexport function createPsbtFromTransaction(\n  tx: UtxoTransaction<bigint>,\n  prevOuts: TxOutput<bigint>[]\n): UtxoPsbt<UtxoTransaction<bigint>> {\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 UtxoPsbt.fromTransaction(tx, prevOuts);\n    case networks.dash:\n      return DashPsbt.fromTransaction(tx, prevOuts);\n    case networks.zcash:\n      return ZcashPsbt.fromTransaction(tx, prevOuts);\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 setPsbtDefaults(\n  psbt: UtxoPsbt<UtxoTransaction<bigint>>,\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      break;\n    case networks.zcash:\n      if (\n        ![\n          ZcashTransaction.VERSION4_BRANCH_CANOPY,\n          ZcashTransaction.VERSION4_BRANCH_NU5,\n          ZcashTransaction.VERSION5_BRANCH_NU5,\n        ].includes(version)\n      ) {\n        throw new Error(`invalid version`);\n      }\n      (psbt as ZcashPsbt).setDefaultsForVersion(network, version);\n      break;\n    default:\n      if (version !== 1) {\n        throw new Error(`invalid version`);\n      }\n      // FIXME: set version here, because there's a bug in the upstream PSBT\n      // that defaults transactions to v2.\n      psbt.setVersion(version);\n  }\n}\n\nexport function createPsbtForNetwork(\n  psbtOpts: PsbtOpts,\n  { version }: { version?: number } = {}\n): UtxoPsbt<UtxoTransaction<bigint>> {\n  let psbt;\n\n  switch (getMainnet(psbtOpts.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      psbt = UtxoPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    case networks.dash: {\n      psbt = DashPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    case networks.zcash: {\n      psbt = ZcashPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    default:\n      throw new Error(`unsupported network`);\n  }\n\n  setPsbtDefaults(psbt, psbtOpts.network, { version });\n\n  return psbt;\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.ecash:\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.ecash:\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":";;;AAEA,0CAA4D;AAE5D,yCAAgD;AAChD,uDAAoD;AACpD,qEAAkE;AAClE,8CAA2C;AAC3C,4DAAyD;AACzD,0EAAuE;AACvE,iDAA8C;AAC9C,6EAA0E;AAC1E,+DAA0E;AAE1E,SAAgB,2BAA2B,CACzC,GAAW,EACX,OAAgB,EAChB,EAAE,OAAO,KAA2B,EAAE,EACtC,aAAkC,QAAQ;IAE1C,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ;YACpB,OAAO,iCAAe,CAAC,UAAU,CAAU,GAAG,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAC9E,KAAK,mBAAQ,CAAC,IAAI;YAChB,OAAO,iCAAe,CAAC,UAAU,CAAU,GAAG,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAC9E,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,mCAAgB,CAAC,qBAAqB,CAAU,GAAG,EAAE,OAAuB,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;KAC7G;IAED,0BAA0B;IAC1B,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AAvBD,kEAuBC;AAED,SAAgB,oBAAoB,CAClC,GAAW,EACX,OAAgB,EAChB,kBAAkB,GAAG,KAAK;IAE1B,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ;YACpB,OAAO,mBAAQ,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACnE,KAAK,mBAAQ,CAAC,IAAI;YAChB,OAAO,mBAAQ,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACnE,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,qBAAS,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,CAAC;KACrE;IAED,0BAA0B;IAC1B,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AAtBD,oDAsBC;AAED,SAAgB,iBAAiB,CAC/B,GAAW,EACX,OAAgB,EAChB,kBAAkB,GAAG,KAAK;IAE1B,OAAO,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,kBAAkB,CAAC,CAAC;AACpF,CAAC;AAND,8CAMC;AAED,SAAgB,yBAAyB,CACvC,EAA2B,EAC3B,QAA4B;IAE5B,QAAQ,qBAAU,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE;QAC9B,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ;YACpB,OAAO,mBAAQ,CAAC,eAAe,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAChD,KAAK,mBAAQ,CAAC,IAAI;YAChB,OAAO,mBAAQ,CAAC,eAAe,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAChD,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,qBAAS,CAAC,eAAe,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;KAClD;IAED,0BAA0B;IAC1B,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AArBD,8DAqBC;AAED,0BAA0B;AAC1B,SAAgB,wBAAwB,CACtC,GAAW,EACX,OAAgB,EAChB,aAAkC,QAAQ;IAE1C,OAAO,2BAA2B,CAAU,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,UAAU,CAAC,CAAC;AAChG,CAAC;AAND,4DAMC;AAED,SAAgB,4BAA4B,CAAC,OAAgB;IAC3D,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,CAAC,CAAC;QACX,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,mCAAgB,CAAC,mBAAmB,CAAC;QAC9C;YACE,OAAO,CAAC,CAAC;KACZ;AACH,CAAC;AAZD,oEAYC;AAED,SAAgB,6BAA6B,CAC3C,GAAoC,EACpC,OAAgB,EAChB,EAAE,OAAO,GAAG,4BAA4B,CAAC,OAAO,CAAC,KAA2B,EAAE;IAE9E,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,KAAK;YACjB,IAAI,OAAO,KAAK,CAAC,EAAE;gBACjB,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;aACpC;YACD,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YACxB,MAAM;QACR,KAAK,mBAAQ,CAAC,KAAK;YAChB,GAAwC,CAAC,qBAAqB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAClF,MAAM;QACR;YACE,IAAI,OAAO,KAAK,CAAC,EAAE;gBACjB,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;aACpC;KACJ;AACH,CAAC;AAvBD,sEAuBC;AAED,SAAgB,eAAe,CAC7B,IAAuC,EACvC,OAAgB,EAChB,EAAE,OAAO,GAAG,4BAA4B,CAAC,OAAO,CAAC,KAA2B,EAAE;IAE9E,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,KAAK;YACjB,IAAI,OAAO,KAAK,CAAC,EAAE;gBACjB,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;aACpC;YACD,MAAM;QACR,KAAK,mBAAQ,CAAC,KAAK;YACjB,IACE,CAAC;gBACC,mCAAgB,CAAC,sBAAsB;gBACvC,mCAAgB,CAAC,mBAAmB;gBACpC,mCAAgB,CAAC,mBAAmB;aACrC,CAAC,QAAQ,CAAC,OAAO,CAAC,EACnB;gBACA,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;aACpC;YACA,IAAkB,CAAC,qBAAqB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAC5D,MAAM;QACR;YACE,IAAI,OAAO,KAAK,CAAC,EAAE;gBACjB,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;aACpC;YACD,sEAAsE;YACtE,oCAAoC;YACpC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;KAC5B;AACH,CAAC;AAlCD,0CAkCC;AAED,SAAgB,oBAAoB,CAClC,QAAkB,EAClB,EAAE,OAAO,KAA2B,EAAE;IAEtC,IAAI,IAAI,CAAC;IAET,QAAQ,qBAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;QACpC,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ,CAAC,CAAC;YACtB,IAAI,GAAG,mBAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrC,MAAM;SACP;QACD,KAAK,mBAAQ,CAAC,IAAI,CAAC,CAAC;YAClB,IAAI,GAAG,mBAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrC,MAAM;SACP;QACD,KAAK,mBAAQ,CAAC,KAAK,CAAC,CAAC;YACnB,IAAI,GAAG,qBAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACtC,MAAM;SACP;QACD;YACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;KAC1C;IAED,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAErD,OAAO,IAAI,CAAC;AACd,CAAC;AAhCD,oDAgCC;AAED,SAAgB,kCAAkC,CAChD,OAAgB,EAChB,EAAE,OAAO,KAA2B,EAAE;IAEtC,IAAI,GAAG,CAAC;IACR,QAAQ,qBAAU,CAAC,OAAO,CAAC,EAAE;QAC3B,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ,CAAC,CAAC;YACtB,GAAG,GAAG,IAAI,+CAAsB,CAAU,OAAO,CAAC,CAAC;YACnD,MAAM;SACP;QACD,KAAK,mBAAQ,CAAC,IAAI;YAChB,GAAG,GAAG,IAAI,+CAAsB,CAAU,OAAO,CAAC,CAAC;YACnD,MAAM;QACR,KAAK,mBAAQ,CAAC,KAAK,CAAC,CAAC;YACnB,GAAG,GAAG,IAAI,iDAAuB,CAAU,OAAuB,CAAC,CAAC;YACpE,MAAM;SACP;QACD;YACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;KAC1C;IAED,6BAA6B,CAAU,GAAG,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAElE,OAAO,GAAG,CAAC;AACb,CAAC;AA9BD,gFA8BC;AAED,SAAgB,uCAAuC,CACrD,EAA4B,EAC5B,WAAiC;IAEjC,QAAQ,qBAAU,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE;QAC9B,KAAK,mBAAQ,CAAC,OAAO,CAAC;QACtB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,SAAS,CAAC;QACxB,KAAK,mBAAQ,CAAC,WAAW,CAAC;QAC1B,KAAK,mBAAQ,CAAC,QAAQ,CAAC;QACvB,KAAK,mBAAQ,CAAC,KAAK,CAAC;QACpB,KAAK,mBAAQ,CAAC,QAAQ;YACpB,OAAO,+CAAsB,CAAC,eAAe,CAAU,EAAE,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QACrF,KAAK,mBAAQ,CAAC,IAAI;YAChB,OAAO,+CAAsB,CAAC,eAAe,CAC3C,EAA8B,EAC9B,SAAS,EACT,WAAkC,CACnC,CAAC;QACJ,KAAK,mBAAQ,CAAC,KAAK;YACjB,OAAO,iDAAuB,CAAC,eAAe,CAC5C,EAA+B,EAC/B,SAAS,EACT,WAAkC,CACnC,CAAC;KACL;IAED,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AA5BD,0FA4BC","sourcesContent":["import { TxOutput } from 'bitcoinjs-lib';\n\nimport { networks, Network, getMainnet } from '../networks';\n\nimport { UtxoPsbt, PsbtOpts } from './UtxoPsbt';\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { UtxoTransactionBuilder } from './UtxoTransactionBuilder';\nimport { DashPsbt } from './dash/DashPsbt';\nimport { DashTransaction } from './dash/DashTransaction';\nimport { DashTransactionBuilder } from './dash/DashTransactionBuilder';\nimport { ZcashPsbt } from './zcash/ZcashPsbt';\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  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.ecash:\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\nexport function createPsbtFromBuffer(\n  buf: Buffer,\n  network: Network,\n  bip32PathsAbsolute = false\n): UtxoPsbt<UtxoTransaction<bigint>> {\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.ecash:\n    case networks.litecoin:\n      return UtxoPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n    case networks.dash:\n      return DashPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n    case networks.zcash:\n      return ZcashPsbt.fromBuffer(buf, { network, bip32PathsAbsolute });\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`invalid network`);\n}\n\nexport function createPsbtFromHex(\n  hex: string,\n  network: Network,\n  bip32PathsAbsolute = false\n): UtxoPsbt<UtxoTransaction<bigint>> {\n  return createPsbtFromBuffer(Buffer.from(hex, 'hex'), network, bip32PathsAbsolute);\n}\n\nexport function createPsbtFromTransaction(\n  tx: UtxoTransaction<bigint>,\n  prevOuts: TxOutput<bigint>[]\n): UtxoPsbt<UtxoTransaction<bigint>> {\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.ecash:\n    case networks.litecoin:\n      return UtxoPsbt.fromTransaction(tx, prevOuts);\n    case networks.dash:\n      return DashPsbt.fromTransaction(tx, prevOuts);\n    case networks.zcash:\n      return ZcashPsbt.fromTransaction(tx, prevOuts);\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    case networks.ecash:\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    case networks.ecash:\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 setPsbtDefaults(\n  psbt: UtxoPsbt<UtxoTransaction<bigint>>,\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    case networks.ecash:\n      if (version !== 2) {\n        throw new Error(`invalid version`);\n      }\n      break;\n    case networks.zcash:\n      if (\n        ![\n          ZcashTransaction.VERSION4_BRANCH_CANOPY,\n          ZcashTransaction.VERSION4_BRANCH_NU5,\n          ZcashTransaction.VERSION5_BRANCH_NU5,\n        ].includes(version)\n      ) {\n        throw new Error(`invalid version`);\n      }\n      (psbt as ZcashPsbt).setDefaultsForVersion(network, version);\n      break;\n    default:\n      if (version !== 1) {\n        throw new Error(`invalid version`);\n      }\n      // FIXME: set version here, because there's a bug in the upstream PSBT\n      // that defaults transactions to v2.\n      psbt.setVersion(version);\n  }\n}\n\nexport function createPsbtForNetwork(\n  psbtOpts: PsbtOpts,\n  { version }: { version?: number } = {}\n): UtxoPsbt<UtxoTransaction<bigint>> {\n  let psbt;\n\n  switch (getMainnet(psbtOpts.network)) {\n    case networks.bitcoin:\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n    case networks.dogecoin:\n    case networks.ecash:\n    case networks.litecoin: {\n      psbt = UtxoPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    case networks.dash: {\n      psbt = DashPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    case networks.zcash: {\n      psbt = ZcashPsbt.createPsbt(psbtOpts);\n      break;\n    }\n    default:\n      throw new Error(`unsupported network`);\n  }\n\n  setPsbtDefaults(psbt, psbtOpts.network, { version });\n\n  return psbt;\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.ecash:\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.ecash:\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"]} |
{ | ||
"name": "@bitgo-beta/utxo-lib", | ||
"version": "2.4.2-beta.148", | ||
"version": "2.4.2-beta.149", | ||
"description": "Client-side Bitcoin JavaScript library", | ||
@@ -49,3 +49,3 @@ "main": "./dist/src/index.js", | ||
"dependencies": { | ||
"@bitgo-beta/blake2b": "3.0.4-beta.148", | ||
"@bitgo-beta/blake2b": "3.0.4-beta.149", | ||
"@noble/secp256k1": "1.6.3", | ||
@@ -87,3 +87,3 @@ "bech32": "^2.0.0", | ||
"license": "MIT", | ||
"gitHead": "3e2f6405801b0e5f51f824edbad4cf596df682ab" | ||
"gitHead": "177879f8783e8a7af3b8d5eb1d38dd9b18392880" | ||
} |
@@ -55,2 +55,3 @@ # BitGo UTXO library | ||
|Dash|`utxolib.networks.dash`|`utxolib.networks.dash`| | ||
|eCash|`utxolib.networks.ecash`|`utxolib.networks.ecashTestnet`| | ||
|Litecoin|`utxolib.networks.litecoin`|`utxolib.networks.litecoinTest`| | ||
@@ -57,0 +58,0 @@ |Zcash|`utxolib.networks.zcash`|`utxolib.networks.zcashTest`| |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
1127427
8821
60
+ Added@bitgo-beta/blake2b@3.0.4-beta.149(transitive)
+ Added@bitgo-beta/blake2b-wasm@3.0.4-beta.149(transitive)
- Removed@bitgo-beta/blake2b@3.0.4-beta.148(transitive)
- Removed@bitgo-beta/blake2b-wasm@3.0.4-beta.148(transitive)