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

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 (457) hide show
  1. package/AUDIT/README.md +9 -0
  2. package/HOW_TO_WRITE_GOOD_CODE.md +2436 -0
  3. package/SECURITY.md +27 -0
  4. package/benchmark/psbt-2000-inputs.bench.ts +178 -0
  5. package/benchmark/signing.bench.ts +147 -0
  6. package/browser/address.d.ts +56 -9
  7. package/browser/address.d.ts.map +1 -0
  8. package/browser/bech32utils.d.ts +9 -1
  9. package/browser/bech32utils.d.ts.map +1 -0
  10. package/browser/bip66.d.ts +11 -6
  11. package/browser/bip66.d.ts.map +1 -0
  12. package/browser/block.d.ts +117 -11
  13. package/browser/block.d.ts.map +1 -0
  14. package/browser/branded.d.ts +20 -0
  15. package/browser/branded.d.ts.map +1 -0
  16. package/browser/crypto/crypto.d.ts +1 -0
  17. package/browser/crypto/crypto.d.ts.map +1 -0
  18. package/browser/crypto.d.ts +46 -7
  19. package/browser/crypto.d.ts.map +1 -0
  20. package/browser/ecc/context.d.ts +129 -0
  21. package/browser/ecc/context.d.ts.map +1 -0
  22. package/browser/ecc/index.d.ts +11 -0
  23. package/browser/ecc/index.d.ts.map +1 -0
  24. package/browser/ecc/types.d.ts +128 -0
  25. package/browser/ecc/types.d.ts.map +1 -0
  26. package/browser/ecpair.d.ts +99 -0
  27. package/browser/errors.d.ts +124 -0
  28. package/browser/errors.d.ts.map +1 -0
  29. package/browser/index.d.ts +32 -5
  30. package/browser/index.d.ts.map +1 -0
  31. package/browser/index.js +12482 -101
  32. package/browser/io/BinaryReader.d.ts +276 -0
  33. package/browser/io/BinaryReader.d.ts.map +1 -0
  34. package/browser/io/BinaryWriter.d.ts +391 -0
  35. package/browser/io/BinaryWriter.d.ts.map +1 -0
  36. package/browser/io/MemoryPool.d.ts +220 -0
  37. package/browser/io/MemoryPool.d.ts.map +1 -0
  38. package/browser/io/base64.d.ts +13 -0
  39. package/browser/io/base64.d.ts.map +1 -0
  40. package/browser/io/hex.d.ts +67 -0
  41. package/browser/io/hex.d.ts.map +1 -0
  42. package/browser/io/index.d.ts +17 -0
  43. package/browser/io/index.d.ts.map +1 -0
  44. package/browser/io/utils.d.ts +199 -0
  45. package/browser/io/utils.d.ts.map +1 -0
  46. package/browser/merkle.d.ts +10 -1
  47. package/browser/merkle.d.ts.map +1 -0
  48. package/browser/networks.d.ts +70 -9
  49. package/browser/networks.d.ts.map +1 -0
  50. package/browser/opcodes.d.ts +1 -0
  51. package/browser/opcodes.d.ts.map +1 -0
  52. package/browser/payments/bip341.d.ts +35 -9
  53. package/browser/payments/bip341.d.ts.map +1 -0
  54. package/browser/payments/embed.d.ts +112 -1
  55. package/browser/payments/embed.d.ts.map +1 -0
  56. package/browser/payments/index.d.ts +17 -10
  57. package/browser/payments/index.d.ts.map +1 -0
  58. package/browser/payments/p2ms.d.ts +150 -0
  59. package/browser/payments/p2ms.d.ts.map +1 -0
  60. package/browser/payments/p2op.d.ts +150 -24
  61. package/browser/payments/p2op.d.ts.map +1 -0
  62. package/browser/payments/p2pk.d.ts +154 -1
  63. package/browser/payments/p2pk.d.ts.map +1 -0
  64. package/browser/payments/p2pkh.d.ts +176 -1
  65. package/browser/payments/p2pkh.d.ts.map +1 -0
  66. package/browser/payments/p2sh.d.ts +150 -1
  67. package/browser/payments/p2sh.d.ts.map +1 -0
  68. package/browser/payments/p2tr.d.ts +185 -1
  69. package/browser/payments/p2tr.d.ts.map +1 -0
  70. package/browser/payments/p2wpkh.d.ts +161 -1
  71. package/browser/payments/p2wpkh.d.ts.map +1 -0
  72. package/browser/payments/p2wsh.d.ts +146 -1
  73. package/browser/payments/p2wsh.d.ts.map +1 -0
  74. package/browser/payments/types.d.ts +94 -64
  75. package/browser/payments/types.d.ts.map +1 -0
  76. package/browser/psbt/bip371.d.ts +34 -8
  77. package/browser/psbt/bip371.d.ts.map +1 -0
  78. package/browser/psbt/psbtutils.d.ts +56 -16
  79. package/browser/psbt/psbtutils.d.ts.map +1 -0
  80. package/browser/psbt/types.d.ts +245 -0
  81. package/browser/psbt/types.d.ts.map +1 -0
  82. package/browser/psbt/utils.d.ts +64 -0
  83. package/browser/psbt/utils.d.ts.map +1 -0
  84. package/browser/psbt/validation.d.ts +84 -0
  85. package/browser/psbt/validation.d.ts.map +1 -0
  86. package/browser/psbt.d.ts +82 -118
  87. package/browser/psbt.d.ts.map +1 -0
  88. package/browser/pubkey.d.ts +27 -6
  89. package/browser/pubkey.d.ts.map +1 -0
  90. package/browser/push_data.d.ts +24 -2
  91. package/browser/push_data.d.ts.map +1 -0
  92. package/browser/script.d.ts +33 -8
  93. package/browser/script.d.ts.map +1 -0
  94. package/browser/script_number.d.ts +17 -0
  95. package/browser/script_number.d.ts.map +1 -0
  96. package/browser/script_signature.d.ts +23 -5
  97. package/browser/script_signature.d.ts.map +1 -0
  98. package/browser/transaction.d.ts +160 -18
  99. package/browser/transaction.d.ts.map +1 -0
  100. package/browser/types.d.ts +36 -38
  101. package/browser/types.d.ts.map +1 -0
  102. package/browser/workers/WorkerSigningPool.d.ts +143 -0
  103. package/browser/workers/WorkerSigningPool.d.ts.map +1 -0
  104. package/browser/workers/WorkerSigningPool.node.d.ts +116 -0
  105. package/browser/workers/WorkerSigningPool.node.d.ts.map +1 -0
  106. package/browser/workers/ecc-bundle.d.ts +25 -0
  107. package/browser/workers/ecc-bundle.d.ts.map +1 -0
  108. package/browser/workers/index.d.ts +91 -0
  109. package/browser/workers/index.d.ts.map +1 -0
  110. package/browser/workers/psbt-parallel.d.ts +88 -0
  111. package/browser/workers/psbt-parallel.d.ts.map +1 -0
  112. package/browser/workers/signing-worker.d.ts +37 -0
  113. package/browser/workers/signing-worker.d.ts.map +1 -0
  114. package/browser/workers/types.d.ts +365 -0
  115. package/browser/workers/types.d.ts.map +1 -0
  116. package/build/address.d.ts +57 -10
  117. package/build/address.d.ts.map +1 -0
  118. package/build/address.js +80 -24
  119. package/build/address.js.map +1 -0
  120. package/build/bech32utils.d.ts +9 -1
  121. package/build/bech32utils.d.ts.map +1 -0
  122. package/build/bech32utils.js +10 -2
  123. package/build/bech32utils.js.map +1 -0
  124. package/build/bip66.d.ts +11 -6
  125. package/build/bip66.d.ts.map +1 -0
  126. package/build/bip66.js +32 -3
  127. package/build/bip66.js.map +1 -0
  128. package/build/block.d.ts +117 -11
  129. package/build/block.d.ts.map +1 -0
  130. package/build/block.js +204 -72
  131. package/build/block.js.map +1 -0
  132. package/build/branded.d.ts +20 -0
  133. package/build/branded.d.ts.map +1 -0
  134. package/build/branded.js +7 -0
  135. package/build/branded.js.map +1 -0
  136. package/build/crypto/crypto.d.ts +1 -0
  137. package/build/crypto/crypto.d.ts.map +1 -0
  138. package/build/crypto/crypto.js +1 -0
  139. package/build/crypto/crypto.js.map +1 -0
  140. package/build/crypto.d.ts +46 -7
  141. package/build/crypto.d.ts.map +1 -0
  142. package/build/crypto.js +65 -20
  143. package/build/crypto.js.map +1 -0
  144. package/build/ecc/context.d.ts +135 -0
  145. package/build/ecc/context.d.ts.map +1 -0
  146. package/build/ecc/context.js +232 -0
  147. package/build/ecc/context.js.map +1 -0
  148. package/build/ecc/index.d.ts +11 -0
  149. package/build/ecc/index.d.ts.map +1 -0
  150. package/build/ecc/index.js +11 -0
  151. package/build/ecc/index.js.map +1 -0
  152. package/build/ecc/types.d.ts +134 -0
  153. package/build/ecc/types.d.ts.map +1 -0
  154. package/build/ecc/types.js +8 -0
  155. package/build/ecc/types.js.map +1 -0
  156. package/build/errors.d.ts +124 -0
  157. package/build/errors.d.ts.map +1 -0
  158. package/build/errors.js +155 -0
  159. package/build/errors.js.map +1 -0
  160. package/build/index.d.ts +32 -5
  161. package/build/index.d.ts.map +1 -0
  162. package/build/index.js +26 -3
  163. package/build/index.js.map +1 -0
  164. package/build/io/BinaryReader.d.ts +276 -0
  165. package/build/io/BinaryReader.d.ts.map +1 -0
  166. package/build/io/BinaryReader.js +425 -0
  167. package/build/io/BinaryReader.js.map +1 -0
  168. package/build/io/BinaryWriter.d.ts +391 -0
  169. package/build/io/BinaryWriter.d.ts.map +1 -0
  170. package/build/io/BinaryWriter.js +611 -0
  171. package/build/io/BinaryWriter.js.map +1 -0
  172. package/build/io/MemoryPool.d.ts +220 -0
  173. package/build/io/MemoryPool.d.ts.map +1 -0
  174. package/build/io/MemoryPool.js +309 -0
  175. package/build/io/MemoryPool.js.map +1 -0
  176. package/build/io/base64.d.ts +13 -0
  177. package/build/io/base64.d.ts.map +1 -0
  178. package/build/io/base64.js +20 -0
  179. package/build/io/base64.js.map +1 -0
  180. package/build/io/hex.d.ts +67 -0
  181. package/build/io/hex.d.ts.map +1 -0
  182. package/build/io/hex.js +138 -0
  183. package/build/io/hex.js.map +1 -0
  184. package/build/io/index.d.ts +17 -0
  185. package/build/io/index.d.ts.map +1 -0
  186. package/build/io/index.js +23 -0
  187. package/build/io/index.js.map +1 -0
  188. package/build/io/utils.d.ts +199 -0
  189. package/build/io/utils.d.ts.map +1 -0
  190. package/build/io/utils.js +271 -0
  191. package/build/io/utils.js.map +1 -0
  192. package/build/merkle.d.ts +10 -1
  193. package/build/merkle.d.ts.map +1 -0
  194. package/build/merkle.js +12 -1
  195. package/build/merkle.js.map +1 -0
  196. package/build/networks.d.ts +70 -9
  197. package/build/networks.d.ts.map +1 -0
  198. package/build/networks.js +90 -4
  199. package/build/networks.js.map +1 -0
  200. package/build/opcodes.d.ts +1 -0
  201. package/build/opcodes.d.ts.map +1 -0
  202. package/build/opcodes.js +1 -0
  203. package/build/opcodes.js.map +1 -0
  204. package/build/payments/bip341.d.ts +36 -9
  205. package/build/payments/bip341.d.ts.map +1 -0
  206. package/build/payments/bip341.js +35 -15
  207. package/build/payments/bip341.js.map +1 -0
  208. package/build/payments/embed.d.ts +120 -1
  209. package/build/payments/embed.d.ts.map +1 -0
  210. package/build/payments/embed.js +215 -34
  211. package/build/payments/embed.js.map +1 -0
  212. package/build/payments/index.d.ts +17 -10
  213. package/build/payments/index.d.ts.map +1 -0
  214. package/build/payments/index.js +20 -10
  215. package/build/payments/index.js.map +1 -0
  216. package/build/payments/p2ms.d.ts +159 -1
  217. package/build/payments/p2ms.d.ts.map +1 -0
  218. package/build/payments/p2ms.js +427 -108
  219. package/build/payments/p2ms.js.map +1 -0
  220. package/build/payments/p2op.d.ts +158 -24
  221. package/build/payments/p2op.d.ts.map +1 -0
  222. package/build/payments/p2op.js +379 -93
  223. package/build/payments/p2op.js.map +1 -0
  224. package/build/payments/p2pk.d.ts +162 -1
  225. package/build/payments/p2pk.d.ts.map +1 -0
  226. package/build/payments/p2pk.js +327 -58
  227. package/build/payments/p2pk.js.map +1 -0
  228. package/build/payments/p2pkh.d.ts +185 -1
  229. package/build/payments/p2pkh.d.ts.map +1 -0
  230. package/build/payments/p2pkh.js +467 -114
  231. package/build/payments/p2pkh.js.map +1 -0
  232. package/build/payments/p2sh.d.ts +159 -1
  233. package/build/payments/p2sh.d.ts.map +1 -0
  234. package/build/payments/p2sh.js +500 -152
  235. package/build/payments/p2sh.js.map +1 -0
  236. package/build/payments/p2tr.d.ts +193 -1
  237. package/build/payments/p2tr.d.ts.map +1 -0
  238. package/build/payments/p2tr.js +592 -174
  239. package/build/payments/p2tr.js.map +1 -0
  240. package/build/payments/p2wpkh.d.ts +170 -1
  241. package/build/payments/p2wpkh.d.ts.map +1 -0
  242. package/build/payments/p2wpkh.js +429 -104
  243. package/build/payments/p2wpkh.js.map +1 -0
  244. package/build/payments/p2wsh.d.ts +155 -1
  245. package/build/payments/p2wsh.d.ts.map +1 -0
  246. package/build/payments/p2wsh.js +466 -144
  247. package/build/payments/p2wsh.js.map +1 -0
  248. package/build/payments/types.d.ts +98 -64
  249. package/build/payments/types.d.ts.map +1 -0
  250. package/build/payments/types.js +17 -13
  251. package/build/payments/types.js.map +1 -0
  252. package/build/psbt/bip371.d.ts +35 -9
  253. package/build/psbt/bip371.d.ts.map +1 -0
  254. package/build/psbt/bip371.js +113 -28
  255. package/build/psbt/bip371.js.map +1 -0
  256. package/build/psbt/psbtutils.d.ts +56 -16
  257. package/build/psbt/psbtutils.d.ts.map +1 -0
  258. package/build/psbt/psbtutils.js +71 -16
  259. package/build/psbt/psbtutils.js.map +1 -0
  260. package/build/psbt/types.d.ts +249 -0
  261. package/build/psbt/types.d.ts.map +1 -0
  262. package/build/psbt/types.js +6 -0
  263. package/build/psbt/types.js.map +1 -0
  264. package/build/psbt/utils.d.ts +68 -0
  265. package/build/psbt/utils.d.ts.map +1 -0
  266. package/build/psbt/utils.js +171 -0
  267. package/build/psbt/utils.js.map +1 -0
  268. package/build/psbt/validation.d.ts +88 -0
  269. package/build/psbt/validation.d.ts.map +1 -0
  270. package/build/psbt/validation.js +149 -0
  271. package/build/psbt/validation.js.map +1 -0
  272. package/build/psbt.d.ts +84 -120
  273. package/build/psbt.d.ts.map +1 -0
  274. package/build/psbt.js +411 -412
  275. package/build/psbt.js.map +1 -0
  276. package/build/pubkey.d.ts +27 -6
  277. package/build/pubkey.d.ts.map +1 -0
  278. package/build/pubkey.js +37 -13
  279. package/build/pubkey.js.map +1 -0
  280. package/build/push_data.d.ts +24 -2
  281. package/build/push_data.d.ts.map +1 -0
  282. package/build/push_data.js +44 -12
  283. package/build/push_data.js.map +1 -0
  284. package/build/script.d.ts +33 -8
  285. package/build/script.d.ts.map +1 -0
  286. package/build/script.js +100 -36
  287. package/build/script.js.map +1 -0
  288. package/build/script_number.d.ts +17 -0
  289. package/build/script_number.d.ts.map +1 -0
  290. package/build/script_number.js +19 -0
  291. package/build/script_number.js.map +1 -0
  292. package/build/script_signature.d.ts +23 -5
  293. package/build/script_signature.d.ts.map +1 -0
  294. package/build/script_signature.js +48 -15
  295. package/build/script_signature.js.map +1 -0
  296. package/build/transaction.d.ts +160 -18
  297. package/build/transaction.d.ts.map +1 -0
  298. package/build/transaction.js +443 -176
  299. package/build/transaction.js.map +1 -0
  300. package/build/tsconfig.build.tsbuildinfo +1 -0
  301. package/build/types.d.ts +36 -38
  302. package/build/types.d.ts.map +1 -0
  303. package/build/types.js +175 -57
  304. package/build/types.js.map +1 -0
  305. package/build/workers/WorkerSigningPool.d.ts +174 -0
  306. package/build/workers/WorkerSigningPool.d.ts.map +1 -0
  307. package/build/workers/WorkerSigningPool.js +553 -0
  308. package/build/workers/WorkerSigningPool.js.map +1 -0
  309. package/build/workers/WorkerSigningPool.node.d.ts +124 -0
  310. package/build/workers/WorkerSigningPool.node.d.ts.map +1 -0
  311. package/build/workers/WorkerSigningPool.node.js +753 -0
  312. package/build/workers/WorkerSigningPool.node.js.map +1 -0
  313. package/build/workers/ecc-bundle.d.ts +25 -0
  314. package/build/workers/ecc-bundle.d.ts.map +1 -0
  315. package/build/workers/ecc-bundle.js +25 -0
  316. package/build/workers/ecc-bundle.js.map +1 -0
  317. package/build/workers/index.d.ts +91 -0
  318. package/build/workers/index.d.ts.map +1 -0
  319. package/build/workers/index.js +114 -0
  320. package/build/workers/index.js.map +1 -0
  321. package/build/workers/psbt-parallel.d.ts +117 -0
  322. package/build/workers/psbt-parallel.d.ts.map +1 -0
  323. package/build/workers/psbt-parallel.js +233 -0
  324. package/build/workers/psbt-parallel.js.map +1 -0
  325. package/build/workers/signing-worker.d.ts +37 -0
  326. package/build/workers/signing-worker.d.ts.map +1 -0
  327. package/build/workers/signing-worker.js +350 -0
  328. package/build/workers/signing-worker.js.map +1 -0
  329. package/build/workers/types.d.ts +365 -0
  330. package/build/workers/types.d.ts.map +1 -0
  331. package/build/workers/types.js +60 -0
  332. package/build/workers/types.js.map +1 -0
  333. package/package.json +83 -25
  334. package/scripts/bundle-ecc.ts +111 -0
  335. package/src/address.ts +81 -44
  336. package/src/bech32utils.ts +3 -3
  337. package/src/bip66.ts +34 -24
  338. package/src/block.ts +196 -84
  339. package/src/branded.ts +18 -0
  340. package/src/crypto.ts +64 -26
  341. package/src/ecc/context.ts +277 -0
  342. package/src/ecc/index.ts +14 -0
  343. package/src/ecc/types.ts +154 -0
  344. package/src/ecpair.d.ts +99 -0
  345. package/src/errors.ts +163 -0
  346. package/src/index.ts +113 -9
  347. package/src/io/BinaryReader.ts +461 -0
  348. package/src/io/BinaryWriter.ts +696 -0
  349. package/src/io/MemoryPool.ts +343 -0
  350. package/src/io/base64.ts +20 -0
  351. package/src/io/hex.ts +155 -0
  352. package/src/io/index.ts +41 -0
  353. package/src/io/utils.ts +283 -0
  354. package/src/merkle.ts +14 -9
  355. package/src/networks.ts +9 -9
  356. package/src/payments/bip341.ts +34 -33
  357. package/src/payments/embed.ts +244 -41
  358. package/src/payments/index.ts +12 -10
  359. package/src/payments/p2ms.ts +490 -118
  360. package/src/payments/p2op.ts +431 -133
  361. package/src/payments/p2pk.ts +370 -72
  362. package/src/payments/p2pkh.ts +524 -130
  363. package/src/payments/p2sh.ts +572 -172
  364. package/src/payments/p2tr.ts +686 -194
  365. package/src/payments/p2wpkh.ts +484 -107
  366. package/src/payments/p2wsh.ts +526 -164
  367. package/src/payments/types.ts +80 -66
  368. package/src/psbt/bip371.ts +68 -51
  369. package/src/psbt/psbtutils.ts +39 -40
  370. package/src/psbt/types.ts +331 -0
  371. package/src/psbt/utils.ts +188 -0
  372. package/src/psbt/validation.ts +192 -0
  373. package/src/psbt.ts +566 -809
  374. package/src/pubkey.ts +24 -25
  375. package/src/push_data.ts +18 -16
  376. package/src/script.ts +82 -64
  377. package/src/script_number.ts +6 -6
  378. package/src/script_signature.ts +33 -36
  379. package/src/transaction.ts +458 -238
  380. package/src/types.ts +231 -100
  381. package/src/workers/WorkerSigningPool.node.ts +887 -0
  382. package/src/workers/WorkerSigningPool.ts +670 -0
  383. package/src/workers/ecc-bundle.ts +26 -0
  384. package/src/workers/index.ts +165 -0
  385. package/src/workers/psbt-parallel.ts +332 -0
  386. package/src/workers/signing-worker.ts +353 -0
  387. package/src/workers/types.ts +413 -0
  388. package/test/address.spec.ts +9 -6
  389. package/test/bitcoin.core.spec.ts +16 -17
  390. package/test/block.spec.ts +8 -7
  391. package/test/bufferutils.spec.ts +228 -214
  392. package/test/crypto.spec.ts +19 -11
  393. package/test/fixtures/p2pk.json +0 -8
  394. package/test/fixtures/p2pkh.json +1 -1
  395. package/test/fixtures/p2sh.json +1 -1
  396. package/test/fixtures/script.json +1 -1
  397. package/test/fixtures/transaction.json +2 -2
  398. package/test/integration/_regtest.ts +25 -0
  399. package/test/integration/addresses.spec.ts +4 -3
  400. package/test/integration/bip32.spec.ts +2 -1
  401. package/test/integration/blocks.spec.ts +1 -1
  402. package/test/integration/cltv.spec.ts +18 -16
  403. package/test/integration/csv.spec.ts +37 -64
  404. package/test/integration/payments.spec.ts +5 -3
  405. package/test/integration/taproot.spec.ts +76 -83
  406. package/test/integration/transactions.spec.ts +38 -35
  407. package/test/payments.spec.ts +35 -13
  408. package/test/payments.utils.ts +17 -16
  409. package/test/psbt.spec.ts +111 -100
  410. package/test/script.spec.ts +11 -10
  411. package/test/script_signature.spec.ts +9 -11
  412. package/test/taproot-cache.spec.ts +694 -0
  413. package/test/transaction.spec.ts +32 -40
  414. package/test/types.spec.ts +74 -29
  415. package/test/workers-pool.spec.ts +963 -0
  416. package/test/workers-signing.spec.ts +635 -0
  417. package/test/workers.spec.ts +1390 -0
  418. package/tsconfig.base.json +34 -18
  419. package/tsconfig.browser.json +15 -0
  420. package/tsconfig.build.json +5 -0
  421. package/tsconfig.json +5 -14
  422. package/vite.config.browser.ts +3 -42
  423. package/vitest.config.integration.ts +11 -0
  424. package/browser/bufferutils.d.ts +0 -34
  425. package/browser/chunks/crypto-BhCpKpek.js +0 -2033
  426. package/browser/chunks/payments-yjA0Evsv.js +0 -1089
  427. package/browser/chunks/psbt-URK2hBFc.js +0 -4039
  428. package/browser/chunks/script-DyPItFEl.js +0 -318
  429. package/browser/chunks/transaction-C_UbhMGn.js +0 -432
  430. package/browser/chunks/utils-DNZi-T5W.js +0 -761
  431. package/browser/ecc_lib.d.ts +0 -3
  432. package/browser/hooks/AdvancedSignatureManager.d.ts +0 -16
  433. package/browser/hooks/HookedSigner.d.ts +0 -4
  434. package/browser/hooks/SignatureManager.d.ts +0 -13
  435. package/browser/payments/lazy.d.ts +0 -2
  436. package/browser/typeforce.d.ts +0 -38
  437. package/build/bufferutils.d.ts +0 -34
  438. package/build/bufferutils.js +0 -141
  439. package/build/ecc_lib.d.ts +0 -3
  440. package/build/ecc_lib.js +0 -61
  441. package/build/hooks/AdvancedSignatureManager.d.ts +0 -16
  442. package/build/hooks/AdvancedSignatureManager.js +0 -52
  443. package/build/hooks/HookedSigner.d.ts +0 -4
  444. package/build/hooks/HookedSigner.js +0 -64
  445. package/build/hooks/SignatureManager.d.ts +0 -13
  446. package/build/hooks/SignatureManager.js +0 -45
  447. package/build/payments/lazy.d.ts +0 -2
  448. package/build/payments/lazy.js +0 -28
  449. package/build/tsconfig.tsbuildinfo +0 -1
  450. package/src/bufferutils.ts +0 -188
  451. package/src/ecc_lib.ts +0 -94
  452. package/src/hooks/AdvancedSignatureManager.ts +0 -104
  453. package/src/hooks/HookedSigner.ts +0 -108
  454. package/src/hooks/SignatureManager.ts +0 -84
  455. package/src/payments/lazy.ts +0 -28
  456. package/src/typeforce.d.ts +0 -38
  457. package/tsconfig.webpack.json +0 -18
