@bitgo-beta/utxo-lib 8.0.3-beta.9 → 8.0.3-beta.900

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (217) hide show
  1. package/README.md +19 -16
  2. package/dist/src/address.d.ts +0 -1
  3. package/dist/src/address.d.ts.map +1 -1
  4. package/dist/src/address.js +10 -10
  5. package/dist/src/addressFormat.d.ts +1 -2
  6. package/dist/src/addressFormat.d.ts.map +1 -1
  7. package/dist/src/addressFormat.js +21 -26
  8. package/dist/src/bitgo/Musig2.d.ts +5 -11
  9. package/dist/src/bitgo/Musig2.d.ts.map +1 -1
  10. package/dist/src/bitgo/Musig2.js +63 -88
  11. package/dist/src/bitgo/PsbtUtil.d.ts +70 -0
  12. package/dist/src/bitgo/PsbtUtil.d.ts.map +1 -0
  13. package/dist/src/bitgo/PsbtUtil.js +132 -0
  14. package/dist/src/bitgo/Unspent.d.ts +2 -3
  15. package/dist/src/bitgo/Unspent.d.ts.map +1 -1
  16. package/dist/src/bitgo/Unspent.js +14 -15
  17. package/dist/src/bitgo/UtxoPsbt.d.ts +26 -40
  18. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -1
  19. package/dist/src/bitgo/UtxoPsbt.js +221 -206
  20. package/dist/src/bitgo/UtxoTransaction.d.ts +0 -1
  21. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -1
  22. package/dist/src/bitgo/UtxoTransaction.js +12 -12
  23. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +0 -1
  24. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -1
  25. package/dist/src/bitgo/UtxoTransactionBuilder.js +1 -1
  26. package/dist/src/bitgo/bitcoincash/address.d.ts +0 -1
  27. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -1
  28. package/dist/src/bitgo/bitcoincash/address.js +11 -12
  29. package/dist/src/bitgo/bitcoincash/index.js +6 -2
  30. package/dist/src/bitgo/dash/DashPsbt.d.ts +1 -1
  31. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -1
  32. package/dist/src/bitgo/dash/DashPsbt.js +4 -1
  33. package/dist/src/bitgo/dash/DashTransaction.d.ts +0 -1
  34. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -1
  35. package/dist/src/bitgo/dash/DashTransaction.js +3 -3
  36. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +0 -1
  37. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -1
  38. package/dist/src/bitgo/dash/DashTransactionBuilder.js +1 -1
  39. package/dist/src/bitgo/dash/index.js +6 -2
  40. package/dist/src/bitgo/index.d.ts +10 -0
  41. package/dist/src/bitgo/index.d.ts.map +1 -1
  42. package/dist/src/bitgo/index.js +10 -3
  43. package/dist/src/bitgo/keyutil.d.ts +9 -1
  44. package/dist/src/bitgo/keyutil.d.ts.map +1 -1
  45. package/dist/src/bitgo/keyutil.js +25 -4
  46. package/dist/src/bitgo/legacysafe/index.d.ts +14 -0
  47. package/dist/src/bitgo/legacysafe/index.d.ts.map +1 -0
  48. package/dist/src/bitgo/legacysafe/index.js +60 -0
  49. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts +1 -1
  50. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts.map +1 -1
  51. package/dist/src/bitgo/litecoin/LitecoinPsbt.js +4 -1
  52. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts +1 -2
  53. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts.map +1 -1
  54. package/dist/src/bitgo/litecoin/LitecoinTransaction.js +2 -2
  55. package/dist/src/bitgo/litecoin/index.js +6 -2
  56. package/dist/src/bitgo/nonStandardHalfSigned.js +2 -3
  57. package/dist/src/bitgo/outputScripts.d.ts +8 -8
  58. package/dist/src/bitgo/outputScripts.d.ts.map +1 -1
  59. package/dist/src/bitgo/outputScripts.js +56 -39
  60. package/dist/src/bitgo/parseInput.d.ts +7 -8
  61. package/dist/src/bitgo/parseInput.d.ts.map +1 -1
  62. package/dist/src/bitgo/parseInput.js +15 -16
  63. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +0 -1
  64. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -1
  65. package/dist/src/bitgo/psbt/fromHalfSigned.js +7 -8
  66. package/dist/src/bitgo/psbt/scriptTypes.d.ts +0 -1
  67. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -1
  68. package/dist/src/bitgo/psbt/scriptTypes.js +7 -8
  69. package/dist/src/bitgo/signature.d.ts +4 -5
  70. package/dist/src/bitgo/signature.d.ts.map +1 -1
  71. package/dist/src/bitgo/signature.js +32 -18
  72. package/dist/src/bitgo/tnumber.js +2 -3
  73. package/dist/src/bitgo/transaction.d.ts +31 -4
  74. package/dist/src/bitgo/transaction.d.ts.map +1 -1
  75. package/dist/src/bitgo/transaction.js +55 -27
  76. package/dist/src/bitgo/transactionAmounts.d.ts +9 -0
  77. package/dist/src/bitgo/transactionAmounts.d.ts.map +1 -0
  78. package/dist/src/bitgo/transactionAmounts.js +32 -0
  79. package/dist/src/bitgo/types.d.ts +8 -2
  80. package/dist/src/bitgo/types.d.ts.map +1 -1
  81. package/dist/src/bitgo/types.js +12 -4
  82. package/dist/src/bitgo/wallet/Psbt.d.ts +90 -27
  83. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -1
  84. package/dist/src/bitgo/wallet/Psbt.js +246 -108
  85. package/dist/src/bitgo/wallet/ScriptId.d.ts +14 -0
  86. package/dist/src/bitgo/wallet/ScriptId.d.ts.map +1 -0
  87. package/dist/src/bitgo/wallet/ScriptId.js +28 -0
  88. package/dist/src/bitgo/wallet/Unspent.d.ts +43 -10
  89. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -1
  90. package/dist/src/bitgo/wallet/Unspent.js +174 -81
  91. package/dist/src/bitgo/wallet/WalletKeys.d.ts +1 -2
  92. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -1
  93. package/dist/src/bitgo/wallet/WalletKeys.js +3 -3
  94. package/dist/src/bitgo/wallet/WalletOutput.d.ts +70 -2
  95. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -1
  96. package/dist/src/bitgo/wallet/WalletOutput.js +179 -43
  97. package/dist/src/bitgo/wallet/WalletScripts.js +4 -5
  98. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +7 -7
  99. package/dist/src/bitgo/wallet/chains.d.ts +2 -2
  100. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -1
  101. package/dist/src/bitgo/wallet/chains.js +10 -10
  102. package/dist/src/bitgo/wallet/index.d.ts +3 -0
  103. package/dist/src/bitgo/wallet/index.d.ts.map +1 -1
  104. package/dist/src/bitgo/wallet/index.js +9 -2
  105. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts +50 -0
  106. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts.map +1 -0
  107. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.js +85 -0
  108. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts +32 -0
  109. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts.map +1 -0
  110. package/dist/src/bitgo/wallet/psbt/RootNodes.js +123 -0
  111. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +1 -2
  112. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -1
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.js +15 -15
  114. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +1 -2
  115. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -1
  116. package/dist/src/bitgo/zcash/ZcashPsbt.js +15 -19
  117. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +3 -2
  118. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -1
  119. package/dist/src/bitgo/zcash/ZcashTransaction.js +31 -21
  120. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +0 -1
  121. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -1
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +6 -4
  123. package/dist/src/bitgo/zcash/address.d.ts +0 -1
  124. package/dist/src/bitgo/zcash/address.d.ts.map +1 -1
  125. package/dist/src/bitgo/zcash/address.js +7 -8
  126. package/dist/src/bitgo/zcash/hashZip0244.d.ts +1 -2
  127. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -1
  128. package/dist/src/bitgo/zcash/hashZip0244.js +9 -10
  129. package/dist/src/bitgo/zcash/index.js +6 -2
  130. package/dist/src/classify.d.ts +0 -1
  131. package/dist/src/classify.d.ts.map +1 -1
  132. package/dist/src/classify.js +5 -5
  133. package/dist/src/index.js +6 -2
  134. package/dist/src/networks.d.ts +2 -2
  135. package/dist/src/networks.d.ts.map +1 -1
  136. package/dist/src/networks.js +67 -21
  137. package/dist/src/noble_ecc.d.ts +7 -7
  138. package/dist/src/noble_ecc.d.ts.map +1 -1
  139. package/dist/src/noble_ecc.js +5 -5
  140. package/dist/src/payments/p2tr.js +13 -18
  141. package/dist/src/payments/p2tr_ns.js +3 -5
  142. package/dist/src/taproot.d.ts +1 -2
  143. package/dist/src/taproot.d.ts.map +1 -1
  144. package/dist/src/taproot.js +21 -22
  145. package/dist/src/templates/multisig/input.d.ts +0 -1
  146. package/dist/src/templates/multisig/input.d.ts.map +1 -1
  147. package/dist/src/templates/multisig/input.js +2 -3
  148. package/dist/src/templates/multisig/output.d.ts +0 -1
  149. package/dist/src/templates/multisig/output.d.ts.map +1 -1
  150. package/dist/src/templates/multisig/output.js +2 -3
  151. package/dist/src/templates/nulldata.d.ts +0 -1
  152. package/dist/src/templates/nulldata.d.ts.map +1 -1
  153. package/dist/src/templates/nulldata.js +3 -3
  154. package/dist/src/templates/pubkey/input.d.ts +0 -1
  155. package/dist/src/templates/pubkey/input.d.ts.map +1 -1
  156. package/dist/src/templates/pubkey/input.js +2 -3
  157. package/dist/src/templates/pubkey/output.d.ts +0 -1
  158. package/dist/src/templates/pubkey/output.d.ts.map +1 -1
  159. package/dist/src/templates/pubkey/output.js +2 -3
  160. package/dist/src/templates/pubkeyhash/input.d.ts +0 -1
  161. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -1
  162. package/dist/src/templates/pubkeyhash/input.js +2 -3
  163. package/dist/src/templates/pubkeyhash/output.d.ts +0 -1
  164. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -1
  165. package/dist/src/templates/pubkeyhash/output.js +2 -3
  166. package/dist/src/templates/scripthash/input.d.ts +0 -1
  167. package/dist/src/templates/scripthash/input.d.ts.map +1 -1
  168. package/dist/src/templates/scripthash/input.js +2 -3
  169. package/dist/src/templates/scripthash/output.d.ts +0 -1
  170. package/dist/src/templates/scripthash/output.d.ts.map +1 -1
  171. package/dist/src/templates/scripthash/output.js +2 -3
  172. package/dist/src/templates/taproot/input.d.ts +0 -1
  173. package/dist/src/templates/taproot/input.d.ts.map +1 -1
  174. package/dist/src/templates/taproot/input.js +2 -3
  175. package/dist/src/templates/taproot/output.d.ts +0 -1
  176. package/dist/src/templates/taproot/output.d.ts.map +1 -1
  177. package/dist/src/templates/taproot/output.js +2 -3
  178. package/dist/src/templates/taprootnofn/input.d.ts +0 -1
  179. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -1
  180. package/dist/src/templates/taprootnofn/input.js +2 -3
  181. package/dist/src/templates/taprootnofn/output.d.ts +0 -1
  182. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -1
  183. package/dist/src/templates/taprootnofn/output.js +2 -3
  184. package/dist/src/templates/witnesscommitment/output.d.ts +0 -1
  185. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -1
  186. package/dist/src/templates/witnesscommitment/output.js +4 -5
  187. package/dist/src/templates/witnesspubkeyhash/input.d.ts +0 -1
  188. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -1
  189. package/dist/src/templates/witnesspubkeyhash/input.js +2 -3
  190. package/dist/src/templates/witnesspubkeyhash/output.d.ts +0 -1
  191. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -1
  192. package/dist/src/templates/witnesspubkeyhash/output.js +2 -3
  193. package/dist/src/templates/witnessscripthash/input.d.ts +0 -1
  194. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -1
  195. package/dist/src/templates/witnessscripthash/input.js +2 -3
  196. package/dist/src/templates/witnessscripthash/output.d.ts +0 -1
  197. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -1
  198. package/dist/src/templates/witnessscripthash/output.js +2 -3
  199. package/dist/src/testutil/index.d.ts +1 -0
  200. package/dist/src/testutil/index.d.ts.map +1 -1
  201. package/dist/src/testutil/index.js +7 -2
  202. package/dist/src/testutil/keys.d.ts +6 -3
  203. package/dist/src/testutil/keys.d.ts.map +1 -1
  204. package/dist/src/testutil/keys.js +24 -10
  205. package/dist/src/testutil/mock.d.ts +2 -3
  206. package/dist/src/testutil/mock.d.ts.map +1 -1
  207. package/dist/src/testutil/mock.js +31 -23
  208. package/dist/src/testutil/psbt.d.ts +40 -16
  209. package/dist/src/testutil/psbt.d.ts.map +1 -1
  210. package/dist/src/testutil/psbt.js +54 -39
  211. package/dist/src/testutil/transaction.d.ts +18 -7
  212. package/dist/src/testutil/transaction.d.ts.map +1 -1
  213. package/dist/src/testutil/transaction.js +33 -26
  214. package/dist/src/transaction_builder.d.ts +0 -1
  215. package/dist/src/transaction_builder.d.ts.map +1 -1
  216. package/dist/src/transaction_builder.js +13 -18
  217. package/package.json +10 -12
@@ -1,24 +1,42 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isPsbt = exports.getSignatureCount = exports.parsePsbtInput = exports.signWalletPsbt = exports.toWalletPsbt = void 0;
3
+ exports.toWalletPsbt = toWalletPsbt;
4
+ exports.signWalletPsbt = signWalletPsbt;
5
+ exports.getPsbtInputScriptType = getPsbtInputScriptType;
6
+ exports.parsePsbtInput = parsePsbtInput;
7
+ exports.toScriptType2Of3s = toScriptType2Of3s;
8
+ exports.getStrictSignatureCount = getStrictSignatureCount;
9
+ exports.getStrictSignatureCounts = getStrictSignatureCounts;
10
+ exports.isPsbtInputArray = isPsbtInputArray;
11
+ exports.isTxInputArray = isTxInputArray;
12
+ exports.isTransactionWithKeyPathSpendInput = isTransactionWithKeyPathSpendInput;
13
+ exports.addXpubsToPsbt = addXpubsToPsbt;
14
+ exports.getSignatureValidationArrayPsbt = getSignatureValidationArrayPsbt;
15
+ exports.extractP2msOnlyHalfSignedTx = extractP2msOnlyHalfSignedTx;
16
+ exports.clonePsbtWithoutNonWitnessUtxo = clonePsbtWithoutNonWitnessUtxo;
17
+ exports.isPsbtLite = isPsbtLite;
18
+ exports.deleteWitnessUtxoForNonSegwitInputs = deleteWitnessUtxoForNonSegwitInputs;
4
19
  const assert = require("assert");
20
+ const utils_1 = require("bip174/src/lib/utils");
21
+ const bs58check = require("bs58check");
5
22
  const UtxoPsbt_1 = require("../UtxoPsbt");
6
23
  const UtxoTransaction_1 = require("../UtxoTransaction");
7
24
  const outputScripts_1 = require("../outputScripts");
25
+ const WalletKeys_1 = require("./WalletKeys");
8
26
  const Unspent_1 = require("../Unspent");
9
27
  const transaction_1 = require("../transaction");
10
28
  const Unspent_2 = require("./Unspent");
11
- const utils_1 = require("bip174/src/lib/utils");
12
29
  const parseInput_1 = require("../parseInput");
13
30
  const Musig2_1 = require("../Musig2");
14
31
  const types_1 = require("../types");
15
32
  const taproot_1 = require("../../taproot");
16
33
  const bitcoinjs_lib_1 = require("bitcoinjs-lib");
17
34
  const index_1 = require("../../index");
35
+ const PsbtUtil_1 = require("../PsbtUtil");
18
36
  function getTaprootSigners(script, walletKeys) {
19
- const parsedPublicKeys = parseInput_1.parsePubScript2Of3(script, 'taprootScriptPathSpend').publicKeys;
37
+ const parsedPublicKeys = (0, parseInput_1.parsePubScript2Of3)(script, 'taprootScriptPathSpend').publicKeys;
20
38
  const walletSigners = parsedPublicKeys.map((publicKey) => {
21
- const index = walletKeys.publicKeys.findIndex((walletPublicKey) => outputScripts_1.toXOnlyPublicKey(walletPublicKey).equals(publicKey));
39
+ const index = walletKeys.publicKeys.findIndex((walletPublicKey) => (0, outputScripts_1.toXOnlyPublicKey)(walletPublicKey).equals(publicKey));
22
40
  if (index >= 0) {
23
41
  return { walletKey: walletKeys.triple[index], rootKey: walletKeys.parent.triple[index] };
24
42
  }
@@ -27,14 +45,14 @@ function getTaprootSigners(script, walletKeys) {
27
45
  return [walletSigners[0], walletSigners[1]];
28
46
  }
29
47
  function updatePsbtInput(psbt, inputIndex, unspent, rootWalletKeys) {
30
- const signatureCount = psbt.getSignatureCount(inputIndex);
31
- const scriptType = outputScripts_1.scriptTypeForChain(unspent.chain);
48
+ const input = (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
49
+ const signatureCount = (0, PsbtUtil_1.getPsbtInputSignatureCount)(input);
50
+ const scriptType = (0, outputScripts_1.scriptTypeForChain)(unspent.chain);
32
51
  if (signatureCount === 0 && scriptType === 'p2tr') {
33
52
  return;
34
53
  }
35
54
  const walletKeys = rootWalletKeys.deriveForChainAndIndex(unspent.chain, unspent.index);
36
55
  if (scriptType === 'p2tr') {
37
- const input = psbt.data.inputs[inputIndex];
38
56
  if (!Array.isArray(input.tapLeafScript) || input.tapLeafScript.length === 0) {
39
57
  throw new Error('Invalid PSBT state. Missing required fields.');
40
58
  }
@@ -42,7 +60,7 @@ function updatePsbtInput(psbt, inputIndex, unspent, rootWalletKeys) {
42
60
  throw new Error('Bitgo only supports a single tap leaf script per input');
43
61
  }
44
62
  const [signer, cosigner] = getTaprootSigners(input.tapLeafScript[0].script, walletKeys);
45
- const leafHash = outputScripts_1.getLeafHash({
63
+ const leafHash = (0, outputScripts_1.getLeafHash)({
46
64
  publicKeys: walletKeys.publicKeys,
47
65
  signer: signer.walletKey.publicKey,
48
66
  cosigner: cosigner.walletKey.publicKey,
@@ -50,7 +68,7 @@ function updatePsbtInput(psbt, inputIndex, unspent, rootWalletKeys) {
50
68
  psbt.updateInput(inputIndex, {
51
69
  tapBip32Derivation: [signer, cosigner].map((walletSigner) => ({
52
70
  leafHashes: [leafHash],
53
- pubkey: outputScripts_1.toXOnlyPublicKey(walletSigner.walletKey.publicKey),
71
+ pubkey: (0, outputScripts_1.toXOnlyPublicKey)(walletSigner.walletKey.publicKey),
54
72
  path: rootWalletKeys.getDerivationPath(walletSigner.rootKey, unspent.chain, unspent.index),
55
73
  masterFingerprint: walletSigner.rootKey.fingerprint,
56
74
  })),
@@ -58,7 +76,7 @@ function updatePsbtInput(psbt, inputIndex, unspent, rootWalletKeys) {
58
76
  }
59
77
  else {
60
78
  if (signatureCount === 0) {
61
- const { witnessScript, redeemScript } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
79
+ const { witnessScript, redeemScript } = (0, outputScripts_1.createOutputScript2of3)(walletKeys.publicKeys, scriptType);
62
80
  if (witnessScript && psbt.data.inputs[inputIndex].witnessScript === undefined) {
63
81
  psbt.updateInput(inputIndex, { witnessScript });
64
82
  }
@@ -84,18 +102,17 @@ function updatePsbtInput(psbt, inputIndex, unspent, rootWalletKeys) {
84
102
  */
85
103
  function toWalletPsbt(tx, unspents, rootWalletKeys) {
86
104
  const prevOutputs = unspents.map((u) => {
87
- assert.notStrictEqual(outputScripts_1.scriptTypeForChain(u.chain), 'p2trMusig2');
88
- return Unspent_1.toPrevOutputWithPrevTx(u, tx.network);
105
+ assert.notStrictEqual((0, outputScripts_1.scriptTypeForChain)(u.chain), 'p2trMusig2');
106
+ return (0, Unspent_1.toPrevOutputWithPrevTx)(u, tx.network);
89
107
  });
90
- const psbt = transaction_1.createPsbtFromTransaction(tx, prevOutputs);
108
+ const psbt = (0, transaction_1.createPsbtFromTransaction)(tx, prevOutputs);
91
109
  unspents.forEach((u, i) => {
92
- if (Unspent_2.isWalletUnspent(u) && u.index !== undefined) {
110
+ if ((0, Unspent_2.isWalletUnspent)(u) && u.index !== undefined) {
93
111
  updatePsbtInput(psbt, i, u, rootWalletKeys);
94
112
  }
95
113
  });
96
114
  return psbt;
97
115
  }
98
- exports.toWalletPsbt = toWalletPsbt;
99
116
  /**
100
117
  * @param psbt
101
118
  * @param inputIndex
@@ -104,7 +121,7 @@ exports.toWalletPsbt = toWalletPsbt;
104
121
  * @return signed PSBT with signer's key for unspent
105
122
  */
106
123
  function signWalletPsbt(psbt, inputIndex, signer, unspent) {
107
- const scriptType = outputScripts_1.scriptTypeForChain(unspent.chain);
124
+ const scriptType = (0, outputScripts_1.scriptTypeForChain)(unspent.chain);
108
125
  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {
109
126
  psbt.signTaprootInputHD(inputIndex, signer);
110
127
  }
@@ -112,12 +129,14 @@ function signWalletPsbt(psbt, inputIndex, signer, unspent) {
112
129
  psbt.signInputHD(inputIndex, signer);
113
130
  }
114
131
  }
115
- exports.signWalletPsbt = signWalletPsbt;
116
- function getScriptType(input) {
132
+ /**
133
+ * @returns script type of the input
134
+ */
135
+ function getPsbtInputScriptType(input) {
117
136
  const isP2pk = (script) => {
118
137
  try {
119
138
  const chunks = bitcoinjs_lib_1.script.decompile(script);
120
- return ((chunks === null || chunks === void 0 ? void 0 : chunks.length) === 2 &&
139
+ return (chunks?.length === 2 &&
121
140
  Buffer.isBuffer(chunks[0]) &&
122
141
  bitcoinjs_lib_1.script.isCanonicalPubKey(chunks[0]) &&
123
142
  chunks[1] === index_1.opcodes.OP_CHECKSIG);
@@ -151,39 +170,40 @@ function getScriptType(input) {
151
170
  }
152
171
  scriptType = 'taprootKeyPathSpend';
153
172
  }
154
- return scriptType;
173
+ if (scriptType) {
174
+ return scriptType;
175
+ }
176
+ throw new Error('could not parse input');
155
177
  }
156
- function parseTaprootKeyPathSignatures(psbt, inputIndex) {
157
- const partialSigs = Musig2_1.parsePsbtMusig2PartialSigs(psbt, inputIndex);
178
+ function parseTaprootKeyPathSignatures(input) {
179
+ const partialSigs = (0, Musig2_1.parsePsbtMusig2PartialSigs)(input);
158
180
  if (!partialSigs) {
159
181
  return { signatures: undefined, participantPublicKeys: undefined };
160
182
  }
161
183
  const signatures = partialSigs.map((pSig) => pSig.partialSig);
162
184
  const participantPublicKeys = partialSigs.map((pSig) => pSig.participantPubKey);
163
- return types_1.isTuple(signatures) && types_1.isTuple(participantPublicKeys)
185
+ return (0, types_1.isTuple)(signatures) && (0, types_1.isTuple)(participantPublicKeys)
164
186
  ? { signatures, participantPublicKeys }
165
187
  : { signatures: [signatures[0]], participantPublicKeys: [participantPublicKeys[0]] };
166
188
  }
167
189
  function parsePartialOrTapScriptSignatures(sig) {
168
- if (!(sig === null || sig === void 0 ? void 0 : sig.length)) {
190
+ if (!sig?.length) {
169
191
  return { signatures: undefined };
170
192
  }
171
193
  if (sig.length > 2) {
172
194
  throw new Error('unexpected signature count');
173
195
  }
174
196
  const signatures = sig.map((tSig) => tSig.signature);
175
- return types_1.isTuple(signatures) ? { signatures } : { signatures: [signatures[0]] };
197
+ return (0, types_1.isTuple)(signatures) ? { signatures } : { signatures: [signatures[0]] };
176
198
  }
177
- function parseSignatures(psbt, inputIndex, scriptType) {
178
- const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
199
+ function parseSignatures(input, scriptType) {
179
200
  return scriptType === 'taprootKeyPathSpend'
180
- ? parseTaprootKeyPathSignatures(psbt, inputIndex)
201
+ ? parseTaprootKeyPathSignatures(input)
181
202
  : scriptType === 'taprootScriptPathSpend'
182
203
  ? parsePartialOrTapScriptSignatures(input.tapScriptSig)
183
204
  : parsePartialOrTapScriptSignatures(input.partialSig);
184
205
  }
185
206
  function parseScript(input, scriptType) {
186
- var _a;
187
207
  let pubScript;
188
208
  if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {
189
209
  pubScript = input.redeemScript;
@@ -195,26 +215,43 @@ function parseScript(input, scriptType) {
195
215
  pubScript = input.tapLeafScript ? input.tapLeafScript[0].script : undefined;
196
216
  }
197
217
  else if (scriptType === 'taprootKeyPathSpend') {
198
- if ((_a = input.witnessUtxo) === null || _a === void 0 ? void 0 : _a.script) {
218
+ if (input.witnessUtxo?.script) {
199
219
  pubScript = input.witnessUtxo.script;
200
220
  }
201
221
  else if (input.tapInternalKey && input.tapMerkleRoot) {
202
- pubScript = taproot_1.createTaprootOutputScript({ internalPubKey: input.tapInternalKey, taptreeRoot: input.tapMerkleRoot });
222
+ pubScript = (0, taproot_1.createTaprootOutputScript)({ internalPubKey: input.tapInternalKey, taptreeRoot: input.tapMerkleRoot });
203
223
  }
204
224
  }
205
225
  if (!pubScript) {
206
226
  throw new Error(`Invalid PSBT state for ${scriptType}. Missing required fields.`);
207
227
  }
208
- return parseInput_1.parsePubScript(pubScript, scriptType);
228
+ return (0, parseInput_1.parsePubScript)(pubScript, scriptType);
209
229
  }
210
- function parseInputMetadata(psbt, inputIndex, scriptType) {
211
- const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
230
+ /**
231
+ * @return psbt metadata are parsed as per below conditions.
232
+ * redeemScript/witnessScript/tapLeafScript matches BitGo.
233
+ * signature and public key count matches BitGo.
234
+ * P2SH-P2PK => scriptType, redeemScript, public key, signature.
235
+ * P2SH => scriptType, redeemScript, public keys, signatures.
236
+ * PW2SH => scriptType, witnessScript, public keys, signatures.
237
+ * P2SH-PW2SH => scriptType, redeemScript, witnessScript, public keys, signatures.
238
+ * P2TR and P2TR MUSIG2 script path => scriptType (taprootScriptPathSpend), pubScript (leaf script), controlBlock,
239
+ * scriptPathLevel, leafVersion, public keys, signatures.
240
+ * P2TR MUSIG2 kep path => scriptType (taprootKeyPathSpend), pubScript (scriptPubKey), participant pub keys (signer),
241
+ * public key (tapOutputkey), signatures (partial signer sigs).
242
+ */
243
+ function parsePsbtInput(input) {
244
+ if ((0, PsbtUtil_1.isPsbtInputFinalized)(input)) {
245
+ throw new Error('Finalized PSBT parsing is not supported');
246
+ }
247
+ const scriptType = getPsbtInputScriptType(input);
212
248
  const parsedPubScript = parseScript(input, scriptType);
213
- const signatures = parseSignatures(psbt, inputIndex, scriptType);
249
+ const signatures = parseSignatures(input, scriptType);
214
250
  if (parsedPubScript.scriptType === 'taprootKeyPathSpend' && 'participantPublicKeys' in signatures) {
215
251
  return {
216
252
  ...parsedPubScript,
217
253
  ...signatures,
254
+ scriptType: parsedPubScript.scriptType,
218
255
  };
219
256
  }
220
257
  if (parsedPubScript.scriptType === 'taprootScriptPathSpend') {
@@ -222,14 +259,15 @@ function parseInputMetadata(psbt, inputIndex, scriptType) {
222
259
  throw new Error('Invalid PSBT state for taprootScriptPathSpend. Missing required fields.');
223
260
  }
224
261
  const controlBlock = input.tapLeafScript[0].controlBlock;
225
- if (!parseInput_1.isValidControlBock(controlBlock)) {
262
+ if (!(0, parseInput_1.isValidControlBock)(controlBlock)) {
226
263
  throw new Error('Invalid PSBT taprootScriptPathSpend controlBlock.');
227
264
  }
228
- const scriptPathLevel = parseInput_1.calculateScriptPathLevel(controlBlock);
229
- const leafVersion = parseInput_1.getLeafVersion(controlBlock);
265
+ const scriptPathLevel = (0, parseInput_1.calculateScriptPathLevel)(controlBlock);
266
+ const leafVersion = (0, parseInput_1.getLeafVersion)(controlBlock);
230
267
  return {
231
268
  ...parsedPubScript,
232
269
  ...signatures,
270
+ scriptType: parsedPubScript.scriptType,
233
271
  controlBlock,
234
272
  scriptPathLevel,
235
273
  leafVersion,
@@ -246,7 +284,7 @@ function parseInputMetadata(psbt, inputIndex, scriptType) {
246
284
  ...signatures,
247
285
  };
248
286
  }
249
- if (parsedPubScript.scriptType === 'p2shP2pk' && (!signatures.signatures || !types_1.isTuple(signatures.signatures))) {
287
+ if (parsedPubScript.scriptType === 'p2shP2pk' && (!signatures.signatures || !(0, types_1.isTuple)(signatures.signatures))) {
250
288
  return {
251
289
  ...parsedPubScript,
252
290
  signatures: signatures.signatures,
@@ -255,88 +293,188 @@ function parseInputMetadata(psbt, inputIndex, scriptType) {
255
293
  throw new Error('invalid pub script');
256
294
  }
257
295
  /**
258
- * @return psbt metadata are parsed as per below conditions.
259
- * redeemScript/witnessScript/tapLeafScript matches BitGo.
260
- * signature and public key count matches BitGo.
261
- * P2SH-P2PK => scriptType, redeemScript, public key, signature.
262
- * P2SH => scriptType, redeemScript, public keys, signatures.
263
- * PW2SH => scriptType, witnessScript, public keys, signatures.
264
- * P2SH-PW2SH => scriptType, redeemScript, witnessScript, public keys, signatures.
265
- * P2TR and P2TR MUSIG2 script path => scriptType (taprootScriptPathSpend), pubScript (leaf script), controlBlock,
266
- * scriptPathLevel, leafVersion, public keys, signatures.
267
- * P2TR MUSIG2 kep path => scriptType (taprootKeyPathSpend), pubScript (scriptPubKey), participant pub keys (signer),
268
- * public key (tapOutputkey), signatures (partial signer sigs).
269
- * Any unsigned PSBT and without required metadata is returned with undefined.
296
+ * Converts a parsed script type into an array of script types.
297
+ * @param parsedScriptType - The parsed script type.
298
+ * @returns An array of ScriptType2Of3 values corresponding to the parsed script type.
270
299
  */
271
- function parsePsbtInput(psbt, inputIndex) {
272
- const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
273
- if (psbt.isInputFinalized(inputIndex)) {
274
- throw new Error('Finalized PSBT parsing is not supported');
275
- }
276
- const scriptType = getScriptType(input);
277
- if (!scriptType) {
278
- if (psbt.getSignatureCount(inputIndex) > 0) {
279
- throw new Error('Invalid PSBT state. Signatures found without scripts.');
280
- }
281
- return undefined;
282
- }
283
- return parseInputMetadata(psbt, inputIndex, scriptType);
300
+ function toScriptType2Of3s(parsedScriptType) {
301
+ return parsedScriptType === 'taprootScriptPathSpend'
302
+ ? ['p2trMusig2', 'p2tr']
303
+ : parsedScriptType === 'taprootKeyPathSpend'
304
+ ? ['p2trMusig2']
305
+ : [parsedScriptType];
284
306
  }
285
- exports.parsePsbtInput = parsePsbtInput;
286
- function parseSignatureCount(signatures) {
287
- const count = signatures ? signatures.filter((s) => !parseInput_1.isPlaceholderSignature(s)).length : 0;
288
- if (count === 0 || count === 1 || count === 2) {
289
- return count;
290
- }
291
- throw new Error('invalid signature count');
292
- }
293
- function getInputSignatureCount(param) {
294
- var _a, _b;
295
- if ('psbt' in param) {
296
- const parsedInput = parsePsbtInput(param.psbt, param.inputIndex);
297
- assert(parsedInput, 'invalid psbt input');
298
- return parseSignatureCount(parsedInput.signatures);
299
- }
300
- else {
301
- if (((_a = param.script) === null || _a === void 0 ? void 0 : _a.length) || ((_b = param.witness) === null || _b === void 0 ? void 0 : _b.length)) {
302
- const parsedInput = parseInput_1.parseSignatureScript(param);
303
- return parsedInput.scriptType === 'taprootKeyPathSpend' ? 2 : parseSignatureCount(parsedInput.signatures);
307
+ /**
308
+ * @returns strictly parse the input and get signature count.
309
+ * unsigned(0), half-signed(1) or fully-signed(2)
310
+ */
311
+ function getStrictSignatureCount(input) {
312
+ const calculateSignatureCount = (signatures) => {
313
+ const count = signatures ? signatures.filter((s) => !(0, parseInput_1.isPlaceholderSignature)(s)).length : 0;
314
+ if (count === 0 || count === 1 || count === 2) {
315
+ return count;
316
+ }
317
+ throw new Error('invalid signature count');
318
+ };
319
+ if ('hash' in input) {
320
+ if (input.script?.length || input.witness?.length) {
321
+ const parsedInput = (0, parseInput_1.parseSignatureScript)(input);
322
+ return parsedInput.scriptType === 'taprootKeyPathSpend' ? 2 : calculateSignatureCount(parsedInput.signatures);
304
323
  }
305
324
  return 0;
306
325
  }
326
+ else {
327
+ return calculateSignatureCount(parsePsbtInput(input).signatures);
328
+ }
307
329
  }
308
330
  /**
309
- * @returns maximum number of signatures across all inputs - 0, 1 and 2.
310
- * It can be used to check given psbt/transaction/array of TxInputs is unsigned(0), half-signed(1) or fully-signed(2).
331
+ * @returns strictly parse input and get signature count for all inputs.
332
+ * 0=unsigned, 1=half-signed or 2=fully-signed
311
333
  */
312
- function getSignatureCount(tx, inputIndex) {
313
- const constructParam = (tx, inputIndex) => {
314
- return tx instanceof UtxoPsbt_1.UtxoPsbt
315
- ? { psbt: tx, inputIndex }
316
- : (tx instanceof UtxoTransaction_1.UtxoTransaction ? tx.ins : tx)[inputIndex];
317
- };
334
+ function getStrictSignatureCounts(tx) {
318
335
  const inputs = tx instanceof UtxoPsbt_1.UtxoPsbt ? tx.data.inputs : tx instanceof UtxoTransaction_1.UtxoTransaction ? tx.ins : tx;
319
- assert(inputIndex === undefined || (inputIndex >= 0 && inputIndex < inputs.length), 'invalid inputIndex range');
320
- const indices = inputIndex === undefined ? inputs.map((_, index) => index) : [inputIndex];
321
- return indices
322
- .map((index, _) => getInputSignatureCount(constructParam(tx, index)))
323
- .reduce((prev, curr) => (curr > prev ? curr : prev), 0);
336
+ return inputs.map((input, _) => getStrictSignatureCount(input));
324
337
  }
325
- exports.getSignatureCount = getSignatureCount;
326
338
  /**
327
- * @return true iff data starts with magic PSBT byte sequence
328
- * @param data byte array or hex string
339
+ * @return true iff inputs array is of PsbtInputType type
329
340
  * */
330
- function isPsbt(data) {
331
- // https://github.com/bitcoin/bips/blob/master/bip-0174.mediawiki#specification
332
- // 0x70736274 - ASCII for 'psbt'. 0xff - separator
333
- if (typeof data === 'string') {
334
- if (data.length < 10) {
341
+ function isPsbtInputArray(inputs) {
342
+ return !isTxInputArray(inputs);
343
+ }
344
+ /**
345
+ * @return true iff inputs array is of TxInput type
346
+ * */
347
+ function isTxInputArray(inputs) {
348
+ assert(!!inputs.length, 'empty inputs array');
349
+ return 'hash' in inputs[0];
350
+ }
351
+ /**
352
+ * @returns true iff given psbt/transaction/tx-input-array/psbt-input-array contains at least one taproot key path spend input
353
+ */
354
+ function isTransactionWithKeyPathSpendInput(data) {
355
+ const inputs = data instanceof UtxoPsbt_1.UtxoPsbt ? data.data.inputs : data instanceof UtxoTransaction_1.UtxoTransaction ? data.ins : data;
356
+ if (!inputs.length) {
357
+ return false;
358
+ }
359
+ if (isPsbtInputArray(inputs)) {
360
+ return inputs.some((input, _) => getPsbtInputScriptType(input) === 'taprootKeyPathSpend');
361
+ }
362
+ return inputs.some((input, _) => {
363
+ // If the input is not signed, it cannot be a taprootKeyPathSpend input because you can only
364
+ // extract a fully signed psbt into a transaction with taprootKeyPathSpend inputs.
365
+ if (getStrictSignatureCount(input) === 0) {
335
366
  return false;
336
367
  }
337
- data = Buffer.from(data.slice(0, 10), 'hex');
368
+ return (0, parseInput_1.parseSignatureScript)(input).scriptType === 'taprootKeyPathSpend';
369
+ });
370
+ }
371
+ /**
372
+ * Set the RootWalletKeys as the globalXpubs on the psbt
373
+ *
374
+ * We do all the matching of the (tap)bip32Derivations masterFingerprint to the fingerprint of the
375
+ * extendedPubkey.
376
+ */
377
+ function addXpubsToPsbt(psbt, rootWalletKeys) {
378
+ const safeRootWalletKeys = new WalletKeys_1.RootWalletKeys(rootWalletKeys.triple.map((bip32) => bip32.neutered()), rootWalletKeys.derivationPrefixes);
379
+ const xPubs = safeRootWalletKeys.triple.map((bip32) => ({
380
+ extendedPubkey: bs58check.decode(bip32.toBase58()),
381
+ masterFingerprint: bip32.fingerprint,
382
+ // TODO: BG-73797 - bip174 currently requires m prefix for this to be a valid globalXpub
383
+ path: 'm',
384
+ }));
385
+ psbt.updateGlobal({ globalXpub: xPubs });
386
+ }
387
+ /**
388
+ * validates signatures for each 2 of 3 input against user, backup, bitgo keys derived from rootWalletKeys.
389
+ * @returns array of input index and its [is valid user sig exist, is valid backup sig exist, is valid user bitgo exist]
390
+ * For p2shP2pk input, [false, false, false] is returned since it is not a 2 of 3 sig input.
391
+ */
392
+ function getSignatureValidationArrayPsbt(psbt, rootWalletKeys) {
393
+ return psbt.data.inputs.map((input, i) => {
394
+ const sigValArrayForInput = getPsbtInputScriptType(input) === 'p2shP2pk'
395
+ ? [false, false, false]
396
+ : psbt.getSignatureValidationArray(i, { rootNodes: rootWalletKeys.triple });
397
+ return [i, sigValArrayForInput];
398
+ });
399
+ }
400
+ /**
401
+ * Extracts the half signed transaction from the psbt for p2ms based script types - p2sh, p2wsh, and p2shP2wsh.
402
+ * The purpose is to provide backward compatibility to keyternal (KRS) that only supports network transaction and p2ms script types.
403
+ */
404
+ function extractP2msOnlyHalfSignedTx(psbt) {
405
+ assert(!!(psbt.data.inputs.length && psbt.data.outputs.length), 'empty inputs or outputs');
406
+ const tx = psbt.getUnsignedTx();
407
+ function isP2msParsedPsbtInput(parsed) {
408
+ return ['p2sh', 'p2shP2wsh', 'p2wsh'].includes(parsed.scriptType);
338
409
  }
339
- return 5 <= data.length && data.readUInt32BE(0) === 0x70736274 && data.readUInt8(4) === 0xff;
410
+ psbt.data.inputs.forEach((input, i) => {
411
+ const parsed = parsePsbtInput(input);
412
+ assert(isP2msParsedPsbtInput(parsed), `unsupported script type ${parsed.scriptType}`);
413
+ assert(input.partialSig?.length === 1, `unexpected signature count ${input.partialSig?.length}`);
414
+ const [partialSig] = input.partialSig;
415
+ assert(input.sighashType !== undefined && input.sighashType === bitcoinjs_lib_1.script.signature.decode(partialSig.signature).hashType, 'signature sighash does not match input sighash type');
416
+ // type casting is to address the invalid type checking in payments.p2ms
417
+ const signatures = parsed.publicKeys.map((pk) => partialSig.pubkey.equals(pk) ? partialSig.signature : bitcoinjs_lib_1.opcodes.OP_0);
418
+ const isP2SH = !!parsed.redeemScript;
419
+ const isP2WSH = !!parsed.witnessScript;
420
+ const payment = index_1.payments.p2ms({ output: parsed.pubScript, signatures }, { validate: false, allowIncomplete: true });
421
+ const p2wsh = isP2WSH ? index_1.payments.p2wsh({ redeem: payment }) : undefined;
422
+ const p2sh = isP2SH ? index_1.payments.p2sh({ redeem: p2wsh || payment }) : undefined;
423
+ if (p2sh?.input) {
424
+ tx.setInputScript(i, p2sh.input);
425
+ }
426
+ if (p2wsh?.witness) {
427
+ tx.setWitness(i, p2wsh.witness);
428
+ }
429
+ });
430
+ return tx;
431
+ }
432
+ /**
433
+ * Clones the psbt without nonWitnessUtxo for non-segwit inputs and witnessUtxo is added instead.
434
+ * It is not BIP-174 compliant, so use it carefully.
435
+ */
436
+ function clonePsbtWithoutNonWitnessUtxo(psbt) {
437
+ const newPsbt = (0, transaction_1.createPsbtFromHex)(psbt.toHex(), psbt.network);
438
+ const txInputs = psbt.txInputs;
439
+ psbt.data.inputs.forEach((input, i) => {
440
+ if (input.nonWitnessUtxo && !input.witnessUtxo) {
441
+ const tx = (0, transaction_1.createTransactionFromBuffer)(input.nonWitnessUtxo, psbt.network, { amountType: 'bigint' });
442
+ if (!txInputs[i].hash.equals(tx.getHash())) {
443
+ throw new Error(`Non-witness UTXO hash for input #${i} doesn't match the hash specified in the prevout`);
444
+ }
445
+ newPsbt.data.inputs[i].witnessUtxo = tx.outs[txInputs[i].index];
446
+ }
447
+ delete newPsbt.data.inputs[i].nonWitnessUtxo;
448
+ });
449
+ return newPsbt;
450
+ }
451
+ /**
452
+ * Returns true if there are non-segwit inputs in the PSBT that do not contain the
453
+ * nonWitnessUtxo.
454
+ *
455
+ * isPsbtLite(clonePsbtWithoutNonWitnessUtxo(psbt)) === true
456
+ *
457
+ * @param psbt
458
+ */
459
+ function isPsbtLite(psbt) {
460
+ let isFull = true;
461
+ const nonSegwitInputTypes = ['p2shP2pk', 'p2sh'];
462
+ psbt.data.inputs.forEach((input) => {
463
+ if (isFull && nonSegwitInputTypes.includes(getPsbtInputScriptType(input))) {
464
+ isFull = !!input.nonWitnessUtxo;
465
+ }
466
+ });
467
+ return !isFull;
468
+ }
469
+ /**
470
+ * Deletes witnessUtxo for non-segwit inputs to make the PSBT BIP-174 compliant.
471
+ */
472
+ function deleteWitnessUtxoForNonSegwitInputs(psbt) {
473
+ psbt.data.inputs.forEach((input, i) => {
474
+ const scriptType = getPsbtInputScriptType(input);
475
+ if (scriptType === 'p2sh' || scriptType === 'p2shP2pk') {
476
+ delete input.witnessUtxo;
477
+ }
478
+ });
340
479
  }
341
- exports.isPsbt = isPsbt;
342
- //# 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';\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 { BIP32Interface } from 'bip32';\nimport { isWalletUnspent, WalletUnspent } from './Unspent';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { PartialSig, PsbtInput, TapScriptSig } from 'bip174/src/lib/interfaces';\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 } from '../types';\nimport { createTaprootOutputScript } from '../../taproot';\nimport { script as bscript, TxInput } from 'bitcoinjs-lib';\nimport { opcodes } from '../../index';\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\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 signatureCount = psbt.getSignatureCount(inputIndex);\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    const input = psbt.data.inputs[inputIndex];\n\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\nfunction getScriptType(input: PsbtInput): ParsedScriptType | undefined {\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  return scriptType;\n}\n\nfunction parseTaprootKeyPathSignatures(psbt: UtxoPsbt, inputIndex: number): TaprootKeyPathSignatureContainer {\n  const partialSigs = parsePsbtMusig2PartialSigs(psbt, inputIndex);\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  psbt: UtxoPsbt,\n  inputIndex: number,\n  scriptType: ParsedScriptType\n): SignatureContainer | TaprootKeyPathSignatureContainer {\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n  return scriptType === 'taprootKeyPathSpend'\n    ? parseTaprootKeyPathSignatures(psbt, inputIndex)\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\nfunction parseInputMetadata(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  scriptType: ParsedScriptType\n): ParsedPsbtP2ms | ParsedPsbtTaproot | ParsedPsbtP2shP2pk {\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n  const parsedPubScript = parseScript(input, scriptType);\n  const signatures = parseSignatures(psbt, inputIndex, 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 * @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 * Any unsigned PSBT and without required metadata is returned with undefined.\n */\nexport function parsePsbtInput(\n  psbt: UtxoPsbt,\n  inputIndex: number\n): ParsedPsbtP2ms | ParsedPsbtTaproot | ParsedPsbtP2shP2pk | undefined {\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n  if (psbt.isInputFinalized(inputIndex)) {\n    throw new Error('Finalized PSBT parsing is not supported');\n  }\n  const scriptType = getScriptType(input);\n  if (!scriptType) {\n    if (psbt.getSignatureCount(inputIndex) > 0) {\n      throw new Error('Invalid PSBT state. Signatures found without scripts.');\n    }\n    return undefined;\n  }\n  return parseInputMetadata(psbt, inputIndex, scriptType);\n}\n\nfunction parseSignatureCount(\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\nfunction getInputSignatureCount(param: TxInput | { psbt: UtxoPsbt; inputIndex: number }): 0 | 1 | 2 {\n  if ('psbt' in param) {\n    const parsedInput = parsePsbtInput(param.psbt, param.inputIndex);\n    assert(parsedInput, 'invalid psbt input');\n    return parseSignatureCount(parsedInput.signatures);\n  } else {\n    if (param.script?.length || param.witness?.length) {\n      const parsedInput = parseSignatureScript(param);\n      return parsedInput.scriptType === 'taprootKeyPathSpend' ? 2 : parseSignatureCount(parsedInput.signatures);\n    }\n    return 0;\n  }\n}\n\n/**\n * @returns maximum number of signatures across all inputs - 0, 1 and 2.\n * It can be used to check given psbt/transaction/array of TxInputs is unsigned(0), half-signed(1) or fully-signed(2).\n */\nexport function getSignatureCount(\n  tx: UtxoPsbt | UtxoTransaction<number | bigint> | TxInput[],\n  inputIndex?: number\n): 0 | 1 | 2 {\n  const constructParam = (tx: UtxoPsbt | UtxoTransaction<number | bigint> | TxInput[], inputIndex: number) => {\n    return tx instanceof UtxoPsbt\n      ? { psbt: tx, inputIndex }\n      : (tx instanceof UtxoTransaction ? tx.ins : tx)[inputIndex];\n  };\n\n  const inputs = tx instanceof UtxoPsbt ? tx.data.inputs : tx instanceof UtxoTransaction ? tx.ins : tx;\n  assert(inputIndex === undefined || (inputIndex >= 0 && inputIndex < inputs.length), 'invalid inputIndex range');\n  const indices = inputIndex === undefined ? inputs.map((_, index) => index) : [inputIndex];\n  return indices\n    .map((index, _) => getInputSignatureCount(constructParam(tx, index)))\n    .reduce((prev, curr) => (curr > prev ? curr : prev), 0);\n}\n\n/**\n * @return true iff data starts with magic PSBT byte sequence\n * @param data byte array or hex string\n * */\nexport function isPsbt(data: Buffer | string): boolean {\n  // https://github.com/bitcoin/bips/blob/master/bip-0174.mediawiki#specification\n  // 0x70736274 - ASCII for 'psbt'. 0xff - separator\n  if (typeof data === 'string') {\n    if (data.length < 10) {\n      return false;\n    }\n    data = Buffer.from(data.slice(0, 10), 'hex');\n  }\n  return 5 <= data.length && data.readUInt32BE(0) === 0x70736274 && data.readUInt8(4) === 0xff;\n}\n"]}
480
+ //# 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 {\n  createOutputScript2of3,\n  getLeafHash,\n  ScriptType2Of3,\n  scriptTypeForChain,\n  toXOnlyPublicKey,\n} from '../outputScripts';\nimport { DerivedWalletKeys, RootWalletKeys } from './WalletKeys';\nimport { toPrevOutputWithPrevTx } from '../Unspent';\nimport { createPsbtFromHex, createPsbtFromTransaction, createTransactionFromBuffer } 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  ParsedScriptType2Of3,\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      scriptType: parsedPubScript.scriptType,\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      scriptType: parsedPubScript.scriptType,\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 * Converts a parsed script type into an array of script types.\n * @param parsedScriptType - The parsed script type.\n * @returns An array of ScriptType2Of3 values corresponding to the parsed script type.\n */\nexport function toScriptType2Of3s(parsedScriptType: ParsedScriptType2Of3): ScriptType2Of3[] {\n  return parsedScriptType === 'taprootScriptPathSpend'\n    ? ['p2trMusig2', 'p2tr']\n    : parsedScriptType === 'taprootKeyPathSpend'\n    ? ['p2trMusig2']\n    : [parsedScriptType];\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 = createPsbtFromHex(psbt.toHex(), psbt.network);\n  const txInputs = psbt.txInputs;\n\n  psbt.data.inputs.forEach((input, i) => {\n    if (input.nonWitnessUtxo && !input.witnessUtxo) {\n      const tx = createTransactionFromBuffer(input.nonWitnessUtxo, psbt.network, { amountType: 'bigint' });\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 * Returns true if there are non-segwit inputs in the PSBT that do not contain the\n * nonWitnessUtxo.\n *\n * isPsbtLite(clonePsbtWithoutNonWitnessUtxo(psbt)) === true\n *\n * @param psbt\n */\nexport function isPsbtLite(psbt: UtxoPsbt): boolean {\n  let isFull = true;\n  const nonSegwitInputTypes = ['p2shP2pk', 'p2sh'];\n  psbt.data.inputs.forEach((input) => {\n    if (isFull && nonSegwitInputTypes.includes(getPsbtInputScriptType(input))) {\n      isFull = !!input.nonWitnessUtxo;\n    }\n  });\n  return !isFull;\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"]}