utxo-lib 1.1.2 → 1.1.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (40) hide show
  1. package/README.md +16 -19
  2. package/dist/src/bitgo/PsbtUtil.d.ts +0 -5
  3. package/dist/src/bitgo/PsbtUtil.d.ts.map +1 -1
  4. package/dist/src/bitgo/PsbtUtil.js +2 -15
  5. package/dist/src/bitgo/UtxoPsbt.d.ts +0 -9
  6. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -1
  7. package/dist/src/bitgo/UtxoPsbt.js +12 -42
  8. package/dist/src/bitgo/index.d.ts +0 -1
  9. package/dist/src/bitgo/index.d.ts.map +1 -1
  10. package/dist/src/bitgo/index.js +2 -3
  11. package/dist/src/bitgo/parseInput.js +2 -2
  12. package/dist/src/bitgo/wallet/Psbt.d.ts +0 -14
  13. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -1
  14. package/dist/src/bitgo/wallet/Psbt.js +3 -71
  15. package/dist/src/bitgo/wallet/WalletOutput.d.ts +1 -17
  16. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -1
  17. package/dist/src/bitgo/wallet/WalletOutput.js +23 -64
  18. package/dist/src/bitgo/wallet/chains.d.ts +1 -1
  19. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +1 -0
  20. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -1
  21. package/dist/src/bitgo/zcash/ZcashPsbt.js +12 -3
  22. package/dist/src/testutil/keys.d.ts +0 -3
  23. package/dist/src/testutil/keys.d.ts.map +1 -1
  24. package/dist/src/testutil/keys.js +2 -17
  25. package/dist/src/testutil/psbt.d.ts +5 -23
  26. package/dist/src/testutil/psbt.d.ts.map +1 -1
  27. package/dist/src/testutil/psbt.js +13 -16
  28. package/dist/src/testutil/transaction.d.ts +5 -14
  29. package/dist/src/testutil/transaction.d.ts.map +1 -1
  30. package/dist/src/testutil/transaction.js +9 -9
  31. package/package.json +5 -5
  32. package/dist/src/base_crypto.d.ts +0 -14
  33. package/dist/src/base_crypto.d.ts.map +0 -1
  34. package/dist/src/base_crypto.js +0 -215
  35. package/dist/src/bitgo/legacysafe/index.d.ts +0 -15
  36. package/dist/src/bitgo/legacysafe/index.d.ts.map +0 -1
  37. package/dist/src/bitgo/legacysafe/index.js +0 -61
  38. package/dist/src/musig.d.ts +0 -390
  39. package/dist/src/musig.d.ts.map +0 -1
  40. package/dist/src/musig.js +0 -447
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.deleteWitnessUtxoForNonSegwitInputs = exports.clonePsbtWithoutNonWitnessUtxo = exports.extractP2msOnlyHalfSignedTx = exports.getSignatureValidationArrayPsbt = exports.addXpubsToPsbt = exports.isTransactionWithKeyPathSpendInput = exports.isTxInputArray = exports.isPsbtInputArray = exports.getStrictSignatureCounts = exports.getStrictSignatureCount = exports.parsePsbtInput = exports.getPsbtInputScriptType = exports.signWalletPsbt = exports.toWalletPsbt = void 0;
3
+ exports.getSignatureValidationArrayPsbt = exports.addXpubsToPsbt = exports.isTransactionWithKeyPathSpendInput = exports.isTxInputArray = exports.isPsbtInputArray = exports.getStrictSignatureCounts = exports.getStrictSignatureCount = exports.parsePsbtInput = exports.getPsbtInputScriptType = exports.signWalletPsbt = exports.toWalletPsbt = void 0;
4
4
  const assert = require("assert");
5
5
  const utils_1 = require("bip174/src/lib/utils");
6
6
  const bs58check = require("bs58check");
7
7
  const UtxoPsbt_1 = require("../UtxoPsbt");
8
8
  const UtxoTransaction_1 = require("../UtxoTransaction");
9
9
  const outputScripts_1 = require("../outputScripts");
10
- const WalletKeys_1 = require("./WalletKeys");
11
10
  const Unspent_1 = require("../Unspent");
12
11
  const transaction_1 = require("../transaction");
13
12
  const Unspent_2 = require("./Unspent");
@@ -357,8 +356,7 @@ exports.isTransactionWithKeyPathSpendInput = isTransactionWithKeyPathSpendInput;
357
356
  * extendedPubkey.
358
357
  */
