utxo-lib 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (249) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +59 -0
  3. package/dist/src/address.d.ts +11 -0
  4. package/dist/src/address.d.ts.map +1 -0
  5. package/dist/src/address.js +37 -0
  6. package/dist/src/addressFormat.d.ts +53 -0
  7. package/dist/src/addressFormat.d.ts.map +1 -0
  8. package/dist/src/addressFormat.js +110 -0
  9. package/dist/src/bitgo/Musig2.d.ts +51 -0
  10. package/dist/src/bitgo/Musig2.d.ts.map +1 -0
  11. package/dist/src/bitgo/Musig2.js +175 -0
  12. package/dist/src/bitgo/Unspent.d.ts +95 -0
  13. package/dist/src/bitgo/Unspent.d.ts.map +1 -0
  14. package/dist/src/bitgo/Unspent.js +138 -0
  15. package/dist/src/bitgo/UtxoPsbt.d.ts +132 -0
  16. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -0
  17. package/dist/src/bitgo/UtxoPsbt.js +469 -0
  18. package/dist/src/bitgo/UtxoTransaction.d.ts +22 -0
  19. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -0
  20. package/dist/src/bitgo/UtxoTransaction.js +97 -0
  21. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +26 -0
  22. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -0
  23. package/dist/src/bitgo/UtxoTransactionBuilder.js +67 -0
  24. package/dist/src/bitgo/bbc/DashPsbt.d.ts +12 -0
  25. package/dist/src/bitgo/bbc/DashPsbt.d.ts.map +1 -0
  26. package/dist/src/bitgo/bbc/DashPsbt.js +27 -0
  27. package/dist/src/bitgo/bbc/DashTransaction.d.ts +39 -0
  28. package/dist/src/bitgo/bbc/DashTransaction.d.ts.map +1 -0
  29. package/dist/src/bitgo/bbc/DashTransaction.js +109 -0
  30. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts +14 -0
  31. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts.map +1 -0
  32. package/dist/src/bitgo/bbc/DashTransactionBuilder.js +28 -0
  33. package/dist/src/bitgo/bbc/index.d.ts +4 -0
  34. package/dist/src/bitgo/bbc/index.d.ts.map +1 -0
  35. package/dist/src/bitgo/bbc/index.js +16 -0
  36. package/dist/src/bitgo/bitcoincash/address.d.ts +35 -0
  37. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -0
  38. package/dist/src/bitgo/bitcoincash/address.js +151 -0
  39. package/dist/src/bitgo/bitcoincash/index.d.ts +2 -0
  40. package/dist/src/bitgo/bitcoincash/index.d.ts.map +1 -0
  41. package/dist/src/bitgo/bitcoincash/index.js +14 -0
  42. package/dist/src/bitgo/dash/DashPsbt.d.ts +12 -0
  43. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -0
  44. package/dist/src/bitgo/dash/DashPsbt.js +27 -0
  45. package/dist/src/bitgo/dash/DashTransaction.d.ts +39 -0
  46. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -0
  47. package/dist/src/bitgo/dash/DashTransaction.js +109 -0
  48. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +14 -0
  49. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -0
  50. package/dist/src/bitgo/dash/DashTransactionBuilder.js +28 -0
  51. package/dist/src/bitgo/dash/index.d.ts +4 -0
  52. package/dist/src/bitgo/dash/index.d.ts.map +1 -0
  53. package/dist/src/bitgo/dash/index.js +16 -0
  54. package/dist/src/bitgo/index.d.ts +17 -0
  55. package/dist/src/bitgo/index.d.ts.map +1 -0
  56. package/dist/src/bitgo/index.js +30 -0
  57. package/dist/src/bitgo/keyutil.d.ts +17 -0
  58. package/dist/src/bitgo/keyutil.d.ts.map +1 -0
  59. package/dist/src/bitgo/keyutil.js +37 -0
  60. package/dist/src/bitgo/nonStandardHalfSigned.d.ts +7 -0
  61. package/dist/src/bitgo/nonStandardHalfSigned.d.ts.map +1 -0
  62. package/dist/src/bitgo/nonStandardHalfSigned.js +56 -0
  63. package/dist/src/bitgo/outputScripts.d.ts +84 -0
  64. package/dist/src/bitgo/outputScripts.d.ts.map +1 -0
  65. package/dist/src/bitgo/outputScripts.js +297 -0
  66. package/dist/src/bitgo/parseInput.d.ts +92 -0
  67. package/dist/src/bitgo/parseInput.d.ts.map +1 -0
  68. package/dist/src/bitgo/parseInput.js +344 -0
  69. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +24 -0
  70. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -0
  71. package/dist/src/bitgo/psbt/fromHalfSigned.js +91 -0
  72. package/dist/src/bitgo/psbt/scriptTypes.d.ts +6 -0
  73. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -0
  74. package/dist/src/bitgo/psbt/scriptTypes.js +23 -0
  75. package/dist/src/bitgo/signature.d.ts +84 -0
  76. package/dist/src/bitgo/signature.d.ts.map +1 -0
  77. package/dist/src/bitgo/signature.js +222 -0
  78. package/dist/src/bitgo/tnumber.d.ts +9 -0
  79. package/dist/src/bitgo/tnumber.d.ts.map +1 -0
  80. package/dist/src/bitgo/tnumber.js +31 -0
  81. package/dist/src/bitgo/transaction.d.ts +29 -0
  82. package/dist/src/bitgo/transaction.d.ts.map +1 -0
  83. package/dist/src/bitgo/transaction.js +247 -0
  84. package/dist/src/bitgo/types.d.ts +5 -0
  85. package/dist/src/bitgo/types.d.ts.map +1 -0
  86. package/dist/src/bitgo/types.js +12 -0
  87. package/dist/src/bitgo/wallet/Psbt.d.ts +47 -0
  88. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -0
  89. package/dist/src/bitgo/wallet/Psbt.js +232 -0
  90. package/dist/src/bitgo/wallet/Unspent.d.ts +47 -0
  91. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -0
  92. package/dist/src/bitgo/wallet/Unspent.js +154 -0
  93. package/dist/src/bitgo/wallet/WalletKeys.d.ts +72 -0
  94. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -0
  95. package/dist/src/bitgo/wallet/WalletKeys.js +104 -0
  96. package/dist/src/bitgo/wallet/WalletOutput.d.ts +18 -0
  97. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -0
  98. package/dist/src/bitgo/wallet/WalletOutput.js +69 -0
  99. package/dist/src/bitgo/wallet/WalletScripts.d.ts +7 -0
  100. package/dist/src/bitgo/wallet/WalletScripts.d.ts.map +1 -0
  101. package/dist/src/bitgo/wallet/WalletScripts.js +15 -0
  102. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts +19 -0
  103. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts.map +1 -0
  104. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +47 -0
  105. package/dist/src/bitgo/wallet/chains.d.ts +57 -0
  106. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -0
  107. package/dist/src/bitgo/wallet/chains.js +106 -0
  108. package/dist/src/bitgo/wallet/index.d.ts +8 -0
  109. package/dist/src/bitgo/wallet/index.d.ts.map +1 -0
  110. package/dist/src/bitgo/wallet/index.js +20 -0
  111. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +26 -0
  112. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -0
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.js +157 -0
  114. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +36 -0
  115. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -0
  116. package/dist/src/bitgo/zcash/ZcashPsbt.js +146 -0
  117. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +61 -0
  118. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -0
  119. package/dist/src/bitgo/zcash/ZcashTransaction.js +341 -0
  120. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +21 -0
  121. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -0
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +105 -0
  123. package/dist/src/bitgo/zcash/address.d.ts +8 -0
  124. package/dist/src/bitgo/zcash/address.d.ts.map +1 -0
  125. package/dist/src/bitgo/zcash/address.js +57 -0
  126. package/dist/src/bitgo/zcash/hashZip0244.d.ts +27 -0
  127. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -0
  128. package/dist/src/bitgo/zcash/hashZip0244.js +184 -0
  129. package/dist/src/bitgo/zcash/index.d.ts +4 -0
  130. package/dist/src/bitgo/zcash/index.d.ts.map +1 -0
  131. package/dist/src/bitgo/zcash/index.js +16 -0
  132. package/dist/src/classify.d.ts +19 -0
  133. package/dist/src/classify.d.ts.map +1 -0
  134. package/dist/src/classify.js +89 -0
  135. package/dist/src/index.d.ts +13 -0
  136. package/dist/src/index.d.ts.map +1 -0
  137. package/dist/src/index.js +36 -0
  138. package/dist/src/networks.d.ts +119 -0
  139. package/dist/src/networks.d.ts.map +1 -0
  140. package/dist/src/networks.js +477 -0
  141. package/dist/src/noble_ecc.d.ts +28 -0
  142. package/dist/src/noble_ecc.d.ts.map +1 -0
  143. package/dist/src/noble_ecc.js +168 -0
  144. package/dist/src/payments/index.d.ts +4 -0
  145. package/dist/src/payments/index.d.ts.map +1 -0
  146. package/dist/src/payments/index.js +8 -0
  147. package/dist/src/payments/p2tr.d.ts +3 -0
  148. package/dist/src/payments/p2tr.d.ts.map +1 -0
  149. package/dist/src/payments/p2tr.js +348 -0
  150. package/dist/src/payments/p2tr_ns.d.ts +3 -0
  151. package/dist/src/payments/p2tr_ns.d.ts.map +1 -0
  152. package/dist/src/payments/p2tr_ns.js +134 -0
  153. package/dist/src/taproot.d.ts +141 -0
  154. package/dist/src/taproot.d.ts.map +1 -0
  155. package/dist/src/taproot.js +384 -0
  156. package/dist/src/templates/multisig/index.d.ts +4 -0
  157. package/dist/src/templates/multisig/index.d.ts.map +1 -0
  158. package/dist/src/templates/multisig/index.js +8 -0
  159. package/dist/src/templates/multisig/input.d.ts +7 -0
  160. package/dist/src/templates/multisig/input.d.ts.map +1 -0
  161. package/dist/src/templates/multisig/input.js +25 -0
  162. package/dist/src/templates/multisig/output.d.ts +7 -0
  163. package/dist/src/templates/multisig/output.d.ts.map +1 -0
  164. package/dist/src/templates/multisig/output.js +38 -0
  165. package/dist/src/templates/nulldata.d.ts +10 -0
  166. package/dist/src/templates/nulldata.d.ts.map +1 -0
  167. package/dist/src/templates/nulldata.js +17 -0
  168. package/dist/src/templates/pubkey/index.d.ts +4 -0
  169. package/dist/src/templates/pubkey/index.d.ts.map +1 -0
  170. package/dist/src/templates/pubkey/index.js +8 -0
  171. package/dist/src/templates/pubkey/input.d.ts +7 -0
  172. package/dist/src/templates/pubkey/input.d.ts.map +1 -0
  173. package/dist/src/templates/pubkey/input.js +14 -0
  174. package/dist/src/templates/pubkey/output.d.ts +7 -0
  175. package/dist/src/templates/pubkey/output.d.ts.map +1 -0
  176. package/dist/src/templates/pubkey/output.js +15 -0
  177. package/dist/src/templates/pubkeyhash/index.d.ts +4 -0
  178. package/dist/src/templates/pubkeyhash/index.d.ts.map +1 -0
  179. package/dist/src/templates/pubkeyhash/index.js +8 -0
  180. package/dist/src/templates/pubkeyhash/input.d.ts +7 -0
  181. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -0
  182. package/dist/src/templates/pubkeyhash/input.js +16 -0
  183. package/dist/src/templates/pubkeyhash/output.d.ts +6 -0
  184. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -0
  185. package/dist/src/templates/pubkeyhash/output.js +20 -0
  186. package/dist/src/templates/scripthash/index.d.ts +4 -0
  187. package/dist/src/templates/scripthash/index.d.ts.map +1 -0
  188. package/dist/src/templates/scripthash/index.js +8 -0
  189. package/dist/src/templates/scripthash/input.d.ts +6 -0
  190. package/dist/src/templates/scripthash/input.d.ts.map +1 -0
  191. package/dist/src/templates/scripthash/input.js +43 -0
  192. package/dist/src/templates/scripthash/output.d.ts +6 -0
  193. package/dist/src/templates/scripthash/output.d.ts.map +1 -0
  194. package/dist/src/templates/scripthash/output.js +15 -0
  195. package/dist/src/templates/taproot/index.d.ts +4 -0
  196. package/dist/src/templates/taproot/index.d.ts.map +1 -0
  197. package/dist/src/templates/taproot/index.js +8 -0
  198. package/dist/src/templates/taproot/input.d.ts +6 -0
  199. package/dist/src/templates/taproot/input.d.ts.map +1 -0
  200. package/dist/src/templates/taproot/input.js +23 -0
  201. package/dist/src/templates/taproot/output.d.ts +6 -0
  202. package/dist/src/templates/taproot/output.d.ts.map +1 -0
  203. package/dist/src/templates/taproot/output.js +15 -0
  204. package/dist/src/templates/taprootnofn/index.d.ts +4 -0
  205. package/dist/src/templates/taprootnofn/index.d.ts.map +1 -0
  206. package/dist/src/templates/taprootnofn/index.js +8 -0
  207. package/dist/src/templates/taprootnofn/input.d.ts +7 -0
  208. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -0
  209. package/dist/src/templates/taprootnofn/input.js +24 -0
  210. package/dist/src/templates/taprootnofn/output.d.ts +7 -0
  211. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -0
  212. package/dist/src/templates/taprootnofn/output.js +28 -0
  213. package/dist/src/templates/witnesscommitment/index.d.ts +3 -0
  214. package/dist/src/templates/witnesscommitment/index.d.ts.map +1 -0
  215. package/dist/src/templates/witnesscommitment/index.js +6 -0
  216. package/dist/src/templates/witnesscommitment/output.d.ts +8 -0
  217. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -0
  218. package/dist/src/templates/witnesscommitment/output.js +31 -0
  219. package/dist/src/templates/witnesspubkeyhash/index.d.ts +4 -0
  220. package/dist/src/templates/witnesspubkeyhash/index.d.ts.map +1 -0
  221. package/dist/src/templates/witnesspubkeyhash/index.js +8 -0
  222. package/dist/src/templates/witnesspubkeyhash/input.d.ts +7 -0
  223. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -0
  224. package/dist/src/templates/witnesspubkeyhash/input.js +19 -0
  225. package/dist/src/templates/witnesspubkeyhash/output.d.ts +6 -0
  226. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -0
  227. package/dist/src/templates/witnesspubkeyhash/output.js +15 -0
  228. package/dist/src/templates/witnessscripthash/index.d.ts +4 -0
  229. package/dist/src/templates/witnessscripthash/index.d.ts.map +1 -0
  230. package/dist/src/templates/witnessscripthash/index.js +8 -0
  231. package/dist/src/templates/witnessscripthash/input.d.ts +6 -0
  232. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -0
  233. package/dist/src/templates/witnessscripthash/input.js +35 -0
  234. package/dist/src/templates/witnessscripthash/output.d.ts +6 -0
  235. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -0
  236. package/dist/src/templates/witnessscripthash/output.js +15 -0
  237. package/dist/src/testutil/index.d.ts +3 -0
  238. package/dist/src/testutil/index.d.ts.map +1 -0
  239. package/dist/src/testutil/index.js +15 -0
  240. package/dist/src/testutil/keys.d.ts +10 -0
  241. package/dist/src/testutil/keys.d.ts.map +1 -0
  242. package/dist/src/testutil/keys.js +40 -0
  243. package/dist/src/testutil/mock.d.ts +21 -0
  244. package/dist/src/testutil/mock.d.ts.map +1 -0
  245. package/dist/src/testutil/mock.js +86 -0
  246. package/dist/src/transaction_builder.d.ts +47 -0
  247. package/dist/src/transaction_builder.d.ts.map +1 -0
  248. package/dist/src/transaction_builder.js +1084 -0
  249. package/package.json +87 -0