@@ -1,21 +1,61 @@
1
- import { PartialSig, PsbtInput } from 'bip174/src/lib/interfaces.js';
2
- export declare const isP2MS: (script: Buffer) => boolean;
3
- export declare const isP2PK: (script: Buffer) => boolean;
4
- export declare const isP2PKH: (script: Buffer) => boolean;
5
- export declare const isP2WPKH: (script: Buffer) => boolean;
6
- export declare const isP2WSHScript: (script: Buffer) => boolean;
7
- export declare const isP2SHScript: (script: Buffer) => boolean;
8
- export declare const isP2TR: (script: Buffer) => boolean;
9
- export declare const isP2OP: (script: Buffer) => boolean;
10
- export declare const isP2A: (script: Buffer) => boolean;
11
- export declare function witnessStackToScriptWitness(witness: Buffer[]): Buffer;
12
- export declare function pubkeyPositionInScript(pubkey: Buffer, script: Buffer): number;
13
- export declare function pubkeyInScript(pubkey: Buffer, script: Buffer): boolean;
1
+ import { PartialSig, PsbtInput } from 'bip174';
2
+ export declare const isP2MS: (script: Uint8Array) => boolean;
3
+ export declare const isP2PK: (script: Uint8Array) => boolean;
4
+ export declare const isP2PKH: (script: Uint8Array) => boolean;
5
+ export declare const isP2WPKH: (script: Uint8Array) => boolean;
6
+ export declare const isP2WSHScript: (script: Uint8Array) => boolean;
7
+ export declare const isP2SHScript: (script: Uint8Array) => boolean;
8
+ export declare const isP2TR: (script: Uint8Array) => boolean;
9
+ export declare const isP2OP: (script: Uint8Array) => boolean;
10
+ export declare const isP2A: (script: Uint8Array) => boolean;
11
+ /**
12
+ * Converts a witness stack to a script witness.
13
+ * @param witness The witness stack to convert.
14
+ * @returns The script witness as a Uint8Array.
15
+ */
16
+ export declare function witnessStackToScriptWitness(witness: Uint8Array[]): Uint8Array;
17
+ /**
18
+ * Finds the position of a public key in a script.
19
+ * @param pubkey The public key to search for.
20
+ * @param script The script to search in.
21
+ * @returns The index of the public key in the script, or -1 if not found.
22
+ * @throws {Error} If there is an unknown script error.
23
+ */
24
+ export declare function pubkeyPositionInScript(pubkey: Uint8Array, script: Uint8Array): number;
25
+ /**
26
+ * Checks if a public key is present in a script.
27
+ * @param pubkey The public key to check.
28
+ * @param script The script to search in.
29
+ * @returns A boolean indicating whether the public key is present in the script.
30
+ */
31
+ export declare function pubkeyInScript(pubkey: Uint8Array, script: Uint8Array): boolean;
32
+ /**
33
+ * Checks if an input contains a signature for a specific action.
34
+ * @param input - The input to check.
35
+ * @param action - The action to check for.
36
+ * @returns A boolean indicating whether the input contains a signature for the specified action.
37
+ */
14
38
  export declare function checkInputForSig(input: PsbtInput, action: string): boolean;