359
358
  function addXpubsToPsbt(psbt, rootWalletKeys) {
360
- const safeRootWalletKeys = new WalletKeys_1.RootWalletKeys(rootWalletKeys.triple.map((bip32) => bip32.neutered()), rootWalletKeys.derivationPrefixes);
361
- const xPubs = safeRootWalletKeys.triple.map((bip32) => ({
359
+ const xPubs = rootWalletKeys.triple.map((bip32) => ({
362
360
  extendedPubkey: bs58check.decode(bip32.toBase58()),
363
361
  masterFingerprint: bip32.fingerprint,
364
362
  // TODO: BG-73797 - bip174 currently requires m prefix for this to be a valid globalXpub
@@ -381,70 +379,4 @@ function getSignatureValidationArrayPsbt(psbt, rootWalletKeys) {
381
379
  });
382
380
  }
383
381
  exports.getSignatureValidationArrayPsbt = getSignatureValidationArrayPsbt;
384
- /**
385
- * Extracts the half signed transaction from the psbt for p2ms based script types - p2sh, p2wsh, and p2shP2wsh.
386
- * The purpose is to provide backward compatibility to keyternal (KRS) that only supports network transaction and p2ms script types.
387
- */
388
- function extractP2msOnlyHalfSignedTx(psbt) {
389
- assert(!!(psbt.data.inputs.length && psbt.data.outputs.length), 'empty inputs or outputs');
390
- const tx = psbt.getUnsignedTx();
391
- function isP2msParsedPsbtInput(parsed) {
392
- return ['p2sh', 'p2shP2wsh', 'p2wsh'].includes(parsed.scriptType);
393
- }
394
- psbt.data.inputs.forEach((input, i) => {
395
- var _a, _b;
396
- const parsed = parsePsbtInput(input);
397
- assert(isP2msParsedPsbtInput(parsed), `unsupported script type ${parsed.scriptType}`);
398
- assert(((_a = input.partialSig) === null || _a === void 0 ? void 0 : _a.length) === 1, `unexpected signature count ${(_b = input.partialSig) === null || _b === void 0 ? void 0 : _b.length}`);
399
- const [partialSig] = input.partialSig;
400
- assert(input.sighashType !== undefined && input.sighashType === bitcoinjs_lib_1.script.signature.decode(partialSig.signature).hashType, 'signature sighash does not match input sighash type');
401
- // type casting is to address the invalid type checking in payments.p2ms
402
- const signatures = parsed.publicKeys.map((pk) => partialSig.pubkey.equals(pk) ? partialSig.signature : bitcoinjs_lib_1.opcodes.OP_0);
403
- const isP2SH = !!parsed.redeemScript;
404
- const isP2WSH = !!parsed.witnessScript;
405
- const payment = index_1.payments.p2ms({ output: parsed.pubScript, signatures }, { validate: false, allowIncomplete: true });
406
- const p2wsh = isP2WSH ? index_1.payments.p2wsh({ redeem: payment }) : undefined;
407
- const p2sh = isP2SH ? index_1.payments.p2sh({ redeem: p2wsh || payment }) : undefined;
408
- if (p2sh === null || p2sh === void 0 ? void 0 : p2sh.input) {
409
- tx.setInputScript(i, p2sh.input);
410
- }
411
- if (p2wsh === null || p2wsh === void 0 ? void 0 : p2wsh.witness) {
412
- tx.setWitness(i, p2wsh.witness);
413
- }
414
- });
415
- return tx;
416
- }
417
- exports.extractP2msOnlyHalfSignedTx = extractP2msOnlyHalfSignedTx;
418
- /**
419
- * Clones the psbt without nonWitnessUtxo for non-segwit inputs and witnessUtxo is added instead.
420
- * It is not BIP-174 compliant, so use it carefully.
421
- */
422
- function clonePsbtWithoutNonWitnessUtxo(psbt) {
423
- const newPsbt = psbt.clone();
424
- const txInputs = psbt.txInputs;
425
- psbt.data.inputs.forEach((input, i) => {
426
- if (input.nonWitnessUtxo && !input.witnessUtxo) {
427
- const tx = UtxoTransaction_1.UtxoTransaction.fromBuffer(input.nonWitnessUtxo, false, 'bigint', psbt.network);
428
- if (!txInputs[i].hash.equals(tx.getHash())) {
429
- throw new Error(`Non-witness UTXO hash for input #${i} doesn't match the hash specified in the prevout`);
430
- }
431
- newPsbt.data.inputs[i].witnessUtxo = tx.outs[txInputs[i].index];
432
- }
433
- delete newPsbt.data.inputs[i].nonWitnessUtxo;
434
- });
435
- return newPsbt;
436
- }
437
- exports.clonePsbtWithoutNonWitnessUtxo = clonePsbtWithoutNonWitnessUtxo;
438
- /**
439
- * Deletes witnessUtxo for non-segwit inputs to make the PSBT BIP-174 compliant.
440
- */
441
- function deleteWitnessUtxoForNonSegwitInputs(psbt) {
442
- psbt.data.inputs.forEach((input, i) => {
443
- const scriptType = getPsbtInputScriptType(input);
444
- if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {
445
- delete input.witnessUtxo;
446
- }
447
- });
448
- }
449
- exports.deleteWitnessUtxoForNonSegwitInputs = deleteWitnessUtxoForNonSegwitInputs;
450
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Psbt.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Psbt.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport { GlobalXpub, PartialSig, PsbtInput, TapScriptSig } from 'bip174/src/lib/interfaces';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { BIP32Interface } from 'bip32';\nimport * as bs58check from 'bs58check';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { createOutputScript2of3, getLeafHash, scriptTypeForChain, toXOnlyPublicKey } from '../outputScripts';\nimport { DerivedWalletKeys, RootWalletKeys } from './WalletKeys';\nimport { toPrevOutputWithPrevTx } from '../Unspent';\nimport { createPsbtFromTransaction } from '../transaction';\nimport { isWalletUnspent, WalletUnspent } from './Unspent';\n\nimport {\n  getLeafVersion,\n  calculateScriptPathLevel,\n  isValidControlBock,\n  ParsedPubScriptP2ms,\n  ParsedPubScriptTaprootScriptPath,\n  parsePubScript2Of3,\n  ParsedPubScriptTaproot,\n  ParsedPubScriptTaprootKeyPath,\n  parsePubScript,\n  ParsedPubScriptP2shP2pk,\n  ParsedScriptType,\n  isPlaceholderSignature,\n  parseSignatureScript,\n} from '../parseInput';\nimport { parsePsbtMusig2PartialSigs } from '../Musig2';\nimport { isTuple, Triple } from '../types';\nimport { createTaprootOutputScript } from '../../taproot';\nimport { opcodes as ops, script as bscript, TxInput } from 'bitcoinjs-lib';\nimport { opcodes, payments } from '../../index';\nimport { getPsbtInputSignatureCount, isPsbtInputFinalized } from '../PsbtUtil';\n\n// only used for building `SignatureContainer`\ntype BaseSignatureContainer<T> = {\n  signatures: T;\n};\n\ntype UnsignedSignatureContainer = BaseSignatureContainer<undefined>;\ntype HalfSignedSignatureContainer = BaseSignatureContainer<[Buffer]>;\ntype FullSignedSignatureContainer = BaseSignatureContainer<[Buffer, Buffer]>;\n\ntype SignatureContainer = UnsignedSignatureContainer | HalfSignedSignatureContainer | FullSignedSignatureContainer;\n\n/**\n * Contents of a pre-finalized PSBT Input for p2trMusig2 key path in the non-finalized state.\n * T is [Buffer] for first signature, [Buffer, Buffer] for both signatures and `undefined` for no signatures.\n */\ntype BaseTaprootKeyPathSignatureContainer<T> = {\n  signatures: T;\n  /** Only contains participants that have added a signature */\n  participantPublicKeys: T;\n};\n\ntype UnsignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<undefined>;\ntype HalfSignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<[Buffer]>;\ntype FullSignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<[Buffer, Buffer]>;\n\ntype TaprootKeyPathSignatureContainer =\n  | UnsignedTaprootKeyPathSignatureContainer\n  | HalfSignedTaprootKeyPathSignatureContainer\n  | FullSignedTaprootKeyPathSignatureContainer;\n\n/**\n * To hold parsed psbt data for p2ms based script types - p2sh, p2wsh, and p2shP2wsh\n */\nexport type ParsedPsbtP2ms = ParsedPubScriptP2ms & SignatureContainer;\n\n/**\n * To hold parsed psbt data for TaprootKeyPathSpend script type.\n */\nexport type ParsedPsbtTaprootKeyPath = ParsedPubScriptTaprootKeyPath & TaprootKeyPathSignatureContainer;\n\n/**\n * To hold parsed psbt data for TaprootScriptPathSpend script path script type.\n */\nexport type ParsedPsbtTaprootScriptPath = ParsedPubScriptTaprootScriptPath &\n  SignatureContainer & {\n    controlBlock: Buffer;\n    leafVersion: number;\n    /** Indicates the level inside the taptree. */\n    scriptPathLevel: number;\n  };\n\nexport type ParsedPsbtTaproot = ParsedPsbtTaprootKeyPath | ParsedPsbtTaprootScriptPath;\n\ntype P2shP2pkSignatureContainer = UnsignedSignatureContainer | HalfSignedSignatureContainer;\n\nexport type ParsedPsbtP2shP2pk = ParsedPubScriptP2shP2pk & P2shP2pkSignatureContainer;\n\ninterface WalletSigner {\n  walletKey: BIP32Interface;\n  rootKey: BIP32Interface;\n}\n\n/**\n * psbt input index and its user, backup, bitgo signatures status\n */\nexport type SignatureValidation = [index: number, sigTriple: Triple<boolean>];\n\nfunction getTaprootSigners(script: Buffer, walletKeys: DerivedWalletKeys): [WalletSigner, WalletSigner] {\n  const parsedPublicKeys = parsePubScript2Of3(script, 'taprootScriptPathSpend').publicKeys;\n  const walletSigners = parsedPublicKeys.map((publicKey) => {\n    const index = walletKeys.publicKeys.findIndex((walletPublicKey) =>\n      toXOnlyPublicKey(walletPublicKey).equals(publicKey)\n    );\n    if (index >= 0) {\n      return { walletKey: walletKeys.triple[index], rootKey: walletKeys.parent.triple[index] };\n    }\n    throw new Error('Taproot public key is not a wallet public key');\n  });\n  return [walletSigners[0], walletSigners[1]];\n}\n\nfunction updatePsbtInput(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  unspent: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys\n): void {\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n  const signatureCount = getPsbtInputSignatureCount(input);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  if (signatureCount === 0 && scriptType === 'p2tr') {\n    return;\n  }\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(unspent.chain, unspent.index);\n\n  if (scriptType === 'p2tr') {\n    if (!Array.isArray(input.tapLeafScript) || input.tapLeafScript.length === 0) {\n      throw new Error('Invalid PSBT state. Missing required fields.');\n    }\n\n    if (input.tapLeafScript.length > 1) {\n      throw new Error('Bitgo only supports a single tap leaf script per input');\n    }\n\n    const [signer, cosigner] = getTaprootSigners(input.tapLeafScript[0].script, walletKeys);\n\n    const leafHash = getLeafHash({\n      publicKeys: walletKeys.publicKeys,\n      signer: signer.walletKey.publicKey,\n      cosigner: cosigner.walletKey.publicKey,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: [signer, cosigner].map((walletSigner) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletSigner.walletKey.publicKey),\n        path: rootWalletKeys.getDerivationPath(walletSigner.rootKey, unspent.chain, unspent.index),\n        masterFingerprint: walletSigner.rootKey.fingerprint,\n      })),\n    });\n  } else {\n    if (signatureCount === 0) {\n      const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n      if (witnessScript && psbt.data.inputs[inputIndex].witnessScript === undefined) {\n        psbt.updateInput(inputIndex, { witnessScript });\n      }\n      if (redeemScript && psbt.data.inputs[inputIndex].redeemScript === undefined) {\n        psbt.updateInput(inputIndex, { redeemScript });\n      }\n    }\n\n    psbt.updateInput(inputIndex, {\n      bip32Derivation: [0, 1, 2].map((idx) => ({\n        pubkey: walletKeys.triple[idx].publicKey,\n        path: walletKeys.paths[idx],\n        masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n      })),\n    });\n  }\n}\n\n/**\n * @return PSBT filled with metatdata as per input params tx, unspents and rootWalletKeys.\n * Unsigned PSBT for taproot input with witnessUtxo\n * Unsigned PSBT for other input with witnessUtxo/nonWitnessUtxo, redeemScript/witnessScript, bip32Derivation\n * Signed PSBT for taproot input with witnessUtxo, tapLeafScript, tapBip32Derivation, tapScriptSig\n * Signed PSBT for other input with witnessUtxo/nonWitnessUtxo, redeemScript/witnessScript, bip32Derivation, partialSig\n */\nexport function toWalletPsbt(\n  tx: UtxoTransaction<bigint>,\n  unspents: WalletUnspent<bigint>[],\n  rootWalletKeys: RootWalletKeys\n): UtxoPsbt {\n  const prevOutputs = unspents.map((u) => {\n    assert.notStrictEqual(scriptTypeForChain(u.chain), 'p2trMusig2');\n    return toPrevOutputWithPrevTx(u, tx.network);\n  });\n  const psbt = createPsbtFromTransaction(tx, prevOutputs);\n  unspents.forEach((u, i) => {\n    if (isWalletUnspent(u) && u.index !== undefined) {\n      updatePsbtInput(psbt, i, u, rootWalletKeys);\n    }\n  });\n  return psbt;\n}\n\n/**\n * @param psbt\n * @param inputIndex\n * @param signer\n * @param unspent\n * @return signed PSBT with signer's key for unspent\n */\nexport function signWalletPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  signer: BIP32Interface,\n  unspent: WalletUnspent<bigint>\n): void {\n  const scriptType = scriptTypeForChain(unspent.chain);\n  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {\n    psbt.signTaprootInputHD(inputIndex, signer);\n  } else {\n    psbt.signInputHD(inputIndex, signer);\n  }\n}\n\n/**\n * @returns script type of the input\n */\nexport function getPsbtInputScriptType(input: PsbtInput): ParsedScriptType {\n  const isP2pk = (script: Buffer) => {\n    try {\n      const chunks = bscript.decompile(script);\n      return (\n        chunks?.length === 2 &&\n        Buffer.isBuffer(chunks[0]) &&\n        bscript.isCanonicalPubKey(chunks[0]) &&\n        chunks[1] === opcodes.OP_CHECKSIG\n      );\n    } catch (e) {\n      return false;\n    }\n  };\n  let scriptType: ParsedScriptType | undefined;\n  if (Buffer.isBuffer(input.redeemScript) && Buffer.isBuffer(input.witnessScript)) {\n    scriptType = 'p2shP2wsh';\n  } else if (Buffer.isBuffer(input.redeemScript)) {\n    scriptType = isP2pk(input.redeemScript) ? 'p2shP2pk' : 'p2sh';\n  } else if (Buffer.isBuffer(input.witnessScript)) {\n    scriptType = 'p2wsh';\n  }\n  if (Array.isArray(input.tapLeafScript) && input.tapLeafScript.length > 0) {\n    if (scriptType) {\n      throw new Error(`Found both ${scriptType} and taprootScriptPath PSBT metadata.`);\n    }\n    if (input.tapLeafScript.length > 1) {\n      throw new Error('Bitgo only supports a single tap leaf script per input.');\n    }\n    scriptType = 'taprootScriptPathSpend';\n  }\n  if (input.tapInternalKey) {\n    if (scriptType) {\n      throw new Error(`Found both ${scriptType} and taprootKeyPath PSBT metadata.`);\n    }\n    scriptType = 'taprootKeyPathSpend';\n  }\n  if (scriptType) {\n    return scriptType;\n  }\n  throw new Error('could not parse input');\n}\n\nfunction parseTaprootKeyPathSignatures(input: PsbtInput): TaprootKeyPathSignatureContainer {\n  const partialSigs = parsePsbtMusig2PartialSigs(input);\n  if (!partialSigs) {\n    return { signatures: undefined, participantPublicKeys: undefined };\n  }\n  const signatures = partialSigs.map((pSig) => pSig.partialSig);\n  const participantPublicKeys = partialSigs.map((pSig) => pSig.participantPubKey);\n  return isTuple<Buffer>(signatures) && isTuple<Buffer>(participantPublicKeys)\n    ? { signatures, participantPublicKeys }\n    : { signatures: [signatures[0]], participantPublicKeys: [participantPublicKeys[0]] };\n}\n\nfunction parsePartialOrTapScriptSignatures(sig: PartialSig[] | TapScriptSig[] | undefined): SignatureContainer {\n  if (!sig?.length) {\n    return { signatures: undefined };\n  }\n  if (sig.length > 2) {\n    throw new Error('unexpected signature count');\n  }\n  const signatures = sig.map((tSig) => tSig.signature);\n  return isTuple<Buffer>(signatures) ? { signatures } : { signatures: [signatures[0]] };\n}\n\nfunction parseSignatures(\n  input: PsbtInput,\n  scriptType: ParsedScriptType\n): SignatureContainer | TaprootKeyPathSignatureContainer {\n  return scriptType === 'taprootKeyPathSpend'\n    ? parseTaprootKeyPathSignatures(input)\n    : scriptType === 'taprootScriptPathSpend'\n    ? parsePartialOrTapScriptSignatures(input.tapScriptSig)\n    : parsePartialOrTapScriptSignatures(input.partialSig);\n}\n\nfunction parseScript(\n  input: PsbtInput,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk {\n  let pubScript: Buffer | undefined;\n  if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {\n    pubScript = input.redeemScript;\n  } else if (scriptType === 'p2wsh' || scriptType === 'p2shP2wsh') {\n    pubScript = input.witnessScript;\n  } else if (scriptType === 'taprootScriptPathSpend') {\n    pubScript = input.tapLeafScript ? input.tapLeafScript[0].script : undefined;\n  } else if (scriptType === 'taprootKeyPathSpend') {\n    if (input.witnessUtxo?.script) {\n      pubScript = input.witnessUtxo.script;\n    } else if (input.tapInternalKey && input.tapMerkleRoot) {\n      pubScript = createTaprootOutputScript({ internalPubKey: input.tapInternalKey, taptreeRoot: input.tapMerkleRoot });\n    }\n  }\n  if (!pubScript) {\n    throw new Error(`Invalid PSBT state for ${scriptType}. Missing required fields.`);\n  }\n  return parsePubScript(pubScript, scriptType);\n}\n\n/**\n * @return psbt metadata are parsed as per below conditions.\n * redeemScript/witnessScript/tapLeafScript matches BitGo.\n * signature and public key count matches BitGo.\n * P2SH-P2PK => scriptType, redeemScript, public key, signature.\n * P2SH => scriptType, redeemScript, public keys, signatures.\n * PW2SH => scriptType, witnessScript, public keys, signatures.\n * P2SH-PW2SH => scriptType, redeemScript, witnessScript, public keys, signatures.\n * P2TR and P2TR MUSIG2 script path => scriptType (taprootScriptPathSpend), pubScript (leaf script), controlBlock,\n * scriptPathLevel, leafVersion, public keys, signatures.\n * P2TR MUSIG2 kep path => scriptType (taprootKeyPathSpend), pubScript (scriptPubKey), participant pub keys (signer),\n * public key (tapOutputkey), signatures (partial signer sigs).\n */\nexport function parsePsbtInput(input: PsbtInput): ParsedPsbtP2ms | ParsedPsbtTaproot | ParsedPsbtP2shP2pk {\n  if (isPsbtInputFinalized(input)) {\n    throw new Error('Finalized PSBT parsing is not supported');\n  }\n  const scriptType = getPsbtInputScriptType(input);\n  const parsedPubScript = parseScript(input, scriptType);\n  const signatures = parseSignatures(input, scriptType);\n\n  if (parsedPubScript.scriptType === 'taprootKeyPathSpend' && 'participantPublicKeys' in signatures) {\n    return {\n      ...parsedPubScript,\n      ...signatures,\n    };\n  }\n  if (parsedPubScript.scriptType === 'taprootScriptPathSpend') {\n    if (!input.tapLeafScript) {\n      throw new Error('Invalid PSBT state for taprootScriptPathSpend. Missing required fields.');\n    }\n    const controlBlock = input.tapLeafScript[0].controlBlock;\n    if (!isValidControlBock(controlBlock)) {\n      throw new Error('Invalid PSBT taprootScriptPathSpend controlBlock.');\n    }\n    const scriptPathLevel = calculateScriptPathLevel(controlBlock);\n    const leafVersion = getLeafVersion(controlBlock);\n    return {\n      ...parsedPubScript,\n      ...signatures,\n      controlBlock,\n      scriptPathLevel,\n      leafVersion,\n    };\n  }\n  if (\n    parsedPubScript.scriptType === 'p2sh' ||\n    parsedPubScript.scriptType === 'p2wsh' ||\n    parsedPubScript.scriptType === 'p2shP2wsh'\n  ) {\n    if (parsedPubScript.scriptType === 'p2shP2wsh') {\n      parsedPubScript.redeemScript = input.redeemScript;\n    }\n    return {\n      ...parsedPubScript,\n      ...signatures,\n    };\n  }\n  if (parsedPubScript.scriptType === 'p2shP2pk' && (!signatures.signatures || !isTuple(signatures.signatures))) {\n    return {\n      ...parsedPubScript,\n      signatures: signatures.signatures,\n    };\n  }\n  throw new Error('invalid pub script');\n}\n\n/**\n * @returns strictly parse the input and get signature count.\n * unsigned(0), half-signed(1) or fully-signed(2)\n */\nexport function getStrictSignatureCount(input: TxInput | PsbtInput): 0 | 1 | 2 {\n  const calculateSignatureCount = (\n    signatures: [Buffer | 0, Buffer | 0, Buffer | 0] | [Buffer, Buffer] | [Buffer] | undefined\n  ): 0 | 1 | 2 => {\n    const count = signatures ? signatures.filter((s) => !isPlaceholderSignature(s)).length : 0;\n    if (count === 0 || count === 1 || count === 2) {\n      return count;\n    }\n    throw new Error('invalid signature count');\n  };\n\n  if ('hash' in input) {\n    if (input.script?.length || input.witness?.length) {\n      const parsedInput = parseSignatureScript(input);\n      return parsedInput.scriptType === 'taprootKeyPathSpend' ? 2 : calculateSignatureCount(parsedInput.signatures);\n    }\n    return 0;\n  } else {\n    return calculateSignatureCount(parsePsbtInput(input).signatures);\n  }\n}\n\n/**\n * @returns strictly parse input and get signature count for all inputs.\n * 0=unsigned, 1=half-signed or 2=fully-signed\n */\nexport function getStrictSignatureCounts(\n  tx: UtxoPsbt | UtxoTransaction<number | bigint> | PsbtInput[] | TxInput[]\n): (0 | 1 | 2)[] {\n  const inputs = tx instanceof UtxoPsbt ? tx.data.inputs : tx instanceof UtxoTransaction ? tx.ins : tx;\n  return inputs.map((input, _) => getStrictSignatureCount(input));\n}\n\n/**\n * @return true iff inputs array is of PsbtInputType type\n * */\nexport function isPsbtInputArray(inputs: PsbtInput[] | TxInput[]): inputs is PsbtInput[] {\n  return !isTxInputArray(inputs);\n}\n\n/**\n * @return true iff inputs array is of TxInput type\n * */\nexport function isTxInputArray(inputs: PsbtInput[] | TxInput[]): inputs is TxInput[] {\n  assert(!!inputs.length, 'empty inputs array');\n  return 'hash' in inputs[0];\n}\n\n/**\n * @returns true iff given psbt/transaction/tx-input-array/psbt-input-array contains at least one taproot key path spend input\n */\nexport function isTransactionWithKeyPathSpendInput(\n  data: UtxoPsbt | UtxoTransaction<bigint | number> | PsbtInput[] | TxInput[]\n): boolean {\n  const inputs = data instanceof UtxoPsbt ? data.data.inputs : data instanceof UtxoTransaction ? data.ins : data;\n  if (!inputs.length) {\n    return false;\n  }\n  if (isPsbtInputArray(inputs)) {\n    return inputs.some((input, _) => getPsbtInputScriptType(input) === 'taprootKeyPathSpend');\n  }\n  return inputs.some((input, _) => {\n    // If the input is not signed, it cannot be a taprootKeyPathSpend input because you can only\n    // extract a fully signed psbt into a transaction with taprootKeyPathSpend inputs.\n    if (getStrictSignatureCount(input) === 0) {\n      return false;\n    }\n    return parseSignatureScript(input).scriptType === 'taprootKeyPathSpend';\n  });\n}\n\n/**\n * Set the RootWalletKeys as the globalXpubs on the psbt\n *\n * We do all the matching of the (tap)bip32Derivations masterFingerprint to the fingerprint of the\n * extendedPubkey.\n */\nexport function addXpubsToPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys): void {\n  const safeRootWalletKeys = new RootWalletKeys(\n    rootWalletKeys.triple.map((bip32) => bip32.neutered()) as Triple<BIP32Interface>,\n    rootWalletKeys.derivationPrefixes\n  );\n  const xPubs = safeRootWalletKeys.triple.map(\n    (bip32): GlobalXpub => ({\n      extendedPubkey: bs58check.decode(bip32.toBase58()),\n      masterFingerprint: bip32.fingerprint,\n      // TODO: BG-73797 - bip174 currently requires m prefix for this to be a valid globalXpub\n      path: 'm',\n    })\n  );\n  psbt.updateGlobal({ globalXpub: xPubs });\n}\n\n/**\n * validates signatures for each 2 of 3 input against user, backup, bitgo keys derived from rootWalletKeys.\n * @returns array of input index and its [is valid user sig exist, is valid backup sig exist, is valid user bitgo exist]\n * For p2shP2pk input, [false, false, false] is returned since it is not a 2 of 3 sig input.\n */\nexport function getSignatureValidationArrayPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys): SignatureValidation[] {\n  return psbt.data.inputs.map((input, i) => {\n    const sigValArrayForInput: Triple<boolean> =\n      getPsbtInputScriptType(input) === 'p2shP2pk'\n        ? [false, false, false]\n        : psbt.getSignatureValidationArray(i, { rootNodes: rootWalletKeys.triple });\n    return [i, sigValArrayForInput];\n  });\n}\n\n/**\n * Extracts the half signed transaction from the psbt for p2ms based script types - p2sh, p2wsh, and p2shP2wsh.\n * The purpose is to provide backward compatibility to keyternal (KRS) that only supports network transaction and p2ms script types.\n */\nexport function extractP2msOnlyHalfSignedTx(psbt: UtxoPsbt): UtxoTransaction<bigint> {\n  assert(!!(psbt.data.inputs.length && psbt.data.outputs.length), 'empty inputs or outputs');\n  const tx = psbt.getUnsignedTx();\n\n  function isP2msParsedPsbtInput(\n    parsed: ParsedPsbtP2ms | ParsedPsbtTaproot | ParsedPsbtP2shP2pk\n  ): parsed is ParsedPsbtP2ms {\n    return ['p2sh', 'p2shP2wsh', 'p2wsh'].includes(parsed.scriptType);\n  }\n\n  psbt.data.inputs.forEach((input, i) => {\n    const parsed = parsePsbtInput(input);\n    assert(isP2msParsedPsbtInput(parsed), `unsupported script type ${parsed.scriptType}`);\n    assert(input.partialSig?.length === 1, `unexpected signature count ${input.partialSig?.length}`);\n    const [partialSig] = input.partialSig;\n    assert(\n      input.sighashType !== undefined && input.sighashType === bscript.signature.decode(partialSig.signature).hashType,\n      'signature sighash does not match input sighash type'\n    );\n\n    // type casting is to address the invalid type checking in payments.p2ms\n    const signatures = parsed.publicKeys.map((pk) =>\n      partialSig.pubkey.equals(pk) ? partialSig.signature : (ops.OP_0 as unknown as Buffer)\n    );\n\n    const isP2SH = !!parsed.redeemScript;\n    const isP2WSH = !!parsed.witnessScript;\n\n    const payment = payments.p2ms({ output: parsed.pubScript, signatures }, { validate: false, allowIncomplete: true });\n    const p2wsh = isP2WSH ? payments.p2wsh({ redeem: payment }) : undefined;\n    const p2sh = isP2SH ? payments.p2sh({ redeem: p2wsh || payment }) : undefined;\n\n    if (p2sh?.input) {\n      tx.setInputScript(i, p2sh.input);\n    }\n    if (p2wsh?.witness) {\n      tx.setWitness(i, p2wsh.witness);\n    }\n  });\n\n  return tx;\n}\n\n/**\n * Clones the psbt without nonWitnessUtxo for non-segwit inputs and witnessUtxo is added instead.\n * It is not BIP-174 compliant, so use it carefully.\n */\nexport function clonePsbtWithoutNonWitnessUtxo(psbt: UtxoPsbt): UtxoPsbt {\n  const newPsbt = psbt.clone();\n  const txInputs = psbt.txInputs;\n\n  psbt.data.inputs.forEach((input, i) => {\n    if (input.nonWitnessUtxo && !input.witnessUtxo) {\n      const tx = UtxoTransaction.fromBuffer<bigint>(input.nonWitnessUtxo, false, 'bigint', psbt.network);\n      if (!txInputs[i].hash.equals(tx.getHash())) {\n        throw new Error(`Non-witness UTXO hash for input #${i} doesn't match the hash specified in the prevout`);\n      }\n      newPsbt.data.inputs[i].witnessUtxo = tx.outs[txInputs[i].index];\n    }\n    delete newPsbt.data.inputs[i].nonWitnessUtxo;\n  });\n\n  return newPsbt;\n}\n\n/**\n * Deletes witnessUtxo for non-segwit inputs to make the PSBT BIP-174 compliant.\n */\nexport function deleteWitnessUtxoForNonSegwitInputs(psbt: UtxoPsbt): void {\n  psbt.data.inputs.forEach((input, i) => {\n    const scriptType = getPsbtInputScriptType(input);\n    if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {\n      delete input.witnessUtxo;\n    }\n  });\n}\n"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Psbt.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Psbt.ts"],"names":[],"mappings":";;;AAAA,iCAAiC;AAGjC,gDAAqD;AAErD,uCAAuC;AACvC,0CAAuC;AACvC,wDAAqD;AACrD,oDAA6G;AAE7G,wCAAoD;AACpD,gDAA2D;AAC3D,uCAA2D;AAE3D,8CAcuB;AACvB,sCAAuD;AACvD,oCAA2C;AAC3C,2CAA0D;AAC1D,iDAA2D;AAC3D,uCAAsC;AACtC,0CAA+E;AAqE/E,SAAS,iBAAiB,CAAC,MAAc,EAAE,UAA6B;IACtE,MAAM,gBAAgB,GAAG,+BAAkB,CAAC,MAAM,EAAE,wBAAwB,CAAC,CAAC,UAAU,CAAC;IACzF,MAAM,aAAa,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;QACvD,MAAM,KAAK,GAAG,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,eAAe,EAAE,EAAE,CAChE,gCAAgB,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CACpD,CAAC;QACF,IAAI,KAAK,IAAI,CAAC,EAAE;YACd,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;SAC1F;QACD,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IACH,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;AAC9C,CAAC;AAED,SAAS,eAAe,CACtB,IAAc,EACd,UAAkB,EAClB,OAA8B,EAC9B,cAA8B;IAE9B,MAAM,KAAK,GAAG,qBAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAC1D,MAAM,cAAc,GAAG,qCAA0B,CAAC,KAAK,CAAC,CAAC;IACzD,MAAM,UAAU,GAAG,kCAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,IAAI,cAAc,KAAK,CAAC,IAAI,UAAU,KAAK,MAAM,EAAE;QACjD,OAAO;KACR;IACD,MAAM,UAAU,GAAG,cAAc,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAEvF,IAAI,UAAU,KAAK,MAAM,EAAE;QACzB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3E,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QAED,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;SAC3E;QAED,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,GAAG,iBAAiB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAExF,MAAM,QAAQ,GAAG,2BAAW,CAAC;YAC3B,UAAU,EAAE,UAAU,CAAC,UAAU;YACjC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,SAAS;YAClC,QAAQ,EAAE,QAAQ,CAAC,SAAS,CAAC,SAAS;SACvC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;gBAC5D,UAAU,EAAE,CAAC,QAAQ,CAAC;gBACtB,MAAM,EAAE,gCAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,SAAS,CAAC;gBAC1D,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC;gBAC1F,iBAAiB,EAAE,YAAY,CAAC,OAAO,CAAC,WAAW;aACpD,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;SAAM;QACL,IAAI,cAAc,KAAK,CAAC,EAAE;YACxB,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,sCAAsB,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAClG,IAAI,aAAa,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,KAAK,SAAS,EAAE;gBAC7E,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;aACjD;YACD,IAAI,YAAY,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,KAAK,SAAS,EAAE;gBAC3E,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;aAChD;SACF;QAED,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACvC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS;gBACxC,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC;gBAC3B,iBAAiB,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW;aAC1D,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;AACH,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,YAAY,CAC1B,EAA2B,EAC3B,QAAiC,EACjC,cAA8B;IAE9B,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACrC,MAAM,CAAC,cAAc,CAAC,kCAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,YAAY,CAAC,CAAC;QACjE,OAAO,gCAAsB,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,MAAM,IAAI,GAAG,uCAAyB,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;IACxD,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACxB,IAAI,yBAAe,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,EAAE;YAC/C,eAAe,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,CAAC,CAAC;SAC7C;IACH,CAAC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAhBD,oCAgBC;AAED;;;;;;GAMG;AACH,SAAgB,cAAc,CAC5B,IAAc,EACd,UAAkB,EAClB,MAAsB,EACtB,OAA8B;IAE9B,MAAM,UAAU,GAAG,kCAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,IAAI,UAAU,KAAK,MAAM,IAAI,UAAU,KAAK,YAAY,EAAE;QACxD,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;KAC7C;SAAM;QACL,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;KACtC;AACH,CAAC;AAZD,wCAYC;AAED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,KAAgB;IACrD,MAAM,MAAM,GAAG,CAAC,MAAc,EAAE,EAAE;QAChC,IAAI;YACF,MAAM,MAAM,GAAG,sBAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACzC,OAAO,CACL,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,MAAK,CAAC;gBACpB,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAC1B,sBAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBACpC,MAAM,CAAC,CAAC,CAAC,KAAK,eAAO,CAAC,WAAW,CAClC,CAAC;SACH;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;IACH,CAAC,CAAC;IACF,IAAI,UAAwC,CAAC;IAC7C,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE;QAC/E,UAAU,GAAG,WAAW,CAAC;KAC1B;SAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE;QAC9C,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC;KAC/D;SAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE;QAC/C,UAAU,GAAG,OAAO,CAAC;KACtB;IACD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;QACxE,IAAI,UAAU,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,cAAc,UAAU,uCAAuC,CAAC,CAAC;SAClF;QACD,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;SAC5E;QACD,UAAU,GAAG,wBAAwB,CAAC;KACvC;IACD,IAAI,KAAK,CAAC,cAAc,EAAE;QACxB,IAAI,UAAU,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,cAAc,UAAU,oCAAoC,CAAC,CAAC;SAC/E;QACD,UAAU,GAAG,qBAAqB,CAAC;KACpC;IACD,IAAI,UAAU,EAAE;QACd,OAAO,UAAU,CAAC;KACnB;IACD,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;AAC3C,CAAC;AAzCD,wDAyCC;AAED,SAAS,6BAA6B,CAAC,KAAgB;IACrD,MAAM,WAAW,GAAG,mCAA0B,CAAC,KAAK,CAAC,CAAC;IACtD,IAAI,CAAC,WAAW,EAAE;QAChB,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,qBAAqB,EAAE,SAAS,EAAE,CAAC;KACpE;IACD,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9D,MAAM,qBAAqB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAChF,OAAO,eAAO,CAAS,UAAU,CAAC,IAAI,eAAO,CAAS,qBAAqB,CAAC;QAC1E,CAAC,CAAC,EAAE,UAAU,EAAE,qBAAqB,EAAE;QACvC,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,qBAAqB,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AACzF,CAAC;AAED,SAAS,iCAAiC,CAAC,GAA8C;IACvF,IAAI,CAAC,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAA,EAAE;QAChB,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC;KAClC;IACD,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;QAClB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;KAC/C;IACD,MAAM,UAAU,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACrD,OAAO,eAAO,CAAS,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AACxF,CAAC;AAED,SAAS,eAAe,CACtB,KAAgB,EAChB,UAA4B;IAE5B,OAAO,UAAU,KAAK,qBAAqB;QACzC,CAAC,CAAC,6BAA6B,CAAC,KAAK,CAAC;QACtC,CAAC,CAAC,UAAU,KAAK,wBAAwB;YACzC,CAAC,CAAC,iCAAiC,CAAC,KAAK,CAAC,YAAY,CAAC;YACvD,CAAC,CAAC,iCAAiC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AAC1D,CAAC;AAED,SAAS,WAAW,CAClB,KAAgB,EAChB,UAA4B;;IAE5B,IAAI,SAA6B,CAAC;IAClC,IAAI,UAAU,KAAK,MAAM,IAAI,UAAU,KAAK,UAAU,EAAE;QACtD,SAAS,GAAG,KAAK,CAAC,YAAY,CAAC;KAChC;SAAM,IAAI,UAAU,KAAK,OAAO,IAAI,UAAU,KAAK,WAAW,EAAE;QAC/D,SAAS,GAAG,KAAK,CAAC,aAAa,CAAC;KACjC;SAAM,IAAI,UAAU,KAAK,wBAAwB,EAAE;QAClD,SAAS,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;KAC7E;SAAM,IAAI,UAAU,KAAK,qBAAqB,EAAE;QAC/C,IAAI,MAAA,KAAK,CAAC,WAAW,0CAAE,MAAM,EAAE;YAC7B,SAAS,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;SACtC;aAAM,IAAI,KAAK,CAAC,cAAc,IAAI,KAAK,CAAC,aAAa,EAAE;YACtD,SAAS,GAAG,mCAAyB,CAAC,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,EAAE,WAAW,EAAE,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC;SACnH;KACF;IACD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,0BAA0B,UAAU,4BAA4B,CAAC,CAAC;KACnF;IACD,OAAO,2BAAc,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;AAC/C,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,cAAc,CAAC,KAAgB;IAC7C,IAAI,+BAAoB,CAAC,KAAK,CAAC,EAAE;QAC/B,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;KAC5D;IACD,MAAM,UAAU,GAAG,sBAAsB,CAAC,KAAK,CAAC,CAAC;IACjD,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IACvD,MAAM,UAAU,GAAG,eAAe,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IAEtD,IAAI,eAAe,CAAC,UAAU,KAAK,qBAAqB,IAAI,uBAAuB,IAAI,UAAU,EAAE;QACjG,OAAO;YACL,GAAG,eAAe;YAClB,GAAG,UAAU;SACd,CAAC;KACH;IACD,IAAI,eAAe,CAAC,UAAU,KAAK,wBAAwB,EAAE;QAC3D,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;SAC5F;QACD,MAAM,YAAY,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QACzD,IAAI,CAAC,+BAAkB,CAAC,YAAY,CAAC,EAAE;YACrC,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;SACtE;QACD,MAAM,eAAe,GAAG,qCAAwB,CAAC,YAAY,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,2BAAc,CAAC,YAAY,CAAC,CAAC;QACjD,OAAO;YACL,GAAG,eAAe;YAClB,GAAG,UAAU;YACb,YAAY;YACZ,eAAe;YACf,WAAW;SACZ,CAAC;KACH;IACD,IACE,eAAe,CAAC,UAAU,KAAK,MAAM;QACrC,eAAe,CAAC,UAAU,KAAK,OAAO;QACtC,eAAe,CAAC,UAAU,KAAK,WAAW,EAC1C;QACA,IAAI,eAAe,CAAC,UAAU,KAAK,WAAW,EAAE;YAC9C,eAAe,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;SACnD;QACD,OAAO;YACL,GAAG,eAAe;YAClB,GAAG,UAAU;SACd,CAAC;KACH;IACD,IAAI,eAAe,CAAC,UAAU,KAAK,UAAU,IAAI,CAAC,CAAC,UAAU,CAAC,UAAU,IAAI,CAAC,eAAO,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE;QAC5G,OAAO;YACL,GAAG,eAAe;YAClB,UAAU,EAAE,UAAU,CAAC,UAAU;SAClC,CAAC;KACH;IACD,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACxC,CAAC;AApDD,wCAoDC;AAED;;;GAGG;AACH,SAAgB,uBAAuB,CAAC,KAA0B;;IAChE,MAAM,uBAAuB,GAAG,CAC9B,UAA0F,EAC/E,EAAE;QACb,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,mCAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3F,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE;YAC7C,OAAO,KAAK,CAAC;SACd;QACD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC,CAAC;IAEF,IAAI,MAAM,IAAI,KAAK,EAAE;QACnB,IAAI,CAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,MAAM,MAAI,MAAA,KAAK,CAAC,OAAO,0CAAE,MAAM,CAAA,EAAE;YACjD,MAAM,WAAW,GAAG,iCAAoB,CAAC,KAAK,CAAC,CAAC;YAChD,OAAO,WAAW,CAAC,UAAU,KAAK,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,uBAAuB,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;SAC/G;QACD,OAAO,CAAC,CAAC;KACV;SAAM;QACL,OAAO,uBAAuB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,CAAC;KAClE;AACH,CAAC;AApBD,0DAoBC;AAED;;;GAGG;AACH,SAAgB,wBAAwB,CACtC,EAAyE;IAEzE,MAAM,MAAM,GAAG,EAAE,YAAY,mBAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,YAAY,iCAAe,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACrG,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC;AAClE,CAAC;AALD,4DAKC;AAED;;KAEK;AACL,SAAgB,gBAAgB,CAAC,MAA+B;IAC9D,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAFD,4CAEC;AAED;;KAEK;AACL,SAAgB,cAAc,CAAC,MAA+B;IAC5D,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC;IAC9C,OAAO,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC;AAHD,wCAGC;AAED;;GAEG;AACH,SAAgB,kCAAkC,CAChD,IAA2E;IAE3E,MAAM,MAAM,GAAG,IAAI,YAAY,mBAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,YAAY,iCAAe,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/G,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;QAClB,OAAO,KAAK,CAAC;KACd;IACD,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAC5B,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,sBAAsB,CAAC,KAAK,CAAC,KAAK,qBAAqB,CAAC,CAAC;KAC3F;IACD,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;QAC9B,4FAA4F;QAC5F,kFAAkF;QAClF,IAAI,uBAAuB,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YACxC,OAAO,KAAK,CAAC;SACd;QACD,OAAO,iCAAoB,CAAC,KAAK,CAAC,CAAC,UAAU,KAAK,qBAAqB,CAAC;IAC1E,CAAC,CAAC,CAAC;AACL,CAAC;AAlBD,gFAkBC;AAED;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,IAAc,EAAE,cAA8B;IAC3E,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,CAAC,GAAG,CACrC,CAAC,KAAK,EAAc,EAAE,CAAC,CAAC;QACtB,cAAc,EAAE,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAClD,iBAAiB,EAAE,KAAK,CAAC,WAAW;QACpC,wFAAwF;QACxF,IAAI,EAAE,GAAG;KACV,CAAC,CACH,CAAC;IACF,IAAI,CAAC,YAAY,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;AAC3C,CAAC;AAVD,wCAUC;AAED;;;;GAIG;AACH,SAAgB,+BAA+B,CAAC,IAAc,EAAE,cAA8B;IAC5F,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;QACvC,MAAM,mBAAmB,GACvB,sBAAsB,CAAC,KAAK,CAAC,KAAK,UAAU;YAC1C,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC;YACvB,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC;QAChF,OAAO,CAAC,CAAC,EAAE,mBAAmB,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;AACL,CAAC;AARD,0EAQC","sourcesContent":["import * as assert from 'assert';\n\nimport { GlobalXpub, PartialSig, PsbtInput, TapScriptSig } from 'bip174/src/lib/interfaces';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { BIP32Interface } from 'bip32';\nimport * as bs58check from 'bs58check';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { createOutputScript2of3, getLeafHash, scriptTypeForChain, toXOnlyPublicKey } from '../outputScripts';\nimport { DerivedWalletKeys, RootWalletKeys } from './WalletKeys';\nimport { toPrevOutputWithPrevTx } from '../Unspent';\nimport { createPsbtFromTransaction } from '../transaction';\nimport { isWalletUnspent, WalletUnspent } from './Unspent';\n\nimport {\n  getLeafVersion,\n  calculateScriptPathLevel,\n  isValidControlBock,\n  ParsedPubScriptP2ms,\n  ParsedPubScriptTaprootScriptPath,\n  parsePubScript2Of3,\n  ParsedPubScriptTaproot,\n  ParsedPubScriptTaprootKeyPath,\n  parsePubScript,\n  ParsedPubScriptP2shP2pk,\n  ParsedScriptType,\n  isPlaceholderSignature,\n  parseSignatureScript,\n} from '../parseInput';\nimport { parsePsbtMusig2PartialSigs } from '../Musig2';\nimport { isTuple, Triple } from '../types';\nimport { createTaprootOutputScript } from '../../taproot';\nimport { script as bscript, TxInput } from 'bitcoinjs-lib';\nimport { opcodes } from '../../index';\nimport { getPsbtInputSignatureCount, isPsbtInputFinalized } from '../PsbtUtil';\n\n// only used for building `SignatureContainer`\ntype BaseSignatureContainer<T> = {\n  signatures: T;\n};\n\ntype UnsignedSignatureContainer = BaseSignatureContainer<undefined>;\ntype HalfSignedSignatureContainer = BaseSignatureContainer<[Buffer]>;\ntype FullSignedSignatureContainer = BaseSignatureContainer<[Buffer, Buffer]>;\n\ntype SignatureContainer = UnsignedSignatureContainer | HalfSignedSignatureContainer | FullSignedSignatureContainer;\n\n/**\n * Contents of a pre-finalized PSBT Input for p2trMusig2 key path in the non-finalized state.\n * T is [Buffer] for first signature, [Buffer, Buffer] for both signatures and `undefined` for no signatures.\n */\ntype BaseTaprootKeyPathSignatureContainer<T> = {\n  signatures: T;\n  /** Only contains participants that have added a signature */\n  participantPublicKeys: T;\n};\n\ntype UnsignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<undefined>;\ntype HalfSignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<[Buffer]>;\ntype FullSignedTaprootKeyPathSignatureContainer = BaseTaprootKeyPathSignatureContainer<[Buffer, Buffer]>;\n\ntype TaprootKeyPathSignatureContainer =\n  | UnsignedTaprootKeyPathSignatureContainer\n  | HalfSignedTaprootKeyPathSignatureContainer\n  | FullSignedTaprootKeyPathSignatureContainer;\n\n/**\n * To hold parsed psbt data for p2ms based script types - p2sh, p2wsh, and p2shP2wsh\n */\nexport type ParsedPsbtP2ms = ParsedPubScriptP2ms & SignatureContainer;\n\n/**\n * To hold parsed psbt data for TaprootKeyPathSpend script type.\n */\nexport type ParsedPsbtTaprootKeyPath = ParsedPubScriptTaprootKeyPath & TaprootKeyPathSignatureContainer;\n\n/**\n * To hold parsed psbt data for TaprootScriptPathSpend script path script type.\n */\nexport type ParsedPsbtTaprootScriptPath = ParsedPubScriptTaprootScriptPath &\n  SignatureContainer & {\n    controlBlock: Buffer;\n    leafVersion: number;\n    /** Indicates the level inside the taptree. */\n    scriptPathLevel: number;\n  };\n\nexport type ParsedPsbtTaproot = ParsedPsbtTaprootKeyPath | ParsedPsbtTaprootScriptPath;\n\ntype P2shP2pkSignatureContainer = UnsignedSignatureContainer | HalfSignedSignatureContainer;\n\nexport type ParsedPsbtP2shP2pk = ParsedPubScriptP2shP2pk & P2shP2pkSignatureContainer;\n\ninterface WalletSigner {\n  walletKey: BIP32Interface;\n  rootKey: BIP32Interface;\n}\n\n/**\n * psbt input index and its user, backup, bitgo signatures status\n */\nexport type SignatureValidation = [index: number, sigTriple: Triple<boolean>];\n\nfunction getTaprootSigners(script: Buffer, walletKeys: DerivedWalletKeys): [WalletSigner, WalletSigner] {\n  const parsedPublicKeys = parsePubScript2Of3(script, 'taprootScriptPathSpend').publicKeys;\n  const walletSigners = parsedPublicKeys.map((publicKey) => {\n    const index = walletKeys.publicKeys.findIndex((walletPublicKey) =>\n      toXOnlyPublicKey(walletPublicKey).equals(publicKey)\n    );\n    if (index >= 0) {\n      return { walletKey: walletKeys.triple[index], rootKey: walletKeys.parent.triple[index] };\n    }\n    throw new Error('Taproot public key is not a wallet public key');\n  });\n  return [walletSigners[0], walletSigners[1]];\n}\n\nfunction updatePsbtInput(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  unspent: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys\n): void {\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n  const signatureCount = getPsbtInputSignatureCount(input);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  if (signatureCount === 0 && scriptType === 'p2tr') {\n    return;\n  }\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(unspent.chain, unspent.index);\n\n  if (scriptType === 'p2tr') {\n    if (!Array.isArray(input.tapLeafScript) || input.tapLeafScript.length === 0) {\n      throw new Error('Invalid PSBT state. Missing required fields.');\n    }\n\n    if (input.tapLeafScript.length > 1) {\n      throw new Error('Bitgo only supports a single tap leaf script per input');\n    }\n\n    const [signer, cosigner] = getTaprootSigners(input.tapLeafScript[0].script, walletKeys);\n\n    const leafHash = getLeafHash({\n      publicKeys: walletKeys.publicKeys,\n      signer: signer.walletKey.publicKey,\n      cosigner: cosigner.walletKey.publicKey,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: [signer, cosigner].map((walletSigner) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletSigner.walletKey.publicKey),\n        path: rootWalletKeys.getDerivationPath(walletSigner.rootKey, unspent.chain, unspent.index),\n        masterFingerprint: walletSigner.rootKey.fingerprint,\n      })),\n    });\n  } else {\n    if (signatureCount === 0) {\n      const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n      if (witnessScript && psbt.data.inputs[inputIndex].witnessScript === undefined) {\n        psbt.updateInput(inputIndex, { witnessScript });\n      }\n      if (redeemScript && psbt.data.inputs[inputIndex].redeemScript === undefined) {\n        psbt.updateInput(inputIndex, { redeemScript });\n      }\n    }\n\n    psbt.updateInput(inputIndex, {\n      bip32Derivation: [0, 1, 2].map((idx) => ({\n        pubkey: walletKeys.triple[idx].publicKey,\n        path: walletKeys.paths[idx],\n        masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n      })),\n    });\n  }\n}\n\n/**\n * @return PSBT filled with metatdata as per input params tx, unspents and rootWalletKeys.\n * Unsigned PSBT for taproot input with witnessUtxo\n * Unsigned PSBT for other input with witnessUtxo/nonWitnessUtxo, redeemScript/witnessScript, bip32Derivation\n * Signed PSBT for taproot input with witnessUtxo, tapLeafScript, tapBip32Derivation, tapScriptSig\n * Signed PSBT for other input with witnessUtxo/nonWitnessUtxo, redeemScript/witnessScript, bip32Derivation, partialSig\n */\nexport function toWalletPsbt(\n  tx: UtxoTransaction<bigint>,\n  unspents: WalletUnspent<bigint>[],\n  rootWalletKeys: RootWalletKeys\n): UtxoPsbt {\n  const prevOutputs = unspents.map((u) => {\n    assert.notStrictEqual(scriptTypeForChain(u.chain), 'p2trMusig2');\n    return toPrevOutputWithPrevTx(u, tx.network);\n  });\n  const psbt = createPsbtFromTransaction(tx, prevOutputs);\n  unspents.forEach((u, i) => {\n    if (isWalletUnspent(u) && u.index !== undefined) {\n      updatePsbtInput(psbt, i, u, rootWalletKeys);\n    }\n  });\n  return psbt;\n}\n\n/**\n * @param psbt\n * @param inputIndex\n * @param signer\n * @param unspent\n * @return signed PSBT with signer's key for unspent\n */\nexport function signWalletPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  signer: BIP32Interface,\n  unspent: WalletUnspent<bigint>\n): void {\n  const scriptType = scriptTypeForChain(unspent.chain);\n  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {\n    psbt.signTaprootInputHD(inputIndex, signer);\n  } else {\n    psbt.signInputHD(inputIndex, signer);\n  }\n}\n\n/**\n * @returns script type of the input\n */\nexport function getPsbtInputScriptType(input: PsbtInput): ParsedScriptType {\n  const isP2pk = (script: Buffer) => {\n    try {\n      const chunks = bscript.decompile(script);\n      return (\n        chunks?.length === 2 &&\n        Buffer.isBuffer(chunks[0]) &&\n        bscript.isCanonicalPubKey(chunks[0]) &&\n        chunks[1] === opcodes.OP_CHECKSIG\n      );\n    } catch (e) {\n      return false;\n    }\n  };\n  let scriptType: ParsedScriptType | undefined;\n  if (Buffer.isBuffer(input.redeemScript) && Buffer.isBuffer(input.witnessScript)) {\n    scriptType = 'p2shP2wsh';\n  } else if (Buffer.isBuffer(input.redeemScript)) {\n    scriptType = isP2pk(input.redeemScript) ? 'p2shP2pk' : 'p2sh';\n  } else if (Buffer.isBuffer(input.witnessScript)) {\n    scriptType = 'p2wsh';\n  }\n  if (Array.isArray(input.tapLeafScript) && input.tapLeafScript.length > 0) {\n    if (scriptType) {\n      throw new Error(`Found both ${scriptType} and taprootScriptPath PSBT metadata.`);\n    }\n    if (input.tapLeafScript.length > 1) {\n      throw new Error('Bitgo only supports a single tap leaf script per input.');\n    }\n    scriptType = 'taprootScriptPathSpend';\n  }\n  if (input.tapInternalKey) {\n    if (scriptType) {\n      throw new Error(`Found both ${scriptType} and taprootKeyPath PSBT metadata.`);\n    }\n    scriptType = 'taprootKeyPathSpend';\n  }\n  if (scriptType) {\n    return scriptType;\n  }\n  throw new Error('could not parse input');\n}\n\nfunction parseTaprootKeyPathSignatures(input: PsbtInput): TaprootKeyPathSignatureContainer {\n  const partialSigs = parsePsbtMusig2PartialSigs(input);\n  if (!partialSigs) {\n    return { signatures: undefined, participantPublicKeys: undefined };\n  }\n  const signatures = partialSigs.map((pSig) => pSig.partialSig);\n  const participantPublicKeys = partialSigs.map((pSig) => pSig.participantPubKey);\n  return isTuple<Buffer>(signatures) && isTuple<Buffer>(participantPublicKeys)\n    ? { signatures, participantPublicKeys }\n    : { signatures: [signatures[0]], participantPublicKeys: [participantPublicKeys[0]] };\n}\n\nfunction parsePartialOrTapScriptSignatures(sig: PartialSig[] | TapScriptSig[] | undefined): SignatureContainer {\n  if (!sig?.length) {\n    return { signatures: undefined };\n  }\n  if (sig.length > 2) {\n    throw new Error('unexpected signature count');\n  }\n  const signatures = sig.map((tSig) => tSig.signature);\n  return isTuple<Buffer>(signatures) ? { signatures } : { signatures: [signatures[0]] };\n}\n\nfunction parseSignatures(\n  input: PsbtInput,\n  scriptType: ParsedScriptType\n): SignatureContainer | TaprootKeyPathSignatureContainer {\n  return scriptType === 'taprootKeyPathSpend'\n    ? parseTaprootKeyPathSignatures(input)\n    : scriptType === 'taprootScriptPathSpend'\n    ? parsePartialOrTapScriptSignatures(input.tapScriptSig)\n    : parsePartialOrTapScriptSignatures(input.partialSig);\n}\n\nfunction parseScript(\n  input: PsbtInput,\n  scriptType: ParsedScriptType\n): ParsedPubScriptP2ms | ParsedPubScriptTaproot | ParsedPubScriptP2shP2pk {\n  let pubScript: Buffer | undefined;\n  if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {\n    pubScript = input.redeemScript;\n  } else if (scriptType === 'p2wsh' || scriptType === 'p2shP2wsh') {\n    pubScript = input.witnessScript;\n  } else if (scriptType === 'taprootScriptPathSpend') {\n    pubScript = input.tapLeafScript ? input.tapLeafScript[0].script : undefined;\n  } else if (scriptType === 'taprootKeyPathSpend') {\n    if (input.witnessUtxo?.script) {\n      pubScript = input.witnessUtxo.script;\n    } else if (input.tapInternalKey && input.tapMerkleRoot) {\n      pubScript = createTaprootOutputScript({ internalPubKey: input.tapInternalKey, taptreeRoot: input.tapMerkleRoot });\n    }\n  }\n  if (!pubScript) {\n    throw new Error(`Invalid PSBT state for ${scriptType}. Missing required fields.`);\n  }\n  return parsePubScript(pubScript, scriptType);\n}\n\n/**\n * @return psbt metadata are parsed as per below conditions.\n * redeemScript/witnessScript/tapLeafScript matches BitGo.\n * signature and public key count matches BitGo.\n * P2SH-P2PK => scriptType, redeemScript, public key, signature.\n * P2SH => scriptType, redeemScript, public keys, signatures.\n * PW2SH => scriptType, witnessScript, public keys, signatures.\n * P2SH-PW2SH => scriptType, redeemScript, witnessScript, public keys, signatures.\n * P2TR and P2TR MUSIG2 script path => scriptType (taprootScriptPathSpend), pubScript (leaf script), controlBlock,\n * scriptPathLevel, leafVersion, public keys, signatures.\n * P2TR MUSIG2 kep path => scriptType (taprootKeyPathSpend), pubScript (scriptPubKey), participant pub keys (signer),\n * public key (tapOutputkey), signatures (partial signer sigs).\n */\nexport function parsePsbtInput(input: PsbtInput): ParsedPsbtP2ms | ParsedPsbtTaproot | ParsedPsbtP2shP2pk {\n  if (isPsbtInputFinalized(input)) {\n    throw new Error('Finalized PSBT parsing is not supported');\n  }\n  const scriptType = getPsbtInputScriptType(input);\n  const parsedPubScript = parseScript(input, scriptType);\n  const signatures = parseSignatures(input, scriptType);\n\n  if (parsedPubScript.scriptType === 'taprootKeyPathSpend' && 'participantPublicKeys' in signatures) {\n    return {\n      ...parsedPubScript,\n      ...signatures,\n    };\n  }\n  if (parsedPubScript.scriptType === 'taprootScriptPathSpend') {\n    if (!input.tapLeafScript) {\n      throw new Error('Invalid PSBT state for taprootScriptPathSpend. Missing required fields.');\n    }\n    const controlBlock = input.tapLeafScript[0].controlBlock;\n    if (!isValidControlBock(controlBlock)) {\n      throw new Error('Invalid PSBT taprootScriptPathSpend controlBlock.');\n    }\n    const scriptPathLevel = calculateScriptPathLevel(controlBlock);\n    const leafVersion = getLeafVersion(controlBlock);\n    return {\n      ...parsedPubScript,\n      ...signatures,\n      controlBlock,\n      scriptPathLevel,\n      leafVersion,\n    };\n  }\n  if (\n    parsedPubScript.scriptType === 'p2sh' ||\n    parsedPubScript.scriptType === 'p2wsh' ||\n    parsedPubScript.scriptType === 'p2shP2wsh'\n  ) {\n    if (parsedPubScript.scriptType === 'p2shP2wsh') {\n      parsedPubScript.redeemScript = input.redeemScript;\n    }\n    return {\n      ...parsedPubScript,\n      ...signatures,\n    };\n  }\n  if (parsedPubScript.scriptType === 'p2shP2pk' && (!signatures.signatures || !isTuple(signatures.signatures))) {\n    return {\n      ...parsedPubScript,\n      signatures: signatures.signatures,\n    };\n  }\n  throw new Error('invalid pub script');\n}\n\n/**\n * @returns strictly parse the input and get signature count.\n * unsigned(0), half-signed(1) or fully-signed(2)\n */\nexport function getStrictSignatureCount(input: TxInput | PsbtInput): 0 | 1 | 2 {\n  const calculateSignatureCount = (\n    signatures: [Buffer | 0, Buffer | 0, Buffer | 0] | [Buffer, Buffer] | [Buffer] | undefined\n  ): 0 | 1 | 2 => {\n    const count = signatures ? signatures.filter((s) => !isPlaceholderSignature(s)).length : 0;\n    if (count === 0 || count === 1 || count === 2) {\n      return count;\n    }\n    throw new Error('invalid signature count');\n  };\n\n  if ('hash' in input) {\n    if (input.script?.length || input.witness?.length) {\n      const parsedInput = parseSignatureScript(input);\n      return parsedInput.scriptType === 'taprootKeyPathSpend' ? 2 : calculateSignatureCount(parsedInput.signatures);\n    }\n    return 0;\n  } else {\n    return calculateSignatureCount(parsePsbtInput(input).signatures);\n  }\n}\n\n/**\n * @returns strictly parse input and get signature count for all inputs.\n * 0=unsigned, 1=half-signed or 2=fully-signed\n */\nexport function getStrictSignatureCounts(\n  tx: UtxoPsbt | UtxoTransaction<number | bigint> | PsbtInput[] | TxInput[]\n): (0 | 1 | 2)[] {\n  const inputs = tx instanceof UtxoPsbt ? tx.data.inputs : tx instanceof UtxoTransaction ? tx.ins : tx;\n  return inputs.map((input, _) => getStrictSignatureCount(input));\n}\n\n/**\n * @return true iff inputs array is of PsbtInputType type\n * */\nexport function isPsbtInputArray(inputs: PsbtInput[] | TxInput[]): inputs is PsbtInput[] {\n  return !isTxInputArray(inputs);\n}\n\n/**\n * @return true iff inputs array is of TxInput type\n * */\nexport function isTxInputArray(inputs: PsbtInput[] | TxInput[]): inputs is TxInput[] {\n  assert(!!inputs.length, 'empty inputs array');\n  return 'hash' in inputs[0];\n}\n\n/**\n * @returns true iff given psbt/transaction/tx-input-array/psbt-input-array contains at least one taproot key path spend input\n */\nexport function isTransactionWithKeyPathSpendInput(\n  data: UtxoPsbt | UtxoTransaction<bigint | number> | PsbtInput[] | TxInput[]\n): boolean {\n  const inputs = data instanceof UtxoPsbt ? data.data.inputs : data instanceof UtxoTransaction ? data.ins : data;\n  if (!inputs.length) {\n    return false;\n  }\n  if (isPsbtInputArray(inputs)) {\n    return inputs.some((input, _) => getPsbtInputScriptType(input) === 'taprootKeyPathSpend');\n  }\n  return inputs.some((input, _) => {\n    // If the input is not signed, it cannot be a taprootKeyPathSpend input because you can only\n    // extract a fully signed psbt into a transaction with taprootKeyPathSpend inputs.\n    if (getStrictSignatureCount(input) === 0) {\n      return false;\n    }\n    return parseSignatureScript(input).scriptType === 'taprootKeyPathSpend';\n  });\n}\n\n/**\n * Set the RootWalletKeys as the globalXpubs on the psbt\n *\n * We do all the matching of the (tap)bip32Derivations masterFingerprint to the fingerprint of the\n * extendedPubkey.\n */\nexport function addXpubsToPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys): void {\n  const xPubs = rootWalletKeys.triple.map(\n    (bip32): GlobalXpub => ({\n      extendedPubkey: bs58check.decode(bip32.toBase58()),\n      masterFingerprint: bip32.fingerprint,\n      // TODO: BG-73797 - bip174 currently requires m prefix for this to be a valid globalXpub\n      path: 'm',\n    })\n  );\n  psbt.updateGlobal({ globalXpub: xPubs });\n}\n\n/**\n * validates signatures for each 2 of 3 input against user, backup, bitgo keys derived from rootWalletKeys.\n * @returns array of input index and its [is valid user sig exist, is valid backup sig exist, is valid user bitgo exist]\n * For p2shP2pk input, [false, false, false] is returned since it is not a 2 of 3 sig input.\n */\nexport function getSignatureValidationArrayPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys): SignatureValidation[] {\n  return psbt.data.inputs.map((input, i) => {\n    const sigValArrayForInput: Triple<boolean> =\n      getPsbtInputScriptType(input) === 'p2shP2pk'\n        ? [false, false, false]\n        : psbt.getSignatureValidationArray(i, { rootNodes: rootWalletKeys.triple });\n    return [i, sigValArrayForInput];\n  });\n}\n"]}
@@ -4,7 +4,7 @@ import { ChainCode } from './chains';
4
4
  /**
5
5
  * Add a verifiable wallet output to the PSBT. The output and all data
6
6
  * needed to verify it from public keys only are added to the PSBT.
7
- * Typically these are change outputs.
7
+ * Typically these are change outputs
8
8
  *
9
9
  * @param psbt the PSBT to add change output to
10
10
  * @param rootWalletKeys keys that will be able to spend the output
@@ -15,20 +15,4 @@ import { ChainCode } from './chains';
15
15
  * @param value value of the change output
16
16
  */
17
17
  export declare function addWalletOutputToPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys, chain: ChainCode, index: number, value: bigint): void;
18
- /**
19
- * Update the wallet output with the required information when necessary. If the
20
- * information is there already, it will skip over it.
21
- *
22
- * This function assumes that the output script and value have already been set.
23
- *
24
- * @param psbt the PSBT to update change output at
25
- * @param rootWalletKeys keys that will be able to spend the output
26
- * @param outputIndex output index where to update the output
27
- * @param chain chain code to use for deriving scripts (and to determine script
28
- * type) chain is an API parameter in the BitGo API, and may be
29
- * any valid ChainCode
30
- * @param index derivation index for the change address
31
- * @param value value of the change output
32
- */
33
- export declare function updateWalletOutputForPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys, outputIndex: number, chain: ChainCode, index: number): void;
34
18
  //# sourceMappingURL=WalletOutput.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"WalletOutput.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletOutput.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAsB,MAAM,UAAU,CAAC;AAGzD;;;;;;;;;;;;GAYG;AACH,wBAAgB,qBAAqB,CACnC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,IAAI,CAYN;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,GACZ,IAAI,CAgEN"}
1
+ {"version":3,"file":"WalletOutput.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletOutput.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAsB,MAAM,UAAU,CAAC;AAGzD;;;;;;;;;;;;GAYG;AACH,wBAAgB,qBAAqB,CACnC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,IAAI,CAgDN"}
@@ -1,13 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.updateWalletOutputForPsbt = exports.addWalletOutputToPsbt = void 0;
3
+ exports.addWalletOutputToPsbt = void 0;
4
4
  const bitcoinjs_lib_1 = require("bitcoinjs-lib");
5
5
  const chains_1 = require("./chains");
6
6
  const outputScripts_1 = require("../outputScripts");
7
7
  /**
8
8
  * Add a verifiable wallet output to the PSBT. The output and all data
9
9
  * needed to verify it from public keys only are added to the PSBT.
10
- * Typically these are change outputs.
10
+ * Typically these are change outputs
11
11
  *
12
12
  * @param psbt the PSBT to add change output to
13
13
  * @param rootWalletKeys keys that will be able to spend the output
@@ -22,53 +22,13 @@ function addWalletOutputToPsbt(psbt, rootWalletKeys, chain, index, value) {
22
22
  const scriptType = chains_1.scriptTypeForChain(chain);
23
23
  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {
24
24
  const payment = scriptType === 'p2tr' ? outputScripts_1.createPaymentP2tr(walletKeys.publicKeys) : outputScripts_1.createPaymentP2trMusig2(walletKeys.publicKeys);
25
- psbt.addOutput({ script: payment.output, value });
26
- }
27
- else {
28
- const { scriptPubKey: script } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
29
- psbt.addOutput({ script, value });
30
- }
31
- updateWalletOutputForPsbt(psbt, rootWalletKeys, psbt.data.outputs.length - 1, chain, index);
32
- }
33
- exports.addWalletOutputToPsbt = addWalletOutputToPsbt;
34
- /**
35
- * Update the wallet output with the required information when necessary. If the
36
- * information is there already, it will skip over it.
37
- *
38
- * This function assumes that the output script and value have already been set.
39
- *
40
- * @param psbt the PSBT to update change output at
41
- * @param rootWalletKeys keys that will be able to spend the output
42
- * @param outputIndex output index where to update the output
43
- * @param chain chain code to use for deriving scripts (and to determine script
44
- * type) chain is an API parameter in the BitGo API, and may be
45
- * any valid ChainCode
46
- * @param index derivation index for the change address
47
- * @param value value of the change output
48
- */
49
- function updateWalletOutputForPsbt(psbt, rootWalletKeys, outputIndex, chain, index) {
50
- if (psbt.data.outputs.length <= outputIndex) {
51
- throw new Error(`outputIndex (${outputIndex}) is too large for the number of outputs (${psbt.data.outputs.length})`);
52
- }
53
- const outputScript = psbt.getOutputScript(outputIndex);
54
- const walletKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);
55
- const scriptType = chains_1.scriptTypeForChain(chain);
56
- const output = psbt.data.outputs[outputIndex];
57
- const update = {};
58
- if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {
59
- const payment = scriptType === 'p2tr' ? outputScripts_1.createPaymentP2tr(walletKeys.publicKeys) : outputScripts_1.createPaymentP2trMusig2(walletKeys.publicKeys);
60
- if (!payment.output || !payment.output.equals(outputScript)) {
61
- throw new Error(`cannot update a p2tr output where the scripts do not match - Failing.`);
62
- }
63
25
  const allLeafHashes = payment.redeems.map((r) => bitcoinjs_lib_1.taproot.hashTapLeaf(r.output));
64
- if (!output.tapTree) {
65
- update.tapTree = payment.tapTree;
66
- }
67
- if (!output.tapInternalKey) {
68
- update.tapInternalKey = payment.internalPubkey;
69
- }
70
- if (!output.tapBip32Derivation) {
71
- update.tapBip32Derivation = [0, 1, 2].map((idx) => {
26
+ psbt.addOutput({
27
+ script: payment.output,
28
+ value,
29
+ tapTree: payment.tapTree,
30
+ tapInternalKey: payment.internalPubkey,
31
+ tapBip32Derivation: [0, 1, 2].map((idx) => {
72
32
  const pubkey = outputScripts_1.toXOnlyPublicKey(walletKeys.triple[idx].publicKey);
73
33
  const leafHashes = [];
74
34
  payment.redeems.forEach((r, idx) => {
@@ -82,29 +42,28 @@ function updateWalletOutputForPsbt(psbt, rootWalletKeys, outputIndex, chain, ind
82
42
  path: walletKeys.paths[idx],
83
43
  masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
84
44
  };
85
- });
86
- }
45
+ }),
46
+ });
87
47
  }
88
48
  else {
89
49
  const { scriptPubKey, witnessScript, redeemScript } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
90
- if (!scriptPubKey.equals(outputScript)) {
91
- throw new Error(`cannot update an output where the scripts do not match - Failing.`);
92
- }
93
- if (!output.bip32Derivation) {
94
- update.bip32Derivation = [0, 1, 2].map((idx) => ({
50
+ psbt.addOutput({
51
+ script: scriptPubKey,
52
+ value,
53
+ bip32Derivation: [0, 1, 2].map((idx) => ({
95
54
  pubkey: walletKeys.triple[idx].publicKey,
96
55
  path: walletKeys.paths[idx],
97
56
  masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
98
- }));
99
- }
100
- if (!output.witnessScript && witnessScript) {
101
- update.witnessScript = witnessScript;
57
+ })),
58
+ });
59
+ const outputIndex = psbt.txOutputs.length - 1;
60
+ if (witnessScript) {
61
+ psbt.updateOutput(outputIndex, { witnessScript });
102
62
  }
103
- if (!output.redeemScript && redeemScript) {
104
- update.redeemScript = redeemScript;
63
+ if (redeemScript) {
64
+ psbt.updateOutput(outputIndex, { redeemScript });
105
65
  }
106
66
  }
107
- psbt.updateOutput(outputIndex, update);
108
67
  }
109
- exports.updateWalletOutputForPsbt = updateWalletOutputForPsbt;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"WalletOutput.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletOutput.ts"],"names":[],"mappings":"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","sourcesContent":["import { taproot } from 'bitcoinjs-lib';\nimport { PsbtOutputUpdate } from 'bip174/src/lib/interfaces';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { RootWalletKeys } from './WalletKeys';\nimport { ChainCode, scriptTypeForChain } from './chains';\nimport { createOutputScript2of3, createPaymentP2tr, createPaymentP2trMusig2, toXOnlyPublicKey } from '../outputScripts';\n\n/**\n * Add a verifiable wallet output to the PSBT. The output and all data\n * needed to verify it from public keys only are added to the PSBT.\n * Typically these are change outputs.\n *\n * @param psbt the PSBT to add change output to\n * @param rootWalletKeys keys that will be able to spend the output\n * @param chain chain code to use for deriving scripts (and to determine script\n *              type) chain is an API parameter in the BitGo API, and may be\n *              any valid ChainCode\n * @param index derivation index for the change address\n * @param value value of the change output\n */\nexport function addWalletOutputToPsbt(\n  psbt: UtxoPsbt,\n  rootWalletKeys: RootWalletKeys,\n  chain: ChainCode,\n  index: number,\n  value: bigint\n): void {\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);\n  const scriptType = scriptTypeForChain(chain);\n  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {\n    const payment =\n      scriptType === 'p2tr' ? createPaymentP2tr(walletKeys.publicKeys) : createPaymentP2trMusig2(walletKeys.publicKeys);\n    psbt.addOutput({ script: payment.output!, value });\n  } else {\n    const { scriptPubKey: script } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    psbt.addOutput({ script, value });\n  }\n  updateWalletOutputForPsbt(psbt, rootWalletKeys, psbt.data.outputs.length - 1, chain, index);\n}\n\n/**\n * Update the wallet output with the required information when necessary. If the\n * information is there already, it will skip over it.\n *\n * This function assumes that the output script and value have already been set.\n *\n * @param psbt the PSBT to update change output at\n * @param rootWalletKeys keys that will be able to spend the output\n * @param outputIndex output index where to update the output\n * @param chain chain code to use for deriving scripts (and to determine script\n *              type) chain is an API parameter in the BitGo API, and may be\n *              any valid ChainCode\n * @param index derivation index for the change address\n * @param value value of the change output\n */\nexport function updateWalletOutputForPsbt(\n  psbt: UtxoPsbt,\n  rootWalletKeys: RootWalletKeys,\n  outputIndex: number,\n  chain: ChainCode,\n  index: number\n): void {\n  if (psbt.data.outputs.length <= outputIndex) {\n    throw new Error(\n      `outputIndex (${outputIndex}) is too large for the number of outputs (${psbt.data.outputs.length})`\n    );\n  }\n\n  const outputScript = psbt.getOutputScript(outputIndex);\n\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(chain, index);\n  const scriptType = scriptTypeForChain(chain);\n  const output = psbt.data.outputs[outputIndex];\n  const update: PsbtOutputUpdate = {};\n  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {\n    const payment =\n      scriptType === 'p2tr' ? createPaymentP2tr(walletKeys.publicKeys) : createPaymentP2trMusig2(walletKeys.publicKeys);\n    if (!payment.output || !payment.output.equals(outputScript)) {\n      throw new Error(`cannot update a p2tr output where the scripts do not match - Failing.`);\n    }\n    const allLeafHashes = payment.redeems!.map((r) => taproot.hashTapLeaf(r.output!));\n\n    if (!output.tapTree) {\n      update.tapTree = payment.tapTree;\n    }\n    if (!output.tapInternalKey) {\n      update.tapInternalKey = payment.internalPubkey;\n    }\n    if (!output.tapBip32Derivation) {\n      update.tapBip32Derivation = [0, 1, 2].map((idx) => {\n        const pubkey = toXOnlyPublicKey(walletKeys.triple[idx].publicKey);\n        const leafHashes: Buffer[] = [];\n        payment.redeems!.forEach((r, idx) => {\n          if (r.pubkeys!.find((pk) => pk.equals(pubkey))) {\n            leafHashes.push(allLeafHashes[idx]);\n          }\n        });\n        return {\n          leafHashes,\n          pubkey,\n          path: walletKeys.paths[idx],\n          masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n        };\n      });\n    }\n  } else {\n    const { scriptPubKey, witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    if (!scriptPubKey.equals(outputScript)) {\n      throw new Error(`cannot update an output where the scripts do not match - Failing.`);\n    }\n    if (!output.bip32Derivation) {\n      update.bip32Derivation = [0, 1, 2].map((idx) => ({\n        pubkey: walletKeys.triple[idx].publicKey,\n        path: walletKeys.paths[idx],\n        masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n      }));\n    }\n    if (!output.witnessScript && witnessScript) {\n      update.witnessScript = witnessScript;\n    }\n    if (!output.redeemScript && redeemScript) {\n      update.redeemScript = redeemScript;\n    }\n  }\n  psbt.updateOutput(outputIndex, update);\n}\n"]}
68
+ exports.addWalletOutputToPsbt = addWalletOutputToPsbt;
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiV2FsbGV0T3V0cHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2JpdGdvL3dhbGxldC9XYWxsZXRPdXRwdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaURBQXdDO0FBR3hDLHFDQUF5RDtBQUN6RCxvREFBd0g7QUFFeEg7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsU0FBZ0IscUJBQXFCLENBQ25DLElBQWMsRUFDZCxjQUE4QixFQUM5QixLQUFnQixFQUNoQixLQUFhLEVBQ2IsS0FBYTtJQUViLE1BQU0sVUFBVSxHQUFHLGNBQWMsQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDdkUsTUFBTSxVQUFVLEdBQUcsMkJBQWtCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0MsSUFBSSxVQUFVLEtBQUssTUFBTSxJQUFJLFVBQVUsS0FBSyxZQUFZLEVBQUU7UUFDeEQsTUFBTSxPQUFPLEdBQ1gsVUFBVSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsaUNBQWlCLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyx1Q0FBdUIsQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDcEgsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLE9BQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLHVCQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxNQUFPLENBQUMsQ0FBQyxDQUFDO1FBRWxGLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDYixNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU87WUFDdkIsS0FBSztZQUNMLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTztZQUN4QixjQUFjLEVBQUUsT0FBTyxDQUFDLGNBQWM7WUFDdEMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO2dCQUN4QyxNQUFNLE1BQU0sR0FBRyxnQ0FBZ0IsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUNsRSxNQUFNLFVBQVUsR0FBYSxFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sQ0FBQyxPQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFO29CQUNsQyxJQUFJLENBQUMsQ0FBQyxPQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUU7d0JBQzlDLFVBQVUsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7cUJBQ3JDO2dCQUNILENBQUMsQ0FBQyxDQUFDO2dCQUNILE9BQU87b0JBQ0wsVUFBVTtvQkFDVixNQUFNO29CQUNOLElBQUksRUFBRSxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztvQkFDM0IsaUJBQWlCLEVBQUUsY0FBYyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxXQUFXO2lCQUMxRCxDQUFDO1lBQ0osQ0FBQyxDQUFDO1NBQ0gsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxHQUFHLHNDQUFzQixDQUFDLFVBQVUsQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDaEgsSUFBSSxDQUFDLFNBQVMsQ0FBQztZQUNiLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLEtBQUs7WUFDTCxlQUFlLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDdkMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsU0FBUztnQkFDeEMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDO2dCQUMzQixpQkFBaUIsRUFBRSxjQUFjLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFdBQVc7YUFDMUQsQ0FBQyxDQUFDO1NBQ0osQ0FBQyxDQUFDO1FBQ0gsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBQzlDLElBQUksYUFBYSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQztTQUNuRDtRQUNELElBQUksWUFBWSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztTQUNsRDtLQUNGO0FBQ0gsQ0FBQztBQXRERCxzREFzREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0YXByb290IH0gZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgeyBVdHhvUHNidCB9IGZyb20gJy4uL1V0eG9Qc2J0JztcbmltcG9ydCB7IFJvb3RXYWxsZXRLZXlzIH0gZnJvbSAnLi9XYWxsZXRLZXlzJztcbmltcG9ydCB7IENoYWluQ29kZSwgc2NyaXB0VHlwZUZvckNoYWluIH0gZnJvbSAnLi9jaGFpbnMnO1xuaW1wb3J0IHsgY3JlYXRlT3V0cHV0U2NyaXB0Mm9mMywgY3JlYXRlUGF5bWVudFAydHIsIGNyZWF0ZVBheW1lbnRQMnRyTXVzaWcyLCB0b1hPbmx5UHVibGljS2V5IH0gZnJvbSAnLi4vb3V0cHV0U2NyaXB0cyc7XG5cbi8qKlxuICogQWRkIGEgdmVyaWZpYWJsZSB3YWxsZXQgb3V0cHV0IHRvIHRoZSBQU0JULiBUaGUgb3V0cHV0IGFuZCBhbGwgZGF0YVxuICogbmVlZGVkIHRvIHZlcmlmeSBpdCBmcm9tIHB1YmxpYyBrZXlzIG9ubHkgYXJlIGFkZGVkIHRvIHRoZSBQU0JULlxuICogVHlwaWNhbGx5IHRoZXNlIGFyZSBjaGFuZ2Ugb3V0cHV0c1xuICpcbiAqIEBwYXJhbSBwc2J0IHRoZSBQU0JUIHRvIGFkZCBjaGFuZ2Ugb3V0cHV0IHRvXG4gKiBAcGFyYW0gcm9vdFdhbGxldEtleXMga2V5cyB0aGF0IHdpbGwgYmUgYWJsZSB0byBzcGVuZCB0aGUgb3V0cHV0XG4gKiBAcGFyYW0gY2hhaW4gY2hhaW4gY29kZSB0byB1c2UgZm9yIGRlcml2aW5nIHNjcmlwdHMgKGFuZCB0byBkZXRlcm1pbmUgc2NyaXB0XG4gKiAgICAgICAgICAgICAgdHlwZSkgY2hhaW4gaXMgYW4gQVBJIHBhcmFtZXRlciBpbiB0aGUgQml0R28gQVBJLCBhbmQgbWF5IGJlXG4gKiAgICAgICAgICAgICAgYW55IHZhbGlkIENoYWluQ29kZVxuICogQHBhcmFtIGluZGV4IGRlcml2YXRpb24gaW5kZXggZm9yIHRoZSBjaGFuZ2UgYWRkcmVzc1xuICogQHBhcmFtIHZhbHVlIHZhbHVlIG9mIHRoZSBjaGFuZ2Ugb3V0cHV0XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhZGRXYWxsZXRPdXRwdXRUb1BzYnQoXG4gIHBzYnQ6IFV0eG9Qc2J0LFxuICByb290V2FsbGV0S2V5czogUm9vdFdhbGxldEtleXMsXG4gIGNoYWluOiBDaGFpbkNvZGUsXG4gIGluZGV4OiBudW1iZXIsXG4gIHZhbHVlOiBiaWdpbnRcbik6IHZvaWQge1xuICBjb25zdCB3YWxsZXRLZXlzID0gcm9vdFdhbGxldEtleXMuZGVyaXZlRm9yQ2hhaW5BbmRJbmRleChjaGFpbiwgaW5kZXgpO1xuICBjb25zdCBzY3JpcHRUeXBlID0gc2NyaXB0VHlwZUZvckNoYWluKGNoYWluKTtcbiAgaWYgKHNjcmlwdFR5cGUgPT09ICdwMnRyJyB8fCBzY3JpcHRUeXBlID09PSAncDJ0ck11c2lnMicpIHtcbiAgICBjb25zdCBwYXltZW50ID1cbiAgICAgIHNjcmlwdFR5cGUgPT09ICdwMnRyJyA/IGNyZWF0ZVBheW1lbnRQMnRyKHdhbGxldEtleXMucHVibGljS2V5cykgOiBjcmVhdGVQYXltZW50UDJ0ck11c2lnMih3YWxsZXRLZXlzLnB1YmxpY0tleXMpO1xuICAgIGNvbnN0IGFsbExlYWZIYXNoZXMgPSBwYXltZW50LnJlZGVlbXMhLm1hcCgocikgPT4gdGFwcm9vdC5oYXNoVGFwTGVhZihyLm91dHB1dCEpKTtcblxuICAgIHBzYnQuYWRkT3V0cHV0KHtcbiAgICAgIHNjcmlwdDogcGF5bWVudC5vdXRwdXQhLFxuICAgICAgdmFsdWUsXG4gICAgICB0YXBUcmVlOiBwYXltZW50LnRhcFRyZWUsXG4gICAgICB0YXBJbnRlcm5hbEtleTogcGF5bWVudC5pbnRlcm5hbFB1YmtleSxcbiAgICAgIHRhcEJpcDMyRGVyaXZhdGlvbjogWzAsIDEsIDJdLm1hcCgoaWR4KSA9PiB7XG4gICAgICAgIGNvbnN0IHB1YmtleSA9IHRvWE9ubHlQdWJsaWNLZXkod2FsbGV0S2V5cy50cmlwbGVbaWR4XS5wdWJsaWNLZXkpO1xuICAgICAgICBjb25zdCBsZWFmSGFzaGVzOiBCdWZmZXJbXSA9IFtdO1xuICAgICAgICBwYXltZW50LnJlZGVlbXMhLmZvckVhY2goKHIsIGlkeCkgPT4ge1xuICAgICAgICAgIGlmIChyLnB1YmtleXMhLmZpbmQoKHBrKSA9PiBway5lcXVhbHMocHVia2V5KSkpIHtcbiAgICAgICAgICAgIGxlYWZIYXNoZXMucHVzaChhbGxMZWFmSGFzaGVzW2lkeF0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgbGVhZkhhc2hlcyxcbiAgICAgICAgICBwdWJrZXksXG4gICAgICAgICAgcGF0aDogd2FsbGV0S2V5cy5wYXRoc1tpZHhdLFxuICAgICAgICAgIG1hc3RlckZpbmdlcnByaW50OiByb290V2FsbGV0S2V5cy50cmlwbGVbaWR4XS5maW5nZXJwcmludCxcbiAgICAgICAgfTtcbiAgICAgIH0pLFxuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHsgc2NyaXB0UHViS2V5LCB3aXRuZXNzU2NyaXB0LCByZWRlZW1TY3JpcHQgfSA9IGNyZWF0ZU91dHB1dFNjcmlwdDJvZjMod2FsbGV0S2V5cy5wdWJsaWNLZXlzLCBzY3JpcHRUeXBlKTtcbiAgICBwc2J0LmFkZE91dHB1dCh7XG4gICAgICBzY3JpcHQ6IHNjcmlwdFB1YktleSxcbiAgICAgIHZhbHVlLFxuICAgICAgYmlwMzJEZXJpdmF0aW9uOiBbMCwgMSwgMl0ubWFwKChpZHgpID0+ICh7XG4gICAgICAgIHB1YmtleTogd2FsbGV0S2V5cy50cmlwbGVbaWR4XS5wdWJsaWNLZXksXG4gICAgICAgIHBhdGg6IHdhbGxldEtleXMucGF0aHNbaWR4XSxcbiAgICAgICAgbWFzdGVyRmluZ2VycHJpbnQ6IHJvb3RXYWxsZXRLZXlzLnRyaXBsZVtpZHhdLmZpbmdlcnByaW50LFxuICAgICAgfSkpLFxuICAgIH0pO1xuICAgIGNvbnN0IG91dHB1dEluZGV4ID0gcHNidC50eE91dHB1dHMubGVuZ3RoIC0gMTtcbiAgICBpZiAod2l0bmVzc1NjcmlwdCkge1xuICAgICAgcHNidC51cGRhdGVPdXRwdXQob3V0cHV0SW5kZXgsIHsgd2l0bmVzc1NjcmlwdCB9KTtcbiAgICB9XG4gICAgaWYgKHJlZGVlbVNjcmlwdCkge1xuICAgICAgcHNidC51cGRhdGVPdXRwdXQob3V0cHV0SW5kZXgsIHsgcmVkZWVtU2NyaXB0IH0pO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -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 | 10 | 11 | 20 | 21 | 30 | 31 | 40 | 41)[];
21
+ export declare const chainCodes: (0 | 30 | 1 | 10 | 11 | 20 | 21 | 31 | 40 | 41)[];
22
22
  export declare type ChainCode = (typeof chainCodes)[number];
23
23
  export declare function isChainCode(n: unknown): n is ChainCode;
24
24
  /**
@@ -27,6 +27,7 @@ export declare class ZcashPsbt extends UtxoPsbt<ZcashTransaction<bigint>> {
27
27
  setDefaultsForVersion(network: Network, version: number): void;
28
28
  signInput(inputIndex: number, keyPair: Signer, sighashTypes?: number[]): this;
29
29
  validateSignaturesOfInput(inputIndex: number, validator: ValidateSigFunction, pubkey?: Buffer): boolean;
30
+ private withUnsafeSignNonSegwitTrue;
30
31
  private setPropertyCheckSignatures;
31
32
  setConsensusBranchId(consensusBranchId: number): void;
32
33
  setVersionGroupId(versionGroupId: number): void;
@@ -1 +1 @@
1
- {"version":3,"file":"ZcashPsbt.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashPsbt.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAGL,gBAAgB,EACjB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAmB,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC1D,OAAO,EAAE,IAAI,IAAI,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAE1C,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAW7D,qBAAa,SAAU,SAAQ,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC/D,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC;IAIlG,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,QAAQ,GAAG,SAAS;IAO7D;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAqCrF;;;;;OAKG;IACH,QAAQ,IAAI,MAAM;IAelB,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,UAAO,GAAG,IAAI;IAOpD,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAsB9D,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI;IAI7E,yBAAyB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO;IAIvG,OAAO,CAAC,0BAA0B;IAQlC,oBAAoB,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI;IAKrD,iBAAiB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAK/C,eAAe,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;CAI5C"}
1
+ {"version":3,"file":"ZcashPsbt.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashPsbt.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAGL,gBAAgB,EACjB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAmB,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC1D,OAAO,EAAE,IAAI,IAAI,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAE1C,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAW7D,qBAAa,SAAU,SAAQ,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC/D,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,gBAAgB,CAAC,MAAM,CAAC;IAIlG,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,QAAQ,GAAG,SAAS;IAO7D;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAqCrF;;;;;OAKG;IACH,QAAQ,IAAI,MAAM;IAelB,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,UAAO,GAAG,IAAI;IAOpD,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAsB9D,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,MAAM,EAAE,GAAG,IAAI;IAI7E,yBAAyB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO;IAIvG,OAAO,CAAC,2BAA2B;IASnC,OAAO,CAAC,0BAA0B;IAQlC,oBAAoB,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI;IAKrD,iBAAiB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAK/C,eAAe,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;CAI5C"}