@btc-vision/bitcoin 6.3.1 → 6.3.3

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 (374) hide show
  1. package/.babelrc +4 -0
  2. package/.gitattributes +2 -0
  3. package/.nyc_output/6368a5b2-daa5-4821-8ed0-b742d6fc7eab.json +1 -0
  4. package/.nyc_output/processinfo/6368a5b2-daa5-4821-8ed0-b742d6fc7eab.json +1 -0
  5. package/.nyc_output/processinfo/index.json +1 -0
  6. package/.prettierrc.json +12 -0
  7. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/.ready +0 -0
  8. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/.release-please-manifest.json +3 -0
  9. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/CHANGELOG.md +962 -0
  10. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/CONTRIBUTING.md +34 -0
  11. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/LICENSE +24 -0
  12. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/README.md +273 -0
  13. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/SECURITY.md +2 -0
  14. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/addon.gypi +204 -0
  15. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/bin/node-gyp.js +138 -0
  16. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/.release-please-manifest.json +3 -0
  17. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/LICENSE +28 -0
  18. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/data/ninja/build.ninja +4 -0
  19. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/data/win/large-pdb-shim.cc +12 -0
  20. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/GypVsCMake.md +116 -0
  21. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/Hacking.md +46 -0
  22. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/InputFormatReference.md +1080 -0
  23. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/LanguageSpecification.md +430 -0
  24. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/README.md +27 -0
  25. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/Testing.md +450 -0
  26. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/docs/UserDocumentation.md +965 -0
  27. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/gyp +8 -0
  28. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/gyp.bat +5 -0
  29. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/gyp_main.py +45 -0
  30. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +365 -0
  31. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSProject.py +206 -0
  32. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings.py +1272 -0
  33. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +1547 -0
  34. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +59 -0
  35. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +153 -0
  36. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSUtil.py +271 -0
  37. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +574 -0
  38. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +692 -0
  39. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/common.py +711 -0
  40. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/common_test.py +171 -0
  41. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/easy_xml.py +169 -0
  42. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/easy_xml_test.py +113 -0
  43. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/flock_tool.py +55 -0
  44. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
  45. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/analyzer.py +804 -0
  46. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/android.py +1173 -0
  47. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/cmake.py +1318 -0
  48. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +127 -0
  49. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +103 -0
  50. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/eclipse.py +461 -0
  51. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/gypd.py +89 -0
  52. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/gypsh.py +57 -0
  53. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +2745 -0
  54. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +3976 -0
  55. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +44 -0
  56. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2964 -0
  57. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +67 -0
  58. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode.py +1391 -0
  59. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +25 -0
  60. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/input.py +3115 -0
  61. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/input_test.py +98 -0
  62. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +771 -0
  63. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1260 -0
  64. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/ninja_syntax.py +174 -0
  65. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +61 -0
  66. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/win_tool.py +373 -0
  67. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation.py +1938 -0
  68. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation_test.py +53 -0
  69. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/xcode_ninja.py +302 -0
  70. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +3198 -0
  71. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/gyp/xml_fix.py +65 -0
  72. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/LICENSE +3 -0
  73. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/LICENSE.APACHE +177 -0
  74. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/LICENSE.BSD +23 -0
  75. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/__init__.py +15 -0
  76. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_elffile.py +108 -0
  77. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_manylinux.py +252 -0
  78. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_musllinux.py +83 -0
  79. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_parser.py +359 -0
  80. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_structures.py +61 -0
  81. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/_tokenizer.py +192 -0
  82. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/markers.py +252 -0
  83. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/metadata.py +825 -0
  84. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/py.typed +0 -0
  85. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/requirements.py +90 -0
  86. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/specifiers.py +1030 -0
  87. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/tags.py +553 -0
  88. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/utils.py +172 -0
  89. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pylib/packaging/version.py +563 -0
  90. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/pyproject.toml +120 -0
  91. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/release-please-config.json +11 -0
  92. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/gyp/test_gyp.py +261 -0
  93. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/Find-VisualStudio.cs +250 -0
  94. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/build.js +227 -0
  95. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/clean.js +15 -0
  96. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/configure.js +328 -0
  97. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/create-config-gypi.js +150 -0
  98. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/download.js +39 -0
  99. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/find-node-directory.js +63 -0
  100. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/find-python.js +310 -0
  101. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/find-visualstudio.js +590 -0
  102. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/install.js +415 -0
  103. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/list.js +26 -0
  104. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/log.js +168 -0
  105. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/node-gyp.js +188 -0
  106. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/process-release.js +146 -0
  107. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/rebuild.js +12 -0
  108. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/remove.js +43 -0
  109. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/lib/util.js +81 -0
  110. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/macOS_Catalina_acid_test.sh +21 -0
  111. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/package.json +51 -0
  112. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/release-please-config.json +40 -0
  113. package/.yarn/unplugged/node-gyp-npm-10.2.0-cad1109948/node_modules/node-gyp/src/win_delay_load_hook.cc +39 -0
  114. package/CHANGELOG.md +403 -0
  115. package/CONTRIBUTING.md +83 -0
  116. package/browser/address.d.ts +16 -0
  117. package/{src → browser}/bip66.d.ts +6 -7
  118. package/{src → browser}/block.d.ts +29 -30
  119. package/{src → browser}/bufferutils.d.ts +34 -54
  120. package/browser/crypto/crypto.d.ts +1 -0
  121. package/{src → browser}/crypto.d.ts +13 -18
  122. package/browser/ecc_lib.d.ts +3 -0
  123. package/browser/hooks/AdvancedSignatureManager.d.ts +16 -0
  124. package/{src → browser}/hooks/HookedSigner.d.ts +4 -4
  125. package/browser/hooks/SignatureManager.d.ts +13 -0
  126. package/browser/index.d.ts +58 -0
  127. package/browser/index.js +2 -0
  128. package/browser/index.js.LICENSE.txt +14 -0
  129. package/browser/merkle.d.ts +1 -0
  130. package/browser/networks.d.ts +23 -0
  131. package/{src → browser}/ops.d.ts +126 -126
  132. package/browser/payments/bip341.d.ts +23 -0
  133. package/browser/payments/embed.d.ts +2 -0
  134. package/browser/payments/index.d.ts +43 -0
  135. package/{src → browser}/payments/lazy.d.ts +2 -2
  136. package/browser/payments/p2ms.d.ts +2 -0
  137. package/browser/payments/p2pk.d.ts +2 -0
  138. package/browser/payments/p2pkh.d.ts +2 -0
  139. package/browser/payments/p2sh.d.ts +2 -0
  140. package/browser/payments/p2tr.d.ts +2 -0
  141. package/browser/payments/p2wpkh.d.ts +2 -0
  142. package/browser/payments/p2wsh.d.ts +2 -0
  143. package/browser/psbt/bip371.d.ts +16 -0
  144. package/browser/psbt/psbtutils.d.ts +26 -0
  145. package/{src → browser}/psbt.d.ts +167 -238
  146. package/browser/push_data.d.ts +7 -0
  147. package/browser/script.d.ts +17 -0
  148. package/browser/script_number.d.ts +2 -0
  149. package/browser/script_signature.d.ts +7 -0
  150. package/{src → browser}/transaction.d.ts +48 -60
  151. package/{src → browser}/types.d.ts +37 -54
  152. package/build/address.d.ts +16 -0
  153. package/build/address.js +148 -0
  154. package/build/bip66.d.ts +6 -0
  155. package/build/bip66.js +99 -0
  156. package/build/block.d.ts +29 -0
  157. package/build/block.js +181 -0
  158. package/build/bufferutils.d.ts +34 -0
  159. package/build/bufferutils.js +141 -0
  160. package/build/crypto/crypto.d.ts +1 -0
  161. package/build/crypto/crypto.js +1 -0
  162. package/build/crypto.d.ts +13 -0
  163. package/build/crypto.js +87 -0
  164. package/build/ecc_lib.d.ts +3 -0
  165. package/build/ecc_lib.js +61 -0
  166. package/build/hooks/AdvancedSignatureManager.d.ts +16 -0
  167. package/build/hooks/AdvancedSignatureManager.js +52 -0
  168. package/build/hooks/HookedSigner.d.ts +4 -0
  169. package/build/hooks/HookedSigner.js +64 -0
  170. package/build/hooks/SignatureManager.d.ts +13 -0
  171. package/build/hooks/SignatureManager.js +45 -0
  172. package/build/index.d.ts +58 -0
  173. package/build/index.js +32 -0
  174. package/build/merkle.d.ts +1 -0
  175. package/build/merkle.js +19 -0
  176. package/build/networks.d.ts +23 -0
  177. package/build/networks.js +121 -0
  178. package/build/ops.d.ts +126 -0
  179. package/{src → build}/ops.js +127 -131
  180. package/build/payments/bip341.d.ts +23 -0
  181. package/build/payments/bip341.js +82 -0
  182. package/build/payments/embed.d.ts +2 -0
  183. package/build/payments/embed.js +39 -0
  184. package/build/payments/index.d.ts +43 -0
  185. package/build/payments/index.js +10 -0
  186. package/build/payments/lazy.d.ts +2 -0
  187. package/{src → build}/payments/lazy.js +28 -32
  188. package/build/payments/p2ms.d.ts +2 -0
  189. package/{src → build}/payments/p2ms.js +128 -158
  190. package/build/payments/p2pk.d.ts +2 -0
  191. package/build/payments/p2pk.js +68 -0
  192. package/build/payments/p2pkh.d.ts +2 -0
  193. package/build/payments/p2pkh.js +173 -0
  194. package/build/payments/p2sh.d.ts +2 -0
  195. package/build/payments/p2sh.js +176 -0
  196. package/build/payments/p2tr.d.ts +2 -0
  197. package/build/payments/p2tr.js +254 -0
  198. package/build/payments/p2wpkh.d.ts +2 -0
  199. package/build/payments/p2wpkh.js +130 -0
  200. package/build/payments/p2wsh.d.ts +2 -0
  201. package/build/payments/p2wsh.js +180 -0
  202. package/build/psbt/bip371.d.ts +16 -0
  203. package/build/psbt/bip371.js +246 -0
  204. package/build/psbt/psbtutils.d.ts +26 -0
  205. package/build/psbt/psbtutils.js +177 -0
  206. package/build/psbt.d.ts +167 -0
  207. package/build/psbt.js +1307 -0
  208. package/build/push_data.d.ts +7 -0
  209. package/build/push_data.js +57 -0
  210. package/build/script.d.ts +17 -0
  211. package/build/script.js +167 -0
  212. package/build/script_number.d.ts +2 -0
  213. package/build/script_number.js +49 -0
  214. package/build/script_signature.d.ts +7 -0
  215. package/build/script_signature.js +49 -0
  216. package/build/transaction.d.ts +48 -0
  217. package/build/transaction.js +445 -0
  218. package/build/types.d.ts +37 -0
  219. package/build/types.js +73 -0
  220. package/cjs/package.json +3 -0
  221. package/coverage/tmp/coverage-31752-1735543485354-0.json +1 -0
  222. package/coverage/tmp/coverage-59920-1735543484555-0.json +1 -0
  223. package/coverage/tmp/coverage-66252-1735543483919-0.json +1 -0
  224. package/coverage/tmp/coverage-68440-1735543485236-0.json +1 -0
  225. package/coverage/tmp/coverage-70588-1735543484426-0.json +1 -0
  226. package/coverage/tmp/coverage-79292-1735543485296-0.json +1 -0
  227. package/coverage/tmp/coverage-80212-1735543483980-0.json +1 -0
  228. package/eslint.config.js +56 -0
  229. package/gulpfile.js +42 -0
  230. package/package.json +105 -50
  231. package/src/{address.js → address.ts} +211 -191
  232. package/src/{bip66.js → bip66.ts} +23 -19
  233. package/src/{block.js → block.ts} +114 -105
  234. package/src/{bufferutils.js → bufferutils.ts} +65 -67
  235. package/src/crypto/crypto-browser.js +75 -0
  236. package/src/crypto/crypto.ts +1 -0
  237. package/src/crypto.ts +108 -0
  238. package/src/{ecc_lib.js → ecc_lib.ts} +25 -53
  239. package/src/hooks/{AdvancedSignatureManager.js → AdvancedSignatureManager.ts} +34 -18
  240. package/src/hooks/HookedSigner.ts +108 -0
  241. package/src/hooks/{SignatureManager.js → SignatureManager.ts} +26 -14
  242. package/src/index.ts +86 -0
  243. package/src/{merkle.js → merkle.ts} +8 -7
  244. package/src/{networks.js → networks.ts} +235 -220
  245. package/src/ops.ts +282 -0
  246. package/src/payments/bip341.ts +140 -0
  247. package/src/payments/embed.ts +55 -0
  248. package/src/payments/{index.d.ts → index.ts} +24 -10
  249. package/src/payments/lazy.ts +28 -0
  250. package/src/payments/p2ms.ts +150 -0
  251. package/src/payments/{p2pk.js → p2pk.ts} +85 -82
  252. package/src/payments/p2pkh.ts +206 -0
  253. package/src/payments/{p2sh.js → p2sh.ts} +206 -204
  254. package/src/payments/{p2tr.js → p2tr.ts} +114 -125
  255. package/src/payments/{p2wpkh.js → p2wpkh.ts} +51 -56
  256. package/src/payments/{p2wsh.js → p2wsh.ts} +69 -81
  257. package/src/psbt/{bip371.js → bip371.ts} +441 -424
  258. package/src/psbt/psbtutils.ts +301 -0
  259. package/src/{psbt.js → psbt.ts} +2187 -1828
  260. package/src/{push_data.js → push_data.ts} +35 -21
  261. package/src/{script.js → script.ts} +93 -77
  262. package/src/{script_number.js → script_number.ts} +15 -21
  263. package/src/{script_signature.js → script_signature.ts} +26 -14
  264. package/src/{transaction.js → transaction.ts} +247 -167
  265. package/src/types.ts +122 -0
  266. package/test/address.spec.js +124 -0
  267. package/test/address.spec.ts +177 -0
  268. package/test/bitcoin.core.spec.js +170 -0
  269. package/test/bitcoin.core.spec.ts +234 -0
  270. package/test/block.spec.js +141 -0
  271. package/test/block.spec.ts +194 -0
  272. package/test/bufferutils.spec.js +427 -0
  273. package/test/bufferutils.spec.ts +513 -0
  274. package/test/crypto.spec.js +41 -0
  275. package/test/crypto.spec.ts +55 -0
  276. package/test/fixtures/address.json +329 -0
  277. package/test/fixtures/block.json +148 -0
  278. package/test/fixtures/bufferutils.json +102 -0
  279. package/test/fixtures/core/README.md +26 -0
  280. package/test/fixtures/core/base58_encode_decode.json +50 -0
  281. package/test/fixtures/core/base58_keys_invalid.json +152 -0
  282. package/test/fixtures/core/base58_keys_valid.json +452 -0
  283. package/test/fixtures/core/blocks.json +27 -0
  284. package/test/fixtures/core/sig_canonical.json +7 -0
  285. package/test/fixtures/core/sig_noncanonical.json +33 -0
  286. package/test/fixtures/core/sighash.json +3505 -0
  287. package/test/fixtures/core/tx_valid.json +2023 -0
  288. package/test/fixtures/crypto.json +43 -0
  289. package/test/fixtures/ecdsa.json +217 -0
  290. package/test/fixtures/ecpair.json +141 -0
  291. package/test/fixtures/embed.json +108 -0
  292. package/test/fixtures/p2ms.json +434 -0
  293. package/test/fixtures/p2pk.json +179 -0
  294. package/test/fixtures/p2pkh.json +276 -0
  295. package/test/fixtures/p2sh.json +508 -0
  296. package/test/fixtures/p2tr.json +1198 -0
  297. package/test/fixtures/p2wpkh.json +290 -0
  298. package/test/fixtures/p2wsh.json +489 -0
  299. package/test/fixtures/psbt.json +924 -0
  300. package/test/fixtures/script.json +465 -0
  301. package/test/fixtures/script_number.json +225 -0
  302. package/test/fixtures/signature.json +140 -0
  303. package/test/fixtures/transaction.json +916 -0
  304. package/test/integration/_regtest.js +7 -0
  305. package/test/integration/_regtest.ts +6 -0
  306. package/test/integration/addresses.spec.js +116 -0
  307. package/test/integration/addresses.spec.ts +154 -0
  308. package/test/integration/bip32.spec.js +85 -0
  309. package/test/integration/bip32.spec.ts +151 -0
  310. package/test/integration/blocks.spec.js +26 -0
  311. package/test/integration/blocks.spec.ts +28 -0
  312. package/test/integration/cltv.spec.js +199 -0
  313. package/test/integration/cltv.spec.ts +283 -0
  314. package/test/integration/csv.spec.js +362 -0
  315. package/test/integration/csv.spec.ts +527 -0
  316. package/test/integration/payments.spec.js +98 -0
  317. package/test/integration/payments.spec.ts +135 -0
  318. package/test/integration/taproot.spec.js +532 -0
  319. package/test/integration/taproot.spec.ts +707 -0
  320. package/test/integration/transactions.spec.js +561 -0
  321. package/test/integration/transactions.spec.ts +769 -0
  322. package/test/payments.spec.js +97 -0
  323. package/test/payments.spec.ts +125 -0
  324. package/test/payments.utils.js +190 -0
  325. package/test/payments.utils.ts +208 -0
  326. package/test/psbt.spec.js +1044 -0
  327. package/test/psbt.spec.ts +1414 -0
  328. package/test/script.spec.js +151 -0
  329. package/test/script.spec.ts +210 -0
  330. package/test/script_number.spec.js +24 -0
  331. package/test/script_number.spec.ts +29 -0
  332. package/test/script_signature.spec.js +52 -0
  333. package/test/script_signature.spec.ts +66 -0
  334. package/test/transaction.spec.js +269 -0
  335. package/test/transaction.spec.ts +387 -0
  336. package/test/ts-node-register.js +5 -0
  337. package/test/tsconfig.json +45 -0
  338. package/test/types.spec.js +46 -0
  339. package/test/types.spec.ts +58 -0
  340. package/tsconfig.base.json +27 -0
  341. package/tsconfig.json +19 -0
  342. package/tsconfig.webpack.json +18 -0
  343. package/webpack.config.js +79 -0
  344. package/src/address.d.ts +0 -42
  345. package/src/crypto.js +0 -128
  346. package/src/ecc_lib.d.ts +0 -17
  347. package/src/hooks/AdvancedSignatureManager.d.ts +0 -44
  348. package/src/hooks/HookedSigner.js +0 -90
  349. package/src/hooks/SignatureManager.d.ts +0 -35
  350. package/src/index.d.ts +0 -42
  351. package/src/index.js +0 -87
  352. package/src/merkle.d.ts +0 -10
  353. package/src/networks.d.ts +0 -83
  354. package/src/payments/bip341.d.ts +0 -49
  355. package/src/payments/bip341.js +0 -124
  356. package/src/payments/embed.d.ts +0 -9
  357. package/src/payments/embed.js +0 -54
  358. package/src/payments/index.js +0 -69
  359. package/src/payments/p2ms.d.ts +0 -9
  360. package/src/payments/p2pk.d.ts +0 -10
  361. package/src/payments/p2pkh.d.ts +0 -10
  362. package/src/payments/p2pkh.js +0 -143
  363. package/src/payments/p2sh.d.ts +0 -10
  364. package/src/payments/p2tr.d.ts +0 -10
  365. package/src/payments/p2wpkh.d.ts +0 -10
  366. package/src/payments/p2wsh.d.ts +0 -10
  367. package/src/psbt/bip371.d.ts +0 -42
  368. package/src/psbt/psbtutils.d.ts +0 -64
  369. package/src/psbt/psbtutils.js +0 -191
  370. package/src/push_data.d.ts +0 -29
  371. package/src/script.d.ts +0 -42
  372. package/src/script_number.d.ts +0 -19
  373. package/src/script_signature.d.ts +0 -21
  374. package/src/types.js +0 -106