@@ -0,0 +1,469 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UtxoPsbt = exports.ProprietaryKeySubtype = exports.PSBT_PROPRIETARY_IDENTIFIER = void 0;
4
+ const bip174_1 = require("bip174");
5
+ const utils_1 = require("bip174/src/lib/utils");
6
+ const bufferutils_1 = require("bitcoinjs-lib/src/bufferutils");
7
+ const __1 = require("..");
8
+ const UtxoTransaction_1 = require("./UtxoTransaction");
9
+ const Unspent_1 = require("./Unspent");
10
+ const scriptTypes_1 = require("./psbt/scriptTypes");
11
+ const fromHalfSigned_1 = require("./psbt/fromHalfSigned");
12
+ const outputScripts_1 = require("./outputScripts");
13
+ const parseInput_1 = require("./parseInput");
14
+ const bip32_1 = require("bip32");
15
+ const bs58check = require("bs58check");
16
+ const proprietaryKeyVal_1 = require("bip174/src/lib/proprietaryKeyVal");
17
+ exports.PSBT_PROPRIETARY_IDENTIFIER = 'BITGO';
18
+ var ProprietaryKeySubtype;
19
+ (function (ProprietaryKeySubtype) {
20
+ ProprietaryKeySubtype[ProprietaryKeySubtype["ZEC_CONSENSUS_BRANCH_ID"] = 0] = "ZEC_CONSENSUS_BRANCH_ID";
21
+ ProprietaryKeySubtype[ProprietaryKeySubtype["MUSIG2_PARTICIPANT_PUB_KEYS"] = 1] = "MUSIG2_PARTICIPANT_PUB_KEYS";
22
+ ProprietaryKeySubtype[ProprietaryKeySubtype["MUSIG2_PUB_NONCE"] = 2] = "MUSIG2_PUB_NONCE";
23
+ })(ProprietaryKeySubtype = exports.ProprietaryKeySubtype || (exports.ProprietaryKeySubtype = {}));
24
+ // TODO: upstream does `checkInputsForPartialSigs` before doing things like
25
+ // `setVersion`. Our inputs could have tapscriptsigs (or in future tapkeysigs)
26
+ // and not fail that check. Do we want to do anything about that?
27
+ class UtxoPsbt extends __1.Psbt {
28
+ static transactionFromBuffer(buffer, network) {
29
+ return UtxoTransaction_1.UtxoTransaction.fromBuffer(buffer, false, 'bigint', network);
30
+ }
31
+ static createPsbt(opts, data) {
32
+ return new UtxoPsbt(opts, data || new bip174_1.Psbt(new __1.PsbtTransaction({ tx: new UtxoTransaction_1.UtxoTransaction(opts.network) })));
33
+ }
34
+ static fromBuffer(buffer, opts) {
35
+ const transactionFromBuffer = (buffer) => {
36
+ const tx = this.transactionFromBuffer(buffer, opts.network);
37
+ return new __1.PsbtTransaction({ tx });
38
+ };
39
+ const psbtBase = bip174_1.Psbt.fromBuffer(buffer, transactionFromBuffer, {
40
+ bip32PathsAbsolute: opts.bip32PathsAbsolute,
41
+ });
42
+ const psbt = this.createPsbt(opts, psbtBase);
43
+ // Upstream checks for duplicate inputs here, but it seems to be of dubious value.
44
+ return psbt;
45
+ }
46
+ static fromHex(data, opts) {
47
+ return this.fromBuffer(Buffer.from(data, 'hex'), opts);
48
+ }
49
+ get network() {
50
+ return this.tx.network;
51
+ }
52
+ toHex() {
53
+ return this.toBuffer().toString('hex');
54
+ }
55
+ /**
56
+ * @return true iff PSBT input is finalized
57
+ */
58
+ isInputFinalized(inputIndex) {
59
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
60
+ return Buffer.isBuffer(input.finalScriptSig) || Buffer.isBuffer(input.finalScriptWitness);
61
+ }
62
+ /**
63
+ * @return partialSig/tapScriptSig count iff input is not finalized
64
+ */
65
+ getSignatureCount(inputIndex) {
66
+ if (this.isInputFinalized(inputIndex)) {
67
+ throw new Error('Input is already finalized');
68
+ }
69
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
70
+ return Math.max(Array.isArray(input.partialSig) ? input.partialSig.length : 0, Array.isArray(input.tapScriptSig) ? input.tapScriptSig.length : 0);
71
+ }
72
+ getNonWitnessPreviousTxids() {
73
+ const txInputs = this.txInputs; // These are somewhat costly to extract
74
+ const txidSet = new Set();
75
+ this.data.inputs.forEach((input, index) => {
76
+ if (!input.witnessUtxo) {
77
+ throw new Error('Must have witness UTXO for all inputs');
78
+ }
79
+ if (!scriptTypes_1.isSegwit(input.witnessUtxo.script, input.redeemScript)) {
80
+ txidSet.add(Unspent_1.getOutputIdForInput(txInputs[index]).txid);
81
+ }
82
+ });
83
+ return [...txidSet];
84
+ }
85
+ addNonWitnessUtxos(txBufs) {
86
+ const txInputs = this.txInputs; // These are somewhat costly to extract
87
+ this.data.inputs.forEach((input, index) => {
88
+ if (!input.witnessUtxo) {
89
+ throw new Error('Must have witness UTXO for all inputs');
90
+ }
91
+ if (!scriptTypes_1.isSegwit(input.witnessUtxo.script, input.redeemScript)) {
92
+ const { txid } = Unspent_1.getOutputIdForInput(txInputs[index]);
93
+ if (txBufs[txid] === undefined) {
94
+ throw new Error('Not all required previous transactions provided');
95
+ }
96
+ this.updateInput(index, { nonWitnessUtxo: txBufs[txid] });
97
+ }
98
+ });
99
+ return this;
100
+ }
101
+ static fromTransaction(transaction, prevOutputs) {
102
+ if (prevOutputs.length !== transaction.ins.length) {
103
+ throw new Error(`Transaction has ${transaction.ins.length} inputs, but ${prevOutputs.length} previous outputs provided`);
104
+ }
105
+ const clonedTransaction = transaction.clone();
106
+ const updates = fromHalfSigned_1.unsign(clonedTransaction, prevOutputs);
107
+ const psbtBase = new bip174_1.Psbt(new __1.PsbtTransaction({ tx: clonedTransaction }));
108
+ clonedTransaction.ins.forEach(() => psbtBase.inputs.push({ unknownKeyVals: [] }));
109
+ clonedTransaction.outs.forEach(() => psbtBase.outputs.push({ unknownKeyVals: [] }));
110
+ const psbt = this.createPsbt({ network: transaction.network }, psbtBase);
111
+ updates.forEach((update, index) => {
112
+ psbt.updateInput(index, update);
113
+ psbt.updateInput(index, { witnessUtxo: { script: prevOutputs[index].script, value: prevOutputs[index].value } });
114
+ });
115
+ return psbt;
116
+ }
117
+ getUnsignedTx() {
118
+ return this.tx.clone();
119
+ }
120
+ static newTransaction(network) {
121
+ return new UtxoTransaction_1.UtxoTransaction(network);
122
+ }
123
+ get tx() {
124
+ return this.data.globalMap.unsignedTx.tx;
125
+ }
126
+ checkForSignatures(propName) {
127
+ this.data.inputs.forEach((input) => {
128
+ var _a, _b;
129
+ if (((_a = input.tapScriptSig) === null || _a === void 0 ? void 0 : _a.length) || input.tapKeySig || ((_b = input.partialSig) === null || _b === void 0 ? void 0 : _b.length)) {
130
+ throw new Error(`Cannot modify ${propName !== null && propName !== void 0 ? propName : 'transaction'} - signatures exist.`);
131
+ }
132
+ });
133
+ }
134
+ /**
135
+ * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
136
+ */
137
+ finalizeAllInputs() {
138
+ utils_1.checkForInput(this.data.inputs, 0); // making sure we have at least one
139
+ this.data.inputs.map((input, idx) => {
140
+ var _a;
141
+ return ((_a = input.tapScriptSig) === null || _a === void 0 ? void 0 : _a.length) ? this.finalizeTaprootInput(idx) : this.finalizeInput(idx);
142
+ });
143
+ return this;
144
+ }
145
+ finalizeTaprootInput(inputIndex) {
146
+ var _a, _b;
147
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
148
+ // witness = control-block script first-sig second-sig
149
+ if (((_a = input.tapLeafScript) === null || _a === void 0 ? void 0 : _a.length) !== 1) {
150
+ throw new Error('Only one leaf script supported for finalizing');
151
+ }
152
+ const { controlBlock, script } = input.tapLeafScript[0];
153
+ const witness = [script, controlBlock];
154
+ const [pubkey1, pubkey2] = parseInput_1.parsePubScript(script, 'p2tr').publicKeys;
155
+ for (const pk of [pubkey1, pubkey2]) {
156
+ const sig = (_b = input.tapScriptSig) === null || _b === void 0 ? void 0 : _b.find(({ pubkey }) => pubkey.equals(pk));
157
+ if (!sig) {
158
+ throw new Error('Could not find signatures in Script Sig.');
159
+ }
160
+ witness.unshift(sig.signature);
161
+ }
162
+ const witnessLength = witness.reduce((s, b) => s + b.length + bufferutils_1.varuint.encodingLength(b.length), 1);
163
+ const bufferWriter = bufferutils_1.BufferWriter.withCapacity(witnessLength);
164
+ bufferWriter.writeVector(witness);
165
+ const finalScriptWitness = bufferWriter.end();
166
+ this.data.updateInput(inputIndex, { finalScriptWitness });
167
+ this.data.clearFinalizedInput(inputIndex);
168
+ return this;
169
+ }
170
+ finalizeTapInputWithSingleLeafScriptAndSignature(inputIndex) {
171
+ var _a, _b;
172
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
173
+ if (((_a = input.tapLeafScript) === null || _a === void 0 ? void 0 : _a.length) !== 1) {
174
+ throw new Error('Only one leaf script supported for finalizing');
175
+ }
176
+ if (((_b = input.tapScriptSig) === null || _b === void 0 ? void 0 : _b.length) !== 1) {
177
+ throw new Error('Could not find signatures in Script Sig.');
178
+ }
179
+ const { controlBlock, script } = input.tapLeafScript[0];
180
+ const witness = [input.tapScriptSig[0].signature, script, controlBlock];
181
+ const witnessLength = witness.reduce((s, b) => s + b.length + bufferutils_1.varuint.encodingLength(b.length), 1);
182
+ const bufferWriter = bufferutils_1.BufferWriter.withCapacity(witnessLength);
183
+ bufferWriter.writeVector(witness);
184
+ const finalScriptWitness = bufferWriter.end();
185
+ this.data.updateInput(inputIndex, { finalScriptWitness });
186
+ this.data.clearFinalizedInput(inputIndex);
187
+ return this;
188
+ }
189
+ /**
190
+ * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
191
+ *
192
+ * Unlike the function it overrides, this does not take a validator. In BitGo
193
+ * context, we know how we want to validate so we just hard code the right
194
+ * validator.
195
+ */
196
+ validateSignaturesOfAllInputs() {
197
+ utils_1.checkForInput(this.data.inputs, 0); // making sure we have at least one
198
+ const results = this.data.inputs.map((input, idx) => {
199
+ var _a;
200
+ return ((_a = input.tapScriptSig) === null || _a === void 0 ? void 0 : _a.length)
201
+ ? this.validateTaprootSignaturesOfInput(idx)
202
+ : this.validateSignaturesOfInput(idx, (p, m, s) => __1.ecc.verify(m, p, s));
203
+ });
204
+ return results.reduce((final, res) => res && final, true);
205
+ }
206
+ validateTaprootSignaturesOfInput(inputIndex, pubkey) {
207
+ const input = this.data.inputs[inputIndex];
208
+ const tapSigs = (input || {}).tapScriptSig;
209
+ if (!input || !tapSigs || tapSigs.length < 1) {
210
+ throw new Error('No signatures to validate');
211
+ }
212
+ let mySigs;
213
+ if (pubkey) {
214
+ const xOnlyPubkey = outputScripts_1.toXOnlyPublicKey(pubkey);
215
+ mySigs = tapSigs.filter((sig) => sig.pubkey.equals(xOnlyPubkey));
216
+ if (mySigs.length < 1) {
217
+ throw new Error('No signatures for this pubkey');
218
+ }
219
+ }
220
+ else {
221
+ mySigs = tapSigs;
222
+ }
223
+ const results = [];
224
+ for (const pSig of mySigs) {
225
+ const { signature, leafHash, pubkey } = pSig;
226
+ let sigHashType;
227
+ let sig;
228
+ if (signature.length === 65) {
229
+ sigHashType = signature[64];
230
+ sig = signature.slice(0, 64);
231
+ }
232
+ else {
233
+ sigHashType = __1.Transaction.SIGHASH_DEFAULT;
234
+ sig = signature;
235
+ }
236
+ const { hash } = this.getTaprootHashForSig(inputIndex, [sigHashType], leafHash);
237
+ results.push(__1.ecc.verifySchnorr(hash, pubkey, sig));
238
+ }
239
+ return results.every((res) => res === true);
240
+ }
241
+ /**
242
+ * @return array of boolean values. True when corresponding index in `publicKeys` has signed the transaction.
243
+ * If no signature in the tx or no public key matching signature, the validation is considered as false.
244
+ */
245
+ getSignatureValidationArray(inputIndex) {
246
+ var _a;
247
+ const noSigErrorMessages = ['No signatures to validate', 'No signatures for this pubkey'];
248
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
249
+ const isP2tr = (_a = input.tapScriptSig) === null || _a === void 0 ? void 0 : _a.length;
250
+ if (!this.data.globalMap.globalXpub) {
251
+ throw new Error('Cannot get signature validation array without global xpubs');
252
+ }
253
+ if (this.data.globalMap.globalXpub.length !== 3) {
254
+ throw new Error(`There must be 3 global xpubs and there are ${this.data.globalMap.globalXpub.length}`);
255
+ }
256
+ return this.data.globalMap.globalXpub.map((xpub) => {
257
+ // const bip32 = ECPair.fromPublicKey(xpub.extendedPubkey, { network: (this as any).opts.network });
258
+ const bip32 = bip32_1.BIP32Factory(__1.ecc).fromBase58(bs58check.encode(xpub.extendedPubkey));
259
+ try {
260
+ return isP2tr
261
+ ? this.validateTaprootSignaturesOfInput(inputIndex, bip32.publicKey)
262
+ : this.validateSignaturesOfInput(inputIndex, (p, m, s) => __1.ecc.verify(m, p, s), bip32.publicKey);
263
+ }
264
+ catch (err) {
265
+ // Not an elegant solution. Might need upstream changes like custom error types.
266
+ if (noSigErrorMessages.includes(err.message)) {
267
+ return false;
268
+ }
269
+ throw err;
270
+ }
271
+ });
272
+ }
273
+ /**
274
+ * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
275
+ */
276
+ signAllInputsHD(hdKeyPair, sighashTypes = [__1.Transaction.SIGHASH_DEFAULT, __1.Transaction.SIGHASH_ALL]) {
277
+ var _a;
278
+ if (!hdKeyPair || !hdKeyPair.publicKey || !hdKeyPair.fingerprint) {
279
+ throw new Error('Need HDSigner to sign input');
280
+ }
281
+ const results = [];
282
+ for (let i = 0; i < this.data.inputs.length; i++) {
283
+ try {
284
+ if ((_a = this.data.inputs[i].tapBip32Derivation) === null || _a === void 0 ? void 0 : _a.length) {
285
+ this.signTaprootInputHD(i, hdKeyPair, sighashTypes);
286
+ }
287
+ else {
288
+ this.signInputHD(i, hdKeyPair, sighashTypes);
289
+ }
290
+ results.push(true);
291
+ }
292
+ catch (err) {
293
+ results.push(false);
294
+ }
295
+ }
296
+ if (results.every((v) => v === false)) {
297
+ throw new Error('No inputs were signed');
298
+ }
299
+ return this;
300
+ }
301
+ /**
302
+ * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts:signInputHD
303
+ */
304
+ signTaprootInputHD(inputIndex, hdKeyPair, sighashTypes = [__1.Transaction.SIGHASH_DEFAULT, __1.Transaction.SIGHASH_ALL]) {
305
+ if (!hdKeyPair || !hdKeyPair.publicKey || !hdKeyPair.fingerprint) {
306
+ throw new Error('Need HDSigner to sign input');
307
+ }
308
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
309
+ if (!input.tapBip32Derivation || input.tapBip32Derivation.length === 0) {
310
+ throw new Error('Need tapBip32Derivation to sign Taproot with HD');
311
+ }
312
+ const myDerivations = input.tapBip32Derivation
313
+ .map((bipDv) => {
314
+ if (bipDv.masterFingerprint.equals(hdKeyPair.fingerprint)) {
315
+ return bipDv;
316
+ }
317
+ })
318
+ .filter((v) => !!v);
319
+ if (myDerivations.length === 0) {
320
+ throw new Error('Need one tapBip32Derivation masterFingerprint to match the HDSigner fingerprint');
321
+ }
322
+ const signers = myDerivations.map((bipDv) => {
323
+ const node = hdKeyPair.derivePath(bipDv.path);
324
+ if (!bipDv.pubkey.equals(node.publicKey.slice(1))) {
325
+ throw new Error('pubkey did not match tapBip32Derivation');
326
+ }
327
+ return { signer: node, leafHashes: bipDv.leafHashes };
328
+ });
329
+ signers.forEach(({ signer, leafHashes }) => this.signTaprootInput(inputIndex, signer, leafHashes, sighashTypes));
330
+ return this;
331
+ }
332
+ signTaprootInput(inputIndex, signer, leafHashes, sighashTypes = [__1.Transaction.SIGHASH_DEFAULT, __1.Transaction.SIGHASH_ALL]) {
333
+ var _a;
334
+ const pubkey = outputScripts_1.toXOnlyPublicKey(signer.publicKey);
335
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
336
+ // Figure out if this is script path or not, if not, tweak the private key
337
+ if (!((_a = input.tapLeafScript) === null || _a === void 0 ? void 0 : _a.length)) {
338
+ // See BitGo/BitGoJS/modules/utxo_lib/src/transaction_builder.ts:trySign for how to support it.
339
+ throw new Error('Taproot key path signing is not supported.');
340
+ }
341
+ if (input.tapLeafScript.length !== 1) {
342
+ throw new Error('Only one leaf script supported for signing');
343
+ }
344
+ const tapLeafScript = input.tapLeafScript[0];
345
+ const parsedControlBlock = __1.taproot.parseControlBlock(__1.ecc, tapLeafScript.controlBlock);
346
+ const { leafVersion } = parsedControlBlock;
347
+ if (leafVersion !== tapLeafScript.leafVersion) {
348
+ throw new Error('Tap script leaf version mismatch with control block');
349
+ }
350
+ const leafHash = __1.taproot.getTapleafHash(__1.ecc, parsedControlBlock, tapLeafScript.script);
351
+ if (!leafHashes.find((l) => l.equals(leafHash))) {
352
+ throw new Error(`Signer cannot sign for leaf hash ${leafHash.toString('hex')}`);
353
+ }
354
+ const { hash, sighashType } = this.getTaprootHashForSig(inputIndex, sighashTypes, leafHash);
355
+ let signature = signer.signSchnorr(hash);
356
+ if (sighashType !== __1.Transaction.SIGHASH_DEFAULT) {
357
+ signature = Buffer.concat([signature, Buffer.of(sighashType)]);
358
+ }
359
+ this.data.updateInput(inputIndex, {
360
+ tapScriptSig: [
361
+ {
362
+ pubkey,
363
+ signature,
364
+ leafHash,
365
+ },
366
+ ],
367
+ });
368
+ return this;
369
+ }
370
+ getTaprootHashForSig(inputIndex, sighashTypes, leafHash) {
371
+ const sighashType = this.data.inputs[inputIndex].sighashType || __1.Transaction.SIGHASH_DEFAULT;
372
+ if (sighashTypes && sighashTypes.indexOf(sighashType) < 0) {
373
+ throw new Error(`Sighash type is not allowed. Retry the sign method passing the ` +
374
+ `sighashTypes array of whitelisted types. Sighash type: ${sighashType}`);
375
+ }
376
+ const txInputs = this.txInputs; // These are somewhat costly to extract
377
+ const prevoutScripts = [];
378
+ const prevoutValues = [];
379
+ this.data.inputs.forEach((input, i) => {
380
+ let prevout;
381
+ if (input.nonWitnessUtxo) {
382
+ // TODO: This could be costly, either cache it here, or find a way to share with super
383
+ const nonWitnessUtxoTx = this.constructor.transactionFromBuffer(input.nonWitnessUtxo, this.tx.network);
384
+ const prevoutHash = txInputs[i].hash;
385
+ const utxoHash = nonWitnessUtxoTx.getHash();
386
+ // If a non-witness UTXO is provided, its hash must match the hash specified in the prevout
387
+ if (!prevoutHash.equals(utxoHash)) {
388
+ throw new Error(`Non-witness UTXO hash for input #${i} doesn't match the hash specified in the prevout`);
389
+ }
390
+ const prevoutIndex = txInputs[i].index;
391
+ prevout = nonWitnessUtxoTx.outs[prevoutIndex];
392
+ }
393
+ else if (input.witnessUtxo) {
394
+ prevout = input.witnessUtxo;
395
+ }
396
+ else {
397
+ throw new Error('Need a Utxo input item for signing');
398
+ }
399
+ prevoutScripts.push(prevout.script);
400
+ prevoutValues.push(prevout.value);
401
+ });
402
+ const hash = this.tx.hashForWitnessV1(inputIndex, prevoutScripts, prevoutValues, sighashType, leafHash);
403
+ return { hash, sighashType };
404
+ }
405
+ /**
406
+ * @retuns true iff the input is taproot.
407
+ */
408
+ isTaprootInput(inputIndex) {
409
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
410
+ function isP2tr(output) {
411
+ try {
412
+ __1.p2trPayments.p2tr({ output }, { eccLib: __1.ecc });
413
+ return true;
414
+ }
415
+ catch (err) {
416
+ return false;
417
+ }
418
+ }
419
+ return !!(input.tapInternalKey ||
420
+ input.tapMerkleRoot ||
421
+ (input.tapLeafScript && input.tapLeafScript.length) ||
422
+ (input.tapBip32Derivation && input.tapBip32Derivation.length) ||
423
+ (input.witnessUtxo && isP2tr(input.witnessUtxo.script)));
424
+ }
425
+ /**
426
+ * @returns hash and hashType for taproot input at inputIndex
427
+ * @throws error if input at inputIndex is not a taproot input
428
+ */
429
+ getTaprootHashForSigChecked(inputIndex, sighashTypes = [__1.Transaction.SIGHASH_DEFAULT, __1.Transaction.SIGHASH_ALL], leafHash) {
430
+ if (!this.isTaprootInput(inputIndex)) {
431
+ throw new Error(`${inputIndex} input is not a taproot type to take taproot tx hash`);
432
+ }
433
+ return this.getTaprootHashForSig(inputIndex, sighashTypes, leafHash);
434
+ }
435
+ /**
436
+ * Adds proprietary key value pair to PSBT input.
437
+ * Default identifierEncoding is utf-8 for identifier.
438
+ */
439
+ addProprietaryKeyValToInput(inputIndex, keyValueData) {
440
+ return this.addUnknownKeyValToInput(inputIndex, {
441
+ key: proprietaryKeyVal_1.encodeProprietaryKey(keyValueData.key),
442
+ value: keyValueData.value,
443
+ });
444
+ }
445
+ /**
446
+ * To search any data from proprietary key value againts keydata.
447
+ * Default identifierEncoding is utf-8 for identifier.
448
+ */
449
+ getProprietaryKeyVals(inputIndex, keySearch) {
450
+ const input = utils_1.checkForInput(this.data.inputs, inputIndex);
451
+ if (!input.unknownKeyVals || input.unknownKeyVals.length === 0) {
452
+ return [];
453
+ }
454
+ const keyVals = input.unknownKeyVals.map(({ key, value }, i) => {
455
+ return { key: proprietaryKeyVal_1.decodeProprietaryKey(key), value };
456
+ });
457
+ return keyVals.filter((keyVal) => {
458
+ return (keySearch === undefined ||
459
+ (keySearch.identifier === keyVal.key.identifier &&
460
+ keySearch.subtype === keyVal.key.subtype &&
461
+ (!Buffer.isBuffer(keySearch.keydata) || keySearch.keydata.equals(keyVal.key.keydata))));
462
+ });
463
+ }
464
+ clone() {
465
+ return super.clone();
466
+ }
467
+ }
468
+ exports.UtxoPsbt = UtxoPsbt;
469
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UtxoPsbt.js","sourceRoot":"","sources":["../../../src/bitgo/UtxoPsbt.ts"],"names":[],"mappings":"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","sourcesContent":["import { Psbt as PsbtBase } from 'bip174';\nimport { TapBip32Derivation, Transaction as ITransaction, TransactionFromBuffer } from 'bip174/src/lib/interfaces';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { BufferWriter, varuint } from 'bitcoinjs-lib/src/bufferutils';\n\nimport {\n  taproot,\n  HDSigner,\n  Psbt,\n  PsbtTransaction,\n  Transaction,\n  TxOutput,\n  Network,\n  ecc as eccLib,\n  p2trPayments,\n} from '..';\nimport { UtxoTransaction } from './UtxoTransaction';\nimport { getOutputIdForInput } from './Unspent';\nimport { isSegwit } from './psbt/scriptTypes';\nimport { unsign } from './psbt/fromHalfSigned';\nimport { toXOnlyPublicKey } from './outputScripts';\nimport { parsePubScript } from './parseInput';\nimport { BIP32Factory } from 'bip32';\nimport * as bs58check from 'bs58check';\nimport { decodeProprietaryKey, encodeProprietaryKey, ProprietaryKey } from 'bip174/src/lib/proprietaryKeyVal';\n\nexport const PSBT_PROPRIETARY_IDENTIFIER = 'BITGO';\n\nexport enum ProprietaryKeySubtype {\n  ZEC_CONSENSUS_BRANCH_ID = 0x00,\n  MUSIG2_PARTICIPANT_PUB_KEYS = 0x01,\n  MUSIG2_PUB_NONCE = 0x02,\n}\n\nexport interface HDTaprootSigner extends HDSigner {\n  /**\n   * The path string must match /^m(\\/\\d+'?)+$/\n   * ex. m/44'/0'/0'/1/23 levels with ' must be hard derivations\n   */\n  derivePath(path: string): HDTaprootSigner;\n  /**\n   * Input hash (the \"message digest\") for the signature algorithm\n   * Return a 64 byte signature (32 byte r and 32 byte s in that order)\n   */\n  signSchnorr(hash: Buffer): Buffer;\n}\n\nexport interface SchnorrSigner {\n  publicKey: Buffer;\n  signSchnorr(hash: Buffer): Buffer;\n}\n\nexport interface TaprootSigner {\n  leafHashes: Buffer[];\n  signer: SchnorrSigner;\n}\n\nexport interface PsbtOpts {\n  network: Network;\n  maximumFeeRate?: number; // [sat/byte]\n  bip32PathsAbsolute?: boolean;\n}\n\n/**\n * Psbt proprietary keydata object.\n * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>\n * => <bytes valuedata>\n */\nexport interface ProprietaryKeyValueData {\n  key: ProprietaryKey;\n  value: Buffer;\n}\n\n/**\n * Psbt proprietary keydata object search fields.\n * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>\n */\nexport interface ProprietaryKeySearch {\n  identifier: string;\n  subtype: number;\n  keydata?: Buffer;\n  identifierEncoding?: BufferEncoding;\n}\n\n// TODO: upstream does `checkInputsForPartialSigs` before doing things like\n// `setVersion`. Our inputs could have tapscriptsigs (or in future tapkeysigs)\n// and not fail that check. Do we want to do anything about that?\nexport class UtxoPsbt<Tx extends UtxoTransaction<bigint> = UtxoTransaction<bigint>> extends Psbt {\n  protected static transactionFromBuffer(buffer: Buffer, network: Network): UtxoTransaction<bigint> {\n    return UtxoTransaction.fromBuffer<bigint>(buffer, false, 'bigint', network);\n  }\n\n  static createPsbt(opts: PsbtOpts, data?: PsbtBase): UtxoPsbt {\n    return new UtxoPsbt(\n      opts,\n      data || new PsbtBase(new PsbtTransaction({ tx: new UtxoTransaction<bigint>(opts.network) }))\n    );\n  }\n\n  static fromBuffer(buffer: Buffer, opts: PsbtOpts): UtxoPsbt {\n    const transactionFromBuffer: TransactionFromBuffer = (buffer: Buffer): ITransaction => {\n      const tx = this.transactionFromBuffer(buffer, opts.network);\n      return new PsbtTransaction({ tx });\n    };\n    const psbtBase = PsbtBase.fromBuffer(buffer, transactionFromBuffer, {\n      bip32PathsAbsolute: opts.bip32PathsAbsolute,\n    });\n    const psbt = this.createPsbt(opts, psbtBase);\n    // Upstream checks for duplicate inputs here, but it seems to be of dubious value.\n    return psbt;\n  }\n\n  static fromHex(data: string, opts: PsbtOpts): UtxoPsbt {\n    return this.fromBuffer(Buffer.from(data, 'hex'), opts);\n  }\n\n  get network(): Network {\n    return this.tx.network;\n  }\n\n  toHex(): string {\n    return this.toBuffer().toString('hex');\n  }\n\n  /**\n   * @return true iff PSBT input is finalized\n   */\n  isInputFinalized(inputIndex: number): boolean {\n    const input = checkForInput(this.data.inputs, inputIndex);\n    return Buffer.isBuffer(input.finalScriptSig) || Buffer.isBuffer(input.finalScriptWitness);\n  }\n\n  /**\n   * @return partialSig/tapScriptSig count iff input is not finalized\n   */\n  getSignatureCount(inputIndex: number): number {\n    if (this.isInputFinalized(inputIndex)) {\n      throw new Error('Input is already finalized');\n    }\n    const input = checkForInput(this.data.inputs, inputIndex);\n    return Math.max(\n      Array.isArray(input.partialSig) ? input.partialSig.length : 0,\n      Array.isArray(input.tapScriptSig) ? input.tapScriptSig.length : 0\n    );\n  }\n\n  getNonWitnessPreviousTxids(): string[] {\n    const txInputs = this.txInputs; // These are somewhat costly to extract\n    const txidSet = new Set<string>();\n    this.data.inputs.forEach((input, index) => {\n      if (!input.witnessUtxo) {\n        throw new Error('Must have witness UTXO for all inputs');\n      }\n      if (!isSegwit(input.witnessUtxo.script, input.redeemScript)) {\n        txidSet.add(getOutputIdForInput(txInputs[index]).txid);\n      }\n    });\n    return [...txidSet];\n  }\n\n  addNonWitnessUtxos(txBufs: Record<string, Buffer>): this {\n    const txInputs = this.txInputs; // These are somewhat costly to extract\n    this.data.inputs.forEach((input, index) => {\n      if (!input.witnessUtxo) {\n        throw new Error('Must have witness UTXO for all inputs');\n      }\n      if (!isSegwit(input.witnessUtxo.script, input.redeemScript)) {\n        const { txid } = getOutputIdForInput(txInputs[index]);\n        if (txBufs[txid] === undefined) {\n          throw new Error('Not all required previous transactions provided');\n        }\n        this.updateInput(index, { nonWitnessUtxo: txBufs[txid] });\n      }\n    });\n    return this;\n  }\n\n  static fromTransaction(transaction: UtxoTransaction<bigint>, prevOutputs: TxOutput<bigint>[]): UtxoPsbt {\n    if (prevOutputs.length !== transaction.ins.length) {\n      throw new Error(\n        `Transaction has ${transaction.ins.length} inputs, but ${prevOutputs.length} previous outputs provided`\n      );\n    }\n    const clonedTransaction = transaction.clone();\n    const updates = unsign(clonedTransaction, prevOutputs);\n\n    const psbtBase = new PsbtBase(new PsbtTransaction({ tx: clonedTransaction }));\n    clonedTransaction.ins.forEach(() => psbtBase.inputs.push({ unknownKeyVals: [] }));\n    clonedTransaction.outs.forEach(() => psbtBase.outputs.push({ unknownKeyVals: [] }));\n    const psbt = this.createPsbt({ network: transaction.network }, psbtBase);\n\n    updates.forEach((update, index) => {\n      psbt.updateInput(index, update);\n      psbt.updateInput(index, { witnessUtxo: { script: prevOutputs[index].script, value: prevOutputs[index].value } });\n    });\n\n    return psbt;\n  }\n\n  getUnsignedTx(): UtxoTransaction<bigint> {\n    return this.tx.clone();\n  }\n\n  protected static newTransaction(network: Network): UtxoTransaction<bigint> {\n    return new UtxoTransaction<bigint>(network);\n  }\n\n  protected get tx(): Tx {\n    return (this.data.globalMap.unsignedTx as PsbtTransaction).tx as Tx;\n  }\n\n  protected checkForSignatures(propName?: string): void {\n    this.data.inputs.forEach((input) => {\n      if (input.tapScriptSig?.length || input.tapKeySig || input.partialSig?.length) {\n        throw new Error(`Cannot modify ${propName ?? 'transaction'} - signatures exist.`);\n      }\n    });\n  }\n\n  /**\n   * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts\n   */\n  finalizeAllInputs(): this {\n    checkForInput(this.data.inputs, 0); // making sure we have at least one\n    this.data.inputs.map((input, idx) => {\n      return input.tapScriptSig?.length ? this.finalizeTaprootInput(idx) : this.finalizeInput(idx);\n    });\n    return this;\n  }\n\n  finalizeTaprootInput(inputIndex: number): this {\n    const input = checkForInput(this.data.inputs, inputIndex);\n    // witness = control-block script first-sig second-sig\n    if (input.tapLeafScript?.length !== 1) {\n      throw new Error('Only one leaf script supported for finalizing');\n    }\n    const { controlBlock, script } = input.tapLeafScript[0];\n    const witness: Buffer[] = [script, controlBlock];\n    const [pubkey1, pubkey2] = parsePubScript(script, 'p2tr').publicKeys;\n    for (const pk of [pubkey1, pubkey2]) {\n      const sig = input.tapScriptSig?.find(({ pubkey }) => pubkey.equals(pk));\n      if (!sig) {\n        throw new Error('Could not find signatures in Script Sig.');\n      }\n      witness.unshift(sig.signature);\n    }\n\n    const witnessLength = witness.reduce((s, b) => s + b.length + varuint.encodingLength(b.length), 1);\n\n    const bufferWriter = BufferWriter.withCapacity(witnessLength);\n    bufferWriter.writeVector(witness);\n    const finalScriptWitness = bufferWriter.end();\n\n    this.data.updateInput(inputIndex, { finalScriptWitness });\n    this.data.clearFinalizedInput(inputIndex);\n\n    return this;\n  }\n\n  finalizeTapInputWithSingleLeafScriptAndSignature(inputIndex: number): this {\n    const input = checkForInput(this.data.inputs, inputIndex);\n    if (input.tapLeafScript?.length !== 1) {\n      throw new Error('Only one leaf script supported for finalizing');\n    }\n    if (input.tapScriptSig?.length !== 1) {\n      throw new Error('Could not find signatures in Script Sig.');\n    }\n\n    const { controlBlock, script } = input.tapLeafScript[0];\n    const witness: Buffer[] = [input.tapScriptSig[0].signature, script, controlBlock];\n    const witnessLength = witness.reduce((s, b) => s + b.length + varuint.encodingLength(b.length), 1);\n\n    const bufferWriter = BufferWriter.withCapacity(witnessLength);\n    bufferWriter.writeVector(witness);\n    const finalScriptWitness = bufferWriter.end();\n\n    this.data.updateInput(inputIndex, { finalScriptWitness });\n    this.data.clearFinalizedInput(inputIndex);\n\n    return this;\n  }\n\n  /**\n   * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts\n   *\n   * Unlike the function it overrides, this does not take a validator. In BitGo\n   * context, we know how we want to validate so we just hard code the right\n   * validator.\n   */\n  validateSignaturesOfAllInputs(): boolean {\n    checkForInput(this.data.inputs, 0); // making sure we have at least one\n    const results = this.data.inputs.map((input, idx) => {\n      return input.tapScriptSig?.length\n        ? this.validateTaprootSignaturesOfInput(idx)\n        : this.validateSignaturesOfInput(idx, (p, m, s) => eccLib.verify(m, p, s));\n    });\n    return results.reduce((final, res) => res && final, true);\n  }\n\n  validateTaprootSignaturesOfInput(inputIndex: number, pubkey?: Buffer): boolean {\n    const input = this.data.inputs[inputIndex];\n    const tapSigs = (input || {}).tapScriptSig;\n    if (!input || !tapSigs || tapSigs.length < 1) {\n      throw new Error('No signatures to validate');\n    }\n    let mySigs;\n    if (pubkey) {\n      const xOnlyPubkey = toXOnlyPublicKey(pubkey);\n      mySigs = tapSigs.filter((sig) => sig.pubkey.equals(xOnlyPubkey));\n      if (mySigs.length < 1) {\n        throw new Error('No signatures for this pubkey');\n      }\n    } else {\n      mySigs = tapSigs;\n    }\n    const results: boolean[] = [];\n\n    for (const pSig of mySigs) {\n      const { signature, leafHash, pubkey } = pSig;\n      let sigHashType: number;\n      let sig: Buffer;\n      if (signature.length === 65) {\n        sigHashType = signature[64];\n        sig = signature.slice(0, 64);\n      } else {\n        sigHashType = Transaction.SIGHASH_DEFAULT;\n        sig = signature;\n      }\n      const { hash } = this.getTaprootHashForSig(inputIndex, [sigHashType], leafHash);\n      results.push(eccLib.verifySchnorr(hash, pubkey, sig));\n    }\n    return results.every((res) => res === true);\n  }\n\n  /**\n   * @return array of boolean values. True when corresponding index in `publicKeys` has signed the transaction.\n   * If no signature in the tx or no public key matching signature, the validation is considered as false.\n   */\n  getSignatureValidationArray(inputIndex: number): boolean[] {\n    const noSigErrorMessages = ['No signatures to validate', 'No signatures for this pubkey'];\n    const input = checkForInput(this.data.inputs, inputIndex);\n    const isP2tr = input.tapScriptSig?.length;\n    if (!this.data.globalMap.globalXpub) {\n      throw new Error('Cannot get signature validation array without global xpubs');\n    }\n    if (this.data.globalMap.globalXpub.length !== 3) {\n      throw new Error(`There must be 3 global xpubs and there are ${this.data.globalMap.globalXpub.length}`);\n    }\n    return this.data.globalMap.globalXpub.map((xpub) => {\n      // const bip32 = ECPair.fromPublicKey(xpub.extendedPubkey, { network: (this as any).opts.network });\n      const bip32 = BIP32Factory(eccLib).fromBase58(bs58check.encode(xpub.extendedPubkey));\n      try {\n        return isP2tr\n          ? this.validateTaprootSignaturesOfInput(inputIndex, bip32.publicKey)\n          : this.validateSignaturesOfInput(inputIndex, (p, m, s) => eccLib.verify(m, p, s), bip32.publicKey);\n      } catch (err) {\n        // Not an elegant solution. Might need upstream changes like custom error types.\n        if (noSigErrorMessages.includes(err.message)) {\n          return false;\n        }\n        throw err;\n      }\n    });\n  }\n\n  /**\n   * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts\n   */\n  signAllInputsHD(\n    hdKeyPair: HDTaprootSigner,\n    sighashTypes: number[] = [Transaction.SIGHASH_DEFAULT, Transaction.SIGHASH_ALL]\n  ): this {\n    if (!hdKeyPair || !hdKeyPair.publicKey || !hdKeyPair.fingerprint) {\n      throw new Error('Need HDSigner to sign input');\n    }\n\n    const results: boolean[] = [];\n    for (let i = 0; i < this.data.inputs.length; i++) {\n      try {\n        if (this.data.inputs[i].tapBip32Derivation?.length) {\n          this.signTaprootInputHD(i, hdKeyPair, sighashTypes);\n        } else {\n          this.signInputHD(i, hdKeyPair, sighashTypes);\n        }\n        results.push(true);\n      } catch (err) {\n        results.push(false);\n      }\n    }\n    if (results.every((v) => v === false)) {\n      throw new Error('No inputs were signed');\n    }\n    return this;\n  }\n\n  /**\n   * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts:signInputHD\n   */\n  signTaprootInputHD(\n    inputIndex: number,\n    hdKeyPair: HDTaprootSigner,\n    sighashTypes: number[] = [Transaction.SIGHASH_DEFAULT, Transaction.SIGHASH_ALL]\n  ): this {\n    if (!hdKeyPair || !hdKeyPair.publicKey || !hdKeyPair.fingerprint) {\n      throw new Error('Need HDSigner to sign input');\n    }\n    const input = checkForInput(this.data.inputs, inputIndex);\n    if (!input.tapBip32Derivation || input.tapBip32Derivation.length === 0) {\n      throw new Error('Need tapBip32Derivation to sign Taproot with HD');\n    }\n    const myDerivations = input.tapBip32Derivation\n      .map((bipDv) => {\n        if (bipDv.masterFingerprint.equals(hdKeyPair.fingerprint)) {\n          return bipDv;\n        }\n      })\n      .filter((v) => !!v) as TapBip32Derivation[];\n    if (myDerivations.length === 0) {\n      throw new Error('Need one tapBip32Derivation masterFingerprint to match the HDSigner fingerprint');\n    }\n    const signers: TaprootSigner[] = myDerivations.map((bipDv) => {\n      const node = hdKeyPair.derivePath(bipDv.path);\n      if (!bipDv.pubkey.equals(node.publicKey.slice(1))) {\n        throw new Error('pubkey did not match tapBip32Derivation');\n      }\n      return { signer: node, leafHashes: bipDv.leafHashes };\n    });\n    signers.forEach(({ signer, leafHashes }) => this.signTaprootInput(inputIndex, signer, leafHashes, sighashTypes));\n    return this;\n  }\n\n  signTaprootInput(\n    inputIndex: number,\n    signer: SchnorrSigner,\n    leafHashes: Buffer[],\n    sighashTypes: number[] = [Transaction.SIGHASH_DEFAULT, Transaction.SIGHASH_ALL]\n  ): this {\n    const pubkey = toXOnlyPublicKey(signer.publicKey);\n    const input = checkForInput(this.data.inputs, inputIndex);\n    // Figure out if this is script path or not, if not, tweak the private key\n    if (!input.tapLeafScript?.length) {\n      // See BitGo/BitGoJS/modules/utxo_lib/src/transaction_builder.ts:trySign for how to support it.\n      throw new Error('Taproot key path signing is not supported.');\n    }\n    if (input.tapLeafScript.length !== 1) {\n      throw new Error('Only one leaf script supported for signing');\n    }\n    const tapLeafScript = input.tapLeafScript[0];\n    const parsedControlBlock = taproot.parseControlBlock(eccLib, tapLeafScript.controlBlock);\n    const { leafVersion } = parsedControlBlock;\n    if (leafVersion !== tapLeafScript.leafVersion) {\n      throw new Error('Tap script leaf version mismatch with control block');\n    }\n    const leafHash = taproot.getTapleafHash(eccLib, parsedControlBlock, tapLeafScript.script);\n    if (!leafHashes.find((l) => l.equals(leafHash))) {\n      throw new Error(`Signer cannot sign for leaf hash ${leafHash.toString('hex')}`);\n    }\n    const { hash, sighashType } = this.getTaprootHashForSig(inputIndex, sighashTypes, leafHash);\n    let signature = signer.signSchnorr(hash);\n    if (sighashType !== Transaction.SIGHASH_DEFAULT) {\n      signature = Buffer.concat([signature, Buffer.of(sighashType)]);\n    }\n    this.data.updateInput(inputIndex, {\n      tapScriptSig: [\n        {\n          pubkey,\n          signature,\n          leafHash,\n        },\n      ],\n    });\n    return this;\n  }\n\n  private getTaprootHashForSig(\n    inputIndex: number,\n    sighashTypes?: number[],\n    leafHash?: Buffer\n  ): {\n    hash: Buffer;\n    sighashType: number;\n  } {\n    const sighashType = this.data.inputs[inputIndex].sighashType || Transaction.SIGHASH_DEFAULT;\n    if (sighashTypes && sighashTypes.indexOf(sighashType) < 0) {\n      throw new Error(\n        `Sighash type is not allowed. Retry the sign method passing the ` +\n          `sighashTypes array of whitelisted types. Sighash type: ${sighashType}`\n      );\n    }\n    const txInputs = this.txInputs; // These are somewhat costly to extract\n    const prevoutScripts: Buffer[] = [];\n    const prevoutValues: bigint[] = [];\n\n    this.data.inputs.forEach((input, i) => {\n      let prevout;\n      if (input.nonWitnessUtxo) {\n        // TODO: This could be costly, either cache it here, or find a way to share with super\n        const nonWitnessUtxoTx = (this.constructor as typeof UtxoPsbt).transactionFromBuffer(\n          input.nonWitnessUtxo,\n          this.tx.network\n        );\n\n        const prevoutHash = txInputs[i].hash;\n        const utxoHash = nonWitnessUtxoTx.getHash();\n\n        // If a non-witness UTXO is provided, its hash must match the hash specified in the prevout\n        if (!prevoutHash.equals(utxoHash)) {\n          throw new Error(`Non-witness UTXO hash for input #${i} doesn't match the hash specified in the prevout`);\n        }\n\n        const prevoutIndex = txInputs[i].index;\n        prevout = nonWitnessUtxoTx.outs[prevoutIndex];\n      } else if (input.witnessUtxo) {\n        prevout = input.witnessUtxo;\n      } else {\n        throw new Error('Need a Utxo input item for signing');\n      }\n      prevoutScripts.push(prevout.script);\n      prevoutValues.push(prevout.value);\n    });\n    const hash = this.tx.hashForWitnessV1(inputIndex, prevoutScripts, prevoutValues, sighashType, leafHash);\n    return { hash, sighashType };\n  }\n\n  /**\n   * @retuns true iff the input is taproot.\n   */\n  isTaprootInput(inputIndex: number): boolean {\n    const input = checkForInput(this.data.inputs, inputIndex);\n    function isP2tr(output: Buffer): boolean {\n      try {\n        p2trPayments.p2tr({ output }, { eccLib });\n        return true;\n      } catch (err) {\n        return false;\n      }\n    }\n    return !!(\n      input.tapInternalKey ||\n      input.tapMerkleRoot ||\n      (input.tapLeafScript && input.tapLeafScript.length) ||\n      (input.tapBip32Derivation && input.tapBip32Derivation.length) ||\n      (input.witnessUtxo && isP2tr(input.witnessUtxo.script))\n    );\n  }\n\n  /**\n   * @returns hash and hashType for taproot input at inputIndex\n   * @throws error if input at inputIndex is not a taproot input\n   */\n  getTaprootHashForSigChecked(\n    inputIndex: number,\n    sighashTypes: number[] = [Transaction.SIGHASH_DEFAULT, Transaction.SIGHASH_ALL],\n    leafHash?: Buffer\n  ): {\n    hash: Buffer;\n    sighashType: number;\n  } {\n    if (!this.isTaprootInput(inputIndex)) {\n      throw new Error(`${inputIndex} input is not a taproot type to take taproot tx hash`);\n    }\n    return this.getTaprootHashForSig(inputIndex, sighashTypes, leafHash);\n  }\n\n  /**\n   * Adds proprietary key value pair to PSBT input.\n   * Default identifierEncoding is utf-8 for identifier.\n   */\n  addProprietaryKeyValToInput(inputIndex: number, keyValueData: ProprietaryKeyValueData): this {\n    return this.addUnknownKeyValToInput(inputIndex, {\n      key: encodeProprietaryKey(keyValueData.key),\n      value: keyValueData.value,\n    });\n  }\n\n  /**\n   * To search any data from proprietary key value againts keydata.\n   * Default identifierEncoding is utf-8 for identifier.\n   */\n  getProprietaryKeyVals(inputIndex: number, keySearch?: ProprietaryKeySearch): ProprietaryKeyValueData[] {\n    const input = checkForInput(this.data.inputs, inputIndex);\n    if (!input.unknownKeyVals || input.unknownKeyVals.length === 0) {\n      return [];\n    }\n    const keyVals = input.unknownKeyVals.map(({ key, value }, i) => {\n      return { key: decodeProprietaryKey(key), value };\n    });\n    return keyVals.filter((keyVal) => {\n      return (\n        keySearch === undefined ||\n        (keySearch.identifier === keyVal.key.identifier &&\n          keySearch.subtype === keyVal.key.subtype &&\n          (!Buffer.isBuffer(keySearch.keydata) || keySearch.keydata.equals(keyVal.key.keydata)))\n      );\n    });\n  }\n\n  clone(): this {\n    return super.clone() as this;\n  }\n}\n"]}
@@ -0,0 +1,22 @@
1
+ /// <reference types="node" />
2
+ import * as bitcoinjs from 'bitcoinjs-lib';
3
+ import { Network } from '../networks';
4
+ export declare function varSliceSize(slice: Buffer): number;
5
+ export declare class UtxoTransaction<TNumber extends number | bigint = number> extends bitcoinjs.Transaction<TNumber> {
6
+ network: Network;
7
+ static SIGHASH_FORKID: number;
8
+ /** @deprecated use SIGHASH_FORKID */
9
+ static SIGHASH_BITCOINCASHBIP143: number;
10
+ constructor(network: Network, transaction?: bitcoinjs.Transaction<bigint | number>, amountType?: 'bigint' | 'number');
11
+ protected static newTransaction<TNumber extends number | bigint = number>(network: Network, transaction?: bitcoinjs.Transaction<bigint | number>, amountType?: 'number' | 'bigint'): UtxoTransaction<TNumber>;
12
+ static fromBuffer<TNumber extends number | bigint = number>(buf: Buffer, noStrict: boolean, amountType?: 'number' | 'bigint', network?: Network, prevOutput?: bitcoinjs.TxOutput<TNumber>[]): UtxoTransaction<TNumber>;
13
+ addForkId(hashType: number): number;
14
+ hashForWitnessV0(inIndex: number, prevOutScript: Buffer, value: TNumber, hashType: number): Buffer;
15
+ /**
16
+ * Calculate the hash to verify the signature against
17
+ */
18
+ hashForSignatureByNetwork(inIndex: number, prevoutScript: Buffer, value: TNumber | undefined, hashType: number): Buffer;
19
+ hashForSignature(inIndex: number, prevOutScript: Buffer, hashType: number, value?: TNumber): Buffer;
20
+ clone<TN2 extends bigint | number = TNumber>(amountType?: 'number' | 'bigint'): UtxoTransaction<TN2>;
21
+ }
22
+ //# sourceMappingURL=UtxoTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UtxoTransaction.d.ts","sourceRoot":"","sources":["../../../src/bitgo/UtxoTransaction.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,SAAS,MAAM,eAAe,CAAC;AAI3C,OAAO,EAAY,OAAO,EAA6B,MAAM,aAAa,CAAC;AAE3E,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAGlD;AAED,qBAAa,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC;IAMlG,OAAO,EAAE,OAAO;IALzB,MAAM,CAAC,cAAc,SAAQ;IAC7B,qCAAqC;IACrC,MAAM,CAAC,yBAAyB,SAAkC;gBAGzD,OAAO,EAAE,OAAO,EACvB,WAAW,CAAC,EAAE,SAAS,CAAC,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC,EACpD,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ;IAiBlC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,EACtE,OAAO,EAAE,OAAO,EAChB,WAAW,CAAC,EAAE,SAAS,CAAC,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC,EACpD,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,GAC/B,eAAe,CAAC,OAAO,CAAC;IAI3B,MAAM,CAAC,UAAU,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,EACxD,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,OAAO,EACjB,UAAU,GAAE,QAAQ,GAAG,QAAmB,EAC1C,OAAO,CAAC,EAAE,OAAO,EACjB,UAAU,CAAC,EAAE,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,GACzC,eAAe,CAAC,OAAO,CAAC;IAW3B,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM;IASnC,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;IAIlG;;OAEG;IACH,yBAAyB,CACvB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,EACrB,KAAK,EAAE,OAAO,GAAG,SAAS,EAC1B,QAAQ,EAAE,MAAM,GACf,MAAM;IAkCT,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,MAAM;IAKnG,KAAK,CAAC,GAAG,SAAS,MAAM,GAAG,MAAM,GAAG,OAAO,EAAE,UAAU,CAAC,EAAE,QAAQ,GAAG,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC;CAIrG"}