15
- type SignatureDecodeFunc = (buffer: Buffer) => {
16
- signature: Buffer;
39
+ type SignatureDecodeFunc = (buffer: Uint8Array) => {
40
+ signature: Uint8Array;
17
41
  hashType: number;
18
42
  };
19
- export declare function signatureBlocksAction(signature: Buffer, signatureDecodeFn: SignatureDecodeFunc, action: string): boolean;
43
+ /**
44
+ * Determines if a given action is allowed for a signature block.
45
+ * @param signature - The signature block.
46
+ * @param signatureDecodeFn - The function used to decode the signature.
47
+ * @param action - The action to be checked.
48
+ * @returns True if the action is allowed, false otherwise.
49
+ */
50
+ export declare function signatureBlocksAction(signature: Uint8Array, signatureDecodeFn: SignatureDecodeFunc, action: string): boolean;
51
+ /**
52
+ * Retrieves the partial signatures (Psigs) from the input's final scripts.
53
+ * Psigs are extracted from both the final scriptSig and final scriptWitness of the input.
54
+ * Only canonical script signatures are considered.
55
+ *
56
+ * @param input - The PsbtInput object representing the input.
57
+ * @returns An array of PartialSig objects containing the extracted Psigs.
58
+ */
20
59
  export declare function getPsigsFromInputFinalScripts(input: PsbtInput): PartialSig[];
21
60
  export {};
61
+ //# sourceMappingURL=psbtutils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"psbtutils.d.ts","sourceRoot":"","sources":["../../src/psbt/psbtutils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AA6BpD,eAAO,MAAM,MAAM,WAX2C,UAAU,KAAK,OAWjC,CAAC;AAC7C,eAAO,MAAM,MAAM,WAZ2C,UAAU,KAAK,OAYjC,CAAC;AAC7C,eAAO,MAAM,OAAO,WAb0C,UAAU,KAAK,OAa/B,CAAC;AAC/C,eAAO,MAAM,QAAQ,WAdyC,UAAU,KAAK,OAc7B,CAAC;AACjD,eAAO,MAAM,aAAa,WAfoC,UAAU,KAAK,OAezB,CAAC;AACrD,eAAO,MAAM,YAAY,WAhBqC,UAAU,KAAK,OAgB3B,CAAC;AACnD,eAAO,MAAM,MAAM,WAjB2C,UAAU,KAAK,OAiBjC,CAAC;AAC7C,eAAO,MAAM,MAAM,WAlB2C,UAAU,KAAK,OAkBjC,CAAC;AAC7C,eAAO,MAAM,KAAK,GAAI,QAAQ,UAAU,KAAG,OAQ1C,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,2BAA2B,CAAC,OAAO,EAAE,UAAU,EAAE,GAAG,UAAU,CA2B7E;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,GAAG,MAAM,CA0CrF;AAED;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,GAAG,OAAO,CAE9E;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAG1E;AAED,KAAK,mBAAmB,GAAG,CAAC,MAAM,EAAE,UAAU,KAAK;IAC/C,SAAS,EAAE,UAAU,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF;;;;;;GAMG;AACH,wBAAgB,qBAAqB,CACjC,SAAS,EAAE,UAAU,EACrB,iBAAiB,EAAE,mBAAmB,EACtC,MAAM,EAAE,MAAM,GACf,OAAO,CAgBT;AAwBD;;;;;;;GAOG;AACH,wBAAgB,6BAA6B,CAAC,KAAK,EAAE,SAAS,GAAG,UAAU,EAAE,CAa5E"}
@@ -0,0 +1,245 @@
1
+ import { Psbt as PsbtBase, PsbtGlobal, PsbtInput, PsbtOutput } from 'bip174';
2
+ import { Network } from '../networks.js';
3
+ import { Transaction, TaprootHashCache } from '../transaction.js';
4
+ import { Bytes32, PublicKey, Satoshi, Script, Signature, SchnorrSignature } from '../types.js';
5
+ /**
6
+ * Transaction input interface for PSBT.
7
+ */
8
+ export interface TransactionInput {
9
+ readonly hash: string | Bytes32;
10
+ readonly index: number;
11
+ readonly sequence?: number | undefined;
12
+ }
13
+ /**
14
+ * PSBT transaction input with Uint8Array hash.
15
+ */
16
+ export interface PsbtTxInput extends TransactionInput {
17
+ readonly hash: Bytes32;
18
+ }
19
+ /**
20
+ * Transaction output interface for PSBT.
21
+ */
22
+ export interface TransactionOutput {
23
+ readonly script: Script;
24
+ readonly value: Satoshi;
25
+ }
26
+ /**
27
+ * PSBT transaction output with optional address.
28
+ */
29
+ export interface PsbtTxOutput extends TransactionOutput {
30
+ readonly address: string | undefined;
31
+ }
32
+ /**
33
+ * Signature validation function type.
34
+ * msghash is 32 byte hash of preimage, signature is 64 byte compact signature (r,s 32 bytes each)
35
+ */
36
+ export type ValidateSigFunction = (pubkey: PublicKey, msghash: Bytes32, signature: Uint8Array) => boolean;
37
+ /**
38
+ * Extended PsbtBase interface with typed inputs and globalMap.
39
+ */
40
+ export interface PsbtBaseExtended extends Omit<PsbtBase, 'inputs'> {
41
+ readonly inputs: PsbtInput[];
42
+ readonly globalMap: PsbtGlobal;
43
+ }
44
+ /**
45
+ * Optional PSBT options.
46
+ */
47
+ export interface PsbtOptsOptional {
48
+ readonly network?: Network | undefined;
49
+ readonly maximumFeeRate?: number | undefined;
50
+ readonly version?: 1 | 2 | 3 | undefined;
51
+ }
52
+ /**
53
+ * Required PSBT options.
54
+ */
55
+ export interface PsbtOpts {
56
+ readonly network: Network;
57
+ maximumFeeRate: number;
58
+ }
59
+ /**
60
+ * Extended PSBT input with additional fields.
61
+ */
62
+ export interface PsbtInputExtended extends PsbtInput, TransactionInput {
63
+ readonly isPayToAnchor?: boolean | undefined;
64
+ }
65
+ /**
66
+ * Extended PSBT output - either address-based or script-based.
67
+ */
68
+ export type PsbtOutputExtended = PsbtOutputExtendedAddress | PsbtOutputExtendedScript;
69
+ /**
70
+ * PSBT output with address.
71
+ */
72
+ export interface PsbtOutputExtendedAddress extends PsbtOutput {
73
+ readonly address: string;
74
+ readonly value: Satoshi;
75
+ }
76
+ /**
77
+ * PSBT output with script.
78
+ */
79
+ export interface PsbtOutputExtendedScript extends PsbtOutput {
80
+ readonly script: Script;
81
+ readonly value: Satoshi;
82
+ }
83
+ /**
84
+ * Base interface for HD signers.
85
+ */
86
+ interface HDSignerBase {
87
+ /**
88
+ * DER format compressed publicKey Uint8Array
89
+ */
90
+ readonly publicKey: PublicKey;
91
+ /**
92
+ * The first 4 bytes of the sha256-ripemd160 of the publicKey
93
+ */
94
+ readonly fingerprint: Uint8Array;
95
+ }
96
+ /**
97
+ * HD signer interface for synchronous signing.
98
+ */
99
+ export interface HDSigner extends HDSignerBase {
100
+ /**
101
+ * The path string must match /^m(\/\d+'?)+$/
102
+ * ex. m/44'/0'/0'/1/23 levels with ' must be hard derivations
103
+ */
104
+ derivePath(path: string): HDSigner;
105
+ /**
106
+ * Input hash (the "message digest") for the signature algorithm
107
+ * Return a 64 byte signature (32 byte r and 32 byte s in that order)
108
+ */
109
+ sign(hash: Bytes32): Uint8Array;
110
+ }
111
+ /**
112
+ * HD signer interface for asynchronous signing.
113
+ */
114
+ export interface HDSignerAsync extends HDSignerBase {
115
+ derivePath(path: string): HDSignerAsync;
116
+ sign(hash: Bytes32): Promise<Uint8Array>;
117
+ }
118
+ /**
119
+ * Alternative signer interface with lowR support.
120
+ */
121
+ export interface SignerAlternative {
122
+ readonly publicKey: PublicKey;
123
+ readonly lowR: boolean;
124
+ sign(hash: Bytes32, lowR?: boolean): Signature;
125
+ verify(hash: Bytes32, signature: Signature): boolean;
126
+ signSchnorr(hash: Bytes32): SchnorrSignature;
127
+ verifySchnorr(hash: Bytes32, signature: SchnorrSignature): boolean;
128
+ }
129
+ /**
130
+ * Basic signer interface for synchronous signing.
131
+ */
132
+ export interface Signer {
133
+ readonly publicKey: PublicKey;
134
+ readonly network?: Network | undefined;
135
+ sign(hash: Bytes32, lowR?: boolean): Signature;
136
+ signSchnorr?(hash: Bytes32): SchnorrSignature;
137
+ getPublicKey?(): PublicKey;
138
+ }
139
+ /**
140
+ * Basic signer interface for asynchronous signing.
141
+ */
142
+ export interface SignerAsync {
143
+ readonly publicKey: PublicKey;
144
+ readonly network?: Network | undefined;
145
+ sign(hash: Bytes32, lowR?: boolean): Promise<Signature>;
146
+ signSchnorr?(hash: Bytes32): Promise<SchnorrSignature>;
147
+ getPublicKey?(): PublicKey;
148
+ }
149
+ /**
150
+ * Minimal key pair interface for checking Taproot hashes.
151
+ * Only requires publicKey and optional signSchnorr presence check.
152
+ * Used by checkTaprootHashesForSig to accept broader key pair types (e.g., worker key pairs).
153
+ */
154
+ export interface TaprootHashCheckSigner {
155
+ readonly publicKey: Uint8Array;
156
+ signSchnorr?(hash: Uint8Array): Uint8Array | Promise<Uint8Array>;
157
+ }
158
+ /**
159
+ * Internal PSBT cache for computed values.
160
+ */
161
+ export interface PsbtCache {
162
+ nonWitnessUtxoTxCache: Transaction[];
163
+ nonWitnessUtxoBufCache: Uint8Array[];
164
+ txInCache: TxInCacheMap;
165
+ tx: Transaction;
166
+ feeRate?: number | undefined;
167
+ fee?: number | undefined;
168
+ extractedTx?: Transaction | undefined;
169
+ unsafeSignNonSegwit: boolean;
170
+ /** Cached flag: true if any input has signatures (avoids O(n) check) */
171
+ hasSignatures: boolean;
172
+ /** Cached prevOuts for Taproot signing (computed once) */
173
+ prevOuts?: readonly PrevOut[] | undefined;
174
+ /** Cached signing scripts */
175
+ signingScripts?: readonly Script[] | undefined;
176
+ /** Cached values */
177
+ values?: readonly Satoshi[] | undefined;
178
+ /** Cached intermediate hashes for Taproot sighash (computed once per PSBT) */
179
+ taprootHashCache?: TaprootHashCache | undefined;
180
+ }
181
+ /**
182
+ * Keys for cached numeric values in the transaction cache.
183
+ */
184
+ export type TxCacheNumberKey = 'feeRate' | 'fee';
185
+ /**
186
+ * Script types for classification.
187
+ */
188
+ export type ScriptType = 'witnesspubkeyhash' | 'pubkeyhash' | 'multisig' | 'pubkey' | 'nonstandard';
189
+ /**
190
+ * All possible script types including witness types.
191
+ * Note: P2WPKH can't be wrapped in P2WSH (already a witness program)
192
+ */
193
+ export type AllScriptType = 'witnesspubkeyhash' | 'pubkeyhash' | 'multisig' | 'pubkey' | 'nonstandard' | 'p2sh-witnesspubkeyhash' | 'p2sh-pubkeyhash' | 'p2sh-multisig' | 'p2sh-pubkey' | 'p2sh-nonstandard' | 'p2wsh-pubkeyhash' | 'p2wsh-multisig' | 'p2wsh-pubkey' | 'p2wsh-nonstandard' | 'p2sh-p2wsh-pubkeyhash' | 'p2sh-p2wsh-multisig' | 'p2sh-p2wsh-pubkey' | 'p2sh-p2wsh-nonstandard';
194
+ /**
195
+ * Return type for getScriptFromInput function.
196
+ */
197
+ export interface GetScriptReturn {
198
+ script: Script | null;
199
+ isSegwit: boolean;
200
+ isP2SH: boolean;
201
+ isP2WSH: boolean;
202
+ }
203
+ /**
204
+ * Index map for transaction input cache.
205
+ */
206
+ export interface TxInCacheMap {
207
+ readonly [index: string]: number;
208
+ }
209
+ /**
210
+ * Previous output data for signing.
211
+ */
212
+ export interface PrevOut {
213
+ readonly script: Script;
214
+ readonly value: Satoshi;
215
+ }
216
+ /**
217
+ * Result from getTaprootHashesForSig containing hash and optional leaf hash.
218
+ */
219
+ export interface TaprootHashResult {
220
+ readonly hash: Bytes32;
221
+ readonly leafHash?: Bytes32 | undefined;
222
+ }
223
+ /**
224
+ * Extended Taproot hash result with pubkey for validation.
225
+ */
226
+ export interface TaprootSigningHash {
227
+ readonly pubkey: PublicKey;
228
+ readonly hash: Bytes32;
229
+ readonly leafHash?: Bytes32 | undefined;
230
+ }
231
+ /**
232
+ * Function type for final scripts computation.
233
+ */
234
+ export type FinalScriptsFunc = (inputIndex: number, input: PsbtInput, script: Script, isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, canRunChecks: boolean) => {
235
+ finalScriptSig: Script | undefined;
236
+ finalScriptWitness: Uint8Array | undefined;
237
+ };
238
+ /**
239
+ * Function type for final Taproot scripts computation.
240
+ */
241
+ export type FinalTaprootScriptsFunc = (inputIndex: number, input: PsbtInput, tapLeafHashToFinalize?: Bytes32) => {
242
+ finalScriptWitness: Uint8Array | undefined;
243
+ };
244
+ export {};
245
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/psbt/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,64 @@
1
+ import { ScriptType } from './types.js';
2
+ /**
3
+ * Converts a witness script buffer to an array of witness stack items.
4
+ * @param buffer - The witness script buffer
5
+ * @returns Array of witness stack items
6
+ */
7
+ export declare function scriptWitnessToWitnessStack(buffer: Uint8Array): Uint8Array[];
8
+ /**
9
+ * Converts a sighash type to a human-readable string.
10
+ * @param sighashType - The sighash type value
11
+ * @returns Human-readable sighash type string
12
+ */
13
+ export declare function sighashTypeToString(sighashType: number): string;
14
+ /**
15
+ * Compresses an uncompressed public key to compressed form.
16
+ * @param pubkey - The public key (33 or 65 bytes)
17
+ * @returns Compressed public key (33 bytes)
18
+ */
19
+ export declare function compressPubkey(pubkey: Uint8Array): Uint8Array;
20
+ /**
21
+ * Checks if a buffer looks like a public key.
22
+ * @param buf - The buffer to check
23
+ * @returns True if the buffer is a valid compressed public key format
24
+ */
25
+ export declare function isPubkeyLike(buf: Uint8Array): boolean;
26
+ /**
27
+ * Checks if a buffer looks like a signature.
28
+ * @param buf - The buffer to check
29
+ * @returns True if the buffer is a valid canonical signature format
30
+ */
31
+ export declare function isSigLike(buf: Uint8Array): boolean;
32
+ /**
33
+ * Classifies a script into a known script type.
34
+ * @param script - The script to classify
35
+ * @returns The script type
36
+ */
37
+ export declare function classifyScript(script: Uint8Array): ScriptType;
38
+ /**
39
+ * Creates an array of numbers from 0 to n-1.
40
+ * @param n - The length of the array
41
+ * @returns Array of numbers [0, 1, 2, ..., n-1]
42
+ */
43
+ export declare function range(n: number): number[];
44
+ /**
45
+ * Validates that a script is not P2WPKH or P2SH (invalid for P2WSH).
46
+ * @param script - The script to check
47
+ * @throws {Error} If the script is P2WPKH or P2SH
48
+ */
49
+ export declare function checkInvalidP2WSH(script: Uint8Array): void;
50
+ /**
51
+ * Extracts the meaningful script from a potentially wrapped script.
52
+ * Handles P2SH, P2WSH, and P2SH-P2WSH wrapping.
53
+ * @param script - The script to analyze
54
+ * @param index - The input/output index (for error messages)
55
+ * @param ioType - Whether this is an input or output
56
+ * @param redeemScript - Optional redeem script for P2SH
57
+ * @param witnessScript - Optional witness script for P2WSH
58
+ * @returns The meaningful script and its type
59
+ */
60
+ export declare function getMeaningfulScript(script: Uint8Array, index: number, ioType: 'input' | 'output', redeemScript?: Uint8Array, witnessScript?: Uint8Array): {
61
+ meaningfulScript: Uint8Array;
62
+ type: 'p2sh' | 'p2wsh' | 'p2sh-p2wsh' | 'raw';
63
+ };
64
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/psbt/utils.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAMH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAI7C;;;;GAIG;AACH,wBAAgB,2BAA2B,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,EAAE,CA0B5E;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAe/D;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,CAQ7D;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAErD;AAED;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAElD;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,CAM7D;AAED;;;;GAIG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAEzC;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI,CAI1D;AAED;;;;;;;;;GASG;AACH,wBAAgB,mBAAmB,CAC/B,MAAM,EAAE,UAAU,EAClB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,OAAO,GAAG,QAAQ,EAC1B,YAAY,CAAC,EAAE,UAAU,EACzB,aAAa,CAAC,EAAE,UAAU,GAC3B;IACC,gBAAgB,EAAE,UAAU,CAAC;IAC7B,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,YAAY,GAAG,KAAK,CAAC;CACjD,CAkCA"}
@@ -0,0 +1,84 @@
1
+ import { PsbtInput } from 'bip174';
2
+ import { Payment, PaymentOpts } from '../payments/index.js';
3
+ import { Transaction } from '../transaction.js';
4
+ import { PsbtCache } from './types.js';
5
+ import { PublicKey, Script } from '../types.js';
6
+ /**
7
+ * Validates that a number is a valid 32-bit unsigned integer.
8
+ * @param num - The number to validate
9
+ * @throws {Error} If the number is not a valid 32-bit integer
10
+ */
11
+ export declare function check32Bit(num: number): void;
12
+ /**
13
+ * Checks if the cache is in a valid state for export.
14
+ * @param cache - The PSBT cache to check
15
+ * @throws {Error} If the cache is not BIP174 compliant
16
+ */
17
+ export declare function checkCache(cache: PsbtCache): void;
18
+ /**
19
+ * Checks if a PSBT input has been finalized.
20
+ * @param input - The PSBT input to check
21
+ * @returns True if the input has finalScriptSig or finalScriptWitness
22
+ */
23
+ export declare function isFinalized(input: PsbtInput): boolean;
24
+ /**
25
+ * Validates that a transaction has empty scriptSigs and witnesses.
26
+ * @param tx - The transaction to check
27
+ * @throws {Error} If any input has non-empty scripts
28
+ */
29
+ export declare function checkTxEmpty(tx: Transaction): void;
30
+ /**
31
+ * Checks and caches a transaction input to detect duplicates.
32
+ * @param cache - The PSBT cache
33
+ * @param input - The input to check
34
+ * @throws {Error} If a duplicate input is detected
35
+ */
36
+ export declare function checkTxInputCache(cache: PsbtCache, input: {
37
+ hash: Uint8Array;
38
+ index: number;
39
+ }): void;
40
+ /**
41
+ * Checks all transaction inputs for duplicates.
42
+ * @param tx - The transaction to check
43
+ * @param cache - The PSBT cache
44
+ * @throws {Error} If duplicate inputs are detected
45
+ */
46
+ export declare function checkTxForDupeIns(tx: Transaction, cache: PsbtCache): void;
47
+ /**
48
+ * Checks if any inputs have partial signatures that would prevent modification.
49
+ * @param inputs - The PSBT inputs to check
50
+ * @param action - The action being attempted (for error message)
51
+ * @param hasSignaturesCache - Optional cached flag (true = definitely has sigs, false = check needed)
52
+ * @throws {Error} If signatures exist and prevent modification
53
+ */
54
+ export declare function checkInputsForPartialSig(inputs: PsbtInput[], action: string, hasSignaturesCache?: boolean): void;
55
+ /**
56
+ * Validates that partial signature sighash types match the input's sighash type.
57
+ * @param input - The PSBT input to check
58
+ * @throws {Error} If sighash types don't match
59
+ */
60
+ export declare function checkPartialSigSighashes(input: PsbtInput): void;
61
+ /**
62
+ * Validates that a pubkey exists in a script.
63
+ * @param pubkey - The pubkey to find
64
+ * @param script - The script to search
65
+ * @param action - The action being attempted (for error message)
66
+ * @throws {Error} If the pubkey is not found in the script
67
+ */
68
+ export declare function checkScriptForPubkey(pubkey: PublicKey, script: Script, action: string): void;
69
+ /**
70
+ * Creates a script checker function for validating redeem/witness scripts.
71
+ * @param payment - The payment function to use (p2sh or p2wsh)
72
+ * @param paymentScriptName - Name for error messages
73
+ * @returns A function that validates scripts match
74
+ */
75
+ export declare function scriptCheckerFactory(payment: (a: Omit<Payment, 'name'>, opts?: PaymentOpts) => Payment, paymentScriptName: string): (idx: number, scriptPubKey: Script, redeemScript: Script, ioType: 'input' | 'output') => void;
76
+ /**
77
+ * Validates that a redeem script matches the scriptPubKey.
78
+ */
79
+ export declare const checkRedeemScript: (idx: number, scriptPubKey: Script, redeemScript: Script, ioType: "input" | "output") => void;
80
+ /**
81
+ * Validates that a witness script matches the scriptPubKey.
82
+ */
83
+ export declare const checkWitnessScript: (idx: number, scriptPubKey: Script, redeemScript: Script, ioType: "input" | "output") => void;
84
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/psbt/validation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAGxC,OAAO,KAAK,EAAe,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAI9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErD;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAI5C;AAED;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAIjD;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAErD;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI,CAWlD;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAC7B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAC3C,IAAI,CAKN;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI,CAIzE;AAED;;;;;;GAMG;AACH,wBAAgB,wBAAwB,CACpC,MAAM,EAAE,SAAS,EAAE,EACnB,MAAM,EAAE,MAAM,EACd,kBAAkB,CAAC,EAAE,OAAO,GAC7B,IAAI,CAaN;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAS/D;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAM5F;AAED;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAChC,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,EAAE,WAAW,KAAK,OAAO,EAClE,iBAAiB,EAAE,MAAM,GAC1B,CACC,GAAG,EAAE,MAAM,EACX,YAAY,EAAE,MAAM,EACpB,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,OAAO,GAAG,QAAQ,KACzB,IAAI,CAiBR;AAED;;GAEG;AACH,eAAO,MAAM,iBAAiB,QA1BrB,MAAM,gBACG,MAAM,gBACN,MAAM,UACZ,OAAO,GAAG,QAAQ,KACzB,IAsBgF,CAAC;AAEtF;;GAEG;AACH,eAAO,MAAM,kBAAkB,QA/BtB,MAAM,gBACG,MAAM,gBACN,MAAM,UACZ,OAAO,GAAG,QAAQ,KACzB,IA2BmF,CAAC"}