@@ -0,0 +1,43 @@
1
+ import { Network } from '../networks';
2
+ import { Taptree } from '../types';
3
+ export * from './bip341.js';
4
+ export * from './embed.js';
5
+ export * from './lazy.js';
6
+ export * from './p2ms.js';
7
+ export * from './p2pk.js';
8
+ export * from './p2pkh.js';
9
+ export * from './p2sh.js';
10
+ export * from './p2tr.js';
11
+ export * from './p2wpkh.js';
12
+ export * from './p2wsh.js';
13
+ export interface Payment {
14
+ name?: string;
15
+ network?: Network;
16
+ output?: Buffer;
17
+ data?: Buffer[];
18
+ m?: number;
19
+ n?: number;
20
+ pubkeys?: Buffer[];
21
+ input?: Buffer;
22
+ signatures?: Buffer[];
23
+ internalPubkey?: Buffer;
24
+ pubkey?: Buffer;
25
+ signature?: Buffer;
26
+ address?: string;
27
+ hash?: Buffer;
28
+ redeem?: Payment;
29
+ redeemVersion?: number;
30
+ scriptTree?: Taptree;
31
+ witness?: Buffer[];
32
+ useHybrid?: boolean;
33
+ useUncompressed?: boolean;
34
+ }
35
+ export type PaymentCreator = (a: Payment, opts?: PaymentOpts) => Payment;
36
+ export type PaymentFunction = () => Payment;
37
+ export interface PaymentOpts {
38
+ validate?: boolean;
39
+ allowIncomplete?: boolean;
40
+ }
41
+ export type StackElement = Buffer | number;
42
+ export type Stack = StackElement[];
43
+ export type StackFunction = () => Stack;
@@ -0,0 +1,10 @@
1
+ export * from './bip341.js';
2
+ export * from './embed.js';
3
+ export * from './lazy.js';
4
+ export * from './p2ms.js';
5
+ export * from './p2pk.js';
6
+ export * from './p2pkh.js';
7
+ export * from './p2sh.js';
8
+ export * from './p2tr.js';
9
+ export * from './p2wpkh.js';
10
+ export * from './p2wsh.js';
@@ -0,0 +1,2 @@
1
+ export declare function prop(object: {}, name: string, f: () => any): void;
2
+ export declare function value<T>(f: () => T): () => T;
@@ -1,32 +1,28 @@
1
- 'use strict';
2
- Object.defineProperty(exports, '__esModule', { value: true });
3
- exports.value = exports.prop = void 0;
4
- function prop(object, name, f) {
5
- Object.defineProperty(object, name, {
6
- configurable: true,
7
- enumerable: true,
8
- get() {
9
- const _value = f.call(this);
10
- this[name] = _value;
11
- return _value;
12
- },
13
- set(_value) {
14
- Object.defineProperty(this, name, {
15
- configurable: true,
16
- enumerable: true,
17
- value: _value,
18
- writable: true,
19
- });
20
- },
21
- });
22
- }
23
- exports.prop = prop;
24
- function value(f) {
25
- let _value;
26
- return () => {
27
- if (_value !== undefined) return _value;
28
- _value = f();
29
- return _value;
30
- };
31
- }
32
- exports.value = value;
1
+ export function prop(object, name, f) {
2
+ Object.defineProperty(object, name, {
3
+ configurable: true,
4
+ enumerable: true,
5
+ get() {
6
+ const _value = f.call(this);
7
+ this[name] = _value;
8
+ return _value;
9
+ },
10
+ set(_value) {
11
+ Object.defineProperty(this, name, {
12
+ configurable: true,
13
+ enumerable: true,
14
+ value: _value,
15
+ writable: true,
16
+ });
17
+ },
18
+ });
19
+ }
20
+ export function value(f) {
21
+ let _value;
22
+ return () => {
23
+ if (_value !== undefined)
24
+ return _value;
25
+ _value = f();
26
+ return _value;
27
+ };
28
+ }
@@ -0,0 +1,2 @@
1
+ import { Payment, PaymentOpts } from './index.js';
2
+ export declare function p2ms(a: Payment, opts?: PaymentOpts): Payment;
@@ -1,158 +1,128 @@
1
- 'use strict';
2
- Object.defineProperty(exports, '__esModule', { value: true });
3
- exports.p2ms = void 0;
4
- const networks_1 = require('../networks');
5
- const bscript = require('../script');
6
- const types_1 = require('../types');
7
- const lazy = require('./lazy');
8
- const OPS = bscript.OPS;
9
- const OP_INT_BASE = OPS.OP_RESERVED; // OP_1 - 1
10
- // input: OP_0 [signatures ...]
11
- // output: m [pubKeys ...] n OP_CHECKMULTISIG
12
- /**
13
- * Represents a function that creates a Pay-to-Multisig (P2MS) payment object.
14
- * @param a - The payment object.
15
- * @param opts - Optional payment options.
16
- * @returns The created payment object.
17
- * @throws {TypeError} If the provided data is not valid.
18
- */
19
- function p2ms(a, opts) {
20
- if (
21
- !a.input &&
22
- !a.output &&
23
- !(a.pubkeys && a.m !== undefined) &&
24
- !a.signatures
25
- )
26
- throw new TypeError('Not enough data');
27
- opts = Object.assign({ validate: true }, opts || {});
28
- function isAcceptableSignature(x) {
29
- return (
30
- bscript.isCanonicalScriptSignature(x) ||
31
- (opts.allowIncomplete && x === OPS.OP_0) !== undefined
32
- );
33
- }
34
- (0, types_1.typeforce)(
35
- {
36
- network: types_1.typeforce.maybe(types_1.typeforce.Object),
37
- m: types_1.typeforce.maybe(types_1.typeforce.Number),
38
- n: types_1.typeforce.maybe(types_1.typeforce.Number),
39
- output: types_1.typeforce.maybe(types_1.typeforce.Buffer),
40
- pubkeys: types_1.typeforce.maybe(
41
- types_1.typeforce.arrayOf(types_1.isPoint),
42
- ),
43
- signatures: types_1.typeforce.maybe(
44
- types_1.typeforce.arrayOf(isAcceptableSignature),
45
- ),
46
- input: types_1.typeforce.maybe(types_1.typeforce.Buffer),
47
- },
48
- a,
49
- );
50
- const network = a.network || networks_1.bitcoin;
51
- const o = { network };
52
- let chunks = [];
53
- let decoded = false;
54
- function decode(output) {
55
- if (decoded) return;
56
- decoded = true;
57
- chunks = bscript.decompile(output);
58
- o.m = chunks[0] - OP_INT_BASE;
59
- o.n = chunks[chunks.length - 2] - OP_INT_BASE;
60
- o.pubkeys = chunks.slice(1, -2);
61
- }
62
- lazy.prop(o, 'output', () => {
63
- if (!a.m) return;
64
- if (!o.n) return;
65
- if (!a.pubkeys) return;
66
- return bscript.compile(
67
- [].concat(
68
- OP_INT_BASE + a.m,
69
- a.pubkeys,
70
- OP_INT_BASE + o.n,
71
- OPS.OP_CHECKMULTISIG,
72
- ),
73
- );
74
- });
75
- lazy.prop(o, 'm', () => {
76
- if (!o.output) return;
77
- decode(o.output);
78
- return o.m;
79
- });
80
- lazy.prop(o, 'n', () => {
81
- if (!o.pubkeys) return;
82
- return o.pubkeys.length;
83
- });
84
- lazy.prop(o, 'pubkeys', () => {
85
- if (!a.output) return;
86
- decode(a.output);
87
- return o.pubkeys;
88
- });
89
- lazy.prop(o, 'signatures', () => {
90
- if (!a.input) return;
91
- return bscript.decompile(a.input).slice(1);
92
- });
93
- lazy.prop(o, 'input', () => {
94
- if (!a.signatures) return;
95
- return bscript.compile([OPS.OP_0].concat(a.signatures));
96
- });
97
- lazy.prop(o, 'witness', () => {
98
- if (!o.input) return;
99
- return [];
100
- });
101
- lazy.prop(o, 'name', () => {
102
- if (!o.m || !o.n) return;
103
- return `p2ms(${o.m} of ${o.n})`;
104
- });
105
- // extended validation
106
- if (opts.validate) {
107
- if (a.output) {
108
- decode(a.output);
109
- if (!types_1.typeforce.Number(chunks[0]))
110
- throw new TypeError('Output is invalid');
111
- if (!types_1.typeforce.Number(chunks[chunks.length - 2]))
112
- throw new TypeError('Output is invalid');
113
- if (chunks[chunks.length - 1] !== OPS.OP_CHECKMULTISIG)
114
- throw new TypeError('Output is invalid');
115
- if (o.m <= 0 || o.n > 16 || o.m > o.n || o.n !== chunks.length - 3)
116
- throw new TypeError('Output is invalid');
117
- if (!o.pubkeys.every(x => (0, types_1.isPoint)(x)))
118
- throw new TypeError('Output is invalid');
119
- if (a.m !== undefined && a.m !== o.m)
120
- throw new TypeError('m mismatch');
121
- if (a.n !== undefined && a.n !== o.n)
122
- throw new TypeError('n mismatch');
123
- if (a.pubkeys && !(0, types_1.stacksEqual)(a.pubkeys, o.pubkeys))
124
- throw new TypeError('Pubkeys mismatch');
125
- }
126
- if (a.pubkeys) {
127
- if (a.n !== undefined && a.n !== a.pubkeys.length)
128
- throw new TypeError('Pubkey count mismatch');
129
- o.n = a.pubkeys.length;
130
- if (o.n < o.m)
131
- throw new TypeError('Pubkey count cannot be less than m');
132
- }
133
- if (a.signatures) {
134
- if (a.signatures.length < o.m)
135
- throw new TypeError('Not enough signatures provided');
136
- if (a.signatures.length > o.m)
137
- throw new TypeError('Too many signatures provided');
138
- }
139
- if (a.input) {
140
- if (a.input[0] !== OPS.OP_0)
141
- throw new TypeError('Input is invalid');
142
- if (
143
- o.signatures.length === 0 ||
144
- !o.signatures.every(isAcceptableSignature)
145
- )
146
- throw new TypeError('Input has invalid signature(s)');
147
- if (
148
- a.signatures &&
149
- !(0, types_1.stacksEqual)(a.signatures, o.signatures)
150
- )
151
- throw new TypeError('Signature mismatch');
152
- if (a.m !== undefined && a.m !== a.signatures.length)
153
- throw new TypeError('Signature count mismatch');
154
- }
155
- }
156
- return Object.assign(o, a);
157
- }
158
- exports.p2ms = p2ms;
1
+ import { bitcoin as BITCOIN_NETWORK } from '../networks.js';
2
+ import * as bscript from '../script.js';
3
+ import { isPoint, stacksEqual, typeforce as typef } from '../types.js';
4
+ import * as lazy from './lazy.js';
5
+ const OPS = bscript.OPS;
6
+ const OP_INT_BASE = OPS.OP_RESERVED;
7
+ export function p2ms(a, opts) {
8
+ if (!a.input && !a.output && !(a.pubkeys && a.m !== undefined) && !a.signatures)
9
+ throw new TypeError('Not enough data');
10
+ opts = Object.assign({ validate: true }, opts || {});
11
+ function isAcceptableSignature(x) {
12
+ return (bscript.isCanonicalScriptSignature(x) ||
13
+ (opts.allowIncomplete && x === OPS.OP_0) !== undefined);
14
+ }
15
+ typef({
16
+ network: typef.maybe(typef.Object),
17
+ m: typef.maybe(typef.Number),
18
+ n: typef.maybe(typef.Number),
19
+ output: typef.maybe(typef.Buffer),
20
+ pubkeys: typef.maybe(typef.arrayOf(isPoint)),
21
+ signatures: typef.maybe(typef.arrayOf(isAcceptableSignature)),
22
+ input: typef.maybe(typef.Buffer),
23
+ }, a);
24
+ const network = a.network || BITCOIN_NETWORK;
25
+ const o = { network };
26
+ let chunks = [];
27
+ let decoded = false;
28
+ function decode(output) {
29
+ if (decoded)
30
+ return;
31
+ decoded = true;
32
+ chunks = bscript.decompile(output);
33
+ o.m = chunks[0] - OP_INT_BASE;
34
+ o.n = chunks[chunks.length - 2] - OP_INT_BASE;
35
+ o.pubkeys = chunks.slice(1, -2);
36
+ }
37
+ lazy.prop(o, 'output', () => {
38
+ if (!a.m)
39
+ return;
40
+ if (!o.n)
41
+ return;
42
+ if (!a.pubkeys)
43
+ return;
44
+ return bscript.compile([].concat(OP_INT_BASE + a.m, a.pubkeys, OP_INT_BASE + o.n, OPS.OP_CHECKMULTISIG));
45
+ });
46
+ lazy.prop(o, 'm', () => {
47
+ if (!o.output)
48
+ return;
49
+ decode(o.output);
50
+ return o.m;
51
+ });
52
+ lazy.prop(o, 'n', () => {
53
+ if (!o.pubkeys)
54
+ return;
55
+ return o.pubkeys.length;
56
+ });
57
+ lazy.prop(o, 'pubkeys', () => {
58
+ if (!a.output)
59
+ return;
60
+ decode(a.output);
61
+ return o.pubkeys;
62
+ });
63
+ lazy.prop(o, 'signatures', () => {
64
+ if (!a.input)
65
+ return;
66
+ return bscript.decompile(a.input).slice(1);
67
+ });
68
+ lazy.prop(o, 'input', () => {
69
+ if (!a.signatures)
70
+ return;
71
+ return bscript.compile([OPS.OP_0].concat(a.signatures));
72
+ });
73
+ lazy.prop(o, 'witness', () => {
74
+ if (!o.input)
75
+ return;
76
+ return [];
77
+ });
78
+ lazy.prop(o, 'name', () => {
79
+ if (!o.m || !o.n)
80
+ return;
81
+ return `p2ms(${o.m} of ${o.n})`;
82
+ });
83
+ if (opts.validate) {
84
+ if (a.output) {
85
+ decode(a.output);
86
+ if (!typef.Number(chunks[0]))
87
+ throw new TypeError('Output is invalid');
88
+ if (!typef.Number(chunks[chunks.length - 2]))
89
+ throw new TypeError('Output is invalid');
90
+ if (chunks[chunks.length - 1] !== OPS.OP_CHECKMULTISIG)
91
+ throw new TypeError('Output is invalid');
92
+ if (o.m <= 0 || o.n > 16 || o.m > o.n || o.n !== chunks.length - 3)
93
+ throw new TypeError('Output is invalid');
94
+ if (!o.pubkeys.every((x) => isPoint(x)))
95
+ throw new TypeError('Output is invalid');
96
+ if (a.m !== undefined && a.m !== o.m)
97
+ throw new TypeError('m mismatch');
98
+ if (a.n !== undefined && a.n !== o.n)
99
+ throw new TypeError('n mismatch');
100
+ if (a.pubkeys && !stacksEqual(a.pubkeys, o.pubkeys))
101
+ throw new TypeError('Pubkeys mismatch');
102
+ }
103
+ if (a.pubkeys) {
104
+ if (a.n !== undefined && a.n !== a.pubkeys.length)
105
+ throw new TypeError('Pubkey count mismatch');
106
+ o.n = a.pubkeys.length;
107
+ if (o.n < o.m)
108
+ throw new TypeError('Pubkey count cannot be less than m');
109
+ }
110
+ if (a.signatures) {
111
+ if (a.signatures.length < o.m)
112
+ throw new TypeError('Not enough signatures provided');
113
+ if (a.signatures.length > o.m)
114
+ throw new TypeError('Too many signatures provided');
115
+ }
116
+ if (a.input) {
117
+ if (a.input[0] !== OPS.OP_0)
118
+ throw new TypeError('Input is invalid');
119
+ if (o.signatures.length === 0 || !o.signatures.every(isAcceptableSignature))
120
+ throw new TypeError('Input has invalid signature(s)');
121
+ if (a.signatures && !stacksEqual(a.signatures, o.signatures))
122
+ throw new TypeError('Signature mismatch');
123
+ if (a.m !== undefined && a.m !== a.signatures.length)
124
+ throw new TypeError('Signature count mismatch');
125
+ }
126
+ }
127
+ return Object.assign(o, a);
128
+ }
@@ -0,0 +1,2 @@
1
+ import { Payment, PaymentOpts } from './index.js';
2
+ export declare function p2pk(a: Payment, opts?: PaymentOpts): Payment;
@@ -0,0 +1,68 @@
1
+ import { bitcoin as BITCOIN_NETWORK } from '../networks.js';
2
+ import * as bscript from '../script.js';
3
+ import { isPoint, typeforce as typef } from '../types.js';
4
+ import * as lazy from './lazy.js';
5
+ const OPS = bscript.OPS;
6
+ export function p2pk(a, opts) {
7
+ if (!a.input && !a.output && !a.pubkey && !a.input && !a.signature)
8
+ throw new TypeError('Not enough data');
9
+ opts = Object.assign({ validate: true }, opts || {});
10
+ typef({
11
+ network: typef.maybe(typef.Object),
12
+ output: typef.maybe(typef.Buffer),
13
+ pubkey: typef.maybe(isPoint),
14
+ signature: typef.maybe(bscript.isCanonicalScriptSignature),
15
+ input: typef.maybe(typef.Buffer),
16
+ }, a);
17
+ const _chunks = lazy.value(() => {
18
+ return bscript.decompile(a.input);
19
+ });
20
+ const network = a.network || BITCOIN_NETWORK;
21
+ const o = { name: 'p2pk', network };
22
+ lazy.prop(o, 'output', () => {
23
+ if (!a.pubkey)
24
+ return;
25
+ return bscript.compile([a.pubkey, OPS.OP_CHECKSIG]);
26
+ });
27
+ lazy.prop(o, 'pubkey', () => {
28
+ if (!a.output)
29
+ return;
30
+ return a.output.slice(1, -1);
31
+ });
32
+ lazy.prop(o, 'signature', () => {
33
+ if (!a.input)
34
+ return;
35
+ return _chunks()[0];
36
+ });
37
+ lazy.prop(o, 'input', () => {
38
+ if (!a.signature)
39
+ return;
40
+ return bscript.compile([a.signature]);
41
+ });
42
+ lazy.prop(o, 'witness', () => {
43
+ if (!o.input)
44
+ return;
45
+ return [];
46
+ });
47
+ if (opts.validate) {
48
+ if (a.output) {
49
+ if (a.output[a.output.length - 1] !== OPS.OP_CHECKSIG)
50
+ throw new TypeError('Output is invalid');
51
+ if (!isPoint(o.pubkey))
52
+ throw new TypeError('Output pubkey is invalid');
53
+ if (a.pubkey && !a.pubkey.equals(o.pubkey))
54
+ throw new TypeError('Pubkey mismatch');
55
+ }
56
+ if (a.signature) {
57
+ if (a.input && !a.input.equals(o.input))
58
+ throw new TypeError('Signature mismatch');
59
+ }
60
+ if (a.input) {
61
+ if (_chunks().length !== 1)
62
+ throw new TypeError('Input is invalid');
63
+ if (!bscript.isCanonicalScriptSignature(o.signature))
64
+ throw new TypeError('Input has invalid signature');
65
+ }
66
+ }
67
+ return Object.assign(o, a);
68
+ }
@@ -0,0 +1,2 @@
1
+ import { Payment, PaymentOpts } from './index.js';
2
+ export declare function p2pkh(a: Payment, opts?: PaymentOpts): Payment;