@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,97 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const assert = require("assert");
4
+ const ecc = require("tiny-secp256k1");
5
+ const mocha_1 = require("mocha");
6
+ const u = require("./payments.utils");
7
+ const src_1 = require("../src");
8
+ ['embed', 'p2ms', 'p2pk', 'p2pkh', 'p2sh', 'p2wpkh', 'p2wsh', 'p2tr'].forEach(p => {
9
+ (0, mocha_1.describe)(p, () => {
10
+ beforeEach(() => {
11
+ (0, src_1.initEccLib)(p === 'p2tr' ? ecc : undefined);
12
+ });
13
+ let fn;
14
+ const payment = require('../src/payments/' + p);
15
+ if (p === 'embed') {
16
+ fn = payment.p2data;
17
+ }
18
+ else {
19
+ fn = payment[p];
20
+ }
21
+ const fixtures = require('./fixtures/' + p);
22
+ fixtures.valid.forEach((f) => {
23
+ (0, mocha_1.it)(f.description + ' as expected', () => {
24
+ const args = u.preform(f.arguments);
25
+ const actual = fn(args, f.options);
26
+ u.equate(actual, f.expected, f.arguments);
27
+ });
28
+ (0, mocha_1.it)(f.description + ' as expected (no validation)', () => {
29
+ const args = u.preform(f.arguments);
30
+ const actual = fn(args, Object.assign({}, f.options, {
31
+ validate: false,
32
+ }));
33
+ u.equate(actual, f.expected, f.arguments);
34
+ });
35
+ });
36
+ fixtures.invalid.forEach((f) => {
37
+ (0, mocha_1.it)('throws ' +
38
+ f.exception +
39
+ (f.description ? 'for ' + f.description : ''), () => {
40
+ const args = u.preform(f.arguments);
41
+ assert.throws(() => {
42
+ fn(args, f.options);
43
+ }, new RegExp(f.exception));
44
+ });
45
+ });
46
+ if (p === 'p2sh') {
47
+ const p2wsh = require('../src/payments/p2wsh').p2wsh;
48
+ const p2pk = require('../src/payments/p2pk').p2pk;
49
+ (0, mocha_1.it)('properly assembles nested p2wsh with names', () => {
50
+ const actual = fn({
51
+ redeem: p2wsh({
52
+ redeem: p2pk({
53
+ pubkey: Buffer.from('03e15819590382a9dd878f01e2f0cbce541564eb415e43b440472d883ecd283058', 'hex'),
54
+ }),
55
+ }),
56
+ });
57
+ assert.strictEqual(actual.address, '3MGbrbye4ttNUXM8WAvBFRKry4fkS9fjuw');
58
+ assert.strictEqual(actual.name, 'p2sh-p2wsh-p2pk');
59
+ assert.strictEqual(actual.redeem.name, 'p2wsh-p2pk');
60
+ assert.strictEqual(actual.redeem.redeem.name, 'p2pk');
61
+ });
62
+ }
63
+ // cross-verify dynamically too
64
+ if (!fixtures.dynamic)
65
+ return;
66
+ const { depends, details } = fixtures.dynamic;
67
+ details.forEach((f) => {
68
+ const detail = u.preform(f);
69
+ const disabled = {};
70
+ if (f.disabled)
71
+ f.disabled.forEach((k) => {
72
+ disabled[k] = true;
73
+ });
74
+ for (const key in depends) {
75
+ if (key in disabled)
76
+ continue;
77
+ const dependencies = depends[key];
78
+ dependencies.forEach((dependency) => {
79
+ if (!Array.isArray(dependency))
80
+ dependency = [dependency];
81
+ const args = {};
82
+ dependency.forEach((d) => {
83
+ u.from(d, detail, args);
84
+ });
85
+ const expected = u.from(key, detail);
86
+ (0, mocha_1.it)(f.description +
87
+ ', ' +
88
+ key +
89
+ ' derives from ' +
90
+ JSON.stringify(dependency), () => {
91
+ u.equate(fn(args), expected);
92
+ });
93
+ });
94
+ }
95
+ });
96
+ });
97
+ });
@@ -0,0 +1,125 @@
1
+ import * as assert from 'assert';
2
+ import * as ecc from 'tiny-secp256k1';
3
+ import { describe, it } from 'mocha';
4
+ import { PaymentCreator } from '../src/payments';
5
+ import * as u from './payments.utils';
6
+ import { initEccLib } from '../src';
7
+
8
+ ['embed', 'p2ms', 'p2pk', 'p2pkh', 'p2sh', 'p2wpkh', 'p2wsh', 'p2tr'].forEach(
9
+ p => {
10
+ describe(p, () => {
11
+ beforeEach(() => {
12
+ initEccLib(p === 'p2tr' ? ecc : undefined);
13
+ });
14
+ let fn: PaymentCreator;
15
+ const payment = require('../src/payments/' + p);
16
+ if (p === 'embed') {
17
+ fn = payment.p2data;
18
+ } else {
19
+ fn = payment[p];
20
+ }
21
+
22
+ const fixtures = require('./fixtures/' + p);
23
+
24
+ fixtures.valid.forEach((f: any) => {
25
+ it(f.description + ' as expected', () => {
26
+ const args = u.preform(f.arguments);
27
+ const actual = fn(args, f.options);
28
+
29
+ u.equate(actual, f.expected, f.arguments);
30
+ });
31
+
32
+ it(f.description + ' as expected (no validation)', () => {
33
+ const args = u.preform(f.arguments);
34
+ const actual = fn(
35
+ args,
36
+ Object.assign({}, f.options, {
37
+ validate: false,
38
+ }),
39
+ );
40
+
41
+ u.equate(actual, f.expected, f.arguments);
42
+ });
43
+ });
44
+
45
+ fixtures.invalid.forEach((f: any) => {
46
+ it(
47
+ 'throws ' +
48
+ f.exception +
49
+ (f.description ? 'for ' + f.description : ''),
50
+ () => {
51
+ const args = u.preform(f.arguments);
52
+
53
+ assert.throws(() => {
54
+ fn(args, f.options);
55
+ }, new RegExp(f.exception));
56
+ },
57
+ );
58
+ });
59
+
60
+ if (p === 'p2sh') {
61
+ const p2wsh = require('../src/payments/p2wsh').p2wsh;
62
+ const p2pk = require('../src/payments/p2pk').p2pk;
63
+ it('properly assembles nested p2wsh with names', () => {
64
+ const actual = fn({
65
+ redeem: p2wsh({
66
+ redeem: p2pk({
67
+ pubkey: Buffer.from(
68
+ '03e15819590382a9dd878f01e2f0cbce541564eb415e43b440472d883ecd283058',
69
+ 'hex',
70
+ ),
71
+ }),
72
+ }),
73
+ });
74
+ assert.strictEqual(
75
+ actual.address,
76
+ '3MGbrbye4ttNUXM8WAvBFRKry4fkS9fjuw',
77
+ );
78
+ assert.strictEqual(actual.name, 'p2sh-p2wsh-p2pk');
79
+ assert.strictEqual(actual.redeem!.name, 'p2wsh-p2pk');
80
+ assert.strictEqual(actual.redeem!.redeem!.name, 'p2pk');
81
+ });
82
+ }
83
+
84
+ // cross-verify dynamically too
85
+ if (!fixtures.dynamic) return;
86
+ const { depends, details } = fixtures.dynamic;
87
+
88
+ details.forEach((f: any) => {
89
+ const detail = u.preform(f);
90
+ const disabled: any = {};
91
+ if (f.disabled)
92
+ f.disabled.forEach((k: string) => {
93
+ disabled[k] = true;
94
+ });
95
+
96
+ for (const key in depends) {
97
+ if (key in disabled) continue;
98
+ const dependencies = depends[key];
99
+
100
+ dependencies.forEach((dependency: any) => {
101
+ if (!Array.isArray(dependency))
102
+ dependency = [dependency];
103
+
104
+ const args = {};
105
+ dependency.forEach((d: any) => {
106
+ u.from(d, detail, args);
107
+ });
108
+ const expected = u.from(key, detail);
109
+
110
+ it(
111
+ f.description +
112
+ ', ' +
113
+ key +
114
+ ' derives from ' +
115
+ JSON.stringify(dependency),
116
+ () => {
117
+ u.equate(fn(args), expected);
118
+ },
119
+ );
120
+ });
121
+ }
122
+ });
123
+ });
124
+ },
125
+ );
@@ -0,0 +1,190 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertScriptTree = exports.from = exports.preform = exports.equate = void 0;
4
+ const t = require("assert");
5
+ const BNETWORKS = require("../src/networks");
6
+ const bscript = require("../src/script");
7
+ function tryHex(x) {
8
+ if (Buffer.isBuffer(x))
9
+ return x.toString('hex');
10
+ if (Array.isArray(x))
11
+ return x.map(tryHex);
12
+ return x;
13
+ }
14
+ function fromHex(x) {
15
+ if (typeof x === 'string')
16
+ return Buffer.from(x, 'hex');
17
+ if (Array.isArray(x))
18
+ return x.map(fromHex);
19
+ return x;
20
+ }
21
+ function tryASM(x) {
22
+ if (Buffer.isBuffer(x))
23
+ return bscript.toASM(x);
24
+ return x;
25
+ }
26
+ function asmToBuffer(x) {
27
+ if (x === '')
28
+ return Buffer.alloc(0);
29
+ return bscript.fromASM(x);
30
+ }
31
+ function carryOver(a, b) {
32
+ for (const k in b) {
33
+ if (!k)
34
+ continue;
35
+ if (k in a && k === 'redeem') {
36
+ carryOver(a[k], b[k]);
37
+ continue;
38
+ }
39
+ // don't, the value was specified
40
+ if (k in a)
41
+ continue;
42
+ // otherwise, expect match
43
+ a[k] = b[k];
44
+ }
45
+ }
46
+ function equateBase(a, b, context) {
47
+ if ('output' in b)
48
+ t.strictEqual(tryASM(a.output), tryASM(b.output), `Inequal ${context}output`);
49
+ if ('input' in b)
50
+ t.strictEqual(tryASM(a.input), tryASM(b.input), `Inequal ${context}input`);
51
+ if ('witness' in b)
52
+ t.deepStrictEqual(tryHex(a.witness), tryHex(b.witness), `Inequal ${context}witness`);
53
+ if ('redeemVersion' in b)
54
+ t.strictEqual(a.redeemVersion, b.redeemVersion, `Inequal ${context}redeemVersion`);
55
+ }
56
+ function equate(a, b, args) {
57
+ b = Object.assign({}, b);
58
+ carryOver(b, args);
59
+ // by null, we mean 'undefined', but JSON
60
+ if (b.input === null)
61
+ b.input = undefined;
62
+ if (b.output === null)
63
+ b.output = undefined;
64
+ if (b.witness === null)
65
+ b.witness = undefined;
66
+ if (b.redeemVersion === null)
67
+ b.redeemVersion = undefined;
68
+ if (b.redeem) {
69
+ if (b.redeem.input === null)
70
+ b.redeem.input = undefined;
71
+ if (b.redeem.output === null)
72
+ b.redeem.output = undefined;
73
+ if (b.redeem.witness === null)
74
+ b.redeem.witness = undefined;
75
+ if (b.redeem.redeemVersion === null)
76
+ b.redeem.redeemVersion = undefined;
77
+ }
78
+ equateBase(a, b, '');
79
+ if (b.redeem)
80
+ equateBase(a.redeem, b.redeem, 'redeem.');
81
+ if (b.network)
82
+ t.deepStrictEqual(a.network, BNETWORKS[b.network], 'Inequal *.network');
83
+ // contextual
84
+ if (b.signature === null)
85
+ b.signature = undefined;
86
+ if (b.signatures === null)
87
+ b.signatures = undefined;
88
+ if ('address' in b)
89
+ t.strictEqual(a.address, b.address, 'Inequal *.address');
90
+ if ('name' in b)
91
+ t.strictEqual(a.name, b.name, 'Inequal *.name');
92
+ if ('hash' in b)
93
+ t.strictEqual(tryHex(a.hash), tryHex(b.hash), 'Inequal *.hash');
94
+ if ('pubkey' in b)
95
+ t.strictEqual(tryHex(a.pubkey), tryHex(b.pubkey), 'Inequal *.pubkey');
96
+ if ('internalPubkey' in b)
97
+ t.strictEqual(tryHex(a.internalPubkey), tryHex(b.internalPubkey), 'Inequal *.internalPubkey');
98
+ if ('signature' in b)
99
+ t.strictEqual(tryHex(a.signature), tryHex(b.signature), 'Inequal signature');
100
+ if ('m' in b)
101
+ t.strictEqual(a.m, b.m, 'Inequal *.m');
102
+ if ('n' in b)
103
+ t.strictEqual(a.n, b.n, 'Inequal *.n');
104
+ if ('pubkeys' in b)
105
+ t.deepStrictEqual(tryHex(a.pubkeys), tryHex(b.pubkeys), 'Inequal *.pubkeys');
106
+ if ('signatures' in b)
107
+ t.deepStrictEqual(tryHex(a.signatures), tryHex(b.signatures), 'Inequal *.signatures');
108
+ if ('data' in b)
109
+ t.deepStrictEqual(tryHex(a.data), tryHex(b.data), 'Inequal *.data');
110
+ }
111
+ exports.equate = equate;
112
+ function preform(x) {
113
+ x = Object.assign({}, x);
114
+ if (x.network)
115
+ x.network = BNETWORKS[x.network];
116
+ if (typeof x.inputHex === 'string') {
117
+ x.input = Buffer.from(x.inputHex, 'hex');
118
+ delete x.inputHex;
119
+ }
120
+ if (typeof x.outputHex === 'string') {
121
+ x.output = Buffer.from(x.outputHex, 'hex');
122
+ delete x.outputHex;
123
+ }
124
+ if (typeof x.output === 'string')
125
+ x.output = asmToBuffer(x.output);
126
+ if (typeof x.input === 'string')
127
+ x.input = asmToBuffer(x.input);
128
+ if (Array.isArray(x.witness))
129
+ x.witness = x.witness.map(fromHex);
130
+ if (x.data)
131
+ x.data = x.data.map(fromHex);
132
+ if (x.hash)
133
+ x.hash = Buffer.from(x.hash, 'hex');
134
+ if (x.pubkey)
135
+ x.pubkey = Buffer.from(x.pubkey, 'hex');
136
+ if (x.internalPubkey)
137
+ x.internalPubkey = Buffer.from(x.internalPubkey, 'hex');
138
+ if (x.signature)
139
+ x.signature = Buffer.from(x.signature, 'hex');
140
+ if (x.pubkeys)
141
+ x.pubkeys = x.pubkeys.map(fromHex);
142
+ if (x.signatures)
143
+ x.signatures = x.signatures.map((y) => {
144
+ return Number.isFinite(y) ? y : Buffer.from(y, 'hex');
145
+ });
146
+ if (x.redeem) {
147
+ x.redeem = Object.assign({}, x.redeem);
148
+ if (typeof x.redeem.input === 'string')
149
+ x.redeem.input = asmToBuffer(x.redeem.input);
150
+ if (typeof x.redeem.output === 'string')
151
+ x.redeem.output = asmToBuffer(x.redeem.output);
152
+ if (Array.isArray(x.redeem.witness))
153
+ x.redeem.witness = x.redeem.witness.map(fromHex);
154
+ if (x.redeem.network)
155
+ x.redeem.network = BNETWORKS[x.redeem.network];
156
+ }
157
+ if (x.scriptTree)
158
+ x.scriptTree = convertScriptTree(x.scriptTree);
159
+ return x;
160
+ }
161
+ exports.preform = preform;
162
+ function from(path, object, result) {
163
+ const paths = path.split('.');
164
+ result = result || {};
165
+ let r = result;
166
+ paths.forEach((k, i) => {
167
+ if (i < paths.length - 1) {
168
+ r[k] = r[k] || {};
169
+ // recurse
170
+ r = r[k];
171
+ object = object[k];
172
+ }
173
+ else {
174
+ r[k] = object[k];
175
+ }
176
+ });
177
+ return result;
178
+ }
179
+ exports.from = from;
180
+ function convertScriptTree(scriptTree, leafVersion) {
181
+ if (Array.isArray(scriptTree))
182
+ return scriptTree.map(tr => convertScriptTree(tr, leafVersion));
183
+ const script = Object.assign({}, scriptTree);
184
+ if (typeof script.output === 'string') {
185
+ script.output = asmToBuffer(scriptTree.output);
186
+ script.version = script.version || leafVersion;
187
+ }
188
+ return script;
189
+ }
190
+ exports.convertScriptTree = convertScriptTree;
@@ -0,0 +1,208 @@
1
+ import * as t from 'assert';
2
+ import * as BNETWORKS from '../src/networks';
3
+ import * as bscript from '../src/script';
4
+
5
+ function tryHex(x: Buffer | Buffer[]): string | string[] {
6
+ if (Buffer.isBuffer(x)) return x.toString('hex');
7
+ if (Array.isArray(x)) return x.map(tryHex) as string[];
8
+ return x;
9
+ }
10
+
11
+ function fromHex(x: string | string[]): Buffer | Buffer[] {
12
+ if (typeof x === 'string') return Buffer.from(x, 'hex');
13
+ if (Array.isArray(x)) return x.map(fromHex) as Buffer[];
14
+ return x;
15
+ }
16
+
17
+ function tryASM(x: Buffer): string {
18
+ if (Buffer.isBuffer(x)) return bscript.toASM(x);
19
+ return x;
20
+ }
21
+
22
+ function asmToBuffer(x: string): Buffer {
23
+ if (x === '') return Buffer.alloc(0);
24
+ return bscript.fromASM(x);
25
+ }
26
+
27
+ function carryOver(a: any, b: any): void {
28
+ for (const k in b) {
29
+ if (!k) continue;
30
+ if (k in a && k === 'redeem') {
31
+ carryOver(a[k], b[k]);
32
+ continue;
33
+ }
34
+
35
+ // don't, the value was specified
36
+ if (k in a) continue;
37
+
38
+ // otherwise, expect match
39
+ a[k] = b[k];
40
+ }
41
+ }
42
+
43
+ function equateBase(a: any, b: any, context: string): void {
44
+ if ('output' in b)
45
+ t.strictEqual(
46
+ tryASM(a.output),
47
+ tryASM(b.output),
48
+ `Inequal ${context}output`,
49
+ );
50
+ if ('input' in b)
51
+ t.strictEqual(
52
+ tryASM(a.input),
53
+ tryASM(b.input),
54
+ `Inequal ${context}input`,
55
+ );
56
+ if ('witness' in b)
57
+ t.deepStrictEqual(
58
+ tryHex(a.witness),
59
+ tryHex(b.witness),
60
+ `Inequal ${context}witness`,
61
+ );
62
+ if ('redeemVersion' in b)
63
+ t.strictEqual(
64
+ a.redeemVersion,
65
+ b.redeemVersion,
66
+ `Inequal ${context}redeemVersion`,
67
+ );
68
+ }
69
+
70
+ export function equate(a: any, b: any, args?: any): void {
71
+ b = Object.assign({}, b);
72
+ carryOver(b, args);
73
+
74
+ // by null, we mean 'undefined', but JSON
75
+ if (b.input === null) b.input = undefined;
76
+ if (b.output === null) b.output = undefined;
77
+ if (b.witness === null) b.witness = undefined;
78
+ if (b.redeemVersion === null) b.redeemVersion = undefined;
79
+ if (b.redeem) {
80
+ if (b.redeem.input === null) b.redeem.input = undefined;
81
+ if (b.redeem.output === null) b.redeem.output = undefined;
82
+ if (b.redeem.witness === null) b.redeem.witness = undefined;
83
+ if (b.redeem.redeemVersion === null) b.redeem.redeemVersion = undefined;
84
+ }
85
+
86
+ equateBase(a, b, '');
87
+ if (b.redeem) equateBase(a.redeem, b.redeem, 'redeem.');
88
+ if (b.network)
89
+ t.deepStrictEqual(
90
+ a.network,
91
+ (BNETWORKS as any)[b.network],
92
+ 'Inequal *.network',
93
+ );
94
+
95
+ // contextual
96
+ if (b.signature === null) b.signature = undefined;
97
+ if (b.signatures === null) b.signatures = undefined;
98
+ if ('address' in b)
99
+ t.strictEqual(a.address, b.address, 'Inequal *.address');
100
+ if ('name' in b) t.strictEqual(a.name, b.name, 'Inequal *.name');
101
+ if ('hash' in b)
102
+ t.strictEqual(tryHex(a.hash), tryHex(b.hash), 'Inequal *.hash');
103
+ if ('pubkey' in b)
104
+ t.strictEqual(tryHex(a.pubkey), tryHex(b.pubkey), 'Inequal *.pubkey');
105
+ if ('internalPubkey' in b)
106
+ t.strictEqual(
107
+ tryHex(a.internalPubkey),
108
+ tryHex(b.internalPubkey),
109
+ 'Inequal *.internalPubkey',
110
+ );
111
+ if ('signature' in b)
112
+ t.strictEqual(
113
+ tryHex(a.signature),
114
+ tryHex(b.signature),
115
+ 'Inequal signature',
116
+ );
117
+ if ('m' in b) t.strictEqual(a.m, b.m, 'Inequal *.m');
118
+ if ('n' in b) t.strictEqual(a.n, b.n, 'Inequal *.n');
119
+ if ('pubkeys' in b)
120
+ t.deepStrictEqual(
121
+ tryHex(a.pubkeys),
122
+ tryHex(b.pubkeys),
123
+ 'Inequal *.pubkeys',
124
+ );
125
+ if ('signatures' in b)
126
+ t.deepStrictEqual(
127
+ tryHex(a.signatures),
128
+ tryHex(b.signatures),
129
+ 'Inequal *.signatures',
130
+ );
131
+ if ('data' in b)
132
+ t.deepStrictEqual(tryHex(a.data), tryHex(b.data), 'Inequal *.data');
133
+ }
134
+
135
+ export function preform(x: any): any {
136
+ x = Object.assign({}, x);
137
+
138
+ if (x.network) x.network = (BNETWORKS as any)[x.network];
139
+ if (typeof x.inputHex === 'string') {
140
+ x.input = Buffer.from(x.inputHex, 'hex');
141
+ delete x.inputHex;
142
+ }
143
+ if (typeof x.outputHex === 'string') {
144
+ x.output = Buffer.from(x.outputHex, 'hex');
145
+ delete x.outputHex;
146
+ }
147
+ if (typeof x.output === 'string') x.output = asmToBuffer(x.output);
148
+ if (typeof x.input === 'string') x.input = asmToBuffer(x.input);
149
+ if (Array.isArray(x.witness)) x.witness = x.witness.map(fromHex);
150
+
151
+ if (x.data) x.data = x.data.map(fromHex);
152
+ if (x.hash) x.hash = Buffer.from(x.hash, 'hex');
153
+ if (x.pubkey) x.pubkey = Buffer.from(x.pubkey, 'hex');
154
+ if (x.internalPubkey)
155
+ x.internalPubkey = Buffer.from(x.internalPubkey, 'hex');
156
+ if (x.signature) x.signature = Buffer.from(x.signature, 'hex');
157
+ if (x.pubkeys) x.pubkeys = x.pubkeys.map(fromHex);
158
+ if (x.signatures)
159
+ x.signatures = x.signatures.map((y: any) => {
160
+ return Number.isFinite(y) ? y : Buffer.from(y, 'hex');
161
+ });
162
+ if (x.redeem) {
163
+ x.redeem = Object.assign({}, x.redeem);
164
+ if (typeof x.redeem.input === 'string')
165
+ x.redeem.input = asmToBuffer(x.redeem.input);
166
+ if (typeof x.redeem.output === 'string')
167
+ x.redeem.output = asmToBuffer(x.redeem.output);
168
+ if (Array.isArray(x.redeem.witness))
169
+ x.redeem.witness = x.redeem.witness.map(fromHex);
170
+ if (x.redeem.network)
171
+ x.redeem.network = (BNETWORKS as any)[x.redeem.network];
172
+ }
173
+
174
+ if (x.scriptTree) x.scriptTree = convertScriptTree(x.scriptTree);
175
+ return x;
176
+ }
177
+
178
+ export function from(path: string, object: any, result?: any): any {
179
+ const paths = path.split('.');
180
+ result = result || {};
181
+
182
+ let r = result;
183
+ paths.forEach((k, i) => {
184
+ if (i < paths.length - 1) {
185
+ r[k] = r[k] || {};
186
+
187
+ // recurse
188
+ r = r[k];
189
+ object = object[k];
190
+ } else {
191
+ r[k] = object[k];
192
+ }
193
+ });
194
+
195
+ return result;
196
+ }
197
+
198
+ export function convertScriptTree(scriptTree: any, leafVersion?: number): any {
199
+ if (Array.isArray(scriptTree))
200
+ return scriptTree.map(tr => convertScriptTree(tr, leafVersion));
201
+
202
+ const script = Object.assign({}, scriptTree);
203
+ if (typeof script.output === 'string') {
204
+ script.output = asmToBuffer(scriptTree.output);
205
+ script.version = script.version || leafVersion;
206
+ }
207
+ return script;
208
+ }