@btc-vision/bitcoin 6.3.1 → 6.3.2

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 (259) 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/CHANGELOG.md +403 -0
  8. package/CONTRIBUTING.md +83 -0
  9. package/browser/address.d.ts +16 -0
  10. package/{src → browser}/bip66.d.ts +6 -7
  11. package/{src → browser}/block.d.ts +29 -30
  12. package/{src → browser}/bufferutils.d.ts +34 -54
  13. package/browser/crypto/crypto.d.ts +1 -0
  14. package/{src → browser}/crypto.d.ts +13 -18
  15. package/browser/ecc_lib.d.ts +3 -0
  16. package/browser/hooks/AdvancedSignatureManager.d.ts +16 -0
  17. package/{src → browser}/hooks/HookedSigner.d.ts +4 -4
  18. package/browser/hooks/SignatureManager.d.ts +13 -0
  19. package/browser/index.d.ts +58 -0
  20. package/browser/index.js +2 -0
  21. package/browser/index.js.LICENSE.txt +14 -0
  22. package/browser/merkle.d.ts +1 -0
  23. package/browser/networks.d.ts +23 -0
  24. package/{src → browser}/ops.d.ts +126 -126
  25. package/browser/payments/bip341.d.ts +23 -0
  26. package/browser/payments/embed.d.ts +2 -0
  27. package/browser/payments/index.d.ts +41 -0
  28. package/{src → browser}/payments/lazy.d.ts +2 -2
  29. package/browser/payments/p2ms.d.ts +2 -0
  30. package/browser/payments/p2pk.d.ts +2 -0
  31. package/browser/payments/p2pkh.d.ts +2 -0
  32. package/browser/payments/p2sh.d.ts +2 -0
  33. package/browser/payments/p2tr.d.ts +2 -0
  34. package/browser/payments/p2wpkh.d.ts +2 -0
  35. package/browser/payments/p2wsh.d.ts +2 -0
  36. package/browser/psbt/bip371.d.ts +16 -0
  37. package/browser/psbt/psbtutils.d.ts +26 -0
  38. package/{src → browser}/psbt.d.ts +167 -238
  39. package/browser/push_data.d.ts +7 -0
  40. package/browser/script.d.ts +17 -0
  41. package/browser/script_number.d.ts +2 -0
  42. package/browser/script_signature.d.ts +7 -0
  43. package/{src → browser}/transaction.d.ts +48 -60
  44. package/{src → browser}/types.d.ts +37 -54
  45. package/build/address.d.ts +16 -0
  46. package/build/address.js +148 -0
  47. package/build/bip66.d.ts +6 -0
  48. package/build/bip66.js +99 -0
  49. package/build/block.d.ts +29 -0
  50. package/build/block.js +181 -0
  51. package/build/bufferutils.d.ts +34 -0
  52. package/build/bufferutils.js +141 -0
  53. package/build/crypto/crypto.d.ts +1 -0
  54. package/build/crypto/crypto.js +1 -0
  55. package/build/crypto.d.ts +13 -0
  56. package/build/crypto.js +87 -0
  57. package/build/ecc_lib.d.ts +3 -0
  58. package/build/ecc_lib.js +61 -0
  59. package/build/hooks/AdvancedSignatureManager.d.ts +16 -0
  60. package/build/hooks/AdvancedSignatureManager.js +52 -0
  61. package/build/hooks/HookedSigner.d.ts +4 -0
  62. package/build/hooks/HookedSigner.js +64 -0
  63. package/build/hooks/SignatureManager.d.ts +13 -0
  64. package/build/hooks/SignatureManager.js +45 -0
  65. package/build/index.d.ts +58 -0
  66. package/build/index.js +32 -0
  67. package/build/merkle.d.ts +1 -0
  68. package/build/merkle.js +19 -0
  69. package/build/networks.d.ts +23 -0
  70. package/build/networks.js +121 -0
  71. package/build/ops.d.ts +126 -0
  72. package/{src → build}/ops.js +127 -131
  73. package/build/payments/bip341.d.ts +23 -0
  74. package/build/payments/bip341.js +82 -0
  75. package/build/payments/embed.d.ts +2 -0
  76. package/build/payments/embed.js +39 -0
  77. package/build/payments/index.d.ts +41 -0
  78. package/build/payments/index.js +10 -0
  79. package/build/payments/lazy.d.ts +2 -0
  80. package/{src → build}/payments/lazy.js +28 -32
  81. package/build/payments/p2ms.d.ts +2 -0
  82. package/{src → build}/payments/p2ms.js +128 -158
  83. package/build/payments/p2pk.d.ts +2 -0
  84. package/build/payments/p2pk.js +68 -0
  85. package/build/payments/p2pkh.d.ts +2 -0
  86. package/build/payments/p2pkh.js +135 -0
  87. package/build/payments/p2sh.d.ts +2 -0
  88. package/build/payments/p2sh.js +175 -0
  89. package/build/payments/p2tr.d.ts +2 -0
  90. package/build/payments/p2tr.js +254 -0
  91. package/build/payments/p2wpkh.d.ts +2 -0
  92. package/build/payments/p2wpkh.js +130 -0
  93. package/build/payments/p2wsh.d.ts +2 -0
  94. package/build/payments/p2wsh.js +180 -0
  95. package/build/psbt/bip371.d.ts +16 -0
  96. package/build/psbt/bip371.js +246 -0
  97. package/build/psbt/psbtutils.d.ts +26 -0
  98. package/build/psbt/psbtutils.js +170 -0
  99. package/build/psbt.d.ts +167 -0
  100. package/build/psbt.js +1305 -0
  101. package/build/push_data.d.ts +7 -0
  102. package/build/push_data.js +57 -0
  103. package/build/script.d.ts +17 -0
  104. package/build/script.js +167 -0
  105. package/build/script_number.d.ts +2 -0
  106. package/build/script_number.js +49 -0
  107. package/build/script_signature.d.ts +7 -0
  108. package/build/script_signature.js +49 -0
  109. package/build/transaction.d.ts +48 -0
  110. package/build/transaction.js +445 -0
  111. package/build/types.d.ts +37 -0
  112. package/build/types.js +73 -0
  113. package/cjs/package.json +3 -0
  114. package/eslint.config.js +56 -0
  115. package/gulpfile.js +42 -0
  116. package/package.json +105 -50
  117. package/src/{address.js → address.ts} +93 -73
  118. package/src/{bip66.js → bip66.ts} +23 -19
  119. package/src/{block.js → block.ts} +114 -105
  120. package/src/{bufferutils.js → bufferutils.ts} +65 -67
  121. package/src/crypto/crypto-browser.js +75 -0
  122. package/src/crypto/crypto.ts +1 -0
  123. package/src/crypto.ts +108 -0
  124. package/src/{ecc_lib.js → ecc_lib.ts} +25 -53
  125. package/src/hooks/{AdvancedSignatureManager.js → AdvancedSignatureManager.ts} +34 -18
  126. package/src/hooks/HookedSigner.ts +108 -0
  127. package/src/hooks/{SignatureManager.js → SignatureManager.ts} +26 -14
  128. package/src/index.ts +86 -0
  129. package/src/{merkle.js → merkle.ts} +8 -7
  130. package/src/{networks.js → networks.ts} +44 -29
  131. package/src/ops.ts +282 -0
  132. package/src/payments/bip341.ts +140 -0
  133. package/src/payments/embed.ts +55 -0
  134. package/src/payments/{index.d.ts → index.ts} +20 -10
  135. package/src/payments/lazy.ts +28 -0
  136. package/src/payments/p2ms.ts +150 -0
  137. package/src/payments/{p2pk.js → p2pk.ts} +32 -29
  138. package/src/payments/{p2pkh.js → p2pkh.ts} +53 -47
  139. package/src/payments/{p2sh.js → p2sh.ts} +72 -71
  140. package/src/payments/{p2tr.js → p2tr.ts} +114 -125
  141. package/src/payments/{p2wpkh.js → p2wpkh.ts} +51 -56
  142. package/src/payments/{p2wsh.js → p2wsh.ts} +69 -81
  143. package/src/psbt/{bip371.js → bip371.ts} +191 -174
  144. package/src/psbt/psbtutils.ts +299 -0
  145. package/src/{psbt.js → psbt.ts} +1025 -679
  146. package/src/{push_data.js → push_data.ts} +35 -21
  147. package/src/{script.js → script.ts} +93 -77
  148. package/src/{script_number.js → script_number.ts} +15 -21
  149. package/src/{script_signature.js → script_signature.ts} +26 -14
  150. package/src/{transaction.js → transaction.ts} +247 -167
  151. package/src/types.ts +122 -0
  152. package/test/address.spec.js +124 -0
  153. package/test/address.spec.ts +177 -0
  154. package/test/bitcoin.core.spec.js +170 -0
  155. package/test/bitcoin.core.spec.ts +234 -0
  156. package/test/block.spec.js +141 -0
  157. package/test/block.spec.ts +194 -0
  158. package/test/bufferutils.spec.js +427 -0
  159. package/test/bufferutils.spec.ts +513 -0
  160. package/test/crypto.spec.js +41 -0
  161. package/test/crypto.spec.ts +55 -0
  162. package/test/fixtures/address.json +329 -0
  163. package/test/fixtures/block.json +148 -0
  164. package/test/fixtures/bufferutils.json +102 -0
  165. package/test/fixtures/core/README.md +26 -0
  166. package/test/fixtures/core/base58_encode_decode.json +50 -0
  167. package/test/fixtures/core/base58_keys_invalid.json +152 -0
  168. package/test/fixtures/core/base58_keys_valid.json +452 -0
  169. package/test/fixtures/core/blocks.json +27 -0
  170. package/test/fixtures/core/sig_canonical.json +7 -0
  171. package/test/fixtures/core/sig_noncanonical.json +33 -0
  172. package/test/fixtures/core/sighash.json +3505 -0
  173. package/test/fixtures/core/tx_valid.json +2023 -0
  174. package/test/fixtures/crypto.json +43 -0
  175. package/test/fixtures/ecdsa.json +217 -0
  176. package/test/fixtures/ecpair.json +141 -0
  177. package/test/fixtures/embed.json +108 -0
  178. package/test/fixtures/p2ms.json +434 -0
  179. package/test/fixtures/p2pk.json +179 -0
  180. package/test/fixtures/p2pkh.json +276 -0
  181. package/test/fixtures/p2sh.json +508 -0
  182. package/test/fixtures/p2tr.json +1198 -0
  183. package/test/fixtures/p2wpkh.json +290 -0
  184. package/test/fixtures/p2wsh.json +489 -0
  185. package/test/fixtures/psbt.json +924 -0
  186. package/test/fixtures/script.json +465 -0
  187. package/test/fixtures/script_number.json +225 -0
  188. package/test/fixtures/signature.json +140 -0
  189. package/test/fixtures/transaction.json +916 -0
  190. package/test/integration/_regtest.js +7 -0
  191. package/test/integration/_regtest.ts +6 -0
  192. package/test/integration/addresses.spec.js +116 -0
  193. package/test/integration/addresses.spec.ts +154 -0
  194. package/test/integration/bip32.spec.js +85 -0
  195. package/test/integration/bip32.spec.ts +151 -0
  196. package/test/integration/blocks.spec.js +26 -0
  197. package/test/integration/blocks.spec.ts +28 -0
  198. package/test/integration/cltv.spec.js +199 -0
  199. package/test/integration/cltv.spec.ts +283 -0
  200. package/test/integration/csv.spec.js +362 -0
  201. package/test/integration/csv.spec.ts +527 -0
  202. package/test/integration/payments.spec.js +98 -0
  203. package/test/integration/payments.spec.ts +135 -0
  204. package/test/integration/taproot.spec.js +532 -0
  205. package/test/integration/taproot.spec.ts +707 -0
  206. package/test/integration/transactions.spec.js +561 -0
  207. package/test/integration/transactions.spec.ts +769 -0
  208. package/test/payments.spec.js +97 -0
  209. package/test/payments.spec.ts +125 -0
  210. package/test/payments.utils.js +190 -0
  211. package/test/payments.utils.ts +208 -0
  212. package/test/psbt.spec.js +1044 -0
  213. package/test/psbt.spec.ts +1414 -0
  214. package/test/script.spec.js +151 -0
  215. package/test/script.spec.ts +210 -0
  216. package/test/script_number.spec.js +24 -0
  217. package/test/script_number.spec.ts +29 -0
  218. package/test/script_signature.spec.js +52 -0
  219. package/test/script_signature.spec.ts +66 -0
  220. package/test/transaction.spec.js +269 -0
  221. package/test/transaction.spec.ts +387 -0
  222. package/test/ts-node-register.js +5 -0
  223. package/test/tsconfig.json +45 -0
  224. package/test/types.spec.js +46 -0
  225. package/test/types.spec.ts +58 -0
  226. package/tsconfig.base.json +27 -0
  227. package/tsconfig.json +19 -0
  228. package/tsconfig.webpack.json +18 -0
  229. package/webpack.config.js +79 -0
  230. package/src/address.d.ts +0 -42
  231. package/src/crypto.js +0 -128
  232. package/src/ecc_lib.d.ts +0 -17
  233. package/src/hooks/AdvancedSignatureManager.d.ts +0 -44
  234. package/src/hooks/HookedSigner.js +0 -90
  235. package/src/hooks/SignatureManager.d.ts +0 -35
  236. package/src/index.d.ts +0 -42
  237. package/src/index.js +0 -87
  238. package/src/merkle.d.ts +0 -10
  239. package/src/networks.d.ts +0 -83
  240. package/src/payments/bip341.d.ts +0 -49
  241. package/src/payments/bip341.js +0 -124
  242. package/src/payments/embed.d.ts +0 -9
  243. package/src/payments/embed.js +0 -54
  244. package/src/payments/index.js +0 -69
  245. package/src/payments/p2ms.d.ts +0 -9
  246. package/src/payments/p2pk.d.ts +0 -10
  247. package/src/payments/p2pkh.d.ts +0 -10
  248. package/src/payments/p2sh.d.ts +0 -10
  249. package/src/payments/p2tr.d.ts +0 -10
  250. package/src/payments/p2wpkh.d.ts +0 -10
  251. package/src/payments/p2wsh.d.ts +0 -10
  252. package/src/psbt/bip371.d.ts +0 -42
  253. package/src/psbt/psbtutils.d.ts +0 -64
  254. package/src/psbt/psbtutils.js +0 -191
  255. package/src/push_data.d.ts +0 -29
  256. package/src/script.d.ts +0 -42
  257. package/src/script_number.d.ts +0 -19
  258. package/src/script_signature.d.ts +0 -21
  259. package/src/types.js +0 -106
