@btc-vision/bitcoin 7.0.0-alpha.0 → 7.0.0-alpha.10

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 (369) hide show
  1. package/README.md +455 -155
  2. package/browser/address.d.ts +6 -2
  3. package/browser/address.d.ts.map +1 -1
  4. package/browser/block.d.ts.map +1 -1
  5. package/browser/branded.d.ts +3 -14
  6. package/browser/branded.d.ts.map +1 -1
  7. package/browser/chunks/psbt-parallel-BBFlkmiv.js +10717 -0
  8. package/browser/crypto.d.ts +1 -1
  9. package/browser/ecc/context.d.ts +25 -24
  10. package/browser/ecc/context.d.ts.map +1 -1
  11. package/browser/ecc/index.d.ts +1 -1
  12. package/browser/ecc/index.d.ts.map +1 -1
  13. package/browser/ecc/types.d.ts +10 -123
  14. package/browser/ecc/types.d.ts.map +1 -1
  15. package/browser/env.d.ts +13 -0
  16. package/browser/env.d.ts.map +1 -0
  17. package/browser/index.d.ts +7 -7
  18. package/browser/index.d.ts.map +1 -1
  19. package/browser/index.js +2497 -11686
  20. package/browser/io/BinaryReader.d.ts +15 -15
  21. package/browser/io/BinaryReader.d.ts.map +1 -1
  22. package/browser/io/BinaryWriter.d.ts +17 -17
  23. package/browser/io/BinaryWriter.d.ts.map +1 -1
  24. package/browser/io/hex.d.ts.map +1 -1
  25. package/browser/io/index.d.ts +0 -1
  26. package/browser/io/index.d.ts.map +1 -1
  27. package/browser/opcodes.d.ts +11 -0
  28. package/browser/opcodes.d.ts.map +1 -1
  29. package/browser/payments/bip341.d.ts +1 -1
  30. package/browser/payments/bip341.d.ts.map +1 -1
  31. package/browser/payments/embed.d.ts +1 -1
  32. package/browser/payments/embed.d.ts.map +1 -1
  33. package/browser/payments/p2ms.d.ts.map +1 -1
  34. package/browser/payments/p2op.d.ts +1 -1
  35. package/browser/payments/p2op.d.ts.map +1 -1
  36. package/browser/payments/p2pk.d.ts +1 -1
  37. package/browser/payments/p2pk.d.ts.map +1 -1
  38. package/browser/payments/p2pkh.d.ts +1 -1
  39. package/browser/payments/p2pkh.d.ts.map +1 -1
  40. package/browser/payments/p2sh.d.ts.map +1 -1
  41. package/browser/payments/p2tr.d.ts +2 -2
  42. package/browser/payments/p2tr.d.ts.map +1 -1
  43. package/browser/payments/p2wpkh.d.ts +1 -1
  44. package/browser/payments/p2wpkh.d.ts.map +1 -1
  45. package/browser/payments/p2wsh.d.ts.map +1 -1
  46. package/browser/payments/types.d.ts +1 -1
  47. package/browser/payments/types.d.ts.map +1 -1
  48. package/browser/psbt/PsbtCache.d.ts +54 -0
  49. package/browser/psbt/PsbtCache.d.ts.map +1 -0
  50. package/browser/psbt/PsbtFinalizer.d.ts +21 -0
  51. package/browser/psbt/PsbtFinalizer.d.ts.map +1 -0
  52. package/browser/psbt/PsbtSigner.d.ts +32 -0
  53. package/browser/psbt/PsbtSigner.d.ts.map +1 -0
  54. package/browser/psbt/PsbtTransaction.d.ts +25 -0
  55. package/browser/psbt/PsbtTransaction.d.ts.map +1 -0
  56. package/browser/psbt/bip371.d.ts.map +1 -1
  57. package/browser/psbt/types.d.ts +5 -71
  58. package/browser/psbt/types.d.ts.map +1 -1
  59. package/browser/psbt/validation.d.ts +1 -1
  60. package/browser/psbt/validation.d.ts.map +1 -1
  61. package/browser/psbt.d.ts +26 -40
  62. package/browser/psbt.d.ts.map +1 -1
  63. package/browser/script.d.ts.map +1 -1
  64. package/browser/transaction.d.ts +4 -4
  65. package/browser/transaction.d.ts.map +1 -1
  66. package/browser/types.d.ts +5 -3
  67. package/browser/types.d.ts.map +1 -1
  68. package/browser/workers/WorkerSigningPool.d.ts +24 -17
  69. package/browser/workers/WorkerSigningPool.d.ts.map +1 -1
  70. package/browser/workers/WorkerSigningPool.node.d.ts +19 -12
  71. package/browser/workers/WorkerSigningPool.node.d.ts.map +1 -1
  72. package/browser/workers/WorkerSigningPool.sequential.d.ts +67 -0
  73. package/browser/workers/WorkerSigningPool.sequential.d.ts.map +1 -0
  74. package/browser/workers/WorkerSigningPool.worklet.d.ts +64 -0
  75. package/browser/workers/WorkerSigningPool.worklet.d.ts.map +1 -0
  76. package/browser/workers/index.browser.d.ts +16 -0
  77. package/browser/workers/index.browser.d.ts.map +1 -0
  78. package/browser/workers/index.d.ts +4 -64
  79. package/browser/workers/index.d.ts.map +1 -1
  80. package/browser/workers/index.js +28 -0
  81. package/browser/workers/index.node.d.ts +17 -0
  82. package/browser/workers/index.node.d.ts.map +1 -0
  83. package/browser/workers/index.react-native.d.ts +28 -0
  84. package/browser/workers/index.react-native.d.ts.map +1 -0
  85. package/browser/workers/index.shared.d.ts +15 -0
  86. package/browser/workers/index.shared.d.ts.map +1 -0
  87. package/browser/workers/psbt-parallel.d.ts +2 -3
  88. package/browser/workers/psbt-parallel.d.ts.map +1 -1
  89. package/browser/workers/types.d.ts +17 -0
  90. package/browser/workers/types.d.ts.map +1 -1
  91. package/build/address.d.ts +6 -2
  92. package/build/address.d.ts.map +1 -1
  93. package/build/address.js +32 -19
  94. package/build/address.js.map +1 -1
  95. package/build/bech32utils.js.map +1 -1
  96. package/build/block.d.ts.map +1 -1
  97. package/build/block.js +2 -4
  98. package/build/block.js.map +1 -1
  99. package/build/branded.d.ts +3 -14
  100. package/build/branded.d.ts.map +1 -1
  101. package/build/branded.js +0 -5
  102. package/build/branded.js.map +1 -1
  103. package/build/crypto.d.ts +1 -1
  104. package/build/ecc/context.d.ts +25 -24
  105. package/build/ecc/context.d.ts.map +1 -1
  106. package/build/ecc/context.js +29 -101
  107. package/build/ecc/context.js.map +1 -1
  108. package/build/ecc/index.d.ts +1 -1
  109. package/build/ecc/index.d.ts.map +1 -1
  110. package/build/ecc/types.d.ts +7 -126
  111. package/build/ecc/types.d.ts.map +1 -1
  112. package/build/ecc/types.js +4 -1
  113. package/build/ecc/types.js.map +1 -1
  114. package/build/env.d.ts +13 -0
  115. package/build/env.d.ts.map +1 -0
  116. package/build/env.js +198 -0
  117. package/build/env.js.map +1 -0
  118. package/build/index.d.ts +8 -7
  119. package/build/index.d.ts.map +1 -1
  120. package/build/index.js +9 -7
  121. package/build/index.js.map +1 -1
  122. package/build/io/BinaryReader.d.ts +15 -15
  123. package/build/io/BinaryReader.d.ts.map +1 -1
  124. package/build/io/BinaryReader.js +17 -17
  125. package/build/io/BinaryReader.js.map +1 -1
  126. package/build/io/BinaryWriter.d.ts +17 -17
  127. package/build/io/BinaryWriter.d.ts.map +1 -1
  128. package/build/io/BinaryWriter.js +39 -39
  129. package/build/io/BinaryWriter.js.map +1 -1
  130. package/build/io/hex.d.ts.map +1 -1
  131. package/build/io/hex.js +2 -1
  132. package/build/io/hex.js.map +1 -1
  133. package/build/io/index.d.ts +0 -1
  134. package/build/io/index.d.ts.map +1 -1
  135. package/build/io/index.js +0 -2
  136. package/build/io/index.js.map +1 -1
  137. package/build/opcodes.d.ts +11 -0
  138. package/build/opcodes.d.ts.map +1 -1
  139. package/build/opcodes.js +19 -4
  140. package/build/opcodes.js.map +1 -1
  141. package/build/payments/bip341.d.ts +1 -2
  142. package/build/payments/bip341.d.ts.map +1 -1
  143. package/build/payments/bip341.js +1 -2
  144. package/build/payments/bip341.js.map +1 -1
  145. package/build/payments/embed.d.ts +1 -1
  146. package/build/payments/embed.d.ts.map +1 -1
  147. package/build/payments/embed.js +14 -14
  148. package/build/payments/embed.js.map +1 -1
  149. package/build/payments/p2ms.d.ts.map +1 -1
  150. package/build/payments/p2ms.js +21 -21
  151. package/build/payments/p2ms.js.map +1 -1
  152. package/build/payments/p2op.d.ts +1 -1
  153. package/build/payments/p2op.d.ts.map +1 -1
  154. package/build/payments/p2op.js +18 -18
  155. package/build/payments/p2op.js.map +1 -1
  156. package/build/payments/p2pk.d.ts +1 -1
  157. package/build/payments/p2pk.d.ts.map +1 -1
  158. package/build/payments/p2pk.js +17 -17
  159. package/build/payments/p2pk.js.map +1 -1
  160. package/build/payments/p2pkh.d.ts +1 -1
  161. package/build/payments/p2pkh.d.ts.map +1 -1
  162. package/build/payments/p2pkh.js +20 -20
  163. package/build/payments/p2pkh.js.map +1 -1
  164. package/build/payments/p2sh.d.ts.map +1 -1
  165. package/build/payments/p2sh.js +22 -20
  166. package/build/payments/p2sh.js.map +1 -1
  167. package/build/payments/p2tr.d.ts +2 -2
  168. package/build/payments/p2tr.d.ts.map +1 -1
  169. package/build/payments/p2tr.js +25 -26
  170. package/build/payments/p2tr.js.map +1 -1
  171. package/build/payments/p2wpkh.d.ts +1 -1
  172. package/build/payments/p2wpkh.d.ts.map +1 -1
  173. package/build/payments/p2wpkh.js +20 -20
  174. package/build/payments/p2wpkh.js.map +1 -1
  175. package/build/payments/p2wsh.d.ts.map +1 -1
  176. package/build/payments/p2wsh.js +22 -22
  177. package/build/payments/p2wsh.js.map +1 -1
  178. package/build/payments/types.d.ts +1 -1
  179. package/build/payments/types.d.ts.map +1 -1
  180. package/build/psbt/PsbtCache.d.ts +54 -0
  181. package/build/psbt/PsbtCache.d.ts.map +1 -0
  182. package/build/psbt/PsbtCache.js +249 -0
  183. package/build/psbt/PsbtCache.js.map +1 -0
  184. package/build/psbt/PsbtFinalizer.d.ts +21 -0
  185. package/build/psbt/PsbtFinalizer.d.ts.map +1 -0
  186. package/build/psbt/PsbtFinalizer.js +157 -0
  187. package/build/psbt/PsbtFinalizer.js.map +1 -0
  188. package/build/psbt/PsbtSigner.d.ts +32 -0
  189. package/build/psbt/PsbtSigner.d.ts.map +1 -0
  190. package/build/psbt/PsbtSigner.js +192 -0
  191. package/build/psbt/PsbtSigner.js.map +1 -0
  192. package/build/psbt/PsbtTransaction.d.ts +25 -0
  193. package/build/psbt/PsbtTransaction.d.ts.map +1 -0
  194. package/build/psbt/PsbtTransaction.js +61 -0
  195. package/build/psbt/PsbtTransaction.js.map +1 -0
  196. package/build/psbt/bip371.d.ts.map +1 -1
  197. package/build/psbt/bip371.js +6 -2
  198. package/build/psbt/bip371.js.map +1 -1
  199. package/build/psbt/psbtutils.js +1 -1
  200. package/build/psbt/psbtutils.js.map +1 -1
  201. package/build/psbt/types.d.ts +5 -71
  202. package/build/psbt/types.d.ts.map +1 -1
  203. package/build/psbt/validation.d.ts +1 -1
  204. package/build/psbt/validation.d.ts.map +1 -1
  205. package/build/psbt/validation.js +1 -1
  206. package/build/psbt/validation.js.map +1 -1
  207. package/build/psbt.d.ts +26 -40
  208. package/build/psbt.d.ts.map +1 -1
  209. package/build/psbt.js +180 -808
  210. package/build/psbt.js.map +1 -1
  211. package/build/script.d.ts.map +1 -1
  212. package/build/script.js +4 -4
  213. package/build/script.js.map +1 -1
  214. package/build/transaction.d.ts +4 -4
  215. package/build/transaction.d.ts.map +1 -1
  216. package/build/transaction.js +6 -5
  217. package/build/transaction.js.map +1 -1
  218. package/build/tsconfig.build.tsbuildinfo +1 -1
  219. package/build/types.d.ts +5 -3
  220. package/build/types.d.ts.map +1 -1
  221. package/build/types.js +14 -25
  222. package/build/types.js.map +1 -1
  223. package/build/workers/WorkerSigningPool.d.ts +24 -17
  224. package/build/workers/WorkerSigningPool.d.ts.map +1 -1
  225. package/build/workers/WorkerSigningPool.js +36 -25
  226. package/build/workers/WorkerSigningPool.js.map +1 -1
  227. package/build/workers/WorkerSigningPool.node.d.ts +19 -12
  228. package/build/workers/WorkerSigningPool.node.d.ts.map +1 -1
  229. package/build/workers/WorkerSigningPool.node.js +60 -28
  230. package/build/workers/WorkerSigningPool.node.js.map +1 -1
  231. package/build/workers/WorkerSigningPool.sequential.d.ts +76 -0
  232. package/build/workers/WorkerSigningPool.sequential.d.ts.map +1 -0
  233. package/build/workers/WorkerSigningPool.sequential.js +160 -0
  234. package/build/workers/WorkerSigningPool.sequential.js.map +1 -0
  235. package/build/workers/WorkerSigningPool.worklet.d.ts +79 -0
  236. package/build/workers/WorkerSigningPool.worklet.d.ts.map +1 -0
  237. package/build/workers/WorkerSigningPool.worklet.js +390 -0
  238. package/build/workers/WorkerSigningPool.worklet.js.map +1 -0
  239. package/build/workers/index.browser.d.ts +24 -0
  240. package/build/workers/index.browser.d.ts.map +1 -0
  241. package/build/workers/index.browser.js +30 -0
  242. package/build/workers/index.browser.js.map +1 -0
  243. package/build/workers/index.d.ts +6 -18
  244. package/build/workers/index.d.ts.map +1 -1
  245. package/build/workers/index.js +12 -14
  246. package/build/workers/index.js.map +1 -1
  247. package/build/workers/index.node.d.ts +38 -0
  248. package/build/workers/index.node.d.ts.map +1 -0
  249. package/build/workers/index.node.js +45 -0
  250. package/build/workers/index.node.js.map +1 -0
  251. package/build/workers/index.react-native.d.ts +28 -0
  252. package/build/workers/index.react-native.d.ts.map +1 -0
  253. package/build/workers/index.react-native.js +67 -0
  254. package/build/workers/index.react-native.js.map +1 -0
  255. package/build/workers/index.shared.d.ts +15 -0
  256. package/build/workers/index.shared.d.ts.map +1 -0
  257. package/build/workers/index.shared.js +20 -0
  258. package/build/workers/index.shared.js.map +1 -0
  259. package/build/workers/psbt-parallel.d.ts +2 -3
  260. package/build/workers/psbt-parallel.d.ts.map +1 -1
  261. package/build/workers/psbt-parallel.js +4 -4
  262. package/build/workers/psbt-parallel.js.map +1 -1
  263. package/build/workers/types.d.ts +17 -0
  264. package/build/workers/types.d.ts.map +1 -1
  265. package/build/workers/types.js.map +1 -1
  266. package/package.json +48 -9
  267. package/src/address.ts +53 -21
  268. package/src/bech32utils.ts +3 -3
  269. package/src/block.ts +17 -10
  270. package/src/branded.ts +15 -13
  271. package/src/crypto.ts +1 -1
  272. package/src/ecc/context.ts +36 -136
  273. package/src/ecc/index.ts +2 -2
  274. package/src/ecc/types.ts +7 -145
  275. package/src/env.ts +239 -0
  276. package/src/index.ts +57 -22
  277. package/src/io/BinaryReader.ts +18 -18
  278. package/src/io/BinaryWriter.ts +43 -43
  279. package/src/io/hex.ts +2 -1
  280. package/src/io/index.ts +0 -3
  281. package/src/opcodes.ts +21 -4
  282. package/src/payments/bip341.ts +5 -7
  283. package/src/payments/embed.ts +19 -19
  284. package/src/payments/p2ms.ts +34 -27
  285. package/src/payments/p2op.ts +22 -22
  286. package/src/payments/p2pk.ts +22 -22
  287. package/src/payments/p2pkh.ts +28 -28
  288. package/src/payments/p2sh.ts +33 -30
  289. package/src/payments/p2tr.ts +40 -40
  290. package/src/payments/p2wpkh.ts +30 -30
  291. package/src/payments/p2wsh.ts +29 -29
  292. package/src/payments/types.ts +1 -1
  293. package/src/psbt/PsbtCache.ts +325 -0
  294. package/src/psbt/PsbtFinalizer.ts +213 -0
  295. package/src/psbt/PsbtSigner.ts +302 -0
  296. package/src/psbt/PsbtTransaction.ts +82 -0
  297. package/src/psbt/bip371.ts +7 -3
  298. package/src/psbt/psbtutils.ts +1 -1
  299. package/src/psbt/types.ts +5 -94
  300. package/src/psbt/validation.ts +5 -12
  301. package/src/psbt.ts +376 -1201
  302. package/src/script.ts +6 -9
  303. package/src/transaction.ts +19 -15
  304. package/src/types.ts +33 -45
  305. package/src/workers/WorkerSigningPool.node.ts +72 -36
  306. package/src/workers/WorkerSigningPool.sequential.ts +191 -0
  307. package/src/workers/WorkerSigningPool.ts +48 -39
  308. package/src/workers/WorkerSigningPool.worklet.ts +522 -0
  309. package/src/workers/index.browser.ts +34 -0
  310. package/src/workers/index.node.ts +50 -0
  311. package/src/workers/index.react-native.ts +110 -0
  312. package/src/workers/index.shared.ts +58 -0
  313. package/src/workers/index.ts +14 -65
  314. package/src/workers/psbt-parallel.ts +8 -13
  315. package/src/workers/types.ts +26 -1
  316. package/test/address.spec.ts +2 -2
  317. package/test/bitcoin.core.spec.ts +5 -2
  318. package/test/browser/payments.spec.ts +151 -0
  319. package/test/browser/psbt.spec.ts +1510 -0
  320. package/test/browser/script.spec.ts +223 -0
  321. package/test/browser/setup.ts +13 -0
  322. package/test/browser/workers-signing.spec.ts +537 -0
  323. package/test/crypto.spec.ts +2 -2
  324. package/test/env.spec.ts +418 -0
  325. package/test/fixtures/core/base58_encode_decode.json +12 -48
  326. package/test/fixtures/core/base58_keys_invalid.json +50 -150
  327. package/test/fixtures/core/sighash.json +1 -3
  328. package/test/fixtures/core/tx_valid.json +133 -501
  329. package/test/fixtures/embed.json +3 -11
  330. package/test/fixtures/p2ms.json +21 -91
  331. package/test/fixtures/p2pk.json +5 -24
  332. package/test/fixtures/p2pkh.json +7 -36
  333. package/test/fixtures/p2sh.json +8 -54
  334. package/test/fixtures/p2tr.json +2 -6
  335. package/test/fixtures/p2wpkh.json +7 -36
  336. package/test/fixtures/p2wsh.json +14 -59
  337. package/test/fixtures/psbt.json +2 -6
  338. package/test/fixtures/script.json +12 -48
  339. package/test/integration/addresses.spec.ts +11 -5
  340. package/test/integration/bip32.spec.ts +1 -1
  341. package/test/integration/cltv.spec.ts +10 -6
  342. package/test/integration/csv.spec.ts +10 -9
  343. package/test/integration/payments.spec.ts +8 -4
  344. package/test/integration/taproot.spec.ts +26 -6
  345. package/test/integration/transactions.spec.ts +22 -8
  346. package/test/payments.spec.ts +1 -1
  347. package/test/payments.utils.ts +1 -1
  348. package/test/psbt.spec.ts +250 -64
  349. package/test/script_signature.spec.ts +1 -1
  350. package/test/transaction.spec.ts +18 -5
  351. package/test/tsconfig.json +6 -20
  352. package/test/workers-pool.spec.ts +65 -23
  353. package/test/workers-sequential.spec.ts +669 -0
  354. package/test/workers-signing.spec.ts +7 -3
  355. package/test/workers-worklet.spec.ts +500 -0
  356. package/test/workers.spec.ts +6 -7
  357. package/typedoc.json +39 -0
  358. package/vite.config.browser.ts +31 -6
  359. package/vitest.config.browser.ts +68 -0
  360. package/browser/ecpair.d.ts +0 -99
  361. package/browser/io/MemoryPool.d.ts +0 -220
  362. package/browser/io/MemoryPool.d.ts.map +0 -1
  363. package/build/io/MemoryPool.d.ts +0 -220
  364. package/build/io/MemoryPool.d.ts.map +0 -1
  365. package/build/io/MemoryPool.js +0 -309
  366. package/build/io/MemoryPool.js.map +0 -1
  367. package/src/ecpair.d.ts +0 -99
  368. package/src/io/MemoryPool.ts +0 -343
  369. package/test/taproot-cache.spec.ts +0 -694
