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

@bitgo/utxo-lib

Package Overview
Dependencies
Maintainers
13
Versions
171
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bitgo/utxo-lib - npm Package Compare versions

Comparing version 9.3.0 to 9.4.0

dist/src/bitgo/legacysafe/index.d.ts

4

dist/src/bitgo/parseInput.js

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

case ':pubkey':
return Buffer.isBuffer(e) && e.length === 33;
return Buffer.isBuffer(e) && (e.length === 33 || e.length === 65);
case ':pubkey-xonly':

@@ -429,2 +429,2 @@ return Buffer.isBuffer(e) && e.length === 32;

exports.parsePubScript = parsePubScript;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseInput.js","sourceRoot":"","sources":["../../../src/bitgo/parseInput.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint no-redeclare: 0 */\nimport * as opcodes from 'bitcoin-ops';\nimport { TxInput, script as bscript } from 'bitcoinjs-lib';\n\nimport { isTriple } from './types';\nimport { isScriptType2Of3 } from './outputScripts';\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 getLeafVersion(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\nexport type ParsedScriptType2Of3 =\n  | 'p2sh'\n  | 'p2shP2wsh'\n  | 'p2wsh'\n  | 'taprootKeyPathSpend' // only implemented for p2trMusig2\n  | 'taprootScriptPathSpend'; // can be for either p2tr or p2trMusig2 output script\n\nexport type ParsedScriptType = ParsedScriptType2Of3 | 'p2shP2pk';\n\nexport type ParsedPubScript = {\n  scriptType: ParsedScriptType;\n};\n\nexport type ParsedSignatureScript = {\n  scriptType: ParsedScriptType;\n};\n\nexport interface ParsedSignatureScriptP2shP2pk extends ParsedSignatureScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n}\n\nexport interface ParsedPubScriptTaprootKeyPath extends ParsedPubScript {\n  scriptType: 'taprootKeyPathSpend';\n  // x-only tapOutputKey\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedPubScriptTaprootScriptPath extends ParsedPubScript {\n  scriptType: 'taprootScriptPathSpend';\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport type ParsedPubScriptTaproot = ParsedPubScriptTaprootKeyPath | ParsedPubScriptTaprootScriptPath;\n\nexport interface ParsedPubScriptP2ms 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 ParsedPubScriptP2shP2pk extends ParsedPubScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n  redeemScript: Buffer;\n}\n\nexport interface ParsedSignatureScriptP2ms 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 signature\n */\nexport interface ParsedSignatureScriptTaprootKeyPath extends ParsedSignatureScript {\n  scriptType: 'taprootKeyPathSpend';\n  signatures: [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: 'taprootScriptPathSpend';\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 | ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot> = (\n  p: InputScriptsUnknown\n) => T | MatchError;\n\nexport type InputPubScript = Buffer;\n\ntype PubScriptParser<T extends ParsedPubScriptTaproot | ParsedPubScriptP2ms | ParsedPubScriptP2shP2pk> = (\n  p: InputPubScript,\n  t: ParsedScriptType\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): ParsedSignatureScriptP2ms | 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 ParsedSignatureScriptP2ms['signatures'],\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n}\n\nconst parseP2sh2Of3: InputParser<ParsedSignatureScriptP2ms> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  return parseP2ms(p.script, 'p2sh');\n};\n\nconst parseP2shP2wsh2Of3: InputParser<ParsedSignatureScriptP2ms> = (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<ParsedSignatureScriptP2ms> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  return parseP2ms(p.witness, 'p2wsh');\n};\n\nconst parseTaprootKeyPath2Of3: InputParser<ParsedSignatureScriptTaprootKeyPath> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  const match = matchScript(p.witness, [':signature']);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const signatures = match[':signature'] as [Buffer];\n  if (isPlaceholderSignature(signatures[0])) {\n    throw new Error(`invalid taproot key path signature`);\n  }\n  return {\n    scriptType: 'taprootKeyPathSpend',\n    signatures,\n  };\n};\n\nconst parseTaprootScriptPath2Of3: 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 = getLeafVersion(controlBlock);\n\n  return {\n    scriptType: 'taprootScriptPathSpend',\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 | ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot {\n  const decScript = bscript.decompile(input.script);\n  const parsers = [\n    parseP2sh2Of3,\n    parseP2shP2wsh2Of3,\n    parseP2wsh2Of3,\n    parseTaprootKeyPath2Of3,\n    parseTaprootScriptPath2Of3,\n    parseP2shP2pk,\n  ] 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): ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input);\n\n  if (\n    !isScriptType2Of3(result.scriptType) &&\n    result.scriptType !== 'taprootKeyPathSpend' &&\n    result.scriptType !== 'taprootScriptPathSpend'\n  ) {\n    throw new Error(`invalid script type`);\n  }\n\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (\n    result.scriptType !== 'taprootKeyPathSpend' &&\n    result.publicKeys.length !== 3 &&\n    (result.publicKeys.length !== 2 || result.scriptType !== 'taprootScriptPathSpend')\n  ) {\n    throw new Error(`unexpected pubkey count`);\n  }\n\n  return result as ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot;\n}\n\nconst parseP2shP2pkPubScript: PubScriptParser<ParsedPubScriptP2shP2pk> = (pubScript, scriptType) => {\n  if (scriptType !== 'p2shP2pk') {\n    throw new Error('invalid script type');\n  }\n  const match = matchScript([pubScript], [{ ':script': [':pubkey', 'OP_CHECKSIG'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const [script] = match[':script'];\n  return {\n    scriptType,\n    publicKeys: script.match[':pubkey'] as [Buffer],\n    pubScript: pubScript,\n    redeemScript: pubScript,\n  };\n};\n\nconst parseP2msPubScript: PubScriptParser<ParsedPubScriptP2ms> = (pubScript, scriptType) => {\n  if (scriptType === 'taprootScriptPathSpend' || scriptType === 'taprootKeyPathSpend' || scriptType === 'p2shP2pk') {\n    throw new Error('invalid script type');\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 parseTaprootKeyPathPubScript: PubScriptParser<ParsedPubScriptTaprootKeyPath> = (pubScript, scriptType) => {\n  if (\n    scriptType === 'p2sh' ||\n    scriptType === 'p2wsh' ||\n    scriptType === 'p2shP2wsh' ||\n    scriptType === 'taprootScriptPathSpend' ||\n    scriptType === 'p2shP2pk'\n  ) {\n    throw new Error('invalid script type');\n  }\n  const match = matchScript([pubScript], [{ ':script': ['OP_1', ':pubkey-xonly'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [script] = match[':script'];\n\n  return {\n    scriptType: 'taprootKeyPathSpend',\n    publicKeys: script.match[':pubkey-xonly'] as [Buffer],\n    pubScript: pubScript,\n  };\n};\n\nconst parseTaprootScriptPathPubScript: PubScriptParser<ParsedPubScriptTaprootScriptPath> = (pubScript, scriptType) => {\n  if (\n    scriptType === 'p2sh' ||\n    scriptType === 'p2wsh' ||\n    scriptType === 'p2shP2wsh' ||\n    scriptType === 'taprootKeyPathSpend' ||\n    scriptType === 'p2shP2pk'\n  ) {\n    throw new Error('invalid script type');\n  }\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,\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 * taprootScriptPathSpend (P2TR and P2TRMUISG2 script path) => scriptType, pubScript, pub keys.\n * taprootKeyPathSpend (P2TRMUISG2 key path) => scriptType, pubScript (34-byte output script), pub key (tapOutputKey).\n */\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootKeyPathSpend'\n): ParsedPubScriptTaprootKeyPath;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootScriptPathSpend'\n): ParsedPubScriptTaprootScriptPath;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedPubScriptP2ms;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType2Of3\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType2Of3\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot {\n  const result =\n    scriptType === 'taprootKeyPathSpend'\n      ? parseTaprootKeyPathPubScript(inputPubScript, scriptType)\n      : scriptType === 'taprootScriptPathSpend'\n      ? parseTaprootScriptPathPubScript(inputPubScript, scriptType)\n      : parseP2msPubScript(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (\n    (result.scriptType === 'taprootKeyPathSpend' && result.publicKeys.length !== 1) ||\n    (result.scriptType === 'taprootScriptPathSpend' && result.publicKeys.length !== 2) ||\n    (isScriptType2Of3(result.scriptType) && result.publicKeys.length !== 3)\n  ) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\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 * taprootScriptPathSpend (P2TR and P2TRMUISG2 script path) => scriptType, pubScript, pub keys.\n * taprootKeyPathSpend (P2TRMUISG2 key path) => scriptType, pubScript (34-byte output script), pub key (tapOutputKey).\n * P2SH-P2PK => scriptType, pubScript, pub key, redeemScript.\n */\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootKeyPathSpend'\n): ParsedPubScriptTaprootKeyPath;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootScriptPathSpend'\n): ParsedPubScriptTaprootScriptPath;\nexport function parsePubScript(inputPubScript: InputPubScript, scriptType: 'p2shP2pk'): ParsedPubScriptP2shP2pk;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedPubScriptP2ms;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk {\n  const result =\n    scriptType === 'p2shP2pk'\n      ? parseP2shP2pkPubScript(inputPubScript, scriptType)\n      : parsePubScript2Of3(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (result.scriptType === 'p2shP2pk' && result.publicKeys.length !== 1) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseInput.js","sourceRoot":"","sources":["../../../src/bitgo/parseInput.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint no-redeclare: 0 */\nimport * as opcodes from 'bitcoin-ops';\nimport { TxInput, script as bscript } from 'bitcoinjs-lib';\n\nimport { isTriple } from './types';\nimport { isScriptType2Of3 } from './outputScripts';\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 getLeafVersion(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\nexport type ParsedScriptType2Of3 =\n  | 'p2sh'\n  | 'p2shP2wsh'\n  | 'p2wsh'\n  | 'taprootKeyPathSpend' // only implemented for p2trMusig2\n  | 'taprootScriptPathSpend'; // can be for either p2tr or p2trMusig2 output script\n\nexport type ParsedScriptType = ParsedScriptType2Of3 | 'p2shP2pk';\n\nexport type ParsedPubScript = {\n  scriptType: ParsedScriptType;\n};\n\nexport type ParsedSignatureScript = {\n  scriptType: ParsedScriptType;\n};\n\nexport interface ParsedSignatureScriptP2shP2pk extends ParsedSignatureScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  signatures: [Buffer];\n}\n\nexport interface ParsedPubScriptTaprootKeyPath extends ParsedPubScript {\n  scriptType: 'taprootKeyPathSpend';\n  // x-only tapOutputKey\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedPubScriptTaprootScriptPath extends ParsedPubScript {\n  scriptType: 'taprootScriptPathSpend';\n  publicKeys: [Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport type ParsedPubScriptTaproot = ParsedPubScriptTaprootKeyPath | ParsedPubScriptTaprootScriptPath;\n\nexport interface ParsedPubScriptP2ms 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 ParsedPubScriptP2shP2pk extends ParsedPubScript {\n  scriptType: 'p2shP2pk';\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n  redeemScript: Buffer;\n}\n\nexport interface ParsedSignatureScriptP2ms 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 signature\n */\nexport interface ParsedSignatureScriptTaprootKeyPath extends ParsedSignatureScript {\n  scriptType: 'taprootKeyPathSpend';\n  signatures: [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: 'taprootScriptPathSpend';\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 || e.length === 65);\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 | ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot> = (\n  p: InputScriptsUnknown\n) => T | MatchError;\n\nexport type InputPubScript = Buffer;\n\ntype PubScriptParser<T extends ParsedPubScriptTaproot | ParsedPubScriptP2ms | ParsedPubScriptP2shP2pk> = (\n  p: InputPubScript,\n  t: ParsedScriptType\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): ParsedSignatureScriptP2ms | 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 ParsedSignatureScriptP2ms['signatures'],\n    redeemScript: scriptType === 'p2sh' ? redeemScript.buffer : undefined,\n    witnessScript: scriptType === 'p2shP2wsh' || scriptType === 'p2wsh' ? redeemScript.buffer : undefined,\n  };\n}\n\nconst parseP2sh2Of3: InputParser<ParsedSignatureScriptP2ms> = (p) => {\n  if (!isLegacy(p)) {\n    return new MatchError(`expected legacy input`);\n  }\n  return parseP2ms(p.script, 'p2sh');\n};\n\nconst parseP2shP2wsh2Of3: InputParser<ParsedSignatureScriptP2ms> = (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<ParsedSignatureScriptP2ms> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  return parseP2ms(p.witness, 'p2wsh');\n};\n\nconst parseTaprootKeyPath2Of3: InputParser<ParsedSignatureScriptTaprootKeyPath> = (p) => {\n  if (!isNativeSegwit(p)) {\n    return new MatchError(`expected native segwit`);\n  }\n  const match = matchScript(p.witness, [':signature']);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const signatures = match[':signature'] as [Buffer];\n  if (isPlaceholderSignature(signatures[0])) {\n    throw new Error(`invalid taproot key path signature`);\n  }\n  return {\n    scriptType: 'taprootKeyPathSpend',\n    signatures,\n  };\n};\n\nconst parseTaprootScriptPath2Of3: 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 = getLeafVersion(controlBlock);\n\n  return {\n    scriptType: 'taprootScriptPathSpend',\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 | ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot {\n  const decScript = bscript.decompile(input.script);\n  const parsers = [\n    parseP2sh2Of3,\n    parseP2shP2wsh2Of3,\n    parseP2wsh2Of3,\n    parseTaprootKeyPath2Of3,\n    parseTaprootScriptPath2Of3,\n    parseP2shP2pk,\n  ] 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): ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot {\n  const result = parseSignatureScript(input);\n\n  if (\n    !isScriptType2Of3(result.scriptType) &&\n    result.scriptType !== 'taprootKeyPathSpend' &&\n    result.scriptType !== 'taprootScriptPathSpend'\n  ) {\n    throw new Error(`invalid script type`);\n  }\n\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (\n    result.scriptType !== 'taprootKeyPathSpend' &&\n    result.publicKeys.length !== 3 &&\n    (result.publicKeys.length !== 2 || result.scriptType !== 'taprootScriptPathSpend')\n  ) {\n    throw new Error(`unexpected pubkey count`);\n  }\n\n  return result as ParsedSignatureScriptP2ms | ParsedSignatureScriptTaproot;\n}\n\nconst parseP2shP2pkPubScript: PubScriptParser<ParsedPubScriptP2shP2pk> = (pubScript, scriptType) => {\n  if (scriptType !== 'p2shP2pk') {\n    throw new Error('invalid script type');\n  }\n  const match = matchScript([pubScript], [{ ':script': [':pubkey', 'OP_CHECKSIG'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n  const [script] = match[':script'];\n  return {\n    scriptType,\n    publicKeys: script.match[':pubkey'] as [Buffer],\n    pubScript: pubScript,\n    redeemScript: pubScript,\n  };\n};\n\nconst parseP2msPubScript: PubScriptParser<ParsedPubScriptP2ms> = (pubScript, scriptType) => {\n  if (scriptType === 'taprootScriptPathSpend' || scriptType === 'taprootKeyPathSpend' || scriptType === 'p2shP2pk') {\n    throw new Error('invalid script type');\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 parseTaprootKeyPathPubScript: PubScriptParser<ParsedPubScriptTaprootKeyPath> = (pubScript, scriptType) => {\n  if (\n    scriptType === 'p2sh' ||\n    scriptType === 'p2wsh' ||\n    scriptType === 'p2shP2wsh' ||\n    scriptType === 'taprootScriptPathSpend' ||\n    scriptType === 'p2shP2pk'\n  ) {\n    throw new Error('invalid script type');\n  }\n  const match = matchScript([pubScript], [{ ':script': ['OP_1', ':pubkey-xonly'] }]);\n  if (match instanceof MatchError) {\n    return match;\n  }\n\n  const [script] = match[':script'];\n\n  return {\n    scriptType: 'taprootKeyPathSpend',\n    publicKeys: script.match[':pubkey-xonly'] as [Buffer],\n    pubScript: pubScript,\n  };\n};\n\nconst parseTaprootScriptPathPubScript: PubScriptParser<ParsedPubScriptTaprootScriptPath> = (pubScript, scriptType) => {\n  if (\n    scriptType === 'p2sh' ||\n    scriptType === 'p2wsh' ||\n    scriptType === 'p2shP2wsh' ||\n    scriptType === 'taprootKeyPathSpend' ||\n    scriptType === 'p2shP2pk'\n  ) {\n    throw new Error('invalid script type');\n  }\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,\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 * taprootScriptPathSpend (P2TR and P2TRMUISG2 script path) => scriptType, pubScript, pub keys.\n * taprootKeyPathSpend (P2TRMUISG2 key path) => scriptType, pubScript (34-byte output script), pub key (tapOutputKey).\n */\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootKeyPathSpend'\n): ParsedPubScriptTaprootKeyPath;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootScriptPathSpend'\n): ParsedPubScriptTaprootScriptPath;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedPubScriptP2ms;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType2Of3\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot;\nexport function parsePubScript2Of3(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType2Of3\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot {\n  const result =\n    scriptType === 'taprootKeyPathSpend'\n      ? parseTaprootKeyPathPubScript(inputPubScript, scriptType)\n      : scriptType === 'taprootScriptPathSpend'\n      ? parseTaprootScriptPathPubScript(inputPubScript, scriptType)\n      : parseP2msPubScript(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (\n    (result.scriptType === 'taprootKeyPathSpend' && result.publicKeys.length !== 1) ||\n    (result.scriptType === 'taprootScriptPathSpend' && result.publicKeys.length !== 2) ||\n    (isScriptType2Of3(result.scriptType) && result.publicKeys.length !== 3)\n  ) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\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 * taprootScriptPathSpend (P2TR and P2TRMUISG2 script path) => scriptType, pubScript, pub keys.\n * taprootKeyPathSpend (P2TRMUISG2 key path) => scriptType, pubScript (34-byte output script), pub key (tapOutputKey).\n * P2SH-P2PK => scriptType, pubScript, pub key, redeemScript.\n */\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootKeyPathSpend'\n): ParsedPubScriptTaprootKeyPath;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'taprootScriptPathSpend'\n): ParsedPubScriptTaprootScriptPath;\nexport function parsePubScript(inputPubScript: InputPubScript, scriptType: 'p2shP2pk'): ParsedPubScriptP2shP2pk;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh'\n): ParsedPubScriptP2ms;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk;\nexport function parsePubScript(\n  inputPubScript: InputPubScript,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk {\n  const result =\n    scriptType === 'p2shP2pk'\n      ? parseP2shP2pkPubScript(inputPubScript, scriptType)\n      : parsePubScript2Of3(inputPubScript, scriptType);\n\n  if (result instanceof MatchError) {\n    throw new Error(result.message);\n  }\n\n  if (result.scriptType === 'p2shP2pk' && result.publicKeys.length !== 1) {\n    throw new Error('unexpected pubkey count');\n  }\n\n  return result;\n}\n"]}

@@ -21,3 +21,3 @@ /**

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

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

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

export declare function getSignatureValidationArrayPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys): SignatureValidation[];
/**
* Extracts the half signed transaction from the psbt for p2ms based script types - p2sh, p2wsh, and p2shP2wsh.
* The purpose is to provide backward compatibility to keyternal (KRS) that only supports network transaction and p2ms script types.
*/
export declare function extractP2msOnlyHalfSignedTx(psbt: UtxoPsbt): UtxoTransaction<bigint>;
export {};
//# sourceMappingURL=Psbt.d.ts.map

@@ -56,3 +56,6 @@ import { ScriptType, ScriptType2Of3 } from '../bitgo/outputScripts';

*/
export declare function signPsbtInput(psbt: UtxoPsbt, input: Input, inputIndex: number, rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned'): void;
export declare function signPsbtInput(psbt: UtxoPsbt, input: Input, inputIndex: number, rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): void;
/**

@@ -62,7 +65,13 @@ * signs with first or second signature for all inputs.

*/
export declare function signAllPsbtInputs(psbt: UtxoPsbt, inputs: Input[], rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned'): void;
export declare function signAllPsbtInputs(psbt: UtxoPsbt, inputs: Input[], rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): void;
/**
* construct psbt for given inputs, outputs, network and root wallet keys.
*/
export declare function constructPsbt(inputs: Input[], outputs: Output[], network: Network, rootWalletKeys: RootWalletKeys, sign: 'unsigned' | 'halfsigned' | 'fullsigned'): UtxoPsbt;
export declare function constructPsbt(inputs: Input[], outputs: Output[], network: Network, rootWalletKeys: RootWalletKeys, sign: 'unsigned' | 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): UtxoPsbt;
/**

@@ -69,0 +78,0 @@ * Verifies signatures of fully signed tx (with taproot key path support).

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

*/
function signPsbtInput(psbt, input, inputIndex, rootWalletKeys, sign) {
const { signerName, cosignerName } = getSigners(input.scriptType);
function signPsbtInput(psbt, input, inputIndex, rootWalletKeys, sign, signers) {
const { signerName, cosignerName } = signers ? signers : getSigners(input.scriptType);
if (sign === 'halfsigned') {

@@ -74,5 +74,5 @@ if (input.scriptType === 'p2shP2pk') {

*/
function signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign) {
function signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign, signers) {
inputs.forEach((input, index) => {
signPsbtInput(psbt, input, index, rootWalletKeys, sign);
signPsbtInput(psbt, input, index, rootWalletKeys, sign, signers);
});

@@ -84,3 +84,3 @@ }

*/
function constructPsbt(inputs, outputs, network, rootWalletKeys, sign) {
function constructPsbt(inputs, outputs, network, rootWalletKeys, sign, signers) {
const totalInputAmount = inputs.reduce((sum, input) => sum + input.value, BigInt(0));

@@ -93,3 +93,3 @@ const outputInputAmount = outputs.reduce((sum, output) => sum + output.value, BigInt(0));

unspents.forEach((u, i) => {
const { signerName, cosignerName } = getSigners(inputs[i].scriptType);
const { signerName, cosignerName } = signers ? signers : getSigners(inputs[i].scriptType);
if (bitgo_1.isWalletUnspent(u) && cosignerName) {

@@ -120,3 +120,3 @@ bitgo_1.addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signerName, cosignerName);

if (sign === 'fullsigned') {
signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign);
signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign, signers);
}

@@ -152,2 +152,2 @@ return psbt;

exports.verifyFullySignedSignatures = verifyFullySignedSignatures;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"psbt.js","sourceRoot":"","sources":["../../../src/testutil/psbt.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport {\n  createOutputScriptP2shP2pk,\n  ScriptType,\n  ScriptType2Of3,\n  scriptTypeP2shP2pk,\n  scriptTypes2Of3,\n} from '../bitgo/outputScripts';\nimport {\n  addReplayProtectionUnspentToPsbt,\n  addWalletOutputToPsbt,\n  addWalletUnspentToPsbt,\n  createPsbtForNetwork,\n  getExternalChainCode,\n  getSignatureVerifications,\n  isWalletUnspent,\n  KeyName,\n  parseSignatureScript2Of3,\n  getInternalChainCode,\n  RootWalletKeys,\n  toOutput,\n  Unspent,\n  UtxoPsbt,\n  UtxoTransaction,\n  verifySignatureWithUnspent,\n  WalletUnspent,\n} from '../bitgo';\nimport { Network } from '../networks';\nimport { mockReplayProtectionUnspent, mockWalletUnspent } from './mock';\nimport { toOutputScript } from '../address';\n\n/**\n * input script type and value.\n * use p2trMusig2 for p2trMusig2 script path.\n * use taprootKeyPathSpend for p2trMusig2 key path.\n */\nexport type InputScriptType = ScriptType | 'taprootKeyPathSpend';\nexport type OutputScriptType = ScriptType2Of3;\n\n/**\n * input script type and value\n */\nexport interface Input {\n  scriptType: InputScriptType;\n  value: bigint;\n}\n\n/**\n * should set either address or scriptType, never both.\n * set isInternalAddress=true for internal output address\n */\nexport interface Output {\n  address?: string;\n  scriptType?: OutputScriptType;\n  value: bigint;\n  isInternalAddress?: boolean;\n}\n\n/**\n * array of supported input script types.\n * use p2trMusig2 for p2trMusig2 script path.\n * use taprootKeyPathSpend for p2trMusig2 key path.\n */\nexport const inputScriptTypes = [...scriptTypes2Of3, 'taprootKeyPathSpend', scriptTypeP2shP2pk] as const;\n\n/**\n * array of supported output script types.\n */\nexport const outputScriptTypes = scriptTypes2Of3;\n\n/**\n * create unspent object from input script type, index, network and root wallet key.\n */\nexport function toUnspent(\n  input: Input,\n  index: number,\n  network: Network,\n  rootWalletKeys: RootWalletKeys\n): Unspent<bigint> {\n  if (input.scriptType === 'p2shP2pk') {\n    return mockReplayProtectionUnspent(network, input.value, { key: rootWalletKeys['user'], vout: index });\n  } else {\n    const chain = getInternalChainCode(input.scriptType === 'taprootKeyPathSpend' ? 'p2trMusig2' : input.scriptType);\n    return mockWalletUnspent(network, input.value, {\n      chain,\n      vout: index,\n      keys: rootWalletKeys,\n      index,\n    });\n  }\n}\n\n/**\n * returns signer and cosigner names for InputScriptType.\n * user and undefined as signer and cosigner respectively for p2shP2pk.\n * user and backup as signer and cosigner respectively for p2trMusig2.\n * user and bitgo as signer and cosigner respectively for other input script types.\n */\nexport function getSigners(inputType: InputScriptType): { signerName: KeyName; cosignerName?: KeyName } {\n  return {\n    signerName: 'user',\n    cosignerName: inputType === 'p2shP2pk' ? undefined : inputType === 'p2trMusig2' ? 'backup' : 'bitgo',\n  };\n}\n\n/**\n * signs with first or second signature for single input.\n * p2shP2pk is signed only with first sign.\n */\nexport function signPsbtInput(\n  psbt: UtxoPsbt,\n  input: Input,\n  inputIndex: number,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned'\n): void {\n  const { signerName, cosignerName } = getSigners(input.scriptType);\n  if (sign === 'halfsigned') {\n    if (input.scriptType === 'p2shP2pk') {\n      psbt.signInput(inputIndex, rootWalletKeys[signerName]);\n    } else {\n      psbt.signInputHD(inputIndex, rootWalletKeys[signerName]);\n    }\n  }\n  if (sign === 'fullsigned' && cosignerName) {\n    psbt.signInputHD(inputIndex, rootWalletKeys[cosignerName]);\n  }\n}\n\n/**\n * signs with first or second signature for all inputs.\n * p2shP2pk is signed only with first sign.\n */\nexport function signAllPsbtInputs(\n  psbt: UtxoPsbt,\n  inputs: Input[],\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned'\n): void {\n  inputs.forEach((input, index) => {\n    signPsbtInput(psbt, input, index, rootWalletKeys, sign);\n  });\n}\n\n/**\n * construct psbt for given inputs, outputs, network and root wallet keys.\n */\nexport function constructPsbt(\n  inputs: Input[],\n  outputs: Output[],\n  network: Network,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'unsigned' | 'halfsigned' | 'fullsigned'\n): UtxoPsbt {\n  const totalInputAmount = inputs.reduce((sum, input) => sum + input.value, BigInt(0));\n  const outputInputAmount = outputs.reduce((sum, output) => sum + output.value, BigInt(0));\n  assert(totalInputAmount >= outputInputAmount, 'total output can not exceed total input');\n  assert(\n    !outputs.some((o) => (o.scriptType && o.address) || (!o.scriptType && !o.address)),\n    'only either output script type or address should be provided'\n  );\n\n  const psbt = createPsbtForNetwork({ network });\n  const unspents = inputs.map((input, i) => toUnspent(input, i, network, rootWalletKeys));\n\n  unspents.forEach((u, i) => {\n    const { signerName, cosignerName } = getSigners(inputs[i].scriptType);\n    if (isWalletUnspent(u) && cosignerName) {\n      addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signerName, cosignerName);\n    } else {\n      const { redeemScript } = createOutputScriptP2shP2pk(rootWalletKeys[signerName].publicKey);\n      assert(redeemScript);\n      addReplayProtectionUnspentToPsbt(psbt, u, redeemScript);\n    }\n  });\n\n  outputs.forEach((output, i) => {\n    if (output.scriptType) {\n      addWalletOutputToPsbt(\n        psbt,\n        rootWalletKeys,\n        output.isInternalAddress ? getInternalChainCode(output.scriptType) : getExternalChainCode(output.scriptType),\n        i,\n        output.value\n      );\n    } else if (output.address) {\n      const { address, value } = output;\n      psbt.addOutput({ script: toOutputScript(address, network), value });\n    }\n  });\n\n  if (sign === 'unsigned') {\n    return psbt;\n  }\n\n  psbt.setAllInputsMusig2NonceHD(rootWalletKeys['user']);\n  psbt.setAllInputsMusig2NonceHD(rootWalletKeys['bitgo']);\n\n  signAllPsbtInputs(psbt, inputs, rootWalletKeys, 'halfsigned');\n\n  if (sign === 'fullsigned') {\n    signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign);\n  }\n\n  return psbt;\n}\n\n/**\n * Verifies signatures of fully signed tx (with taproot key path support).\n * NOTE: taproot key path tx can only be built and signed with PSBT.\n */\nexport function verifyFullySignedSignatures(\n  tx: UtxoTransaction<bigint>,\n  unspents: WalletUnspent<bigint>[],\n  walletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName\n): boolean {\n  const prevOutputs = unspents.map((u) => toOutput(u, tx.network));\n  return unspents.every((u, index) => {\n    if (parseSignatureScript2Of3(tx.ins[index]).scriptType === 'taprootKeyPathSpend') {\n      const result = getSignatureVerifications(tx, index, u.value, undefined, prevOutputs);\n      return result.length === 1 && result[0].signature;\n    } else {\n      const result = verifySignatureWithUnspent(tx, index, unspents, walletKeys);\n      if ((signer === 'user' && cosigner === 'bitgo') || (signer === 'bitgo' && cosigner === 'user')) {\n        return result[0] && !result[1] && result[2];\n      } else if ((signer === 'user' && cosigner === 'backup') || (signer === 'backup' && cosigner === 'user')) {\n        return result[0] && result[1] && !result[2];\n      } else {\n        return !result[0] && result[1] && result[2];\n      }\n    }\n  });\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"psbt.js","sourceRoot":"","sources":["../../../src/testutil/psbt.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport {\n  createOutputScriptP2shP2pk,\n  ScriptType,\n  ScriptType2Of3,\n  scriptTypeP2shP2pk,\n  scriptTypes2Of3,\n} from '../bitgo/outputScripts';\nimport {\n  addReplayProtectionUnspentToPsbt,\n  addWalletOutputToPsbt,\n  addWalletUnspentToPsbt,\n  createPsbtForNetwork,\n  getExternalChainCode,\n  getSignatureVerifications,\n  isWalletUnspent,\n  KeyName,\n  parseSignatureScript2Of3,\n  getInternalChainCode,\n  RootWalletKeys,\n  toOutput,\n  Unspent,\n  UtxoPsbt,\n  UtxoTransaction,\n  verifySignatureWithUnspent,\n  WalletUnspent,\n} from '../bitgo';\nimport { Network } from '../networks';\nimport { mockReplayProtectionUnspent, mockWalletUnspent } from './mock';\nimport { toOutputScript } from '../address';\n\n/**\n * input script type and value.\n * use p2trMusig2 for p2trMusig2 script path.\n * use taprootKeyPathSpend for p2trMusig2 key path.\n */\nexport type InputScriptType = ScriptType | 'taprootKeyPathSpend';\nexport type OutputScriptType = ScriptType2Of3;\n\n/**\n * input script type and value\n */\nexport interface Input {\n  scriptType: InputScriptType;\n  value: bigint;\n}\n\n/**\n * should set either address or scriptType, never both.\n * set isInternalAddress=true for internal output address\n */\nexport interface Output {\n  address?: string;\n  scriptType?: OutputScriptType;\n  value: bigint;\n  isInternalAddress?: boolean;\n}\n\n/**\n * array of supported input script types.\n * use p2trMusig2 for p2trMusig2 script path.\n * use taprootKeyPathSpend for p2trMusig2 key path.\n */\nexport const inputScriptTypes = [...scriptTypes2Of3, 'taprootKeyPathSpend', scriptTypeP2shP2pk] as const;\n\n/**\n * array of supported output script types.\n */\nexport const outputScriptTypes = scriptTypes2Of3;\n\n/**\n * create unspent object from input script type, index, network and root wallet key.\n */\nexport function toUnspent(\n  input: Input,\n  index: number,\n  network: Network,\n  rootWalletKeys: RootWalletKeys\n): Unspent<bigint> {\n  if (input.scriptType === 'p2shP2pk') {\n    return mockReplayProtectionUnspent(network, input.value, { key: rootWalletKeys['user'], vout: index });\n  } else {\n    const chain = getInternalChainCode(input.scriptType === 'taprootKeyPathSpend' ? 'p2trMusig2' : input.scriptType);\n    return mockWalletUnspent(network, input.value, {\n      chain,\n      vout: index,\n      keys: rootWalletKeys,\n      index,\n    });\n  }\n}\n\n/**\n * returns signer and cosigner names for InputScriptType.\n * user and undefined as signer and cosigner respectively for p2shP2pk.\n * user and backup as signer and cosigner respectively for p2trMusig2.\n * user and bitgo as signer and cosigner respectively for other input script types.\n */\nexport function getSigners(inputType: InputScriptType): { signerName: KeyName; cosignerName?: KeyName } {\n  return {\n    signerName: 'user',\n    cosignerName: inputType === 'p2shP2pk' ? undefined : inputType === 'p2trMusig2' ? 'backup' : 'bitgo',\n  };\n}\n\n/**\n * signs with first or second signature for single input.\n * p2shP2pk is signed only with first sign.\n */\nexport function signPsbtInput(\n  psbt: UtxoPsbt,\n  input: Input,\n  inputIndex: number,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): void {\n  const { signerName, cosignerName } = signers ? signers : getSigners(input.scriptType);\n  if (sign === 'halfsigned') {\n    if (input.scriptType === 'p2shP2pk') {\n      psbt.signInput(inputIndex, rootWalletKeys[signerName]);\n    } else {\n      psbt.signInputHD(inputIndex, rootWalletKeys[signerName]);\n    }\n  }\n  if (sign === 'fullsigned' && cosignerName) {\n    psbt.signInputHD(inputIndex, rootWalletKeys[cosignerName]);\n  }\n}\n\n/**\n * signs with first or second signature for all inputs.\n * p2shP2pk is signed only with first sign.\n */\nexport function signAllPsbtInputs(\n  psbt: UtxoPsbt,\n  inputs: Input[],\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): void {\n  inputs.forEach((input, index) => {\n    signPsbtInput(psbt, input, index, rootWalletKeys, sign, signers);\n  });\n}\n\n/**\n * construct psbt for given inputs, outputs, network and root wallet keys.\n */\nexport function constructPsbt(\n  inputs: Input[],\n  outputs: Output[],\n  network: Network,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'unsigned' | 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): UtxoPsbt {\n  const totalInputAmount = inputs.reduce((sum, input) => sum + input.value, BigInt(0));\n  const outputInputAmount = outputs.reduce((sum, output) => sum + output.value, BigInt(0));\n  assert(totalInputAmount >= outputInputAmount, 'total output can not exceed total input');\n  assert(\n    !outputs.some((o) => (o.scriptType && o.address) || (!o.scriptType && !o.address)),\n    'only either output script type or address should be provided'\n  );\n\n  const psbt = createPsbtForNetwork({ network });\n  const unspents = inputs.map((input, i) => toUnspent(input, i, network, rootWalletKeys));\n\n  unspents.forEach((u, i) => {\n    const { signerName, cosignerName } = signers ? signers : getSigners(inputs[i].scriptType);\n    if (isWalletUnspent(u) && cosignerName) {\n      addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signerName, cosignerName);\n    } else {\n      const { redeemScript } = createOutputScriptP2shP2pk(rootWalletKeys[signerName].publicKey);\n      assert(redeemScript);\n      addReplayProtectionUnspentToPsbt(psbt, u, redeemScript);\n    }\n  });\n\n  outputs.forEach((output, i) => {\n    if (output.scriptType) {\n      addWalletOutputToPsbt(\n        psbt,\n        rootWalletKeys,\n        output.isInternalAddress ? getInternalChainCode(output.scriptType) : getExternalChainCode(output.scriptType),\n        i,\n        output.value\n      );\n    } else if (output.address) {\n      const { address, value } = output;\n      psbt.addOutput({ script: toOutputScript(address, network), value });\n    }\n  });\n\n  if (sign === 'unsigned') {\n    return psbt;\n  }\n\n  psbt.setAllInputsMusig2NonceHD(rootWalletKeys['user']);\n  psbt.setAllInputsMusig2NonceHD(rootWalletKeys['bitgo']);\n\n  signAllPsbtInputs(psbt, inputs, rootWalletKeys, 'halfsigned');\n\n  if (sign === 'fullsigned') {\n    signAllPsbtInputs(psbt, inputs, rootWalletKeys, sign, signers);\n  }\n\n  return psbt;\n}\n\n/**\n * Verifies signatures of fully signed tx (with taproot key path support).\n * NOTE: taproot key path tx can only be built and signed with PSBT.\n */\nexport function verifyFullySignedSignatures(\n  tx: UtxoTransaction<bigint>,\n  unspents: WalletUnspent<bigint>[],\n  walletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName\n): boolean {\n  const prevOutputs = unspents.map((u) => toOutput(u, tx.network));\n  return unspents.every((u, index) => {\n    if (parseSignatureScript2Of3(tx.ins[index]).scriptType === 'taprootKeyPathSpend') {\n      const result = getSignatureVerifications(tx, index, u.value, undefined, prevOutputs);\n      return result.length === 1 && result[0].signature;\n    } else {\n      const result = verifySignatureWithUnspent(tx, index, unspents, walletKeys);\n      if ((signer === 'user' && cosigner === 'bitgo') || (signer === 'bitgo' && cosigner === 'user')) {\n        return result[0] && !result[1] && result[2];\n      } else if ((signer === 'user' && cosigner === 'backup') || (signer === 'backup' && cosigner === 'user')) {\n        return result[0] && result[1] && !result[2];\n      } else {\n        return !result[0] && result[1] && result[2];\n      }\n    }\n  });\n}\n"]}

@@ -8,3 +8,3 @@ import { ScriptType, ScriptType2Of3 } from '../bitgo/outputScripts';

export declare type TxnInputScriptType = Exclude<ScriptType, 'p2trMusig2'>;
export declare type TxnOutputScriptType = Exclude<ScriptType2Of3, 'p2trMusig2'>;
export declare type TxnOutputScriptType = ScriptType2Of3;
/**

@@ -34,3 +34,3 @@ * output script type and value

*/
export declare const txnOutputScriptTypes: readonly ["p2sh", "p2shP2wsh", "p2wsh", "p2tr"];
export declare const txnOutputScriptTypes: readonly ["p2sh", "p2shP2wsh", "p2wsh", "p2tr", "p2trMusig2"];
/**

@@ -53,3 +53,6 @@ * create unspent object from input script type, index, network and root wallet key.

*/
export declare function signTxnInput<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, input: TxnInput<TNumber>, inputIndex: number, rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned'): void;
export declare function signTxnInput<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, input: TxnInput<TNumber>, inputIndex: number, rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): void;
/**

@@ -59,7 +62,13 @@ * signs with first or second signature for all inputs.

*/
export declare function signAllTxnInputs<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, inputs: TxnInput<TNumber>[], rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned'): void;
export declare function signAllTxnInputs<TNumber extends number | bigint>(txb: UtxoTransactionBuilder<TNumber>, inputs: TxnInput<TNumber>[], rootWalletKeys: RootWalletKeys, sign: 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): void;
/**
* construct transaction for given inputs, outputs, network and root wallet keys.
*/
export declare function constructTxnBuilder<TNumber extends number | bigint>(inputs: TxnInput<TNumber>[], outputs: TxnOutput<TNumber>[], network: Network, rootWalletKeys: RootWalletKeys, sign: 'unsigned' | 'halfsigned' | 'fullsigned'): UtxoTransactionBuilder<TNumber>;
export declare function constructTxnBuilder<TNumber extends number | bigint>(inputs: TxnInput<TNumber>[], outputs: TxnOutput<TNumber>[], network: Network, rootWalletKeys: RootWalletKeys, sign: 'unsigned' | 'halfsigned' | 'fullsigned', signers?: {
signerName: KeyName;
cosignerName?: KeyName;
}): UtxoTransactionBuilder<TNumber>;
//# sourceMappingURL=transaction.d.ts.map

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

*/
exports.txnOutputScriptTypes = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr'];
exports.txnOutputScriptTypes = outputScripts_1.scriptTypes2Of3;
/**

@@ -50,4 +50,4 @@ * create unspent object from input script type, index, network and root wallet key.

*/
function signTxnInput(txb, input, inputIndex, rootWalletKeys, sign) {
const { signerName, cosignerName } = getTxnSigners(input.scriptType);
function signTxnInput(txb, input, inputIndex, rootWalletKeys, sign, signers) {
const { signerName, cosignerName } = signers ? signers : getTxnSigners(input.scriptType);
const unspent = toTxnUnspent(input, inputIndex, txb.network, rootWalletKeys);

@@ -71,5 +71,5 @@ if (sign === 'halfsigned') {

*/
function signAllTxnInputs(txb, inputs, rootWalletKeys, sign) {
function signAllTxnInputs(txb, inputs, rootWalletKeys, sign, signers) {
inputs.forEach((input, index) => {
signTxnInput(txb, input, index, rootWalletKeys, sign);
signTxnInput(txb, input, index, rootWalletKeys, sign, signers);
});

@@ -81,3 +81,3 @@ }

*/
function constructTxnBuilder(inputs, outputs, network, rootWalletKeys, sign) {
function constructTxnBuilder(inputs, outputs, network, rootWalletKeys, sign, signers) {
const totalInputAmount = inputs.reduce((sum, input) => sum + BigInt(input.value), BigInt(0));

@@ -104,5 +104,5 @@ const outputInputAmount = outputs.reduce((sum, output) => sum + BigInt(output.value), BigInt(0));

}
signAllTxnInputs(txb, inputs, rootWalletKeys, 'halfsigned');
signAllTxnInputs(txb, inputs, rootWalletKeys, 'halfsigned', signers);
if (sign === 'fullsigned') {
signAllTxnInputs(txb, inputs, rootWalletKeys, sign);
signAllTxnInputs(txb, inputs, rootWalletKeys, sign, signers);
}

@@ -112,2 +112,2 @@ return txb;

exports.constructTxnBuilder = constructTxnBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/testutil/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport { ScriptType, ScriptType2Of3, scriptTypeP2shP2pk } from '../bitgo/outputScripts';\nimport {\n  getExternalChainCode,\n  isWalletUnspent,\n  KeyName,\n  getInternalChainCode,\n  RootWalletKeys,\n  Unspent,\n  UtxoTransactionBuilder,\n  createTransactionBuilderForNetwork,\n  addToTransactionBuilder,\n  getWalletAddress,\n  signInputP2shP2pk,\n  signInputWithUnspent,\n  WalletUnspentSigner,\n} from '../bitgo';\nimport { Network } from '../networks';\nimport { mockReplayProtectionUnspent, mockWalletUnspent } from './mock';\n\n/**\n * input script type and value.\n */\nexport type TxnInputScriptType = Exclude<ScriptType, 'p2trMusig2'>;\nexport type TxnOutputScriptType = Exclude<ScriptType2Of3, 'p2trMusig2'>;\n\n/**\n * output script type and value\n */\nexport interface TxnInput<TNumber extends number | bigint> {\n  scriptType: TxnInputScriptType;\n  value: TNumber;\n}\n\n/**\n * should set either address or scriptType, never both.\n * set isInternalAddress=true for internal output address\n */\nexport interface TxnOutput<TNumber extends number | bigint> {\n  address?: string;\n  scriptType?: TxnOutputScriptType;\n  value: TNumber;\n  isInternalAddress?: boolean;\n}\n\n/**\n * array of supported input script types.\n */\nexport const txnInputScriptTypes = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', scriptTypeP2shP2pk] as const;\n\n/**\n * array of supported output script types.\n */\nexport const txnOutputScriptTypes = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr'] as const;\n\n/**\n * create unspent object from input script type, index, network and root wallet key.\n */\nexport function toTxnUnspent<TNumber extends number | bigint>(\n  input: TxnInput<TNumber>,\n  index: number,\n  network: Network,\n  rootWalletKeys: RootWalletKeys\n): Unspent<TNumber> {\n  if (input.scriptType === 'p2shP2pk') {\n    return mockReplayProtectionUnspent<TNumber>(network, input.value, { key: rootWalletKeys['user'], vout: index });\n  } else {\n    return mockWalletUnspent<TNumber>(network, input.value, {\n      chain: getInternalChainCode(input.scriptType),\n      vout: index,\n      keys: rootWalletKeys,\n      index,\n    });\n  }\n}\n\n/**\n * returns signer and cosigner names for TxnInputScriptType.\n * user and undefined as signer and cosigner respectively for p2shP2pk.\n * user and bitgo as signer and cosigner respectively for other input script types.\n */\nexport function getTxnSigners(inputType: TxnInputScriptType): { signerName: KeyName; cosignerName?: KeyName } {\n  return {\n    signerName: 'user',\n    cosignerName: inputType === 'p2shP2pk' ? undefined : 'bitgo',\n  };\n}\n\n/**\n * signs with first or second signature for single input.\n * p2shP2pk is signed only with first sign.\n */\nexport function signTxnInput<TNumber extends number | bigint>(\n  txb: UtxoTransactionBuilder<TNumber>,\n  input: TxnInput<TNumber>,\n  inputIndex: number,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned'\n): void {\n  const { signerName, cosignerName } = getTxnSigners(input.scriptType);\n  const unspent = toTxnUnspent(input, inputIndex, txb.network, rootWalletKeys);\n  if (sign === 'halfsigned') {\n    if (input.scriptType === 'p2shP2pk') {\n      signInputP2shP2pk(txb, inputIndex, rootWalletKeys[signerName]);\n    } else if (isWalletUnspent(unspent) && cosignerName) {\n      signInputWithUnspent(\n        txb,\n        inputIndex,\n        unspent,\n        WalletUnspentSigner.from(rootWalletKeys, rootWalletKeys[signerName], rootWalletKeys[cosignerName])\n      );\n    }\n  }\n  if (isWalletUnspent(unspent) && sign === 'fullsigned' && cosignerName) {\n    signInputWithUnspent(\n      txb,\n      inputIndex,\n      unspent,\n      WalletUnspentSigner.from(rootWalletKeys, rootWalletKeys[cosignerName], rootWalletKeys[signerName])\n    );\n  }\n}\n\n/**\n * signs with first or second signature for all inputs.\n * p2shP2pk is signed only with first sign.\n */\nexport function signAllTxnInputs<TNumber extends number | bigint>(\n  txb: UtxoTransactionBuilder<TNumber>,\n  inputs: TxnInput<TNumber>[],\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned'\n): void {\n  inputs.forEach((input, index) => {\n    signTxnInput(txb, input, index, rootWalletKeys, sign);\n  });\n}\n\n/**\n * construct transaction for given inputs, outputs, network and root wallet keys.\n */\nexport function constructTxnBuilder<TNumber extends number | bigint>(\n  inputs: TxnInput<TNumber>[],\n  outputs: TxnOutput<TNumber>[],\n  network: Network,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'unsigned' | 'halfsigned' | 'fullsigned'\n): UtxoTransactionBuilder<TNumber> {\n  const totalInputAmount = inputs.reduce((sum, input) => sum + BigInt(input.value), BigInt(0));\n  const outputInputAmount = outputs.reduce((sum, output) => sum + BigInt(output.value), BigInt(0));\n  assert(totalInputAmount >= outputInputAmount, 'total output can not exceed total input');\n  assert(\n    !outputs.some((o) => (o.scriptType && o.address) || (!o.scriptType && !o.address)),\n    'only either output script type or address should be provided'\n  );\n\n  const txb = createTransactionBuilderForNetwork<TNumber>(network);\n\n  const unspents = inputs.map((input, i) => toTxnUnspent(input, i, network, rootWalletKeys));\n\n  unspents.forEach((u, i) => {\n    addToTransactionBuilder(txb, u);\n  });\n\n  outputs.forEach((output, i) => {\n    const address = output.scriptType\n      ? getWalletAddress(\n          rootWalletKeys,\n          output.isInternalAddress ? getInternalChainCode(output.scriptType) : getExternalChainCode(output.scriptType),\n          i,\n          network\n        )\n      : output.address;\n    if (!address) {\n      throw new Error('address is missing');\n    }\n    txb.addOutput(address, output.value);\n  });\n\n  if (sign === 'unsigned') {\n    return txb;\n  }\n\n  signAllTxnInputs(txb, inputs, rootWalletKeys, 'halfsigned');\n\n  if (sign === 'fullsigned') {\n    signAllTxnInputs(txb, inputs, rootWalletKeys, sign);\n  }\n\n  return txb;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/testutil/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport { ScriptType, ScriptType2Of3, scriptTypeP2shP2pk, scriptTypes2Of3 } from '../bitgo/outputScripts';\nimport {\n  getExternalChainCode,\n  isWalletUnspent,\n  KeyName,\n  getInternalChainCode,\n  RootWalletKeys,\n  Unspent,\n  UtxoTransactionBuilder,\n  createTransactionBuilderForNetwork,\n  addToTransactionBuilder,\n  getWalletAddress,\n  signInputP2shP2pk,\n  signInputWithUnspent,\n  WalletUnspentSigner,\n} from '../bitgo';\nimport { Network } from '../networks';\nimport { mockReplayProtectionUnspent, mockWalletUnspent } from './mock';\n\n/**\n * input script type and value.\n */\nexport type TxnInputScriptType = Exclude<ScriptType, 'p2trMusig2'>;\nexport type TxnOutputScriptType = ScriptType2Of3;\n\n/**\n * output script type and value\n */\nexport interface TxnInput<TNumber extends number | bigint> {\n  scriptType: TxnInputScriptType;\n  value: TNumber;\n}\n\n/**\n * should set either address or scriptType, never both.\n * set isInternalAddress=true for internal output address\n */\nexport interface TxnOutput<TNumber extends number | bigint> {\n  address?: string;\n  scriptType?: TxnOutputScriptType;\n  value: TNumber;\n  isInternalAddress?: boolean;\n}\n\n/**\n * array of supported input script types.\n */\nexport const txnInputScriptTypes = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', scriptTypeP2shP2pk] as const;\n\n/**\n * array of supported output script types.\n */\nexport const txnOutputScriptTypes = scriptTypes2Of3;\n\n/**\n * create unspent object from input script type, index, network and root wallet key.\n */\nexport function toTxnUnspent<TNumber extends number | bigint>(\n  input: TxnInput<TNumber>,\n  index: number,\n  network: Network,\n  rootWalletKeys: RootWalletKeys\n): Unspent<TNumber> {\n  if (input.scriptType === 'p2shP2pk') {\n    return mockReplayProtectionUnspent<TNumber>(network, input.value, { key: rootWalletKeys['user'], vout: index });\n  } else {\n    return mockWalletUnspent<TNumber>(network, input.value, {\n      chain: getInternalChainCode(input.scriptType),\n      vout: index,\n      keys: rootWalletKeys,\n      index,\n    });\n  }\n}\n\n/**\n * returns signer and cosigner names for TxnInputScriptType.\n * user and undefined as signer and cosigner respectively for p2shP2pk.\n * user and bitgo as signer and cosigner respectively for other input script types.\n */\nexport function getTxnSigners(inputType: TxnInputScriptType): { signerName: KeyName; cosignerName?: KeyName } {\n  return {\n    signerName: 'user',\n    cosignerName: inputType === 'p2shP2pk' ? undefined : 'bitgo',\n  };\n}\n\n/**\n * signs with first or second signature for single input.\n * p2shP2pk is signed only with first sign.\n */\nexport function signTxnInput<TNumber extends number | bigint>(\n  txb: UtxoTransactionBuilder<TNumber>,\n  input: TxnInput<TNumber>,\n  inputIndex: number,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): void {\n  const { signerName, cosignerName } = signers ? signers : getTxnSigners(input.scriptType);\n  const unspent = toTxnUnspent(input, inputIndex, txb.network, rootWalletKeys);\n  if (sign === 'halfsigned') {\n    if (input.scriptType === 'p2shP2pk') {\n      signInputP2shP2pk(txb, inputIndex, rootWalletKeys[signerName]);\n    } else if (isWalletUnspent(unspent) && cosignerName) {\n      signInputWithUnspent(\n        txb,\n        inputIndex,\n        unspent,\n        WalletUnspentSigner.from(rootWalletKeys, rootWalletKeys[signerName], rootWalletKeys[cosignerName])\n      );\n    }\n  }\n  if (isWalletUnspent(unspent) && sign === 'fullsigned' && cosignerName) {\n    signInputWithUnspent(\n      txb,\n      inputIndex,\n      unspent,\n      WalletUnspentSigner.from(rootWalletKeys, rootWalletKeys[cosignerName], rootWalletKeys[signerName])\n    );\n  }\n}\n\n/**\n * signs with first or second signature for all inputs.\n * p2shP2pk is signed only with first sign.\n */\nexport function signAllTxnInputs<TNumber extends number | bigint>(\n  txb: UtxoTransactionBuilder<TNumber>,\n  inputs: TxnInput<TNumber>[],\n  rootWalletKeys: RootWalletKeys,\n  sign: 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): void {\n  inputs.forEach((input, index) => {\n    signTxnInput(txb, input, index, rootWalletKeys, sign, signers);\n  });\n}\n\n/**\n * construct transaction for given inputs, outputs, network and root wallet keys.\n */\nexport function constructTxnBuilder<TNumber extends number | bigint>(\n  inputs: TxnInput<TNumber>[],\n  outputs: TxnOutput<TNumber>[],\n  network: Network,\n  rootWalletKeys: RootWalletKeys,\n  sign: 'unsigned' | 'halfsigned' | 'fullsigned',\n  signers?: { signerName: KeyName; cosignerName?: KeyName }\n): UtxoTransactionBuilder<TNumber> {\n  const totalInputAmount = inputs.reduce((sum, input) => sum + BigInt(input.value), BigInt(0));\n  const outputInputAmount = outputs.reduce((sum, output) => sum + BigInt(output.value), BigInt(0));\n  assert(totalInputAmount >= outputInputAmount, 'total output can not exceed total input');\n  assert(\n    !outputs.some((o) => (o.scriptType && o.address) || (!o.scriptType && !o.address)),\n    'only either output script type or address should be provided'\n  );\n\n  const txb = createTransactionBuilderForNetwork<TNumber>(network);\n\n  const unspents = inputs.map((input, i) => toTxnUnspent(input, i, network, rootWalletKeys));\n\n  unspents.forEach((u, i) => {\n    addToTransactionBuilder(txb, u);\n  });\n\n  outputs.forEach((output, i) => {\n    const address = output.scriptType\n      ? getWalletAddress(\n          rootWalletKeys,\n          output.isInternalAddress ? getInternalChainCode(output.scriptType) : getExternalChainCode(output.scriptType),\n          i,\n          network\n        )\n      : output.address;\n    if (!address) {\n      throw new Error('address is missing');\n    }\n    txb.addOutput(address, output.value);\n  });\n\n  if (sign === 'unsigned') {\n    return txb;\n  }\n\n  signAllTxnInputs(txb, inputs, rootWalletKeys, 'halfsigned', signers);\n\n  if (sign === 'fullsigned') {\n    signAllTxnInputs(txb, inputs, rootWalletKeys, sign, signers);\n  }\n\n  return txb;\n}\n"]}
{
"name": "@bitgo/utxo-lib",
"version": "9.3.0",
"version": "9.4.0",
"description": "Client-side Bitcoin JavaScript library",
"main": "./dist/src/index.js",
"engines": {
"node": ">=10.22.0 <17",
"node": ">=10.22.0 <19",
"npm": ">=3.10.10"

@@ -49,3 +49,3 @@ },

"dependencies": {
"@bitgo/blake2b": "^3.2.2",
"@bitgo/blake2b": "^3.2.3",
"@brandonblack/musig": "^0.0.1-alpha.0",

@@ -88,3 +88,3 @@ "@noble/secp256k1": "1.6.3",

"license": "MIT",
"gitHead": "923e14ba0bb21f9dc77b0dd95d7bd965d4b2901d"
"gitHead": "dc93da5f593f20f227b0202dce2f897241e20fe2"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc