utxo-lib 1.0.8 → 1.0.9

Sign up to get free protection for your applications and to get access to all the features.
@@ -268,7 +268,7 @@ function parseSignatureScript(input) {
268
268
  const parsers = [parseP2sh2Of3, parseP2shP2wsh2Of3, parseP2wsh2Of3, parseP2tr2Of3, parseP2shP2pk];
269
269
  for (const f of parsers) {
270
270
  const parsed = f({
271
- script: (decScript === null || decScript === void 0 ? void 0 : decScript.length) === 0 ? null : decScript,
271
+ script: decScript?.length === 0 ? null : decScript,
272
272
  witness: input.witness.length === 0 ? null : input.witness,
273
273
  });
274
274
  if (parsed instanceof MatchError) {
@@ -341,4 +341,4 @@ function parsePubScript(inputPubScript, scriptType) {
341
341
  return result;
342
342
  }
343
343
  exports.parsePubScript = parsePubScript;
344
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseInput.js","sourceRoot":"","sources":["../../../src/bitgo/parseInput.ts"],"names":[],"mappings":"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","sourcesContent":["import * as opcodes from 'bitcoin-ops';\nimport { TxInput, script as bscript } from 'bitcoinjs-lib';\n\nimport { isScriptType2Of3, ScriptType, ScriptType2Of3 } from './outputScripts';\nimport { isTriple } from './types';\n\nexport function isPlaceholderSignature(v: number | Buffer): boolean {\n  if (Buffer.isBuffer(v)) {\n    return v.length === 0;\n  }\n  return v === 0;\n}\n\n/**\n * @return true iff P2TR script path's control block matches BitGo's need\n */\nexport function isValidControlBock(controlBlock: Buffer): boolean {\n  // The last stack element is called the control block c, and must have length 33 + 32m\n  return Buffer.isBuffer(controlBlock) && 33 <= controlBlock.length && controlBlock.length % 32 === 1;\n}\n\n/**\n * @return script path level for P2TR control block\n */\nexport function calculateScriptPathLevel(controlBlock: Buffer): number {\n  if (!Buffer.isBuffer(controlBlock)) {\n    throw new Error('Invalid control block type.');\n  }\n  if (controlBlock.length === 65) {\n    return 1;\n  }\n  if (controlBlock.length === 97) {\n    return 2;\n  }\n  throw new Error('unexpected control block length.');\n}\n\n/**\n * @return leaf version for P2TR control block.\n */\nexport function getScriptPathLevel(controlBlock: Buffer): number {\n  if (Buffer.isBuffer(controlBlock) && controlBlock.length > 0) {\n    return controlBlock[0] & 0xfe;\n  }\n  throw new Error('unexpected leafVersion.');\n}\n\ninterface ParsedScript {\n  scriptType: ScriptType;\n}\n\nexport type ParsedPubScript = ParsedScript;\nexport type ParsedSignatureScript = ParsedScript;\n\nexport interface ParsedSignatureScriptP2shP2pk extends ParsedSignatureScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n}\n\nexport interface ParsedPubScriptTaprootScriptPath extends ParsedPubScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedPubScript2Of3 extends ParsedPubScript {\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n  redeemScript: Buffer | undefined;\n  witnessScript: Buffer | undefined;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';\n  publicKeys: [Buffer, Buffer, Buffer];\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    /* Partially signed transactions with placeholder signatures.\n       For p2sh, the placeholder is OP_0 (number 0) */\n    | [Buffer | 0, Buffer | 0, Buffer | 0];\n  pubScript: Buffer;\n  redeemScript: Buffer | undefined;\n  witnessScript: Buffer | undefined;\n}\n\n/**\n * Keypath spends only have a single pubkey and single signature\n */\nexport interface ParsedSignatureScriptTaprootKeyPath extends ParsedSignatureScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n  pubScript: Buffer;\n}\n\n/**\n * Taproot Scriptpath spends are more similar to regular p2ms spends and have two public keys and\n * two signatures\n */\nexport interface ParsedSignatureScriptTaprootScriptPath extends ParsedSignatureScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer, Buffer];\n  signatures: [Buffer, Buffer];\n  controlBlock: Buffer;\n  leafVersion: number;\n  /** Indicates the level inside the taptree. */\n  scriptPathLevel: number;\n  pubScript: Buffer;\n}\n\nexport type ParsedSignatureScriptTaproot = ParsedSignatureScriptTaprootKeyPath | ParsedSignatureScriptTaprootScriptPath;\n\ntype DecompiledScript = Array<Buffer | number>;\n\n/**\n * Static script elements\n */\ntype ScriptPatternConstant =\n  | 'OP_0'\n  | 'OP_1'\n  | 'OP_2'\n  | 'OP_3'\n  | 'OP_CHECKMULTISIG'\n  | 'OP_CHECKSIG'\n  | 'OP_CHECKSIGVERIFY';\n\n/**\n * Script elements that can be captured\n */\ntype ScriptPatternCapture =\n  | ':pubkey'\n  | ':pubkey-xonly'\n  | ':signature'\n  | ':control-block'\n  | { ':script': ScriptPatternElement[] };\n\ntype ScriptPatternElement = ScriptPatternConstant | ScriptPatternCapture;\n\n/**\n * Result for a successful script match\n */\ntype MatchResult = {\n  ':pubkey': Buffer[];\n  ':pubkey-xonly': Buffer[];\n  ':control-block': Buffer[];\n  ':signature': (Buffer | 0)[];\n  ':script': { buffer: Buffer; match: MatchResult }[];\n};\n\nfunction emptyMatchResult(): MatchResult {\n  return {\n    ':pubkey': [],\n    ':pubkey-xonly': [],\n    ':control-block': [],\n    ':signature': [],\n    ':script': [],\n  };\n}\n\nclass MatchError extends Error {\n  // this property is required to prohibit `return new Error()` when the return type demands `MatchError`\n  __type = 'MatchError';\n  constructor(message: string) {\n    super(message);\n  }\n\n  static forPatternElement(p: ScriptPatternElement): MatchError {\n    if (typeof p === 'object' && ':script' in p) {\n      return new MatchError(`error matching nested script`);\n    }\n    return new MatchError(`error matching ${p}`);\n  }\n}\n\n/**\n * @param script\n * @param pattern\n * @return MatchResult if script matches pattern. The result will contain the matched values.\n */\nfunction matchScript(script: DecompiledScript, pattern: ScriptPatternElement[]): MatchResult | MatchError {\n  /**\n   * Match a single script element with a ScriptPatternElement\n   */\n  function matchElement(e: Buffer | number, p: ScriptPatternElement): MatchResult | boolean {\n    switch (p) {\n      case 'OP_0':\n        return e === opcodes.OP_0 || (Buffer.isBuffer(e) && e.length === 0);\n      case 'OP_1':\n      case 'OP_2':\n      case 'OP_3':\n      case 'OP_CHECKMULTISIG':\n      case 'OP_CHECKSIG':\n      case 'OP_CHECKSIGVERIFY':\n        return e === opcodes[p];\n      case ':pubkey':\n        return Buffer.isBuffer(e) && e.length === 33;\n      case ':pubkey-xonly':\n        return Buffer.isBuffer(e) && e.length === 32;\n      case ':signature':\n        return Buffer.isBuffer(e) || isPlaceholderSignature(e);\n      case ':control-block':\n        return Buffer.isBuffer(e) && isValidControlBock(e);\n      default:\n        throw new Error(`unknown pattern element ${p}`);\n    }\n  }\n\n  if (script.length !== pattern.length) {\n    return new MatchError(`length mismatch`);\n  }\n\n  // Go over each pattern element.\n  // Collect captures into a result object.\n  return pattern.reduce((obj: MatchResult | MatchError, p, i): MatchResult | MatchError => {\n    // if we had a previous mismatch, short-circuit\n    if (obj instanceof MatchError) {\n      return obj;\n    }\n\n    const e = script[i];\n\n    // for ':script' pattern elements, decompile script element and recurse\n    if (typeof p === 'object' && ':script' in p) {\n      if (!Buffer.isBuffer(e)) {\n        return new MatchError(`expected buffer for :script`);\n      }\n      const dec = bscript.decompile(e);\n      if (!dec) {\n        return new MatchError(`error decompiling nested script`);\n      }\n      const match = matchScript(dec, p[':script']);\n      if (match instanceof MatchError) {\n        return match;\n      }\n      obj[':script'].push({\n        buffer: e,\n        match,\n      });\n      return obj;\n    }\n\n    const match = matchElement(e, p);\n    if (!match) {\n      return MatchError.forPatternElement(p);\n    }\n\n    // if pattern element is a capture, add it to the result obj\n    if (p === ':signature' && e === 0) {\n      obj[p].push(e);\n    } else if (p in obj) {\n      if (!Buffer.isBuffer(e)) {\n        throw new Error(`invalid capture value`);\n      }\n      obj[p].push(e);\n    }\n\n    return obj;\n  }, emptyMatchResult());\n}\n\n/**\n * @param script\n * @param patterns\n * @return first match\n */\nfunction matchScriptSome(script: DecompiledScript, patterns: ScriptPatternElement[][]): MatchResult | MatchError {\n  for (const p of patterns) {\n    const m = matchScript(script, p);\n    if (m instanceof MatchError) {\n      continue;\n    }\n    return m;\n  }\n  return new MatchError(`no match for script`);\n}\n\ntype InputScripts<TScript, TWitness> = {\n  script: TScript;\n  witness: TWitness;\n};\n\ntype InputScriptsLegacy = InputScripts<DecompiledScript, null>;\ntype InputScriptsWrappedSegwit = InputScripts<DecompiledScript, Buffer[]>;\ntype InputScriptsNativeSegwit = InputScripts<null, Buffer[]>;\n\ntype InputScriptsUnknown = InputScripts<DecompiledScript | null, Buffer[] | null>;\n\ntype InputParser<T extends ParsedSignatureScriptP2shP2pk | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot> = (\n  p: InputScriptsUnknown\n) => T | MatchError;\n\nexport type InputPubScript = Buffer;\n\ntype PubScriptParser<T extends ParsedPubScriptTaprootScriptPath | ParsedPubScript2Of3> = (\n  p: InputPubScript,\n  ScriptType2Of3\n) => T | MatchError;\n\nfunction isLegacy(p: InputScriptsUnknown): p is InputScriptsLegacy {\n  return Boolean(p.script && !p.witness);\n}\n\nfunction isWrappedSegwit(p: InputScriptsUnknown): p is InputScriptsWrappedSegwit {\n  return Boolean(p.script && p.witness);\n}\n\nfunction isNativeSegwit(p: InputScriptsUnknown): p is InputScriptsNativeSegwit {\n  return Boolean(!p.script && p.witness);\n}\n\nconst parseP2shP2pk: InputParser<ParsedSignatureScriptP2shP2pk> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  const match = matchScript(p.script, [':signature', { ':script': [':pubkey', 'OP_CHECKSIG'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  return {\n    scriptType: 'p2shP2pk',\n    publicKeys: match[':script'][0].match[':pubkey'] as [Buffer],\n    signatures: match[':signature'] as [Buffer],\n  };\n};\n\nfunction parseP2ms(\n  decScript: DecompiledScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedSignatureScript2Of3 | MatchError {\n  const pattern2Of3: ScriptPatternElement[] = ['OP_2', ':pubkey', ':pubkey', ':pubkey', 'OP_3', 'OP_CHECKMULTISIG'];\n\n  const match = matchScriptSome(decScript, [\n    /* full-signed, no placeholder signature */\n    ['OP_0', ':signature', ':signature', { ':script': pattern2Of3 }],\n    /* half-signed, placeholder signatures */\n    ['OP_0', ':signature', ':signature', ':signature', { ':script': pattern2Of3 }],\n  ]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [redeemScript] = match[':script'];\n\n  if (!isTriple(redeemScript.match[':pubkey'])) {\n    throw new Error(`invalid pubkey count`);\n  }\n\n  return {\n    scriptType,\n    publicKeys: redeemScript.match[':pubkey'],\n    pubScript: redeemScript.buffer,\n    signatures: match[':signature'] as ParsedSignatureScript2Of3['signatures'],\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n}\n\nconst parseP2sh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  return parseP2ms(p.script, 'p2sh');\n};\n\nconst parseP2shP2wsh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isWrappedSegwit(p)) {\n    return new MatchError(`expected wrapped segwit input`);\n  }\n  return { ...parseP2ms(p.witness, 'p2shP2wsh'), redeemScript: p.script[0] as Buffer };\n};\n\nconst parseP2wsh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  return parseP2ms(p.witness, 'p2wsh');\n};\n\nconst parseP2tr2Of3: InputParser<ParsedSignatureScriptTaproot> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  // assumes no annex\n  const match = matchScript(p.witness, [\n    ':signature',\n    ':signature',\n    { ':script': [':pubkey-xonly', 'OP_CHECKSIGVERIFY', ':pubkey-xonly', 'OP_CHECKSIG'] },\n    ':control-block',\n  ]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const [controlBlock] = match[':control-block'];\n  const scriptPathLevel = calculateScriptPathLevel(controlBlock);\n\n  const leafVersion = getScriptPathLevel(controlBlock);\n\n  return {\n    scriptType: 'p2tr',\n    pubScript: match[':script'][0].buffer,\n    publicKeys: match[':script'][0].match[':pubkey-xonly'] as [Buffer, Buffer],\n    signatures: match[':signature'] as [Buffer, Buffer],\n    controlBlock,\n    scriptPathLevel,\n    leafVersion,\n  };\n};\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: TxInput\n): ParsedSignatureScriptP2shP2pk | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const decScript = bscript.decompile(input.script);\n  const parsers = [parseP2sh2Of3, parseP2shP2wsh2Of3, parseP2wsh2Of3, parseP2tr2Of3, parseP2shP2pk] as const;\n  for (const f of parsers) {\n    const parsed = f({\n      script: decScript?.length === 0 ? null : decScript,\n      witness: input.witness.length === 0 ? null : input.witness,\n    });\n    if (parsed instanceof MatchError) {\n      continue;\n    }\n    return parsed;\n  }\n  throw new Error(`could not parse input`);\n}\n\nexport function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input);\n\n  if (!isScriptType2Of3(result.scriptType)) {\n    throw new Error(`invalid script type`);\n  }\n\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (result.publicKeys.length !== 3 && (result.publicKeys.length !== 2 || result.scriptType !== 'p2tr')) {\n    throw new Error(`unexpected pubkey count`);\n  }\n\n  return result as ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot;\n}\n\nconst parseP2msPubScript: PubScriptParser<ParsedPubScript2Of3> = (\n  pubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n) => {\n  const match = matchScript(\n    [pubScript],\n    [{ ':script': ['OP_2', ':pubkey', ':pubkey', ':pubkey', 'OP_3', 'OP_CHECKMULTISIG'] }]\n  );\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [redeemScript] = match[':script'];\n\n  if (!isTriple(redeemScript.match[':pubkey'])) {\n    throw new Error('invalid pubkey count');\n  }\n\n  return {\n    scriptType,\n    publicKeys: redeemScript.match[':pubkey'],\n    pubScript: redeemScript.buffer,\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n};\n\nconst parseP2tr2Of3PubScript: PubScriptParser<ParsedPubScriptTaprootScriptPath> = (pubScript, scriptType: 'p2tr') => {\n  const match = matchScript(\n    [pubScript],\n    [{ ':script': [':pubkey-xonly', 'OP_CHECKSIGVERIFY', ':pubkey-xonly', 'OP_CHECKSIG'] }]\n  );\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  return {\n    scriptType: 'p2tr',\n    pubScript: match[':script'][0].buffer,\n    publicKeys: match[':script'][0].match[':pubkey-xonly'] as [Buffer, Buffer],\n  };\n};\n\n/**\n * @return pubScript (scriptPubKey/redeemScript/witnessScript) is parsed.\n * P2SH => scriptType, pubScript (redeemScript), redeemScript, public keys\n * PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.\n * P2SH-PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.\n * P2TR => scriptType, pubScript, controlBlock, scriptPathLevel, leafVersion, pub keys, signatures.\n */\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ScriptType2Of3\n): ParsedPubScript2Of3 | ParsedPubScriptTaprootScriptPath {\n  const result =\n    scriptType === 'p2tr'\n      ? parseP2tr2Of3PubScript(inputPubScript, scriptType)\n      : parseP2msPubScript(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (result.publicKeys.length !== 3 && (result.publicKeys.length !== 2 || result.scriptType !== 'p2tr')) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\n}\n"]}
344
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseInput.js","sourceRoot":"","sources":["../../../src/bitgo/parseInput.ts"],"names":[],"mappings":"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","sourcesContent":["import * as opcodes from 'bitcoin-ops';\nimport { TxInput, script as bscript } from 'bitcoinjs-lib';\n\nimport { isScriptType2Of3, ScriptType, ScriptType2Of3 } from './outputScripts';\nimport { isTriple } from './types';\n\nexport function isPlaceholderSignature(v: number | Buffer): boolean {\n  if (Buffer.isBuffer(v)) {\n    return v.length === 0;\n  }\n  return v === 0;\n}\n\n/**\n * @return true iff P2TR script path's control block matches BitGo's need\n */\nexport function isValidControlBock(controlBlock: Buffer): boolean {\n  // The last stack element is called the control block c, and must have length 33 + 32m\n  return Buffer.isBuffer(controlBlock) && 33 <= controlBlock.length && controlBlock.length % 32 === 1;\n}\n\n/**\n * @return script path level for P2TR control block\n */\nexport function calculateScriptPathLevel(controlBlock: Buffer): number {\n  if (!Buffer.isBuffer(controlBlock)) {\n    throw new Error('Invalid control block type.');\n  }\n  if (controlBlock.length === 65) {\n    return 1;\n  }\n  if (controlBlock.length === 97) {\n    return 2;\n  }\n  throw new Error('unexpected control block length.');\n}\n\n/**\n * @return leaf version for P2TR control block.\n */\nexport function getScriptPathLevel(controlBlock: Buffer): number {\n  if (Buffer.isBuffer(controlBlock) && controlBlock.length > 0) {\n    return controlBlock[0] & 0xfe;\n  }\n  throw new Error('unexpected leafVersion.');\n}\n\ninterface ParsedScript {\n  scriptType: ScriptType;\n}\n\nexport type ParsedPubScript = ParsedScript;\nexport type ParsedSignatureScript = ParsedScript;\n\nexport interface ParsedSignatureScriptP2shP2pk extends ParsedSignatureScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n}\n\nexport interface ParsedPubScriptTaprootScriptPath extends ParsedPubScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedPubScript2Of3 extends ParsedPubScript {\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n  redeemScript: Buffer | undefined;\n  witnessScript: Buffer | undefined;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';\n  publicKeys: [Buffer, Buffer, Buffer];\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    /* Partially signed transactions with placeholder signatures.\n       For p2sh, the placeholder is OP_0 (number 0) */\n    | [Buffer | 0, Buffer | 0, Buffer | 0];\n  pubScript: Buffer;\n  redeemScript: Buffer | undefined;\n  witnessScript: Buffer | undefined;\n}\n\n/**\n * Keypath spends only have a single pubkey and single signature\n */\nexport interface ParsedSignatureScriptTaprootKeyPath extends ParsedSignatureScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n  pubScript: Buffer;\n}\n\n/**\n * Taproot Scriptpath spends are more similar to regular p2ms spends and have two public keys and\n * two signatures\n */\nexport interface ParsedSignatureScriptTaprootScriptPath extends ParsedSignatureScript {\n  scriptType: 'p2tr';\n  publicKeys: [Buffer, Buffer];\n  signatures: [Buffer, Buffer];\n  controlBlock: Buffer;\n  leafVersion: number;\n  /** Indicates the level inside the taptree. */\n  scriptPathLevel: number;\n  pubScript: Buffer;\n}\n\nexport type ParsedSignatureScriptTaproot = ParsedSignatureScriptTaprootKeyPath | ParsedSignatureScriptTaprootScriptPath;\n\ntype DecompiledScript = Array<Buffer | number>;\n\n/**\n * Static script elements\n */\ntype ScriptPatternConstant =\n  | 'OP_0'\n  | 'OP_1'\n  | 'OP_2'\n  | 'OP_3'\n  | 'OP_CHECKMULTISIG'\n  | 'OP_CHECKSIG'\n  | 'OP_CHECKSIGVERIFY';\n\n/**\n * Script elements that can be captured\n */\ntype ScriptPatternCapture =\n  | ':pubkey'\n  | ':pubkey-xonly'\n  | ':signature'\n  | ':control-block'\n  | { ':script': ScriptPatternElement[] };\n\ntype ScriptPatternElement = ScriptPatternConstant | ScriptPatternCapture;\n\n/**\n * Result for a successful script match\n */\ntype MatchResult = {\n  ':pubkey': Buffer[];\n  ':pubkey-xonly': Buffer[];\n  ':control-block': Buffer[];\n  ':signature': (Buffer | 0)[];\n  ':script': { buffer: Buffer; match: MatchResult }[];\n};\n\nfunction emptyMatchResult(): MatchResult {\n  return {\n    ':pubkey': [],\n    ':pubkey-xonly': [],\n    ':control-block': [],\n    ':signature': [],\n    ':script': [],\n  };\n}\n\nclass MatchError extends Error {\n  // this property is required to prohibit `return new Error()` when the return type demands `MatchError`\n  __type = 'MatchError';\n  constructor(message: string) {\n    super(message);\n  }\n\n  static forPatternElement(p: ScriptPatternElement): MatchError {\n    if (typeof p === 'object' && ':script' in p) {\n      return new MatchError(`error matching nested script`);\n    }\n    return new MatchError(`error matching ${p}`);\n  }\n}\n\n/**\n * @param script\n * @param pattern\n * @return MatchResult if script matches pattern. The result will contain the matched values.\n */\nfunction matchScript(script: DecompiledScript, pattern: ScriptPatternElement[]): MatchResult | MatchError {\n  /**\n   * Match a single script element with a ScriptPatternElement\n   */\n  function matchElement(e: Buffer | number, p: ScriptPatternElement): MatchResult | boolean {\n    switch (p) {\n      case 'OP_0':\n        return e === opcodes.OP_0 || (Buffer.isBuffer(e) && e.length === 0);\n      case 'OP_1':\n      case 'OP_2':\n      case 'OP_3':\n      case 'OP_CHECKMULTISIG':\n      case 'OP_CHECKSIG':\n      case 'OP_CHECKSIGVERIFY':\n        return e === opcodes[p];\n      case ':pubkey':\n        return Buffer.isBuffer(e) && e.length === 33;\n      case ':pubkey-xonly':\n        return Buffer.isBuffer(e) && e.length === 32;\n      case ':signature':\n        return Buffer.isBuffer(e) || isPlaceholderSignature(e);\n      case ':control-block':\n        return Buffer.isBuffer(e) && isValidControlBock(e);\n      default:\n        throw new Error(`unknown pattern element ${p}`);\n    }\n  }\n\n  if (script.length !== pattern.length) {\n    return new MatchError(`length mismatch`);\n  }\n\n  // Go over each pattern element.\n  // Collect captures into a result object.\n  return pattern.reduce((obj: MatchResult | MatchError, p, i): MatchResult | MatchError => {\n    // if we had a previous mismatch, short-circuit\n    if (obj instanceof MatchError) {\n      return obj;\n    }\n\n    const e = script[i];\n\n    // for ':script' pattern elements, decompile script element and recurse\n    if (typeof p === 'object' && ':script' in p) {\n      if (!Buffer.isBuffer(e)) {\n        return new MatchError(`expected buffer for :script`);\n      }\n      const dec = bscript.decompile(e);\n      if (!dec) {\n        return new MatchError(`error decompiling nested script`);\n      }\n      const match = matchScript(dec, p[':script']);\n      if (match instanceof MatchError) {\n        return match;\n      }\n      obj[':script'].push({\n        buffer: e,\n        match,\n      });\n      return obj;\n    }\n\n    const match = matchElement(e, p);\n    if (!match) {\n      return MatchError.forPatternElement(p);\n    }\n\n    // if pattern element is a capture, add it to the result obj\n    if (p === ':signature' && e === 0) {\n      obj[p].push(e);\n    } else if (p in obj) {\n      if (!Buffer.isBuffer(e)) {\n        throw new Error(`invalid capture value`);\n      }\n      obj[p].push(e);\n    }\n\n    return obj;\n  }, emptyMatchResult());\n}\n\n/**\n * @param script\n * @param patterns\n * @return first match\n */\nfunction matchScriptSome(script: DecompiledScript, patterns: ScriptPatternElement[][]): MatchResult | MatchError {\n  for (const p of patterns) {\n    const m = matchScript(script, p);\n    if (m instanceof MatchError) {\n      continue;\n    }\n    return m;\n  }\n  return new MatchError(`no match for script`);\n}\n\ntype InputScripts<TScript, TWitness> = {\n  script: TScript;\n  witness: TWitness;\n};\n\ntype InputScriptsLegacy = InputScripts<DecompiledScript, null>;\ntype InputScriptsWrappedSegwit = InputScripts<DecompiledScript, Buffer[]>;\ntype InputScriptsNativeSegwit = InputScripts<null, Buffer[]>;\n\ntype InputScriptsUnknown = InputScripts<DecompiledScript | null, Buffer[] | null>;\n\ntype InputParser<T extends ParsedSignatureScriptP2shP2pk | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot> = (\n  p: InputScriptsUnknown\n) => T | MatchError;\n\nexport type InputPubScript = Buffer;\n\ntype PubScriptParser<T extends ParsedPubScriptTaprootScriptPath | ParsedPubScript2Of3> = (\n  p: InputPubScript,\n  ScriptType2Of3\n) => T | MatchError;\n\nfunction isLegacy(p: InputScriptsUnknown): p is InputScriptsLegacy {\n  return Boolean(p.script && !p.witness);\n}\n\nfunction isWrappedSegwit(p: InputScriptsUnknown): p is InputScriptsWrappedSegwit {\n  return Boolean(p.script && p.witness);\n}\n\nfunction isNativeSegwit(p: InputScriptsUnknown): p is InputScriptsNativeSegwit {\n  return Boolean(!p.script && p.witness);\n}\n\nconst parseP2shP2pk: InputParser<ParsedSignatureScriptP2shP2pk> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  const match = matchScript(p.script, [':signature', { ':script': [':pubkey', 'OP_CHECKSIG'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  return {\n    scriptType: 'p2shP2pk',\n    publicKeys: match[':script'][0].match[':pubkey'] as [Buffer],\n    signatures: match[':signature'] as [Buffer],\n  };\n};\n\nfunction parseP2ms(\n  decScript: DecompiledScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedSignatureScript2Of3 | MatchError {\n  const pattern2Of3: ScriptPatternElement[] = ['OP_2', ':pubkey', ':pubkey', ':pubkey', 'OP_3', 'OP_CHECKMULTISIG'];\n\n  const match = matchScriptSome(decScript, [\n    /* full-signed, no placeholder signature */\n    ['OP_0', ':signature', ':signature', { ':script': pattern2Of3 }],\n    /* half-signed, placeholder signatures */\n    ['OP_0', ':signature', ':signature', ':signature', { ':script': pattern2Of3 }],\n  ]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [redeemScript] = match[':script'];\n\n  if (!isTriple(redeemScript.match[':pubkey'])) {\n    throw new Error(`invalid pubkey count`);\n  }\n\n  return {\n    scriptType,\n    publicKeys: redeemScript.match[':pubkey'],\n    pubScript: redeemScript.buffer,\n    signatures: match[':signature'] as ParsedSignatureScript2Of3['signatures'],\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n}\n\nconst parseP2sh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  return parseP2ms(p.script, 'p2sh');\n};\n\nconst parseP2shP2wsh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isWrappedSegwit(p)) {\n    return new MatchError(`expected wrapped segwit input`);\n  }\n  return { ...parseP2ms(p.witness, 'p2shP2wsh'), redeemScript: p.script[0] as Buffer };\n};\n\nconst parseP2wsh2Of3: InputParser<ParsedSignatureScript2Of3> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  return parseP2ms(p.witness, 'p2wsh');\n};\n\nconst parseP2tr2Of3: InputParser<ParsedSignatureScriptTaproot> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  // assumes no annex\n  const match = matchScript(p.witness, [\n    ':signature',\n    ':signature',\n    { ':script': [':pubkey-xonly', 'OP_CHECKSIGVERIFY', ':pubkey-xonly', 'OP_CHECKSIG'] },\n    ':control-block',\n  ]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const [controlBlock] = match[':control-block'];\n  const scriptPathLevel = calculateScriptPathLevel(controlBlock);\n\n  const leafVersion = getScriptPathLevel(controlBlock);\n\n  return {\n    scriptType: 'p2tr',\n    pubScript: match[':script'][0].buffer,\n    publicKeys: match[':script'][0].match[':pubkey-xonly'] as [Buffer, Buffer],\n    signatures: match[':signature'] as [Buffer, Buffer],\n    controlBlock,\n    scriptPathLevel,\n    leafVersion,\n  };\n};\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: TxInput\n): ParsedSignatureScriptP2shP2pk | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const decScript = bscript.decompile(input.script);\n  const parsers = [parseP2sh2Of3, parseP2shP2wsh2Of3, parseP2wsh2Of3, parseP2tr2Of3, parseP2shP2pk] as const;\n  for (const f of parsers) {\n    const parsed = f({\n      script: decScript?.length === 0 ? null : decScript,\n      witness: input.witness.length === 0 ? null : input.witness,\n    });\n    if (parsed instanceof MatchError) {\n      continue;\n    }\n    return parsed;\n  }\n  throw new Error(`could not parse input`);\n}\n\nexport function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input);\n\n  if (!isScriptType2Of3(result.scriptType)) {\n    throw new Error(`invalid script type`);\n  }\n\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (result.publicKeys.length !== 3 && (result.publicKeys.length !== 2 || result.scriptType !== 'p2tr')) {\n    throw new Error(`unexpected pubkey count`);\n  }\n\n  return result as ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot;\n}\n\nconst parseP2msPubScript: PubScriptParser<ParsedPubScript2Of3> = (\n  pubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n) => {\n  const match = matchScript(\n    [pubScript],\n    [{ ':script': ['OP_2', ':pubkey', ':pubkey', ':pubkey', 'OP_3', 'OP_CHECKMULTISIG'] }]\n  );\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [redeemScript] = match[':script'];\n\n  if (!isTriple(redeemScript.match[':pubkey'])) {\n    throw new Error('invalid pubkey count');\n  }\n\n  return {\n    scriptType,\n    publicKeys: redeemScript.match[':pubkey'],\n    pubScript: redeemScript.buffer,\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n};\n\nconst parseP2tr2Of3PubScript: PubScriptParser<ParsedPubScriptTaprootScriptPath> = (pubScript, scriptType: 'p2tr') => {\n  const match = matchScript(\n    [pubScript],\n    [{ ':script': [':pubkey-xonly', 'OP_CHECKSIGVERIFY', ':pubkey-xonly', 'OP_CHECKSIG'] }]\n  );\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  return {\n    scriptType: 'p2tr',\n    pubScript: match[':script'][0].buffer,\n    publicKeys: match[':script'][0].match[':pubkey-xonly'] as [Buffer, Buffer],\n  };\n};\n\n/**\n * @return pubScript (scriptPubKey/redeemScript/witnessScript) is parsed.\n * P2SH => scriptType, pubScript (redeemScript), redeemScript, public keys\n * PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.\n * P2SH-PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.\n * P2TR => scriptType, pubScript, controlBlock, scriptPathLevel, leafVersion, pub keys, signatures.\n */\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ScriptType2Of3\n): ParsedPubScript2Of3 | ParsedPubScriptTaprootScriptPath {\n  const result =\n    scriptType === 'p2tr'\n      ? parseP2tr2Of3PubScript(inputPubScript, scriptType)\n      : parseP2msPubScript(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (result.publicKeys.length !== 3 && (result.publicKeys.length !== 2 || result.scriptType !== 'p2tr')) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\n}\n"]}
@@ -3,12 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.isSegwit = exports.isTaproot = exports.isP2wpkh = exports.isP2wsh = void 0;
4
4
  const opcodes = require("bitcoin-ops");
5
5
  function isP2wsh(scriptPubkey, redeemScript) {
6
- const witnessProgramCandidate = redeemScript !== null && redeemScript !== void 0 ? redeemScript : scriptPubkey;
6
+ const witnessProgramCandidate = redeemScript ?? scriptPubkey;
7
7
  return witnessProgramCandidate[0] === opcodes.OP_0 && witnessProgramCandidate.length === 34;
8
8
  }
9
9
  exports.isP2wsh = isP2wsh;
10
10
  function isP2wpkh(scriptPubkey, redeemScript) {
11
- const witnessProgramCandidate = redeemScript !== null && redeemScript !== void 0 ? redeemScript : scriptPubkey;
11
+ const witnessProgramCandidate = redeemScript ?? scriptPubkey;
12
12
  return witnessProgramCandidate[0] === opcodes.OP_0 && witnessProgramCandidate.length === 22;
13
13
  }
14
14
  exports.isP2wpkh = isP2wpkh;
@@ -20,4 +20,4 @@ function isSegwit(scriptPubkey, redeemScript) {
20
20
  return isTaproot(scriptPubkey) || isP2wsh(scriptPubkey, redeemScript) || isP2wpkh(scriptPubkey, redeemScript);
21
21
  }
22
22
  exports.isSegwit = isSegwit;
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyaXB0VHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vcHNidC9zY3JpcHRUeXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx1Q0FBdUM7QUFFdkMsU0FBZ0IsT0FBTyxDQUFDLFlBQW9CLEVBQUUsWUFBcUI7SUFDakUsTUFBTSx1QkFBdUIsR0FBRyxZQUFZLGFBQVosWUFBWSxjQUFaLFlBQVksR0FBSSxZQUFZLENBQUM7SUFDN0QsT0FBTyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsSUFBSSxJQUFJLHVCQUF1QixDQUFDLE1BQU0sS0FBSyxFQUFFLENBQUM7QUFDOUYsQ0FBQztBQUhELDBCQUdDO0FBRUQsU0FBZ0IsUUFBUSxDQUFDLFlBQW9CLEVBQUUsWUFBcUI7SUFDbEUsTUFBTSx1QkFBdUIsR0FBRyxZQUFZLGFBQVosWUFBWSxjQUFaLFlBQVksR0FBSSxZQUFZLENBQUM7SUFDN0QsT0FBTyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsSUFBSSxJQUFJLHVCQUF1QixDQUFDLE1BQU0sS0FBSyxFQUFFLENBQUM7QUFDOUYsQ0FBQztBQUhELDRCQUdDO0FBRUQsU0FBZ0IsU0FBUyxDQUFDLFlBQW9CO0lBQzVDLE9BQU8sWUFBWSxDQUFDLENBQUMsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxJQUFJLElBQUksWUFBWSxDQUFDLE1BQU0sS0FBSyxFQUFFLENBQUM7QUFDeEUsQ0FBQztBQUZELDhCQUVDO0FBRUQsU0FBZ0IsUUFBUSxDQUFDLFlBQW9CLEVBQUUsWUFBcUI7SUFDbEUsT0FBTyxTQUFTLENBQUMsWUFBWSxDQUFDLElBQUksT0FBTyxDQUFDLFlBQVksRUFBRSxZQUFZLENBQUMsSUFBSSxRQUFRLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFDO0FBQ2hILENBQUM7QUFGRCw0QkFFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIG9wY29kZXMgZnJvbSAnYml0Y29pbi1vcHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gaXNQMndzaChzY3JpcHRQdWJrZXk6IEJ1ZmZlciwgcmVkZWVtU2NyaXB0PzogQnVmZmVyKTogYm9vbGVhbiB7XG4gIGNvbnN0IHdpdG5lc3NQcm9ncmFtQ2FuZGlkYXRlID0gcmVkZWVtU2NyaXB0ID8/IHNjcmlwdFB1YmtleTtcbiAgcmV0dXJuIHdpdG5lc3NQcm9ncmFtQ2FuZGlkYXRlWzBdID09PSBvcGNvZGVzLk9QXzAgJiYgd2l0bmVzc1Byb2dyYW1DYW5kaWRhdGUubGVuZ3RoID09PSAzNDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUDJ3cGtoKHNjcmlwdFB1YmtleTogQnVmZmVyLCByZWRlZW1TY3JpcHQ/OiBCdWZmZXIpOiBib29sZWFuIHtcbiAgY29uc3Qgd2l0bmVzc1Byb2dyYW1DYW5kaWRhdGUgPSByZWRlZW1TY3JpcHQgPz8gc2NyaXB0UHVia2V5O1xuICByZXR1cm4gd2l0bmVzc1Byb2dyYW1DYW5kaWRhdGVbMF0gPT09IG9wY29kZXMuT1BfMCAmJiB3aXRuZXNzUHJvZ3JhbUNhbmRpZGF0ZS5sZW5ndGggPT09IDIyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNUYXByb290KHNjcmlwdFB1YmtleTogQnVmZmVyKTogYm9vbGVhbiB7XG4gIHJldHVybiBzY3JpcHRQdWJrZXlbMF0gPT09IG9wY29kZXMuT1BfMSAmJiBzY3JpcHRQdWJrZXkubGVuZ3RoID09PSAzNDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzU2Vnd2l0KHNjcmlwdFB1YmtleTogQnVmZmVyLCByZWRlZW1TY3JpcHQ/OiBCdWZmZXIpOiBib29sZWFuIHtcbiAgcmV0dXJuIGlzVGFwcm9vdChzY3JpcHRQdWJrZXkpIHx8IGlzUDJ3c2goc2NyaXB0UHVia2V5LCByZWRlZW1TY3JpcHQpIHx8IGlzUDJ3cGtoKHNjcmlwdFB1YmtleSwgcmVkZWVtU2NyaXB0KTtcbn1cbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyaXB0VHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vcHNidC9zY3JpcHRUeXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx1Q0FBdUM7QUFFdkMsU0FBZ0IsT0FBTyxDQUFDLFlBQW9CLEVBQUUsWUFBcUI7SUFDakUsTUFBTSx1QkFBdUIsR0FBRyxZQUFZLElBQUksWUFBWSxDQUFDO0lBQzdELE9BQU8sdUJBQXVCLENBQUMsQ0FBQyxDQUFDLEtBQUssT0FBTyxDQUFDLElBQUksSUFBSSx1QkFBdUIsQ0FBQyxNQUFNLEtBQUssRUFBRSxDQUFDO0FBQzlGLENBQUM7QUFIRCwwQkFHQztBQUVELFNBQWdCLFFBQVEsQ0FBQyxZQUFvQixFQUFFLFlBQXFCO0lBQ2xFLE1BQU0sdUJBQXVCLEdBQUcsWUFBWSxJQUFJLFlBQVksQ0FBQztJQUM3RCxPQUFPLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxJQUFJLElBQUksdUJBQXVCLENBQUMsTUFBTSxLQUFLLEVBQUUsQ0FBQztBQUM5RixDQUFDO0FBSEQsNEJBR0M7QUFFRCxTQUFnQixTQUFTLENBQUMsWUFBb0I7SUFDNUMsT0FBTyxZQUFZLENBQUMsQ0FBQyxDQUFDLEtBQUssT0FBTyxDQUFDLElBQUksSUFBSSxZQUFZLENBQUMsTUFBTSxLQUFLLEVBQUUsQ0FBQztBQUN4RSxDQUFDO0FBRkQsOEJBRUM7QUFFRCxTQUFnQixRQUFRLENBQUMsWUFBb0IsRUFBRSxZQUFxQjtJQUNsRSxPQUFPLFNBQVMsQ0FBQyxZQUFZLENBQUMsSUFBSSxPQUFPLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxJQUFJLFFBQVEsQ0FBQyxZQUFZLEVBQUUsWUFBWSxDQUFDLENBQUM7QUFDaEgsQ0FBQztBQUZELDRCQUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgb3Bjb2RlcyBmcm9tICdiaXRjb2luLW9wcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1Ayd3NoKHNjcmlwdFB1YmtleTogQnVmZmVyLCByZWRlZW1TY3JpcHQ/OiBCdWZmZXIpOiBib29sZWFuIHtcbiAgY29uc3Qgd2l0bmVzc1Byb2dyYW1DYW5kaWRhdGUgPSByZWRlZW1TY3JpcHQgPz8gc2NyaXB0UHVia2V5O1xuICByZXR1cm4gd2l0bmVzc1Byb2dyYW1DYW5kaWRhdGVbMF0gPT09IG9wY29kZXMuT1BfMCAmJiB3aXRuZXNzUHJvZ3JhbUNhbmRpZGF0ZS5sZW5ndGggPT09IDM0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNQMndwa2goc2NyaXB0UHVia2V5OiBCdWZmZXIsIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcik6IGJvb2xlYW4ge1xuICBjb25zdCB3aXRuZXNzUHJvZ3JhbUNhbmRpZGF0ZSA9IHJlZGVlbVNjcmlwdCA/PyBzY3JpcHRQdWJrZXk7XG4gIHJldHVybiB3aXRuZXNzUHJvZ3JhbUNhbmRpZGF0ZVswXSA9PT0gb3Bjb2Rlcy5PUF8wICYmIHdpdG5lc3NQcm9ncmFtQ2FuZGlkYXRlLmxlbmd0aCA9PT0gMjI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1RhcHJvb3Qoc2NyaXB0UHVia2V5OiBCdWZmZXIpOiBib29sZWFuIHtcbiAgcmV0dXJuIHNjcmlwdFB1YmtleVswXSA9PT0gb3Bjb2Rlcy5PUF8xICYmIHNjcmlwdFB1YmtleS5sZW5ndGggPT09IDM0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNTZWd3aXQoc2NyaXB0UHVia2V5OiBCdWZmZXIsIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcik6IGJvb2xlYW4ge1xuICByZXR1cm4gaXNUYXByb290KHNjcmlwdFB1YmtleSkgfHwgaXNQMndzaChzY3JpcHRQdWJrZXksIHJlZGVlbVNjcmlwdCkgfHwgaXNQMndwa2goc2NyaXB0UHVia2V5LCByZWRlZW1TY3JpcHQpO1xufVxuIl19
@@ -18,7 +18,7 @@ export declare const chainCodesP2shP2wsh: readonly [10, 11];
18
18
  export declare const chainCodesP2wsh: readonly [20, 21];
19
19
  export declare const chainCodesP2tr: readonly [30, 31];
20
20
  export declare const chainCodesP2trMusig2: readonly [40, 41];
21
- export declare const chainCodes: (0 | 1 | 31 | 20 | 10 | 11 | 21 | 30 | 40 | 41)[];
21
+ export declare const chainCodes: (0 | 30 | 1 | 31 | 20 | 10 | 11 | 21 | 40 | 41)[];
22
22
  export declare type ChainCode = typeof chainCodes[number];
23
23
  export declare function isChainCode(n: unknown): n is ChainCode;
24
24
  /**
@@ -29,11 +29,10 @@ class ZcashPsbt extends UtxoPsbt_1.UtxoPsbt {
29
29
  * @param opts options
30
30
  */
31
31
  static fromBuffer(buffer, opts) {
32
- var _a;
33
32
  const psbt = super.fromBuffer(buffer, opts);
34
33
  // Read `consensusBranchId` from the global-map
35
34
  let consensusBranchId = undefined;
36
- (_a = psbt.data.globalMap.unknownKeyVals) === null || _a === void 0 ? void 0 : _a.forEach(({ key, value }, i) => {
35
+ psbt.data.globalMap.unknownKeyVals?.forEach(({ key, value }, i) => {
37
36
  if (key.equals(CONSENSUS_BRANCH_ID_KEY)) {
38
37
  consensusBranchId = value.readUint32LE();
39
38
  }
@@ -143,4 +142,4 @@ class ZcashPsbt extends UtxoPsbt_1.UtxoPsbt {
143
142
  }
144
143
  }
145
144
  exports.ZcashPsbt = ZcashPsbt;
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashPsbt.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashPsbt.ts"],"names":[],"mappings":"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","sourcesContent":["import { PSBT_PROPRIETARY_IDENTIFIER, PsbtOpts, ProprietaryKeySubtype, UtxoPsbt } from '../UtxoPsbt';\nimport {\n  getDefaultConsensusBranchIdForVersion,\n  getDefaultVersionGroupIdForVersion,\n  ZcashTransaction,\n} from './ZcashTransaction';\nimport { Network, PsbtTransaction, Signer } from '../../';\nimport { Psbt as PsbtBase } from 'bip174';\nimport * as types from 'bitcoinjs-lib/src/types';\nimport { ValidateSigFunction } from 'bitcoinjs-lib/src/psbt';\nconst typeforce = require('typeforce');\n\nconst CONSENSUS_BRANCH_ID_KEY = Buffer.concat([\n  Buffer.of(0xfc),\n  Buffer.of(0x05),\n  Buffer.from(PSBT_PROPRIETARY_IDENTIFIER),\n  Buffer.of(ProprietaryKeySubtype.ZEC_CONSENSUS_BRANCH_ID),\n]);\n\nexport class ZcashPsbt extends UtxoPsbt<ZcashTransaction<bigint>> {\n  protected static transactionFromBuffer(buffer: Buffer, network: Network): ZcashTransaction<bigint> {\n    return ZcashTransaction.fromBuffer<bigint>(buffer, false, 'bigint', network);\n  }\n\n  static createPsbt(opts: PsbtOpts, data?: PsbtBase): ZcashPsbt {\n    return new ZcashPsbt(\n      opts,\n      data || new PsbtBase(new PsbtTransaction({ tx: new ZcashTransaction<bigint>(opts.network) }))\n    );\n  }\n\n  /**\n   * In version < 5 of Zcash transactions, the consensus branch ID is not serialized in the transaction\n   * whereas in version 5 it is. If the transaction is less than a version 5, set the consensus branch id\n   * in the global map in the psbt. If it is a version 5 transaction, throw an error if the consensus\n   * branch id is set in the psbt (because it should be on the transaction already).\n   * @param buffer Psbt buffer\n   * @param opts options\n   */\n  static fromBuffer(buffer: Buffer, opts: PsbtOpts): UtxoPsbt<ZcashTransaction<bigint>> {\n    const psbt = super.fromBuffer(buffer, opts) as ZcashPsbt;\n\n    // Read `consensusBranchId` from the global-map\n    let consensusBranchId: number | undefined = undefined;\n    psbt.data.globalMap.unknownKeyVals?.forEach(({ key, value }, i) => {\n      if (key.equals(CONSENSUS_BRANCH_ID_KEY)) {\n        consensusBranchId = value.readUint32LE();\n      }\n    });\n    switch (psbt.tx.version) {\n      case 4:\n      case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      case ZcashTransaction.VERSION4_BRANCH_NU5:\n        if (!consensusBranchId || !psbt.data.globalMap.unknownKeyVals) {\n          throw new Error('Could not find consensus branch id on psbt for version 4 Zcash transaction');\n        }\n        psbt.tx.consensusBranchId = consensusBranchId;\n        psbt.data.globalMap.unknownKeyVals = psbt.data.globalMap.unknownKeyVals.filter(\n          ({ key }) => key !== CONSENSUS_BRANCH_ID_KEY\n        );\n\n        // Delete consensusBranchId from globalMap so that if we were to serialize the psbt again\n        // we would not add a duplicate key into the global map\n        psbt.data.globalMap.unknownKeyVals.pop();\n        return psbt;\n      case 5:\n      case ZcashTransaction.VERSION5_BRANCH_NU5:\n        if (consensusBranchId) {\n          throw new Error('Found consensus branch id in psbt global-map for version 5 Zcash transaction');\n        }\n        return psbt;\n      default:\n        throw new Error(`Unsupported transaction version ${psbt.tx.version}`);\n    }\n  }\n\n  /**\n   * If it is a version 4 transaction, add the consensus branch id to\n   * the global map. If it is a version 5 transaction, just return the\n   * buffer because the consensus branch id is already serialized in\n   * the transaction.\n   */\n  toBuffer(): Buffer {\n    if (this.tx.version === 5 || this.tx.version === ZcashTransaction.VERSION5_BRANCH_NU5) {\n      return super.toBuffer();\n    }\n    const value = Buffer.alloc(4);\n    value.writeUint32LE(this.tx.consensusBranchId);\n    this.addUnknownKeyValToGlobal({ key: CONSENSUS_BRANCH_ID_KEY, value });\n    if (!this.data.globalMap.unknownKeyVals) {\n      throw new Error('Failed adding consensus branch id to unknownKeyVals');\n    }\n    const buff = super.toBuffer();\n    this.data.globalMap.unknownKeyVals.pop();\n    return buff;\n  }\n\n  setVersion(version: number, overwinter = true): this {\n    typeforce(types.UInt32, version);\n    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.version = version;\n    return this;\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  // For Zcash transactions, we do not have to have non-witness UTXO data for non-segwit\n  // transactions because zcash hashes the value directly. Thus, it is unnecessary to have\n  // the previous transaction hash on the unspent.\n  signInput(inputIndex: number, keyPair: Signer, sighashTypes?: number[]): this {\n    return this.withUnsafeSignNonSegwitTrue(super.signInput.bind(this, inputIndex, keyPair, sighashTypes));\n  }\n\n  validateSignaturesOfInput(inputIndex: number, validator: ValidateSigFunction, pubkey?: Buffer): boolean {\n    return this.withUnsafeSignNonSegwitTrue(super.validateSignaturesOfInput.bind(this, inputIndex, validator, pubkey));\n  }\n\n  private withUnsafeSignNonSegwitTrue<T>(fn: () => T): T {\n    (this as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = true;\n    try {\n      return fn();\n    } finally {\n      (this as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = false;\n    }\n  }\n\n  private setPropertyCheckSignatures(propName: keyof ZcashTransaction<bigint>, value: unknown) {\n    if (this.tx[propName] === value) {\n      return;\n    }\n    this.checkForSignatures(propName);\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"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashPsbt.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashPsbt.ts"],"names":[],"mappings":";;;AAAA,0CAAqG;AACrG,yDAI4B;AAC5B,8BAA0D;AAC1D,mCAA0C;AAC1C,iDAAiD;AAEjD,MAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;AAEvC,MAAM,uBAAuB,GAAG,MAAM,CAAC,MAAM,CAAC;IAC5C,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC;IACf,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC;IACf,MAAM,CAAC,IAAI,CAAC,sCAA2B,CAAC;IACxC,MAAM,CAAC,EAAE,CAAC,gCAAqB,CAAC,uBAAuB,CAAC;CACzD,CAAC,CAAC;AAEH,MAAa,SAAU,SAAQ,mBAAkC;IACrD,MAAM,CAAC,qBAAqB,CAAC,MAAc,EAAE,OAAgB;QACrE,OAAO,mCAAgB,CAAC,UAAU,CAAS,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC/E,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,IAAc,EAAE,IAAe;QAC/C,OAAO,IAAI,SAAS,CAClB,IAAI,EACJ,IAAI,IAAI,IAAI,aAAQ,CAAC,IAAI,mBAAe,CAAC,EAAE,EAAE,EAAE,IAAI,mCAAgB,CAAS,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAC9F,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,MAAc,EAAE,IAAc;QAC9C,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAc,CAAC;QAEzD,+CAA+C;QAC/C,IAAI,iBAAiB,GAAuB,SAAS,CAAC;QACtD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;YAChE,IAAI,GAAG,CAAC,MAAM,CAAC,uBAAuB,CAAC,EAAE;gBACvC,iBAAiB,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;aAC1C;QACH,CAAC,CAAC,CAAC;QACH,QAAQ,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE;YACvB,KAAK,CAAC,CAAC;YACP,KAAK,mCAAgB,CAAC,sBAAsB,CAAC;YAC7C,KAAK,mCAAgB,CAAC,mBAAmB;gBACvC,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE;oBAC7D,MAAM,IAAI,KAAK,CAAC,4EAA4E,CAAC,CAAC;iBAC/F;gBACD,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;gBAC9C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAC5E,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,GAAG,KAAK,uBAAuB,CAC7C,CAAC;gBAEF,yFAAyF;gBACzF,uDAAuD;gBACvD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;gBACzC,OAAO,IAAI,CAAC;YACd,KAAK,CAAC,CAAC;YACP,KAAK,mCAAgB,CAAC,mBAAmB;gBACvC,IAAI,iBAAiB,EAAE;oBACrB,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;iBACjG;gBACD,OAAO,IAAI,CAAC;YACd;gBACE,MAAM,IAAI,KAAK,CAAC,mCAAmC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC;SACzE;IACH,CAAC;IAED;;;;;OAKG;IACH,QAAQ;QACN,IAAI,IAAI,CAAC,EAAE,CAAC,OAAO,KAAK,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,OAAO,KAAK,mCAAgB,CAAC,mBAAmB,EAAE;YACrF,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;SACzB;QACD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC9B,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC;QAC/C,IAAI,CAAC,wBAAwB,CAAC,EAAE,GAAG,EAAE,uBAAuB,EAAE,KAAK,EAAE,CAAC,CAAC;QACvE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE;YACvC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;SACxE;QACD,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;QACzC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,UAAU,CAAC,OAAe,EAAE,UAAU,GAAG,IAAI;QAC3C,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACjC,IAAI,CAAC,EAAE,CAAC,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,EAAE,CAAC,OAAO,GAAG,OAAO,CAAC;QAC1B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,qBAAqB,CAAC,OAAgB,EAAE,OAAe;QACrD,QAAQ,OAAO,EAAE;YACf,KAAK,CAAC,CAAC;YACP,KAAK,mCAAgB,CAAC,sBAAsB,CAAC;YAC7C,KAAK,mCAAgB,CAAC,mBAAmB;gBACvC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBACnB,MAAM;YACR,KAAK,CAAC,CAAC;YACP,KAAK,mCAAgB,CAAC,mBAAmB;gBACvC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBACnB,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,mBAAmB,OAAO,EAAE,CAAC,CAAC;SACjD;QAED,IAAI,CAAC,EAAE,CAAC,cAAc,GAAG,qDAAkC,CAAC,OAAO,CAAC,CAAC;QACrE,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,wDAAqC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACtF,CAAC;IAED,sFAAsF;IACtF,wFAAwF;IACxF,gDAAgD;IAChD,SAAS,CAAC,UAAkB,EAAE,OAAe,EAAE,YAAuB;QACpE,OAAO,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;IACzG,CAAC;IAED,yBAAyB,CAAC,UAAkB,EAAE,SAA8B,EAAE,MAAe;QAC3F,OAAO,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;IACrH,CAAC;IAEO,2BAA2B,CAAI,EAAW;QAC/C,IAAY,CAAC,OAAO,CAAC,uBAAuB,GAAG,IAAI,CAAC;QACrD,IAAI;YACF,OAAO,EAAE,EAAE,CAAC;SACb;gBAAS;YACP,IAAY,CAAC,OAAO,CAAC,uBAAuB,GAAG,KAAK,CAAC;SACvD;IACH,CAAC;IAEO,0BAA0B,CAAC,QAAwC,EAAE,KAAc;QACzF,IAAI,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,KAAK,EAAE;YAC/B,OAAO;SACR;QACD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAClC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,KAAY,CAAC;IACnC,CAAC;IAED,oBAAoB,CAAC,iBAAyB;QAC5C,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;QAC3C,IAAI,CAAC,0BAA0B,CAAC,mBAAmB,EAAE,iBAAiB,CAAC,CAAC;IAC1E,CAAC;IAED,iBAAiB,CAAC,cAAsB;QACtC,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QACxC,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,EAAE,cAAc,CAAC,CAAC;IACpE,CAAC;IAED,eAAe,CAAC,YAAoB;QAClC,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;QACtC,IAAI,CAAC,0BAA0B,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC;IAChE,CAAC;CACF;AAlJD,8BAkJC","sourcesContent":["import { PSBT_PROPRIETARY_IDENTIFIER, PsbtOpts, ProprietaryKeySubtype, UtxoPsbt } from '../UtxoPsbt';\nimport {\n  getDefaultConsensusBranchIdForVersion,\n  getDefaultVersionGroupIdForVersion,\n  ZcashTransaction,\n} from './ZcashTransaction';\nimport { Network, PsbtTransaction, Signer } from '../../';\nimport { Psbt as PsbtBase } from 'bip174';\nimport * as types from 'bitcoinjs-lib/src/types';\nimport { ValidateSigFunction } from 'bitcoinjs-lib/src/psbt';\nconst typeforce = require('typeforce');\n\nconst CONSENSUS_BRANCH_ID_KEY = Buffer.concat([\n  Buffer.of(0xfc),\n  Buffer.of(0x05),\n  Buffer.from(PSBT_PROPRIETARY_IDENTIFIER),\n  Buffer.of(ProprietaryKeySubtype.ZEC_CONSENSUS_BRANCH_ID),\n]);\n\nexport class ZcashPsbt extends UtxoPsbt<ZcashTransaction<bigint>> {\n  protected static transactionFromBuffer(buffer: Buffer, network: Network): ZcashTransaction<bigint> {\n    return ZcashTransaction.fromBuffer<bigint>(buffer, false, 'bigint', network);\n  }\n\n  static createPsbt(opts: PsbtOpts, data?: PsbtBase): ZcashPsbt {\n    return new ZcashPsbt(\n      opts,\n      data || new PsbtBase(new PsbtTransaction({ tx: new ZcashTransaction<bigint>(opts.network) }))\n    );\n  }\n\n  /**\n   * In version < 5 of Zcash transactions, the consensus branch ID is not serialized in the transaction\n   * whereas in version 5 it is. If the transaction is less than a version 5, set the consensus branch id\n   * in the global map in the psbt. If it is a version 5 transaction, throw an error if the consensus\n   * branch id is set in the psbt (because it should be on the transaction already).\n   * @param buffer Psbt buffer\n   * @param opts options\n   */\n  static fromBuffer(buffer: Buffer, opts: PsbtOpts): UtxoPsbt<ZcashTransaction<bigint>> {\n    const psbt = super.fromBuffer(buffer, opts) as ZcashPsbt;\n\n    // Read `consensusBranchId` from the global-map\n    let consensusBranchId: number | undefined = undefined;\n    psbt.data.globalMap.unknownKeyVals?.forEach(({ key, value }, i) => {\n      if (key.equals(CONSENSUS_BRANCH_ID_KEY)) {\n        consensusBranchId = value.readUint32LE();\n      }\n    });\n    switch (psbt.tx.version) {\n      case 4:\n      case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      case ZcashTransaction.VERSION4_BRANCH_NU5:\n        if (!consensusBranchId || !psbt.data.globalMap.unknownKeyVals) {\n          throw new Error('Could not find consensus branch id on psbt for version 4 Zcash transaction');\n        }\n        psbt.tx.consensusBranchId = consensusBranchId;\n        psbt.data.globalMap.unknownKeyVals = psbt.data.globalMap.unknownKeyVals.filter(\n          ({ key }) => key !== CONSENSUS_BRANCH_ID_KEY\n        );\n\n        // Delete consensusBranchId from globalMap so that if we were to serialize the psbt again\n        // we would not add a duplicate key into the global map\n        psbt.data.globalMap.unknownKeyVals.pop();\n        return psbt;\n      case 5:\n      case ZcashTransaction.VERSION5_BRANCH_NU5:\n        if (consensusBranchId) {\n          throw new Error('Found consensus branch id in psbt global-map for version 5 Zcash transaction');\n        }\n        return psbt;\n      default:\n        throw new Error(`Unsupported transaction version ${psbt.tx.version}`);\n    }\n  }\n\n  /**\n   * If it is a version 4 transaction, add the consensus branch id to\n   * the global map. If it is a version 5 transaction, just return the\n   * buffer because the consensus branch id is already serialized in\n   * the transaction.\n   */\n  toBuffer(): Buffer {\n    if (this.tx.version === 5 || this.tx.version === ZcashTransaction.VERSION5_BRANCH_NU5) {\n      return super.toBuffer();\n    }\n    const value = Buffer.alloc(4);\n    value.writeUint32LE(this.tx.consensusBranchId);\n    this.addUnknownKeyValToGlobal({ key: CONSENSUS_BRANCH_ID_KEY, value });\n    if (!this.data.globalMap.unknownKeyVals) {\n      throw new Error('Failed adding consensus branch id to unknownKeyVals');\n    }\n    const buff = super.toBuffer();\n    this.data.globalMap.unknownKeyVals.pop();\n    return buff;\n  }\n\n  setVersion(version: number, overwinter = true): this {\n    typeforce(types.UInt32, version);\n    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.version = version;\n    return this;\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  // For Zcash transactions, we do not have to have non-witness UTXO data for non-segwit\n  // transactions because zcash hashes the value directly. Thus, it is unnecessary to have\n  // the previous transaction hash on the unspent.\n  signInput(inputIndex: number, keyPair: Signer, sighashTypes?: number[]): this {\n    return this.withUnsafeSignNonSegwitTrue(super.signInput.bind(this, inputIndex, keyPair, sighashTypes));\n  }\n\n  validateSignaturesOfInput(inputIndex: number, validator: ValidateSigFunction, pubkey?: Buffer): boolean {\n    return this.withUnsafeSignNonSegwitTrue(super.validateSignaturesOfInput.bind(this, inputIndex, validator, pubkey));\n  }\n\n  private withUnsafeSignNonSegwitTrue<T>(fn: () => T): T {\n    (this as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = true;\n    try {\n      return fn();\n    } finally {\n      (this as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = false;\n    }\n  }\n\n  private setPropertyCheckSignatures(propName: keyof ZcashTransaction<bigint>, value: unknown) {\n    if (this.tx[propName] === value) {\n      return;\n    }\n    this.checkForSignatures(propName);\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"]}
@@ -74,7 +74,7 @@ class ZcashTransaction extends UtxoTransaction_1.UtxoTransaction {
74
74
  consensusBranchId = tx.consensusBranchId;
75
75
  }
76
76
  }
77
- this.consensusBranchId = consensusBranchId !== null && consensusBranchId !== void 0 ? consensusBranchId : getDefaultConsensusBranchIdForVersion(network, this.version);
77
+ this.consensusBranchId = consensusBranchId ?? getDefaultConsensusBranchIdForVersion(network, this.version);
78
78
  }
79
79
  static fromBuffer(buffer, __noStrict, amountType = 'number', network) {
80
80
  /* istanbul ignore next */
@@ -338,4 +338,4 @@ ZcashTransaction.VERSION_SAPLING = 4;
338
338
  ZcashTransaction.VERSION4_BRANCH_CANOPY = 400;
339
339
  ZcashTransaction.VERSION4_BRANCH_NU5 = 450;
340
340
  ZcashTransaction.VERSION5_BRANCH_NU5 = 500;
341
- //# 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<bigint | number>, amountType?: 'bigint' | 'number') {\n    super(network, tx, amountType);\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: bigint | number | 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    // ZCash amounts are always within Number.MAX_SAFE_INTEGER\n    value = typeof value === 'bigint' ? Number(value) : value;\n    typeforce(types.tuple(types.UInt32, types.Buffer, types.Number), [inIndex, prevOutScript, value]);\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<TN2 extends number | bigint = TNumber>(amountType?: 'bigint' | 'number'): ZcashTransaction<TN2> {\n    return new ZcashTransaction<TN2>(this.network, this, amountType);\n  }\n}\n"]}
341
+ //# 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<bigint | number>, amountType?: 'bigint' | 'number') {\n    super(network, tx, amountType);\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: bigint | number | 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    // ZCash amounts are always within Number.MAX_SAFE_INTEGER\n    value = typeof value === 'bigint' ? Number(value) : value;\n    typeforce(types.tuple(types.UInt32, types.Buffer, types.Number), [inIndex, prevOutScript, value]);\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<TN2 extends number | bigint = TNumber>(amountType?: 'bigint' | 'number'): ZcashTransaction<TN2> {\n    return new ZcashTransaction<TN2>(this.network, this, amountType);\n  }\n}\n"]}