@@ -0,0 +1,249 @@
1
+ import * as bscript from '../script.js';
2
+ import { isP2TR, isP2WPKH, pubkeyInScript } from './psbtutils.js';
3
+ import { getMeaningfulScript, isPubkeyLike, isSigLike, scriptWitnessToWitnessStack, } from './utils.js';
4
+ import { isFinalized } from './validation.js';
5
+ import { isUnknownSegwitVersion } from '../address.js';
6
+ /**
7
+ * Internal PSBT cache for computed values.
8
+ * Wraps all cache management previously handled by a plain interface + scattered helper functions.
9
+ */
10
+ export class PsbtCache {
11
+ nonWitnessUtxoTxCache;
12
+ nonWitnessUtxoBufCache;
13
+ txInCache;
14
+ tx;
15
+ unsafeSignNonSegwit;
16
+ hasSignatures;
17
+ fee;
18
+ feeRate;
19
+ extractedTx;
20
+ prevOuts;
21
+ signingScripts;
22
+ values;
23
+ taprootHashCache;
24
+ constructor(tx) {
25
+ this.nonWitnessUtxoTxCache = [];
26
+ this.nonWitnessUtxoBufCache = [];
27
+ this.txInCache = {};
28
+ this.tx = tx;
29
+ this.unsafeSignNonSegwit = false;
30
+ this.hasSignatures = false;
31
+ }
32
+ /**
33
+ * Invalidates cached computed values.
34
+ * @param scope - 'full' clears everything (for input changes), 'outputs' clears fee/extract/taproot caches
35
+ */
36
+ invalidate(scope) {
37
+ this.fee = undefined;
38
+ this.feeRate = undefined;
39
+ this.extractedTx = undefined;
40
+ this.taprootHashCache = undefined;
41
+ if (scope === 'full') {
42
+ this.prevOuts = undefined;
43
+ this.signingScripts = undefined;
44
+ this.values = undefined;
45
+ }
46
+ }
47
+ addNonWitnessTxCache(input, inputIndex, txFromBuffer) {
48
+ if (!input.nonWitnessUtxo)
49
+ throw new Error('nonWitnessUtxo is required');
50
+ if (input === null || input === Object.prototype) {
51
+ throw new Error('Invalid input object');
52
+ }
53
+ const nonWitnessUtxoBuf = input.nonWitnessUtxo;
54
+ this.nonWitnessUtxoBufCache[inputIndex] = nonWitnessUtxoBuf;
55
+ this.nonWitnessUtxoTxCache[inputIndex] = txFromBuffer(nonWitnessUtxoBuf);
56
+ }
57
+ getNonWitnessUtxoTx(input, inputIndex, txFromBuffer) {
58
+ const cached = this.nonWitnessUtxoTxCache[inputIndex];
59
+ if (!cached) {
60
+ this.addNonWitnessTxCache(input, inputIndex, txFromBuffer);
61
+ }
62
+ return this.nonWitnessUtxoTxCache[inputIndex];
63
+ }
64
+ getScriptFromUtxo(inputIndex, input, txFromBuffer) {
65
+ const { script } = this.getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer);
66
+ return script;
67
+ }
68
+ getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer) {
69
+ if (input.witnessUtxo !== undefined) {
70
+ return {
71
+ script: input.witnessUtxo.script,
72
+ value: input.witnessUtxo.value,
73
+ };
74
+ }
75
+ else if (input.nonWitnessUtxo !== undefined) {
76
+ const nonWitnessUtxoTx = this.getNonWitnessUtxoTx(input, inputIndex, txFromBuffer);
77
+ const o = nonWitnessUtxoTx.outs[this.tx.ins[inputIndex].index];
78
+ return { script: o.script, value: o.value };
79
+ }
80
+ else {
81
+ throw new Error("Can't find pubkey in input without Utxo data");
82
+ }
83
+ }
84
+ computeFee(inputs, disableOutputChecks = false, txFromBuffer) {
85
+ if (!inputs.every(isFinalized))
86
+ throw new Error('PSBT must be finalized to calculate fee');
87
+ if (this.fee !== undefined)
88
+ return this.fee;
89
+ let tx;
90
+ let mustFinalize = true;
91
+ if (this.extractedTx) {
92
+ tx = this.extractedTx;
93
+ mustFinalize = false;
94
+ }
95
+ else {
96
+ tx = this.tx.clone();
97
+ }
98
+ const { fee } = this.finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer);
99
+ return fee;
100
+ }
101
+ computeFeeRate(inputs, disableOutputChecks = false, txFromBuffer) {
102
+ if (!inputs.every(isFinalized))
103
+ throw new Error('PSBT must be finalized to calculate fee rate');
104
+ if (this.feeRate !== undefined)
105
+ return this.feeRate;
106
+ let tx;
107
+ let mustFinalize = true;
108
+ if (this.extractedTx) {
109
+ tx = this.extractedTx;
110
+ mustFinalize = false;
111
+ }
112
+ else {
113
+ tx = this.tx.clone();
114
+ }
115
+ const { feeRate } = this.finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer);
116
+ return feeRate;
117
+ }
118
+ checkFees(opts) {
119
+ const feeRate = this.feeRate;
120
+ if (!this.extractedTx)
121
+ throw new Error('Transaction not extracted');
122
+ if (feeRate === undefined)
123
+ throw new Error('Fee rate not computed');
124
+ const vsize = this.extractedTx.virtualSize();
125
+ const satoshis = feeRate * vsize;
126
+ if (feeRate >= opts.maximumFeeRate) {
127
+ throw new Error(`Warning: You are paying around ${(satoshis / 1e8).toFixed(8)} in ` +
128
+ `fees, which is ${feeRate} satoshi per byte for a transaction ` +
129
+ `with a VSize of ${vsize} bytes (segwit counted as 0.25 byte per ` +
130
+ `byte). Use setMaximumFeeRate method to raise your threshold, or ` +
131
+ `pass true to the first arg of extractTransaction.`);
132
+ }
133
+ }
134
+ pubkeyInInput(pubkey, input, inputIndex, txFromBuffer) {
135
+ const script = this.getScriptFromUtxo(inputIndex, input, txFromBuffer);
136
+ const { meaningfulScript } = getMeaningfulScript(script, inputIndex, 'input', input.redeemScript, input.witnessScript);
137
+ return pubkeyInScript(pubkey, meaningfulScript);
138
+ }
139
+ pubkeyInOutput(pubkey, output, outputIndex) {
140
+ const script = this.tx.outs[outputIndex].script;
141
+ const { meaningfulScript } = getMeaningfulScript(script, outputIndex, 'output', output.redeemScript, output.witnessScript);
142
+ return pubkeyInScript(pubkey, meaningfulScript);
143
+ }
144
+ redeemFromFinalScriptSig(finalScript) {
145
+ if (!finalScript)
146
+ return;
147
+ const decomp = bscript.decompile(finalScript);
148
+ if (!decomp)
149
+ return;
150
+ const lastItem = decomp[decomp.length - 1];
151
+ if (!(lastItem instanceof Uint8Array) || isPubkeyLike(lastItem) || isSigLike(lastItem))
152
+ return;
153
+ const sDecomp = bscript.decompile(lastItem);
154
+ if (!sDecomp)
155
+ return;
156
+ return lastItem;
157
+ }
158
+ redeemFromFinalWitnessScript(finalScript) {
159
+ if (!finalScript)
160
+ return;
161
+ const decomp = scriptWitnessToWitnessStack(finalScript);
162
+ const lastItem = decomp[decomp.length - 1];
163
+ if (isPubkeyLike(lastItem))
164
+ return;
165
+ const sDecomp = bscript.decompile(lastItem);
166
+ if (!sDecomp)
167
+ return;
168
+ return lastItem;
169
+ }
170
+ /**
171
+ * Finalize transaction inputs and compute fee amounts.
172
+ * Returns computed values instead of mutating cache parameters directly.
173
+ */
174
+ finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer) {
175
+ let inputAmount = 0n;
176
+ inputs.forEach((input, idx) => {
177
+ if (mustFinalize && input.finalScriptSig)
178
+ tx.ins[idx].script = input.finalScriptSig;
179
+ if (mustFinalize && input.finalScriptWitness) {
180
+ tx.ins[idx].witness = scriptWitnessToWitnessStack(input.finalScriptWitness);
181
+ }
182
+ if (input.witnessUtxo) {
183
+ inputAmount += input.witnessUtxo.value;
184
+ }
185
+ else if (input.nonWitnessUtxo) {
186
+ if (!txFromBuffer)
187
+ throw new Error('txFromBuffer is required for nonWitnessUtxo inputs');
188
+ const nwTx = this.getNonWitnessUtxoTx(input, idx, txFromBuffer);
189
+ const vout = tx.ins[idx].index;
190
+ const out = nwTx.outs[vout];
191
+ inputAmount += out.value;
192
+ }
193
+ });
194
+ const outputAmount = tx.outs.reduce((total, o) => total + o.value, 0n);
195
+ const feeValue = inputAmount - outputAmount;
196
+ if (!disableOutputChecks) {
197
+ if (feeValue < 0n) {
198
+ throw new Error(`Outputs are spending more than Inputs ${inputAmount} < ${outputAmount}`);
199
+ }
200
+ }
201
+ const bytes = tx.virtualSize();
202
+ const fee = Number(feeValue);
203
+ const feeRate = Math.floor(fee / bytes);
204
+ this.fee = fee;
205
+ this.extractedTx = tx;
206
+ this.feeRate = feeRate;
207
+ return { fee, feeRate };
208
+ }
209
+ getScriptFromInput(inputIndex, input, txFromBuffer) {
210
+ const res = {
211
+ script: null,
212
+ isSegwit: false,
213
+ isP2SH: false,
214
+ isP2WSH: false,
215
+ };
216
+ res.isP2SH = !!input.redeemScript;
217
+ res.isP2WSH = !!input.witnessScript;
218
+ if (input.witnessScript) {
219
+ res.script = input.witnessScript;
220
+ }
221
+ else if (input.redeemScript) {
222
+ res.script = input.redeemScript;
223
+ }
224
+ else {
225
+ if (input.nonWitnessUtxo) {
226
+ const nonWitnessUtxoTx = this.getNonWitnessUtxoTx(input, inputIndex, txFromBuffer);
227
+ const prevoutIndex = this.tx.ins[inputIndex].index;
228
+ res.script = nonWitnessUtxoTx.outs[prevoutIndex].script;
229
+ }
230
+ else if (input.witnessUtxo) {
231
+ res.script = input.witnessUtxo.script;
232
+ }
233
+ }
234
+ if (input.witnessScript || (res.script && isP2WPKH(res.script))) {
235
+ res.isSegwit = true;
236
+ }
237
+ else {
238
+ if (res.script && isUnknownSegwitVersion(res.script)) {
239
+ res.isSegwit = true;
240
+ }
241
+ }
242
+ return res;
243
+ }
244
+ getPrevoutTaprootKey(inputIndex, input, txFromBuffer) {
245
+ const { script } = this.getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer);
246
+ return isP2TR(script) ? script.subarray(2, 34) : null;
247
+ }
248
+ }
249
+ //# sourceMappingURL=PsbtCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PsbtCache.js","sourceRoot":"","sources":["../../src/psbt/PsbtCache.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import type { PartialSig, PsbtInput } from 'bip174';
2
+ import type { Transaction } from '../transaction.js';
3
+ import type { Script } from '../types.js';
4
+ import type { PsbtCache } from './PsbtCache.js';
5
+ import type { GetScriptReturn } from './types.js';
6
+ export interface FinalScriptsResult {
7
+ readonly finalScriptSig: Script | undefined;
8
+ readonly finalScriptWitness: Uint8Array | undefined;
9
+ }
10
+ /**
11
+ * Class wrapping all finalization logic for PSBT.
12
+ */
13
+ export declare class PsbtFinalizer {
14
+ #private;
15
+ constructor(cache: PsbtCache, txFromBuffer: (buf: Uint8Array) => Transaction);
16
+ getFinalScripts(inputIndex: number, input: PsbtInput, script: Script, isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, canRunChecks?: boolean, solution?: Uint8Array[]): FinalScriptsResult;
17
+ getScriptFromInput(inputIndex: number, input: PsbtInput): GetScriptReturn;
18
+ }
19
+ export declare function getFinalScripts(inputIndex: number, input: PsbtInput, script: Script, isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, canRunChecks?: boolean, solution?: Uint8Array[]): FinalScriptsResult;
20
+ export declare function prepareFinalScripts(script: Uint8Array, scriptType: string, partialSig: PartialSig[], isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, solution?: Uint8Array[]): FinalScriptsResult;
21
+ //# sourceMappingURL=PsbtFinalizer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PsbtFinalizer.d.ts","sourceRoot":"","sources":["../../src/psbt/PsbtFinalizer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAMpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAa,MAAM,EAAa,MAAM,aAAa,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD,MAAM,WAAW,kBAAkB;IAC/B,QAAQ,CAAC,cAAc,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5C,QAAQ,CAAC,kBAAkB,EAAE,UAAU,GAAG,SAAS,CAAC;CACvD;AAED;;GAEG;AACH,qBAAa,aAAa;;gBAIH,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,EAAE,UAAU,KAAK,WAAW;IAK5E,eAAe,CAClB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,YAAY,GAAE,OAAc,EAC5B,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB;IAkBd,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,eAAe;CAGnF;AAED,wBAAgB,eAAe,CAC3B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,YAAY,GAAE,OAAc,EAC5B,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB,CAgBpB;AAED,wBAAgB,mBAAmB,CAC/B,MAAM,EAAE,UAAU,EAClB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,UAAU,EAAE,EACxB,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB,CAiCpB"}
@@ -0,0 +1,157 @@
1
+ import { equals } from '../io/index.js';
2
+ import * as payments from '../payments/index.js';
3
+ import { witnessStackToScriptWitness } from './psbtutils.js';
4
+ import { classifyScript, compressPubkey } from './utils.js';
5
+ /**
6
+ * Class wrapping all finalization logic for PSBT.
7
+ */
8
+ export class PsbtFinalizer {
9
+ #cache;
10
+ #txFromBuffer;
11
+ constructor(cache, txFromBuffer) {
12
+ this.#cache = cache;
13
+ this.#txFromBuffer = txFromBuffer;
14
+ }
15
+ getFinalScripts(inputIndex, input, script, isSegwit, isP2SH, isP2WSH, canRunChecks = true, solution) {
16
+ const scriptType = classifyScript(script);
17
+ if (!canFinalize(input, script, scriptType) && canRunChecks) {
18
+ throw new Error(`Can not finalize input #${inputIndex}`);
19
+ }
20
+ if (!input.partialSig)
21
+ throw new Error('Input missing partial signatures');
22
+ return prepareFinalScripts(script, scriptType, input.partialSig, isSegwit, isP2SH, isP2WSH, solution);
23
+ }
24
+ getScriptFromInput(inputIndex, input) {
25
+ return this.#cache.getScriptFromInput(inputIndex, input, this.#txFromBuffer);
26
+ }
27
+ }
28
+ export function getFinalScripts(inputIndex, input, script, isSegwit, isP2SH, isP2WSH, canRunChecks = true, solution) {
29
+ const scriptType = classifyScript(script);
30
+ if (!canFinalize(input, script, scriptType) && canRunChecks) {
31
+ throw new Error(`Can not finalize input #${inputIndex}`);
32
+ }
33
+ if (!input.partialSig)
34
+ throw new Error('Input missing partial signatures');
35
+ return prepareFinalScripts(script, scriptType, input.partialSig, isSegwit, isP2SH, isP2WSH, solution);
36
+ }
37
+ export function prepareFinalScripts(script, scriptType, partialSig, isSegwit, isP2SH, isP2WSH, solution) {
38
+ let finalScriptSig;
39
+ let finalScriptWitness;
40
+ const payment = getPayment(script, scriptType, partialSig);
41
+ const p2wsh = !isP2WSH ? null : payments.p2wsh({ redeem: payment });
42
+ const p2sh = !isP2SH ? null : payments.p2sh({ redeem: p2wsh || payment });
43
+ if (isSegwit) {
44
+ if (p2wsh && p2wsh.witness) {
45
+ finalScriptWitness = witnessStackToScriptWitness(p2wsh.witness);
46
+ }
47
+ else if (payment && payment.witness) {
48
+ finalScriptWitness = witnessStackToScriptWitness(payment.witness);
49
+ }
50
+ else {
51
+ finalScriptWitness = witnessStackToScriptWitness(solution ?? [new Uint8Array([0x00])]);
52
+ }
53
+ if (p2sh) {
54
+ finalScriptSig = p2sh?.input;
55
+ }
56
+ }
57
+ else {
58
+ if (p2sh) {
59
+ finalScriptSig = p2sh?.input;
60
+ }
61
+ else {
62
+ if (!payment) {
63
+ finalScriptSig = (Array.isArray(solution) && solution[0] ? solution[0] : new Uint8Array([0x01]));
64
+ }
65
+ else {
66
+ finalScriptSig = payment.input;
67
+ }
68
+ }
69
+ }
70
+ return { finalScriptSig, finalScriptWitness };
71
+ }
72
+ function canFinalize(input, script, scriptType) {
73
+ switch (scriptType) {
74
+ case 'pubkey':
75
+ case 'pubkeyhash':
76
+ case 'witnesspubkeyhash':
77
+ return hasSigs(1, input.partialSig);
78
+ case 'multisig': {
79
+ const p2ms = payments.p2ms({
80
+ output: script,
81
+ });
82
+ if (p2ms.m === undefined)
83
+ throw new Error('Cannot determine m for multisig');
84
+ return hasSigs(p2ms.m, input.partialSig, p2ms.pubkeys);
85
+ }
86
+ case 'nonstandard':
87
+ return true;
88
+ default:
89
+ return false;
90
+ }
91
+ }
92
+ function hasSigs(neededSigs, partialSig, pubkeys) {
93
+ if (!partialSig)
94
+ return false;
95
+ let sigs;
96
+ if (pubkeys) {
97
+ sigs = pubkeys
98
+ .map((pkey) => {
99
+ const pubkey = compressPubkey(pkey);
100
+ return partialSig.find((pSig) => equals(pSig.pubkey, pubkey));
101
+ })
102
+ .filter((v) => !!v);
103
+ }
104
+ else {
105
+ sigs = partialSig;
106
+ }
107
+ if (sigs.length > neededSigs)
108
+ throw new Error('Too many signatures');
109
+ return sigs.length === neededSigs;
110
+ }
111
+ function getPayment(script, scriptType, partialSig) {
112
+ const scriptBranded = script;
113
+ switch (scriptType) {
114
+ case 'multisig': {
115
+ const sigs = getSortedSigs(script, partialSig);
116
+ return payments.p2ms({
117
+ output: scriptBranded,
118
+ signatures: sigs,
119
+ });
120
+ }
121
+ case 'pubkey':
122
+ return payments.p2pk({
123
+ output: scriptBranded,
124
+ signature: partialSig[0].signature,
125
+ });
126
+ case 'pubkeyhash':
127
+ return payments.p2pkh({
128
+ output: scriptBranded,
129
+ pubkey: partialSig[0].pubkey,
130
+ signature: partialSig[0].signature,
131
+ });
132
+ case 'witnesspubkeyhash':
133
+ return payments.p2wpkh({
134
+ output: scriptBranded,
135
+ pubkey: partialSig[0].pubkey,
136
+ signature: partialSig[0].signature,
137
+ });
138
+ default:
139
+ throw new Error(`Unknown script type: ${scriptType}`);
140
+ }
141
+ }
142
+ function getSortedSigs(script, partialSig) {
143
+ const p2ms = payments.p2ms({ output: script });
144
+ if (!p2ms.pubkeys)
145
+ throw new Error('Cannot extract pubkeys from multisig script');
146
+ const result = [];
147
+ for (const pk of p2ms.pubkeys) {
148
+ const matched = partialSig.filter((ps) => {
149
+ return equals(ps.pubkey, pk);
150
+ })[0];
151
+ if (matched) {
152
+ result.push(new Uint8Array(matched.signature));
153
+ }
154
+ }
155
+ return result;
156
+ }
157
+ //# sourceMappingURL=PsbtFinalizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PsbtFinalizer.js","sourceRoot":"","sources":["../../src/psbt/PsbtFinalizer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import type { Bip32Derivation, PsbtInput } from 'bip174';
2
+ import { Transaction } from '../transaction.js';
3
+ import type { Bytes32, MessageHash, PublicKey, Script } from '../types.js';
4
+ import type { PsbtCache } from './PsbtCache.js';
5
+ import type { HDSigner, HDSignerAsync } from './types.js';
6
+ export interface HashForSig {
7
+ readonly pubkey: PublicKey;
8
+ readonly hash: MessageHash;
9
+ readonly leafHash?: Bytes32;
10
+ }
11
+ /**
12
+ * Class wrapping all signing-related logic for PSBT.
13
+ */
14
+ export declare class PsbtSigner {
15
+ #private;
16
+ constructor(cache: PsbtCache, txFromBuffer: (buf: Uint8Array) => Transaction);
17
+ getHashAndSighashType(inputs: PsbtInput[], inputIndex: number, pubkey: Uint8Array, sighashTypes: number[]): {
18
+ hash: MessageHash;
19
+ sighashType: number;
20
+ };
21
+ getHashForSig(inputIndex: number, input: PsbtInput, forValidate: boolean, sighashTypes?: number[]): {
22
+ script: Script;
23
+ hash: MessageHash;
24
+ sighashType: number;
25
+ };
26
+ getTaprootHashesForSig(inputIndex: number, input: PsbtInput, inputs: PsbtInput[], pubkey: Uint8Array, tapLeafHashToSign?: Uint8Array, allowedSighashTypes?: number[]): HashForSig[];
27
+ getAllTaprootHashesForSig(inputIndex: number, input: PsbtInput, inputs: PsbtInput[]): HashForSig[];
28
+ trimTaprootSig(signature: Uint8Array): Uint8Array;
29
+ getSignersFromHD<T extends HDSigner | HDSignerAsync>(inputIndex: number, inputs: PsbtInput[], hdKeyPair: T): T[];
30
+ bip32DerivationIsMine(root: HDSigner): (d: Bip32Derivation) => boolean;
31
+ }
32
+ //# sourceMappingURL=PsbtSigner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PsbtSigner.d.ts","sourceRoot":"","sources":["../../src/psbt/PsbtSigner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAUzD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EAAW,OAAO,EAAE,WAAW,EAAE,SAAS,EAAW,MAAM,EAAE,MAAM,aAAa,CAAC;AAC7F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,WAAW,UAAU;IACvB,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC;IAC3B,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC;IAC3B,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;CAC/B;AAED;;GAEG;AACH,qBAAa,UAAU;;gBAIA,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,EAAE,UAAU,KAAK,WAAW;IAK5E,qBAAqB,CACxB,MAAM,EAAE,SAAS,EAAE,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,UAAU,EAClB,YAAY,EAAE,MAAM,EAAE,GACvB;QAAE,IAAI,EAAE,WAAW,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;IAatC,aAAa,CAChB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,WAAW,EAAE,OAAO,EACpB,YAAY,CAAC,EAAE,MAAM,EAAE,GACxB;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,WAAW,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;IAiFtD,sBAAsB,CACzB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,EAAE,EACnB,MAAM,EAAE,UAAU,EAClB,iBAAiB,CAAC,EAAE,UAAU,EAC9B,mBAAmB,CAAC,EAAE,MAAM,EAAE,GAC/B,UAAU,EAAE;IAuER,yBAAyB,CAC5B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,EAAE,GACpB,UAAU,EAAE;IAqBR,cAAc,CAAC,SAAS,EAAE,UAAU,GAAG,UAAU;IAIjD,gBAAgB,CAAC,CAAC,SAAS,QAAQ,GAAG,aAAa,EACtD,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,SAAS,EAAE,EACnB,SAAS,EAAE,CAAC,GACb,CAAC,EAAE;IA6BC,qBAAqB,CAAC,IAAI,EAAE,QAAQ,GAAG,CAAC,CAAC,EAAE,eAAe,KAAK,OAAO;CAchF"}