@@ -0,0 +1,43 @@
1
+ {
2
+ "hashes": [
3
+ {
4
+ "hex": "0000000000000001",
5
+ "hash160": "cdb00698f02afd929ffabea308340fa99ac2afa8",
6
+ "hash256": "3ae5c198d17634e79059c2cd735491553d22c4e09d1d9fea3ecf214565df2284",
7
+ "ripemd160": "8d1a05d1bc08870968eb8a81ad4393fd3aac6633",
8
+ "sha1": "cb473678976f425d6ec1339838f11011007ad27d",
9
+ "sha256": "cd2662154e6d76b2b2b92e70c0cac3ccf534f9b74eb5b89819ec509083d00a50"
10
+ },
11
+ {
12
+ "hex": "0101010101010101",
13
+ "hash160": "abaf1119f83e384210fe8e222eac76e2f0da39dc",
14
+ "hash256": "728338d99f356175c4945ef5cccfa61b7b56143cbbf426ddd0e0fc7cfe8c3c23",
15
+ "ripemd160": "5825701b4b9767fd35063b286dca3582853e0630",
16
+ "sha1": "c0357a32ed1f6a03be92dd094476f7f1a2e214ec",
17
+ "sha256": "04abc8821a06e5a30937967d11ad10221cb5ac3b5273e434f1284ee87129a061"
18
+ },
19
+ {
20
+ "hex": "ffffffffffffffff",
21
+ "hash160": "f86221f5a1fca059a865c0b7d374dfa9d5f3aeb4",
22
+ "hash256": "752adad0a7b9ceca853768aebb6965eca126a62965f698a0c1bc43d83db632ad",
23
+ "ripemd160": "cb760221600ed34337ca3ab70016b5f58c838120",
24
+ "sha1": "be673e8a56eaa9d8c1d35064866701c11ef8e089",
25
+ "sha256": "12a3ae445661ce5dee78d0650d33362dec29c4f82af05e7e57fb595bbbacf0ca"
26
+ },
27
+ {
28
+ "hex": "4c6f72656d20697073756d20646f6c6f722073697420616d65742c20636f6e73656374657475722061646970697363696e6720656c69742e20446f6e65632061742066617563696275732073617069656e2c2076656c20666163696c6973697320617263752e20536564207574206d61737361206e6962682e205574206d6f6c6c69732070756c76696e6172206d617373612e20557420756c6c616d636f7270657220646f6c6f7220656e696d2c20696e206d6f6c657374696520656e696d20636f6e64696d656e74756d2061632e20416c697175616d206572617420766f6c75747061742e204e756c6c6120736f64616c657320617420647569206e656320",
29
+ "hash160": "9763e6b367c363bd6b88a7b361c98e6beee243a5",
30
+ "hash256": "033588797115feb3545052670cac2a46584ab3cb460de63756ee0275e66b5799",
31
+ "ripemd160": "cad8593dcdef12ee334c97bab9787f07b3f3a1a5",
32
+ "sha1": "10d96fb43aca84e342206887bbeed3065d4e4344",
33
+ "sha256": "a7fb8276035057ed6479c5f2305a96da100ac43f0ac10f277e5ab8c5457429da"
34
+ }
35
+ ],
36
+ "taggedHash": [
37
+ {
38
+ "tag": "TapTweak",
39
+ "hex": "0101010101010101",
40
+ "result": "71ae15bad52efcecf4c9f672bfbded68a4adb8258f1b95f0d06aefdb5ebd14e9"
41
+ }
42
+ ]
43
+ }
@@ -0,0 +1,217 @@
1
+ {
2
+ "valid": {
3
+ "ecdsa": [
4
+ {
5
+ "d": "01",
6
+ "k": "ec633bd56a5774a0940cb97e27a9e4e51dc94af737596a0c5cbb3d30332d92a5",
7
+ "message": "Everything should be made as simple as possible, but not simpler.",
8
+ "signature": {
9
+ "r": "33a69cd2065432a30f3d1ce4eb0d59b8ab58c74f27c41a7fdb5696ad4e6108c9",
10
+ "s": "6f807982866f785d3f6418d24163ddae117b7db4d5fdf0071de069fa54342262"
11
+ }
12
+ },
13
+ {
14
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364140",
15
+ "k": "9dc74cbfd383980fb4ae5d2680acddac9dac956dca65a28c80ac9c847c2374e4",
16
+ "message": "Equations are more important to me, because politics is for the present, but an equation is something for eternity.",
17
+ "signature": {
18
+ "r": "54c4a33c6423d689378f160a7ff8b61330444abb58fb470f96ea16d99d4a2fed",
19
+ "s": "07082304410efa6b2943111b6a4e0aaa7b7db55a07e9861d1fb3cb1f421044a5"
20
+ }
21
+ },
22
+ {
23
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364140",
24
+ "k": "fd27071f01648ebbdd3e1cfbae48facc9fa97edc43bbbc9a7fdc28eae13296f5",
25
+ "message": "Not only is the Universe stranger than we think, it is stranger than we can think.",
26
+ "signature": {
27
+ "r": "ff466a9f1b7b273e2f4c3ffe032eb2e814121ed18ef84665d0f515360dab3dd0",
28
+ "s": "6fc95f5132e5ecfdc8e5e6e616cc77151455d46ed48f5589b7db7771a332b283"
29
+ }
30
+ },
31
+ {
32
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
33
+ "k": "f0cd2ba5fc7c183de589f6416220a36775a146740798756d8d949f7166dcc87f",
34
+ "message": "How wonderful that we have met with a paradox. Now we have some hope of making progress.",
35
+ "signature": {
36
+ "r": "c0dafec8251f1d5010289d210232220b03202cba34ec11fec58b3e93a85b91d3",
37
+ "s": "75afdc06b7d6322a590955bf264e7aaa155847f614d80078a90292fe205064d3"
38
+ }
39
+ },
40
+ {
41
+ "d": "69ec59eaa1f4f2e36b639716b7c30ca86d9a5375c7b38d8918bd9c0ebc80ba64",
42
+ "k": "6bb4a594ad57c1aa22dbe991a9d8501daf4688bf50a4892ef21bd7c711afda97",
43
+ "message": "Computer science is no more about computers than astronomy is about telescopes.",
44
+ "signature": {
45
+ "r": "7186363571d65e084e7f02b0b77c3ec44fb1b257dee26274c38c928986fea45d",
46
+ "s": "0de0b38e06807e46bda1f1e293f4f6323e854c86d58abdd00c46c16441085df6"
47
+ }
48
+ },
49
+ {
50
+ "d": "00000000000000000000000000007246174ab1e92e9149c6e446fe194d072637",
51
+ "k": "097b5c8ee22c3ea78a4d3635e0ff6fe85a1eb92ce317ded90b9e71aab2b861cb",
52
+ "message": "...if you aren't, at any given time, scandalized by code you wrote five or even three years ago, you're not learning anywhere near enough",
53
+ "signature": {
54
+ "r": "fbfe5076a15860ba8ed00e75e9bd22e05d230f02a936b653eb55b61c99dda487",
55
+ "s": "0e68880ebb0050fe4312b1b1eb0899e1b82da89baa5b895f612619edf34cbd37"
56
+ }
57
+ },
58
+ {
59
+ "d": "000000000000000000000000000000000000000000056916d0f9b31dc9b637f3",
60
+ "k": "19355c36c8cbcdfb2382e23b194b79f8c97bf650040fc7728dfbf6b39a97c25b",
61
+ "message": "The question of whether computers can think is like the question of whether submarines can swim.",
62
+ "signature": {
63
+ "r": "cde1302d83f8dd835d89aef803c74a119f561fbaef3eb9129e45f30de86abbf9",
64
+ "s": "06ce643f5049ee1f27890467b77a6a8e11ec4661cc38cd8badf90115fbd03cef"
65
+ }
66
+ }
67
+ ],
68
+ "rfc6979": [
69
+ {
70
+ "message": "test data",
71
+ "d": "fee0a1f7afebf9d2a5a80c0c98a31c709681cce195cbcd06342b517970c0be1e",
72
+ "k0": "fcce1de7a9bcd6b2d3defade6afa1913fb9229e3b7ddf4749b55c4848b2a196e",
73
+ "k1": "727fbcb59eb48b1d7d46f95a04991fc512eb9dbf9105628e3aec87428df28fd8",
74
+ "k15": "398f0e2c9f79728f7b3d84d447ac3a86d8b2083c8f234a0ffa9c4043d68bd258"
75
+ },
76
+ {
77
+ "message": "Everything should be made as simple as possible, but not simpler.",
78
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
79
+ "k0": "ec633bd56a5774a0940cb97e27a9e4e51dc94af737596a0c5cbb3d30332d92a5",
80
+ "k1": "df55b6d1b5c48184622b0ead41a0e02bfa5ac3ebdb4c34701454e80aabf36f56",
81
+ "k15": "def007a9a3c2f7c769c75da9d47f2af84075af95cadd1407393dc1e26086ef87"
82
+ },
83
+ {
84
+ "message": "Satoshi Nakamoto",
85
+ "d": "0000000000000000000000000000000000000000000000000000000000000002",
86
+ "k0": "d3edc1b8224e953f6ee05c8bbf7ae228f461030e47caf97cde91430b4607405e",
87
+ "k1": "f86d8e43c09a6a83953f0ab6d0af59fb7446b4660119902e9967067596b58374",
88
+ "k15": "241d1f57d6cfd2f73b1ada7907b199951f95ef5ad362b13aed84009656e0254a"
89
+ },
90
+ {
91
+ "message": "Diffie Hellman",
92
+ "d": "7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f",
93
+ "k0": "c378a41cb17dce12340788dd3503635f54f894c306d52f6e9bc4b8f18d27afcc",
94
+ "k1": "90756c96fef41152ac9abe08819c4e95f16da2af472880192c69a2b7bac29114",
95
+ "k15": "7b3f53300ab0ccd0f698f4d67db87c44cf3e9e513d9df61137256652b2e94e7c"
96
+ },
97
+ {
98
+ "message": "Japan",
99
+ "d": "8080808080808080808080808080808080808080808080808080808080808080",
100
+ "k0": "f471e61b51d2d8db78f3dae19d973616f57cdc54caaa81c269394b8c34edcf59",
101
+ "k1": "6819d85b9730acc876fdf59e162bf309e9f63dd35550edf20869d23c2f3e6d17",
102
+ "k15": "d8e8bae3ee330a198d1f5e00ad7c5f9ed7c24c357c0a004322abca5d9cd17847"
103
+ },
104
+ {
105
+ "message": "Bitcoin",
106
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364140",
107
+ "k0": "36c848ffb2cbecc5422c33a994955b807665317c1ce2a0f59c689321aaa631cc",
108
+ "k1": "4ed8de1ec952a4f5b3bd79d1ff96446bcd45cabb00fc6ca127183e14671bcb85",
109
+ "k15": "56b6f47babc1662c011d3b1f93aa51a6e9b5f6512e9f2e16821a238d450a31f8"
110
+ },
111
+ {
112
+ "message": "i2FLPP8WEus5WPjpoHwheXOMSobUJVaZM1JPMQZq",
113
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364140",
114
+ "k0": "6e9b434fcc6bbb081a0463c094356b47d62d7efae7da9c518ed7bac23f4e2ed6",
115
+ "k1": "ae5323ae338d6117ce8520a43b92eacd2ea1312ae514d53d8e34010154c593bb",
116
+ "k15": "3eaa1b61d1b8ab2f1ca71219c399f2b8b3defa624719f1e96fe3957628c2c4ea"
117
+ },
118
+ {
119
+ "message": "lEE55EJNP7aLrMtjkeJKKux4Yg0E8E1SAJnWTCEh",
120
+ "d": "3881e5286abc580bb6139fe8e83d7c8271c6fe5e5c2d640c1f0ed0e1ee37edc9",
121
+ "k0": "5b606665a16da29cc1c5411d744ab554640479dd8abd3c04ff23bd6b302e7034",
122
+ "k1": "f8b25263152c042807c992eacd2ac2cc5790d1e9957c394f77ea368e3d9923bd",
123
+ "k15": "ea624578f7e7964ac1d84adb5b5087dd14f0ee78b49072aa19051cc15dab6f33"
124
+ },
125
+ {
126
+ "message": "2SaVPvhxkAPrayIVKcsoQO5DKA8Uv5X/esZFlf+y",
127
+ "d": "7259dff07922de7f9c4c5720d68c9745e230b32508c497dd24cb95ef18856631",
128
+ "k0": "3ab6c19ab5d3aea6aa0c6da37516b1d6e28e3985019b3adb388714e8f536686b",
129
+ "k1": "19af21b05004b0ce9cdca82458a371a9d2cf0dc35a813108c557b551c08eb52e",
130
+ "k15": "117a32665fca1b7137a91c4739ac5719fec0cf2e146f40f8e7c21b45a07ebc6a"
131
+ },
132
+ {
133
+ "message": "00A0OwO2THi7j5Z/jp0FmN6nn7N/DQd6eBnCS+/b",
134
+ "d": "0d6ea45d62b334777d6995052965c795a4f8506044b4fd7dc59c15656a28f7aa",
135
+ "k0": "79487de0c8799158294d94c0eb92ee4b567e4dc7ca18addc86e49d31ce1d2db6",
136
+ "k1": "9561d2401164a48a8f600882753b3105ebdd35e2358f4f808c4f549c91490009",
137
+ "k15": "b0d273634129ff4dbdf0df317d4062a1dbc58818f88878ffdb4ec511c77976c0"
138
+ }
139
+ ]
140
+ },
141
+ "invalid": {
142
+ "verify": [
143
+ {
144
+ "description": "The wrong signature",
145
+ "d": "01",
146
+ "message": "foo",
147
+ "signature": {
148
+ "r": "54c4a33c6423d689378f160a7ff8b61330444abb58fb470f96ea16d99d4a2fed",
149
+ "s": "07082304410efa6b2943111b6a4e0aaa7b7db55a07e9861d1fb3cb1f421044a5"
150
+ }
151
+ },
152
+ {
153
+ "description": "Invalid r value (< 0)",
154
+ "d": "01",
155
+ "message": "foo",
156
+ "signature": {
157
+ "r": "-01",
158
+ "s": "02"
159
+ }
160
+ },
161
+ {
162
+ "description": "Invalid r value (== 0)",
163
+ "d": "01",
164
+ "message": "foo",
165
+ "signature": {
166
+ "r": "00",
167
+ "s": "02"
168
+ }
169
+ },
170
+ {
171
+ "description": "Invalid r value (>= n)",
172
+ "d": "01",
173
+ "message": "foo",
174
+ "signature": {
175
+ "r": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141",
176
+ "s": "02"
177
+ }
178
+ },
179
+ {
180
+ "description": "Invalid s value (< 0)",
181
+ "d": "01",
182
+ "message": "foo",
183
+ "signature": {
184
+ "r": "02",
185
+ "s": "-01"
186
+ }
187
+ },
188
+ {
189
+ "description": "Invalid s value (== 0)",
190
+ "d": "01",
191
+ "message": "foo",
192
+ "signature": {
193
+ "r": "02",
194
+ "s": "00"
195
+ }
196
+ },
197
+ {
198
+ "description": "Invalid s value (>= n)",
199
+ "d": "01",
200
+ "message": "foo",
201
+ "signature": {
202
+ "r": "02",
203
+ "s": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"
204
+ }
205
+ },
206
+ {
207
+ "description": "Invalid r, s values (r = s = -n)",
208
+ "d": "01",
209
+ "message": "foo",
210
+ "signature": {
211
+ "r": "-fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141",
212
+ "s": "-fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"
213
+ }
214
+ }
215
+ ]
216
+ }
217
+ }
@@ -0,0 +1,141 @@
1
+ {
2
+ "valid": [
3
+ {
4
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
5
+ "Q": "0279be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798",
6
+ "compressed": true,
7
+ "network": "bitcoin",
8
+ "address": "1BgGZ9tcN4rm9KBzDn7KprQz87SZ26SAMH",
9
+ "WIF": "KwDiBf89QgGbjEhKnhXJuH7LrciVrZi3qYjgd9M7rFU73sVHnoWn"
10
+ },
11
+ {
12
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
13
+ "Q": "0479be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",
14
+ "compressed": false,
15
+ "network": "bitcoin",
16
+ "address": "1EHNa6Q4Jz2uvNExL497mE43ikXhwF6kZm",
17
+ "WIF": "5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreAnchuDf"
18
+ },
19
+ {
20
+ "d": "2bfe58ab6d9fd575bdc3a624e4825dd2b375d64ac033fbc46ea79dbab4f69a3e",
21
+ "Q": "02b80011a883a0fd621ad46dfc405df1e74bf075cbaf700fd4aebef6e96f848340",
22
+ "compressed": true,
23
+ "network": "bitcoin",
24
+ "address": "1MasfEKgSiaSeri2C6kgznaqBNtyrZPhNq",
25
+ "WIF": "KxhEDBQyyEFymvfJD96q8stMbJMbZUb6D1PmXqBWZDU2WvbvVs9o"
26
+ },
27
+ {
28
+ "d": "6c4313b03f2e7324d75e642f0ab81b734b724e13fec930f309e222470236d66b",
29
+ "Q": "024289801366bcee6172b771cf5a7f13aaecd237a0b9a1ff9d769cabc2e6b70a34",
30
+ "compressed": true,
31
+ "network": "bitcoin",
32
+ "address": "1LwwMWdSEMHJ2dMhSvAHZ3g95tG2UBv9jg",
33
+ "WIF": "KzrA86mCVMGWnLGBQu9yzQa32qbxb5dvSK4XhyjjGAWSBKYX4rHx"
34
+ },
35
+ {
36
+ "d": "6c4313b03f2e7324d75e642f0ab81b734b724e13fec930f309e222470236d66b",
37
+ "Q": "044289801366bcee6172b771cf5a7f13aaecd237a0b9a1ff9d769cabc2e6b70a34cec320a0565fb7caf11b1ca2f445f9b7b012dda5718b3cface369ee3a034ded6",
38
+ "compressed": false,
39
+ "network": "bitcoin",
40
+ "address": "1zXcfvKCLgsFdJDYPuqpu1sF3q92tnnUM",
41
+ "WIF": "5JdxzLtFPHNe7CAL8EBC6krdFv9pwPoRo4e3syMZEQT9srmK8hh"
42
+ },
43
+ {
44
+ "d": "6c4313b03f2e7324d75e642f0ab81b734b724e13fec930f309e222470236d66b",
45
+ "Q": "024289801366bcee6172b771cf5a7f13aaecd237a0b9a1ff9d769cabc2e6b70a34",
46
+ "compressed": true,
47
+ "network": "testnet",
48
+ "address": "n1TteZiR3NiYojqKAV8fNxtTwsrjM7kVdj",
49
+ "WIF": "cRD9b1m3vQxmwmjSoJy7Mj56f4uNFXjcWMCzpQCEmHASS4edEwXv"
50
+ },
51
+ {
52
+ "d": "6c4313b03f2e7324d75e642f0ab81b734b724e13fec930f309e222470236d66b",
53
+ "Q": "044289801366bcee6172b771cf5a7f13aaecd237a0b9a1ff9d769cabc2e6b70a34cec320a0565fb7caf11b1ca2f445f9b7b012dda5718b3cface369ee3a034ded6",
54
+ "compressed": false,
55
+ "network": "testnet",
56
+ "address": "mgWUuj1J1N882jmqFxtDepEC73Rr22E9GU",
57
+ "WIF": "92Qba5hnyWSn5Ffcka56yMQauaWY6ZLd91Vzxbi4a9CCetaHtYj"
58
+ },
59
+ {
60
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364140",
61
+ "Q": "0379be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798",
62
+ "compressed": true,
63
+ "network": "bitcoin",
64
+ "address": "1GrLCmVQXoyJXaPJQdqssNqwxvha1eUo2E",
65
+ "WIF": "L5oLkpV3aqBjhki6LmvChTCV6odsp4SXM6FfU2Gppt5kFLaHLuZ9"
66
+ }
67
+ ],
68
+ "invalid": {
69
+ "fromPrivateKey": [
70
+ {
71
+ "exception": "Private key not in range \\[1, n\\)",
72
+ "d": "0000000000000000000000000000000000000000000000000000000000000000"
73
+ },
74
+ {
75
+ "exception": "Private key not in range \\[1, n\\)",
76
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"
77
+ },
78
+ {
79
+ "exception": "Private key not in range \\[1, n\\)",
80
+ "d": "fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364142"
81
+ },
82
+ {
83
+ "exception": "Expected property \"compressed\" of type \\?Boolean, got Number 2",
84
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
85
+ "options": {
86
+ "compressed": 2
87
+ }
88
+ },
89
+ {
90
+ "exception": "Expected property \"network.messagePrefix\" of type Buffer|String, got undefined",
91
+ "d": "0000000000000000000000000000000000000000000000000000000000000001",
92
+ "options": {
93
+ "network": {}
94
+ }
95
+ }
96
+ ],
97
+ "fromPublicKey": [
98
+ {
99
+ "exception": "Expected isPoint, got Buffer",
100
+ "Q": "",
101
+ "options": {}
102
+ },
103
+ {
104
+ "exception": "Expected property \"network.messagePrefix\" of type Buffer|String, got undefined",
105
+ "Q": "044289801366bcee6172b771cf5a7f13aaecd237a0b9a1ff9d769cabc2e6b70a34cec320a0565fb7caf11b1ca2f445f9b7b012dda5718b3cface369ee3a034ded6",
106
+ "options": {
107
+ "network": {}
108
+ }
109
+ },
110
+ {
111
+ "description": "Bad X coordinate (== P)",
112
+ "exception": "Expected isPoint, got Buffer",
113
+ "Q": "040000000000000000000000000000000000000000000000000000000000000001fffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f",
114
+ "options": {}
115
+ }
116
+ ],
117
+ "fromWIF": [
118
+ {
119
+ "exception": "Invalid network version",
120
+ "network": "bitcoin",
121
+ "WIF": "92Qba5hnyWSn5Ffcka56yMQauaWY6ZLd91Vzxbi4a9CCetaHtYj"
122
+ },
123
+ {
124
+ "exception": "Unknown network version",
125
+ "WIF": "brQnSed3Fia1w9VcbbS6ZGDgJ6ENkgwuQY2LS7pEC5bKHD1fMF"
126
+ },
127
+ {
128
+ "exception": "Invalid compression flag",
129
+ "WIF": "KwDiBf89QgGbjEhKnhXJuH7LrciVrZi3qYjgd9M7rFU73sfZr2ym"
130
+ },
131
+ {
132
+ "exception": "Invalid WIF length",
133
+ "WIF": "3tq8Vmhh9SN5XhjTGSWgx8iKk59XbKG6UH4oqpejRuJhfYD"
134
+ },
135
+ {
136
+ "exception": "Invalid WIF length",
137
+ "WIF": "38uMpGARR2BJy5p4dNFKYg9UsWNoBtkpbdrXDjmfvz8krCtw3T1W92ZDSR"
138
+ }
139
+ ]
140
+ }
141
+ }
@@ -0,0 +1,108 @@
1
+ {
2
+ "valid": [
3
+ {
4
+ "description": "output from output",
5
+ "arguments": {
6
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
7
+ },
8
+ "options": {},
9
+ "expected": {
10
+ "data": [
11
+ "a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
12
+ ],
13
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4",
14
+ "input": null,
15
+ "witness": null
16
+ }
17
+ },
18
+ {
19
+ "description": "output from data",
20
+ "arguments": {
21
+ "data": [
22
+ "a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
23
+ ]
24
+ },
25
+ "expected": {
26
+ "data": [
27
+ "a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
28
+ ],
29
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4",
30
+ "input": null,
31
+ "witness": null
32
+ }
33
+ }
34
+ ],
35
+ "invalid": [
36
+ {
37
+ "exception": "Not enough data",
38
+ "arguments": {}
39
+ },
40
+ {
41
+ "description": "First OP is not OP_RETURN",
42
+ "exception": "Output is invalid",
43
+ "options": {},
44
+ "arguments": {
45
+ "output": "OP_1 OP_2 OP_ADD"
46
+ }
47
+ },
48
+ {
49
+ "description": "Return value and data do not match",
50
+ "exception": "Data mismatch",
51
+ "options": {},
52
+ "arguments": {
53
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4",
54
+ "data": [
55
+ "a3b147dbe4a85579fc4b5a1855555555555555555555555555555555555555555555555555555555"
56
+ ]
57
+ }
58
+ },
59
+ {
60
+ "description": "Script length incorrect",
61
+ "exception": "Data mismatch",
62
+ "options": {},
63
+ "arguments": {
64
+ "output": "OP_RETURN a3b1 47db",
65
+ "data": [
66
+ "a3b1"
67
+ ]
68
+ }
69
+ },
70
+ {
71
+ "description": "Return data is not buffer",
72
+ "exception": "Output is invalid",
73
+ "options": {},
74
+ "arguments": {
75
+ "output": "OP_RETURN OP_1"
76
+ }
77
+ }
78
+ ],
79
+ "dynamic": {
80
+ "depends": {
81
+ "data": [
82
+ "data",
83
+ "output"
84
+ ],
85
+ "output": [
86
+ "output",
87
+ "data"
88
+ ]
89
+ },
90
+ "details": [
91
+ {
92
+ "description": "embed",
93
+ "data": [
94
+ "a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
95
+ ],
96
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e07267e62b9a0d6858f9127735cadd82f67e06c24dbc4"
97
+ },
98
+ {
99
+ "description": "embed",
100
+ "data": [
101
+ "a3b147dbe4a85579fc4b5a1811e76620560e0726",
102
+ "7e62b9a0d6858f9127735cadd82f67e06c24dbc4"
103
+ ],
104
+ "output": "OP_RETURN a3b147dbe4a85579fc4b5a1811e76620560e0726 7e62b9a0d6858f9127735cadd82f67e06c24dbc4"
105
+ }
106
+ ]
107
+ }
108
+ }