utxo-lib 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (249) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +59 -0
  3. package/dist/src/address.d.ts +11 -0
  4. package/dist/src/address.d.ts.map +1 -0
  5. package/dist/src/address.js +37 -0
  6. package/dist/src/addressFormat.d.ts +53 -0
  7. package/dist/src/addressFormat.d.ts.map +1 -0
  8. package/dist/src/addressFormat.js +110 -0
  9. package/dist/src/bitgo/Musig2.d.ts +51 -0
  10. package/dist/src/bitgo/Musig2.d.ts.map +1 -0
  11. package/dist/src/bitgo/Musig2.js +175 -0
  12. package/dist/src/bitgo/Unspent.d.ts +95 -0
  13. package/dist/src/bitgo/Unspent.d.ts.map +1 -0
  14. package/dist/src/bitgo/Unspent.js +138 -0
  15. package/dist/src/bitgo/UtxoPsbt.d.ts +132 -0
  16. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -0
  17. package/dist/src/bitgo/UtxoPsbt.js +469 -0
  18. package/dist/src/bitgo/UtxoTransaction.d.ts +22 -0
  19. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -0
  20. package/dist/src/bitgo/UtxoTransaction.js +97 -0
  21. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +26 -0
  22. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -0
  23. package/dist/src/bitgo/UtxoTransactionBuilder.js +67 -0
  24. package/dist/src/bitgo/bbc/DashPsbt.d.ts +12 -0
  25. package/dist/src/bitgo/bbc/DashPsbt.d.ts.map +1 -0
  26. package/dist/src/bitgo/bbc/DashPsbt.js +27 -0
  27. package/dist/src/bitgo/bbc/DashTransaction.d.ts +39 -0
  28. package/dist/src/bitgo/bbc/DashTransaction.d.ts.map +1 -0
  29. package/dist/src/bitgo/bbc/DashTransaction.js +109 -0
  30. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts +14 -0
  31. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts.map +1 -0
  32. package/dist/src/bitgo/bbc/DashTransactionBuilder.js +28 -0
  33. package/dist/src/bitgo/bbc/index.d.ts +4 -0
  34. package/dist/src/bitgo/bbc/index.d.ts.map +1 -0
  35. package/dist/src/bitgo/bbc/index.js +16 -0
  36. package/dist/src/bitgo/bitcoincash/address.d.ts +35 -0
  37. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -0
  38. package/dist/src/bitgo/bitcoincash/address.js +151 -0
  39. package/dist/src/bitgo/bitcoincash/index.d.ts +2 -0
  40. package/dist/src/bitgo/bitcoincash/index.d.ts.map +1 -0
  41. package/dist/src/bitgo/bitcoincash/index.js +14 -0
  42. package/dist/src/bitgo/dash/DashPsbt.d.ts +12 -0
  43. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -0
  44. package/dist/src/bitgo/dash/DashPsbt.js +27 -0
  45. package/dist/src/bitgo/dash/DashTransaction.d.ts +39 -0
  46. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -0
  47. package/dist/src/bitgo/dash/DashTransaction.js +109 -0
  48. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +14 -0
  49. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -0
  50. package/dist/src/bitgo/dash/DashTransactionBuilder.js +28 -0
  51. package/dist/src/bitgo/dash/index.d.ts +4 -0
  52. package/dist/src/bitgo/dash/index.d.ts.map +1 -0
  53. package/dist/src/bitgo/dash/index.js +16 -0
  54. package/dist/src/bitgo/index.d.ts +17 -0
  55. package/dist/src/bitgo/index.d.ts.map +1 -0
  56. package/dist/src/bitgo/index.js +30 -0
  57. package/dist/src/bitgo/keyutil.d.ts +17 -0
  58. package/dist/src/bitgo/keyutil.d.ts.map +1 -0
  59. package/dist/src/bitgo/keyutil.js +37 -0
  60. package/dist/src/bitgo/nonStandardHalfSigned.d.ts +7 -0
  61. package/dist/src/bitgo/nonStandardHalfSigned.d.ts.map +1 -0
  62. package/dist/src/bitgo/nonStandardHalfSigned.js +56 -0
  63. package/dist/src/bitgo/outputScripts.d.ts +84 -0
  64. package/dist/src/bitgo/outputScripts.d.ts.map +1 -0
  65. package/dist/src/bitgo/outputScripts.js +297 -0
  66. package/dist/src/bitgo/parseInput.d.ts +92 -0
  67. package/dist/src/bitgo/parseInput.d.ts.map +1 -0
  68. package/dist/src/bitgo/parseInput.js +344 -0
  69. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +24 -0
  70. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -0
  71. package/dist/src/bitgo/psbt/fromHalfSigned.js +91 -0
  72. package/dist/src/bitgo/psbt/scriptTypes.d.ts +6 -0
  73. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -0
  74. package/dist/src/bitgo/psbt/scriptTypes.js +23 -0
  75. package/dist/src/bitgo/signature.d.ts +84 -0
  76. package/dist/src/bitgo/signature.d.ts.map +1 -0
  77. package/dist/src/bitgo/signature.js +222 -0
  78. package/dist/src/bitgo/tnumber.d.ts +9 -0
  79. package/dist/src/bitgo/tnumber.d.ts.map +1 -0
  80. package/dist/src/bitgo/tnumber.js +31 -0
  81. package/dist/src/bitgo/transaction.d.ts +29 -0
  82. package/dist/src/bitgo/transaction.d.ts.map +1 -0
  83. package/dist/src/bitgo/transaction.js +247 -0
  84. package/dist/src/bitgo/types.d.ts +5 -0
  85. package/dist/src/bitgo/types.d.ts.map +1 -0
  86. package/dist/src/bitgo/types.js +12 -0
  87. package/dist/src/bitgo/wallet/Psbt.d.ts +47 -0
  88. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -0
  89. package/dist/src/bitgo/wallet/Psbt.js +232 -0
  90. package/dist/src/bitgo/wallet/Unspent.d.ts +47 -0
  91. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -0
  92. package/dist/src/bitgo/wallet/Unspent.js +154 -0
  93. package/dist/src/bitgo/wallet/WalletKeys.d.ts +72 -0
  94. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -0
  95. package/dist/src/bitgo/wallet/WalletKeys.js +104 -0
  96. package/dist/src/bitgo/wallet/WalletOutput.d.ts +18 -0
  97. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -0
  98. package/dist/src/bitgo/wallet/WalletOutput.js +69 -0
  99. package/dist/src/bitgo/wallet/WalletScripts.d.ts +7 -0
  100. package/dist/src/bitgo/wallet/WalletScripts.d.ts.map +1 -0
  101. package/dist/src/bitgo/wallet/WalletScripts.js +15 -0
  102. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts +19 -0
  103. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts.map +1 -0
  104. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +47 -0
  105. package/dist/src/bitgo/wallet/chains.d.ts +57 -0
  106. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -0
  107. package/dist/src/bitgo/wallet/chains.js +106 -0
  108. package/dist/src/bitgo/wallet/index.d.ts +8 -0
  109. package/dist/src/bitgo/wallet/index.d.ts.map +1 -0
  110. package/dist/src/bitgo/wallet/index.js +20 -0
  111. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +26 -0
  112. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -0
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.js +157 -0
  114. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +36 -0
  115. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -0
  116. package/dist/src/bitgo/zcash/ZcashPsbt.js +146 -0
  117. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +61 -0
  118. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -0
  119. package/dist/src/bitgo/zcash/ZcashTransaction.js +341 -0
  120. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +21 -0
  121. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -0
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +105 -0
  123. package/dist/src/bitgo/zcash/address.d.ts +8 -0
  124. package/dist/src/bitgo/zcash/address.d.ts.map +1 -0
  125. package/dist/src/bitgo/zcash/address.js +57 -0
  126. package/dist/src/bitgo/zcash/hashZip0244.d.ts +27 -0
  127. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -0
  128. package/dist/src/bitgo/zcash/hashZip0244.js +184 -0
  129. package/dist/src/bitgo/zcash/index.d.ts +4 -0
  130. package/dist/src/bitgo/zcash/index.d.ts.map +1 -0
  131. package/dist/src/bitgo/zcash/index.js +16 -0
  132. package/dist/src/classify.d.ts +19 -0
  133. package/dist/src/classify.d.ts.map +1 -0
  134. package/dist/src/classify.js +89 -0
  135. package/dist/src/index.d.ts +13 -0
  136. package/dist/src/index.d.ts.map +1 -0
  137. package/dist/src/index.js +36 -0
  138. package/dist/src/networks.d.ts +119 -0
  139. package/dist/src/networks.d.ts.map +1 -0
  140. package/dist/src/networks.js +477 -0
  141. package/dist/src/noble_ecc.d.ts +28 -0
  142. package/dist/src/noble_ecc.d.ts.map +1 -0
  143. package/dist/src/noble_ecc.js +168 -0
  144. package/dist/src/payments/index.d.ts +4 -0
  145. package/dist/src/payments/index.d.ts.map +1 -0
  146. package/dist/src/payments/index.js +8 -0
  147. package/dist/src/payments/p2tr.d.ts +3 -0
  148. package/dist/src/payments/p2tr.d.ts.map +1 -0
  149. package/dist/src/payments/p2tr.js +348 -0
  150. package/dist/src/payments/p2tr_ns.d.ts +3 -0
  151. package/dist/src/payments/p2tr_ns.d.ts.map +1 -0
  152. package/dist/src/payments/p2tr_ns.js +134 -0
  153. package/dist/src/taproot.d.ts +141 -0
  154. package/dist/src/taproot.d.ts.map +1 -0
  155. package/dist/src/taproot.js +384 -0
  156. package/dist/src/templates/multisig/index.d.ts +4 -0
  157. package/dist/src/templates/multisig/index.d.ts.map +1 -0
  158. package/dist/src/templates/multisig/index.js +8 -0
  159. package/dist/src/templates/multisig/input.d.ts +7 -0
  160. package/dist/src/templates/multisig/input.d.ts.map +1 -0
  161. package/dist/src/templates/multisig/input.js +25 -0
  162. package/dist/src/templates/multisig/output.d.ts +7 -0
  163. package/dist/src/templates/multisig/output.d.ts.map +1 -0
  164. package/dist/src/templates/multisig/output.js +38 -0
  165. package/dist/src/templates/nulldata.d.ts +10 -0
  166. package/dist/src/templates/nulldata.d.ts.map +1 -0
  167. package/dist/src/templates/nulldata.js +17 -0
  168. package/dist/src/templates/pubkey/index.d.ts +4 -0
  169. package/dist/src/templates/pubkey/index.d.ts.map +1 -0
  170. package/dist/src/templates/pubkey/index.js +8 -0
  171. package/dist/src/templates/pubkey/input.d.ts +7 -0
  172. package/dist/src/templates/pubkey/input.d.ts.map +1 -0
  173. package/dist/src/templates/pubkey/input.js +14 -0
  174. package/dist/src/templates/pubkey/output.d.ts +7 -0
  175. package/dist/src/templates/pubkey/output.d.ts.map +1 -0
  176. package/dist/src/templates/pubkey/output.js +15 -0
  177. package/dist/src/templates/pubkeyhash/index.d.ts +4 -0
  178. package/dist/src/templates/pubkeyhash/index.d.ts.map +1 -0
  179. package/dist/src/templates/pubkeyhash/index.js +8 -0
  180. package/dist/src/templates/pubkeyhash/input.d.ts +7 -0
  181. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -0
  182. package/dist/src/templates/pubkeyhash/input.js +16 -0
  183. package/dist/src/templates/pubkeyhash/output.d.ts +6 -0
  184. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -0
  185. package/dist/src/templates/pubkeyhash/output.js +20 -0
  186. package/dist/src/templates/scripthash/index.d.ts +4 -0
  187. package/dist/src/templates/scripthash/index.d.ts.map +1 -0
  188. package/dist/src/templates/scripthash/index.js +8 -0
  189. package/dist/src/templates/scripthash/input.d.ts +6 -0
  190. package/dist/src/templates/scripthash/input.d.ts.map +1 -0
  191. package/dist/src/templates/scripthash/input.js +43 -0
  192. package/dist/src/templates/scripthash/output.d.ts +6 -0
  193. package/dist/src/templates/scripthash/output.d.ts.map +1 -0
  194. package/dist/src/templates/scripthash/output.js +15 -0
  195. package/dist/src/templates/taproot/index.d.ts +4 -0
  196. package/dist/src/templates/taproot/index.d.ts.map +1 -0
  197. package/dist/src/templates/taproot/index.js +8 -0
  198. package/dist/src/templates/taproot/input.d.ts +6 -0
  199. package/dist/src/templates/taproot/input.d.ts.map +1 -0
  200. package/dist/src/templates/taproot/input.js +23 -0
  201. package/dist/src/templates/taproot/output.d.ts +6 -0
  202. package/dist/src/templates/taproot/output.d.ts.map +1 -0
  203. package/dist/src/templates/taproot/output.js +15 -0
  204. package/dist/src/templates/taprootnofn/index.d.ts +4 -0
  205. package/dist/src/templates/taprootnofn/index.d.ts.map +1 -0
  206. package/dist/src/templates/taprootnofn/index.js +8 -0
  207. package/dist/src/templates/taprootnofn/input.d.ts +7 -0
  208. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -0
  209. package/dist/src/templates/taprootnofn/input.js +24 -0
  210. package/dist/src/templates/taprootnofn/output.d.ts +7 -0
  211. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -0
  212. package/dist/src/templates/taprootnofn/output.js +28 -0
  213. package/dist/src/templates/witnesscommitment/index.d.ts +3 -0
  214. package/dist/src/templates/witnesscommitment/index.d.ts.map +1 -0
  215. package/dist/src/templates/witnesscommitment/index.js +6 -0
  216. package/dist/src/templates/witnesscommitment/output.d.ts +8 -0
  217. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -0
  218. package/dist/src/templates/witnesscommitment/output.js +31 -0
  219. package/dist/src/templates/witnesspubkeyhash/index.d.ts +4 -0
  220. package/dist/src/templates/witnesspubkeyhash/index.d.ts.map +1 -0
  221. package/dist/src/templates/witnesspubkeyhash/index.js +8 -0
  222. package/dist/src/templates/witnesspubkeyhash/input.d.ts +7 -0
  223. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -0
  224. package/dist/src/templates/witnesspubkeyhash/input.js +19 -0
  225. package/dist/src/templates/witnesspubkeyhash/output.d.ts +6 -0
  226. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -0
  227. package/dist/src/templates/witnesspubkeyhash/output.js +15 -0
  228. package/dist/src/templates/witnessscripthash/index.d.ts +4 -0
  229. package/dist/src/templates/witnessscripthash/index.d.ts.map +1 -0
  230. package/dist/src/templates/witnessscripthash/index.js +8 -0
  231. package/dist/src/templates/witnessscripthash/input.d.ts +6 -0
  232. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -0
  233. package/dist/src/templates/witnessscripthash/input.js +35 -0
  234. package/dist/src/templates/witnessscripthash/output.d.ts +6 -0
  235. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -0
  236. package/dist/src/templates/witnessscripthash/output.js +15 -0
  237. package/dist/src/testutil/index.d.ts +3 -0
  238. package/dist/src/testutil/index.d.ts.map +1 -0
  239. package/dist/src/testutil/index.js +15 -0
  240. package/dist/src/testutil/keys.d.ts +10 -0
  241. package/dist/src/testutil/keys.d.ts.map +1 -0
  242. package/dist/src/testutil/keys.js +40 -0
  243. package/dist/src/testutil/mock.d.ts +21 -0
  244. package/dist/src/testutil/mock.d.ts.map +1 -0
  245. package/dist/src/testutil/mock.js +86 -0
  246. package/dist/src/transaction_builder.d.ts +47 -0
  247. package/dist/src/transaction_builder.d.ts.map +1 -0
  248. package/dist/src/transaction_builder.js +1084 -0
  249. package/package.json +87 -0
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.musig = exports.bip32 = exports.ECPair = exports.ecc = void 0;
4
+ const createHash = require("create-hash");
5
+ const createHmac = require("create-hmac");
6
+ const ecpair_1 = require("ecpair");
7
+ const necc = require("@noble/secp256k1");
8
+ const bip32_1 = require("bip32");
9
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
10
+ // @ts-ignore base_crypto is exported as a subPath export, ignoring since compiler complains about importing like this
11
+ const baseCrypto = require("@brandonblack/musig/base_crypto");
12
+ const musig_1 = require("@brandonblack/musig");
13
+ necc.utils.sha256Sync = (...messages) => {
14
+ const sha256 = createHash('sha256');
15
+ for (const message of messages)
16
+ sha256.update(message);
17
+ return sha256.digest();
18
+ };
19
+ necc.utils.hmacSha256Sync = (key, ...messages) => {
20
+ const hash = createHmac('sha256', Buffer.from(key));
21
+ messages.forEach((m) => hash.update(m));
22
+ return Uint8Array.from(hash.digest());
23
+ };
24
+ const defaultTrue = (param) => param !== false;
25
+ function throwToNull(fn) {
26
+ try {
27
+ return fn();
28
+ }
29
+ catch (e) {
30
+ return null;
31
+ }
32
+ }
33
+ function isPoint(p, xOnly) {
34
+ if ((p.length === 32) !== xOnly)
35
+ return false;
36
+ try {
37
+ return !!necc.Point.fromHex(p);
38
+ }
39
+ catch (e) {
40
+ return false;
41
+ }
42
+ }
43
+ function toBigInt(b) {
44
+ return Buffer.from(b).readBigUint64BE();
45
+ }
46
+ const ecc = {
47
+ isPoint: (p) => isPoint(p, false),
48
+ isPrivate: (d) => necc.utils.isValidPrivateKey(d),
49
+ isXOnlyPoint: (p) => isPoint(p, true),
50
+ xOnlyPointAddTweak: (p, tweak) => throwToNull(() => {
51
+ const P = necc.utils.pointAddScalar(p, tweak, true);
52
+ const parity = P[0] % 2 === 1 ? 1 : 0;
53
+ return { parity, xOnlyPubkey: P.slice(1) };
54
+ }),
55
+ pointFromScalar: (sk, compressed) => throwToNull(() => necc.getPublicKey(sk, defaultTrue(compressed))),
56
+ pointCompress: (p, compressed) => {
57
+ return necc.Point.fromHex(p).toRawBytes(defaultTrue(compressed));
58
+ },
59
+ pointMultiply: (a, tweak, compressed) => throwToNull(() => necc.utils.pointMultiply(a, tweak, defaultTrue(compressed))),
60
+ pointAdd: (a, b, compressed) => throwToNull(() => {
61
+ const A = necc.Point.fromHex(a);
62
+ const B = necc.Point.fromHex(b);
63
+ return A.add(B).toRawBytes(defaultTrue(compressed));
64
+ }),
65
+ pointAddScalar: (p, tweak, compressed) => throwToNull(() => necc.utils.pointAddScalar(p, tweak, defaultTrue(compressed))),
66
+ privateAdd: (d, tweak) => throwToNull(() => {
67
+ const res = necc.utils.privateAdd(d, tweak);
68
+ // tiny-secp256k1 returns null rather than allowing a 0 private key to be returned
69
+ // ECPair.testEcc() requires that behavior.
70
+ if (res === null || res === void 0 ? void 0 : res.every((i) => i === 0))
71
+ return null;
72
+ return res;
73
+ }),
74
+ privateNegate: (d) => necc.utils.privateNegate(d),
75
+ sign: (h, d, e) => {
76
+ return necc.signSync(h, d, { der: false, extraEntropy: e });
77
+ },
78
+ signSchnorr: (h, d, e = Buffer.alloc(32, 0x00)) => {
79
+ return necc.schnorr.signSync(h, d, e);
80
+ },
81
+ verify: (h, Q, signature, strict) => {
82
+ return necc.verify(signature, h, Q, { strict });
83
+ },
84
+ verifySchnorr: (h, Q, signature) => {
85
+ return necc.schnorr.verifySync(signature, h, Q);
86
+ },
87
+ };
88
+ exports.ecc = ecc;
89
+ const crypto = {
90
+ ...baseCrypto,
91
+ pointMultiplyUnsafe(p, a, compress) {
92
+ try {
93
+ const product = necc.Point.fromHex(p).multiplyAndAddUnsafe(necc.Point.ZERO, toBigInt(a), BigInt(1));
94
+ if (!product)
95
+ return null;
96
+ return product.toRawBytes(compress);
97
+ }
98
+ catch {
99
+ return null;
100
+ }
101
+ },
102
+ pointMultiplyAndAddUnsafe(p1, a, p2, compress) {
103
+ try {
104
+ const p2p = necc.Point.fromHex(p2);
105
+ const p = necc.Point.fromHex(p1).multiplyAndAddUnsafe(p2p, toBigInt(a), BigInt(1));
106
+ if (!p)
107
+ return null;
108
+ return p.toRawBytes(compress);
109
+ }
110
+ catch {
111
+ return null;
112
+ }
113
+ },
114
+ pointAdd(a, b, compress) {
115
+ try {
116
+ return necc.Point.fromHex(a).add(necc.Point.fromHex(b)).toRawBytes(compress);
117
+ }
118
+ catch {
119
+ return null;
120
+ }
121
+ },
122
+ pointAddTweak(p, tweak, compress) {
123
+ try {
124
+ const P = necc.Point.fromHex(p);
125
+ const t = baseCrypto.readSecret(tweak);
126
+ const Q = necc.Point.BASE.multiplyAndAddUnsafe(P, t, BigInt(1));
127
+ if (!Q)
128
+ throw new Error('Tweaked point at infinity');
129
+ return Q.toRawBytes(compress);
130
+ }
131
+ catch {
132
+ return null;
133
+ }
134
+ },
135
+ pointCompress(p, compress = true) {
136
+ return necc.Point.fromHex(p).toRawBytes(compress);
137
+ },
138
+ liftX(p) {
139
+ try {
140
+ return necc.Point.fromHex(p).toRawBytes(false);
141
+ }
142
+ catch {
143
+ return null;
144
+ }
145
+ },
146
+ getPublicKey(s, compress) {
147
+ try {
148
+ return necc.getPublicKey(s, compress);
149
+ }
150
+ catch {
151
+ return null;
152
+ }
153
+ },
154
+ taggedHash: necc.utils.taggedHashSync,
155
+ sha256(...messages) {
156
+ const sha256 = createHash('sha256');
157
+ for (const message of messages)
158
+ sha256.update(message);
159
+ return sha256.digest();
160
+ },
161
+ };
162
+ const ECPair = ecpair_1.ECPairFactory(ecc);
163
+ exports.ECPair = ECPair;
164
+ const bip32 = bip32_1.BIP32Factory(ecc);
165
+ exports.bip32 = bip32;
166
+ const musig = musig_1.MuSigFactory(crypto);
167
+ exports.musig = musig;
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"noble_ecc.js","sourceRoot":"","sources":["../../src/noble_ecc.ts"],"names":[],"mappings":";;;AAAA,0CAA0C;AAC1C,0CAA0C;AAC1C,mCAAmE;AACnE,yCAAyC;AACzC,iCAA+D;AAC/D,6DAA6D;AAC7D,sHAAsH;AACtH,8DAA8D;AAC9D,+CAA0D;AAE1D,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,GAAG,QAAsB,EAAc,EAAE;IAChE,MAAM,MAAM,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;IACpC,KAAK,MAAM,OAAO,IAAI,QAAQ;QAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACvD,OAAO,MAAM,CAAC,MAAM,EAAE,CAAC;AACzB,CAAC,CAAC;AAEF,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,CAAC,GAAe,EAAE,GAAG,QAAsB,EAAc,EAAE;IACrF,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACpD,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IACxC,OAAO,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,KAAe,EAAW,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC;AAElE,SAAS,WAAW,CAAO,EAAc;IACvC,IAAI;QACF,OAAO,EAAE,EAAE,CAAC;KACb;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,IAAI,CAAC;KACb;AACH,CAAC;AAED,SAAS,OAAO,CAAC,CAAa,EAAE,KAAc;IAC5C,IAAI,CAAC,CAAC,CAAC,MAAM,KAAK,EAAE,CAAC,KAAK,KAAK;QAAE,OAAO,KAAK,CAAC;IAC9C,IAAI;QACF,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;KAChC;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,KAAK,CAAC;KACd;AACH,CAAC;AAED,SAAS,QAAQ,CAAC,CAAsB;IACtC,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,CAAC;AAC1C,CAAC;AAED,MAAM,GAAG,GAAG;IACV,OAAO,EAAE,CAAC,CAAa,EAAW,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,CAAC;IACtD,SAAS,EAAE,CAAC,CAAa,EAAW,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACtE,YAAY,EAAE,CAAC,CAAa,EAAW,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC;IAE1D,kBAAkB,EAAE,CAAC,CAAa,EAAE,KAAiB,EAAqD,EAAE,CAC1G,WAAW,CAAC,GAAG,EAAE;QACf,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACtC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IAC7C,CAAC,CAAC;IAEJ,eAAe,EAAE,CAAC,EAAc,EAAE,UAAoB,EAAqB,EAAE,CAC3E,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IAEnE,aAAa,EAAE,CAAC,CAAa,EAAE,UAAoB,EAAc,EAAE;QACjE,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,aAAa,EAAE,CAAC,CAAa,EAAE,KAAiB,EAAE,UAAoB,EAAqB,EAAE,CAC3F,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IAEhF,QAAQ,EAAE,CAAC,CAAa,EAAE,CAAa,EAAE,UAAoB,EAAqB,EAAE,CAClF,WAAW,CAAC,GAAG,EAAE;QACf,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC;IAEJ,cAAc,EAAE,CAAC,CAAa,EAAE,KAAiB,EAAE,UAAoB,EAAqB,EAAE,CAC5F,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjF,UAAU,EAAE,CAAC,CAAa,EAAE,KAAiB,EAAqB,EAAE,CAClE,WAAW,CAAC,GAAG,EAAE;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAC5C,kFAAkF;QAClF,2CAA2C;QAC3C,IAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;YAAE,OAAO,IAAI,CAAC;QAC5C,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;IAEJ,aAAa,EAAE,CAAC,CAAa,EAAc,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC;IAEzE,IAAI,EAAE,CAAC,CAAa,EAAE,CAAa,EAAE,CAAc,EAAc,EAAE;QACjE,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,WAAW,EAAE,CAAC,CAAa,EAAE,CAAa,EAAE,IAAgB,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,CAAC,EAAc,EAAE;QAChG,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,EAAE,CAAC,CAAa,EAAE,CAAa,EAAE,SAAqB,EAAE,MAAgB,EAAW,EAAE;QACzF,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,aAAa,EAAE,CAAC,CAAa,EAAE,CAAa,EAAE,SAAqB,EAAW,EAAE;QAC9E,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;CACF,CAAC;AAsEO,kBAAG;AApEZ,MAAM,MAAM,GAAG;IACb,GAAG,UAAU;IACb,mBAAmB,CAAC,CAAa,EAAE,CAAa,EAAE,QAAiB;QACjE,IAAI;YACF,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACpG,IAAI,CAAC,OAAO;gBAAE,OAAO,IAAI,CAAC;YAC1B,OAAO,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SACrC;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,yBAAyB,CAAC,EAAc,EAAE,CAAa,EAAE,EAAc,EAAE,QAAiB;QACxF,IAAI;YACF,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACnC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,oBAAoB,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACnF,IAAI,CAAC,CAAC;gBAAE,OAAO,IAAI,CAAC;YACpB,OAAO,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC/B;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,QAAQ,CAAC,CAAa,EAAE,CAAa,EAAE,QAAiB;QACtD,IAAI;YACF,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC9E;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,aAAa,CAAC,CAAa,EAAE,KAAiB,EAAE,QAAiB;QAC/D,IAAI;YACF,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAChC,MAAM,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACvC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAChE,IAAI,CAAC,CAAC;gBAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;YACrD,OAAO,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC/B;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,aAAa,CAAC,CAAa,EAAE,QAAQ,GAAG,IAAI;QAC1C,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;IACD,KAAK,CAAC,CAAa;QACjB,IAAI;YACF,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SAChD;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,YAAY,CAAC,CAAa,EAAE,QAAiB;QAC3C,IAAI;YACF,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;SACvC;QAAC,MAAM;YACN,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,cAAc;IACrC,MAAM,CAAC,GAAG,QAAsB;QAC9B,MAAM,MAAM,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC;QACpC,KAAK,MAAM,OAAO,IAAI,QAAQ;YAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACvD,OAAO,MAAM,CAAC,MAAM,EAAE,CAAC;IACzB,CAAC;CACF,CAAC;AAEF,MAAM,MAAM,GAAc,sBAAa,CAAC,GAAG,CAAC,CAAC;AAI/B,wBAAM;AAHpB,MAAM,KAAK,GAAa,oBAAY,CAAC,GAAG,CAAC,CAAC;AAGQ,sBAAK;AAFvD,MAAM,KAAK,GAAU,oBAAY,CAAC,MAAM,CAAC,CAAC;AAEyC,sBAAK","sourcesContent":["import * as createHash from 'create-hash';\nimport * as createHmac from 'create-hmac';\nimport { ECPairAPI, ECPairFactory, ECPairInterface } from 'ecpair';\nimport * as necc from '@noble/secp256k1';\nimport { BIP32API, BIP32Factory, BIP32Interface } from 'bip32';\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore base_crypto is exported as a subPath export, ignoring since compiler complains about importing like this\nimport * as baseCrypto from '@brandonblack/musig/base_crypto';\nimport { MuSig, MuSigFactory } from '@brandonblack/musig';\n\nnecc.utils.sha256Sync = (...messages: Uint8Array[]): Uint8Array => {\n  const sha256 = createHash('sha256');\n  for (const message of messages) sha256.update(message);\n  return sha256.digest();\n};\n\nnecc.utils.hmacSha256Sync = (key: Uint8Array, ...messages: Uint8Array[]): Uint8Array => {\n  const hash = createHmac('sha256', Buffer.from(key));\n  messages.forEach((m) => hash.update(m));\n  return Uint8Array.from(hash.digest());\n};\n\nconst defaultTrue = (param?: boolean): boolean => param !== false;\n\nfunction throwToNull<Type>(fn: () => Type): Type | null {\n  try {\n    return fn();\n  } catch (e) {\n    return null;\n  }\n}\n\nfunction isPoint(p: Uint8Array, xOnly: boolean): boolean {\n  if ((p.length === 32) !== xOnly) return false;\n  try {\n    return !!necc.Point.fromHex(p);\n  } catch (e) {\n    return false;\n  }\n}\n\nfunction toBigInt(b: Uint8Array | Buffer): bigint {\n  return Buffer.from(b).readBigUint64BE();\n}\n\nconst ecc = {\n  isPoint: (p: Uint8Array): boolean => isPoint(p, false),\n  isPrivate: (d: Uint8Array): boolean => necc.utils.isValidPrivateKey(d),\n  isXOnlyPoint: (p: Uint8Array): boolean => isPoint(p, true),\n\n  xOnlyPointAddTweak: (p: Uint8Array, tweak: Uint8Array): { parity: 0 | 1; xOnlyPubkey: Uint8Array } | null =>\n    throwToNull(() => {\n      const P = necc.utils.pointAddScalar(p, tweak, true);\n      const parity = P[0] % 2 === 1 ? 1 : 0;\n      return { parity, xOnlyPubkey: P.slice(1) };\n    }),\n\n  pointFromScalar: (sk: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.getPublicKey(sk, defaultTrue(compressed))),\n\n  pointCompress: (p: Uint8Array, compressed?: boolean): Uint8Array => {\n    return necc.Point.fromHex(p).toRawBytes(defaultTrue(compressed));\n  },\n\n  pointMultiply: (a: Uint8Array, tweak: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.utils.pointMultiply(a, tweak, defaultTrue(compressed))),\n\n  pointAdd: (a: Uint8Array, b: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => {\n      const A = necc.Point.fromHex(a);\n      const B = necc.Point.fromHex(b);\n      return A.add(B).toRawBytes(defaultTrue(compressed));\n    }),\n\n  pointAddScalar: (p: Uint8Array, tweak: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.utils.pointAddScalar(p, tweak, defaultTrue(compressed))),\n\n  privateAdd: (d: Uint8Array, tweak: Uint8Array): Uint8Array | null =>\n    throwToNull(() => {\n      const res = necc.utils.privateAdd(d, tweak);\n      // tiny-secp256k1 returns null rather than allowing a 0 private key to be returned\n      // ECPair.testEcc() requires that behavior.\n      if (res?.every((i) => i === 0)) return null;\n      return res;\n    }),\n\n  privateNegate: (d: Uint8Array): Uint8Array => necc.utils.privateNegate(d),\n\n  sign: (h: Uint8Array, d: Uint8Array, e?: Uint8Array): Uint8Array => {\n    return necc.signSync(h, d, { der: false, extraEntropy: e });\n  },\n\n  signSchnorr: (h: Uint8Array, d: Uint8Array, e: Uint8Array = Buffer.alloc(32, 0x00)): Uint8Array => {\n    return necc.schnorr.signSync(h, d, e);\n  },\n\n  verify: (h: Uint8Array, Q: Uint8Array, signature: Uint8Array, strict?: boolean): boolean => {\n    return necc.verify(signature, h, Q, { strict });\n  },\n\n  verifySchnorr: (h: Uint8Array, Q: Uint8Array, signature: Uint8Array): boolean => {\n    return necc.schnorr.verifySync(signature, h, Q);\n  },\n};\n\nconst crypto = {\n  ...baseCrypto,\n  pointMultiplyUnsafe(p: Uint8Array, a: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const product = necc.Point.fromHex(p).multiplyAndAddUnsafe(necc.Point.ZERO, toBigInt(a), BigInt(1));\n      if (!product) return null;\n      return product.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointMultiplyAndAddUnsafe(p1: Uint8Array, a: Uint8Array, p2: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const p2p = necc.Point.fromHex(p2);\n      const p = necc.Point.fromHex(p1).multiplyAndAddUnsafe(p2p, toBigInt(a), BigInt(1));\n      if (!p) return null;\n      return p.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointAdd(a: Uint8Array, b: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      return necc.Point.fromHex(a).add(necc.Point.fromHex(b)).toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointAddTweak(p: Uint8Array, tweak: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const P = necc.Point.fromHex(p);\n      const t = baseCrypto.readSecret(tweak);\n      const Q = necc.Point.BASE.multiplyAndAddUnsafe(P, t, BigInt(1));\n      if (!Q) throw new Error('Tweaked point at infinity');\n      return Q.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointCompress(p: Uint8Array, compress = true): Uint8Array {\n    return necc.Point.fromHex(p).toRawBytes(compress);\n  },\n  liftX(p: Uint8Array): Uint8Array | null {\n    try {\n      return necc.Point.fromHex(p).toRawBytes(false);\n    } catch {\n      return null;\n    }\n  },\n  getPublicKey(s: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      return necc.getPublicKey(s, compress);\n    } catch {\n      return null;\n    }\n  },\n  taggedHash: necc.utils.taggedHashSync,\n  sha256(...messages: Uint8Array[]): Uint8Array {\n    const sha256 = createHash('sha256');\n    for (const message of messages) sha256.update(message);\n    return sha256.digest();\n  },\n};\n\nconst ECPair: ECPairAPI = ECPairFactory(ecc);\nconst bip32: BIP32API = BIP32Factory(ecc);\nconst musig: MuSig = MuSigFactory(crypto);\n\nexport { ecc, ECPair, ECPairAPI, ECPairInterface, bip32, BIP32API, BIP32Interface, musig, MuSig };\n"]}
@@ -0,0 +1,4 @@
1
+ import { p2tr_ns } from './p2tr_ns';
2
+ import { p2tr } from './p2tr';
3
+ export { p2tr_ns, p2tr };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/payments/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.p2tr = exports.p2tr_ns = void 0;
4
+ const p2tr_ns_1 = require("./p2tr_ns");
5
+ Object.defineProperty(exports, "p2tr_ns", { enumerable: true, get: function () { return p2tr_ns_1.p2tr_ns; } });
6
+ const p2tr_1 = require("./p2tr");
7
+ Object.defineProperty(exports, "p2tr", { enumerable: true, get: function () { return p2tr_1.p2tr; } });
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGF5bWVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBQW9DO0FBRzNCLHdGQUhBLGlCQUFPLE9BR0E7QUFGaEIsaUNBQThCO0FBRVoscUZBRlQsV0FBSSxPQUVTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcDJ0cl9ucyB9IGZyb20gJy4vcDJ0cl9ucyc7XG5pbXBvcnQgeyBwMnRyIH0gZnJvbSAnLi9wMnRyJztcblxuZXhwb3J0IHsgcDJ0cl9ucywgcDJ0ciB9O1xuIl19
@@ -0,0 +1,3 @@
1
+ import { Payment, PaymentOpts } from 'bitcoinjs-lib';
2
+ export declare function p2tr(a: Payment, opts?: PaymentOpts): Payment;
3
+ //# sourceMappingURL=p2tr.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"p2tr.d.ts","sourceRoot":"","sources":["../../../src/payments/p2tr.ts"],"names":[],"mappings":"AAIA,OAAO,EAAqB,OAAO,EAAE,WAAW,EAAQ,MAAM,eAAe,CAAC;AAgC9E,wBAAgB,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,WAAW,GAAG,OAAO,CAwU5D"}
@@ -0,0 +1,348 @@
1
+ "use strict";
2
+ // SegWit version 1 P2TR output type for Taproot defined in
3
+ // https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.p2tr = void 0;
6
+ const networks_1 = require("../networks");
7
+ const bitcoinjs_lib_1 = require("bitcoinjs-lib");
8
+ const taproot = require("../taproot");
9
+ const noble_ecc_1 = require("../noble_ecc");
10
+ const necc = require("@noble/secp256k1");
11
+ const typef = require('typeforce');
12
+ const OPS = bitcoinjs_lib_1.script.OPS;
13
+ const { bech32m } = require('bech32');
14
+ const BITCOIN_NETWORK = networks_1.networks.bitcoin;
15
+ /**
16
+ * A secp256k1 x coordinate with unknown discrete logarithm used for eliminating
17
+ * keypath spends, equal to SHA256(uncompressedDER(SECP256K1_GENERATOR_POINT)).
18
+ */
19
+ const H = Buffer.from('50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0', 'hex');
20
+ const EMPTY_BUFFER = Buffer.alloc(0);
21
+ function isPlainPubkey(pubKey) {
22
+ if (pubKey.length !== 33)
23
+ return false;
24
+ try {
25
+ return !!necc.Point.fromHex(pubKey);
26
+ }
27
+ catch (e) {
28
+ return false;
29
+ }
30
+ }
31
+ function isPlainPubkeys(pubkeys) {
32
+ return pubkeys.every(isPlainPubkey);
33
+ }
34
+ // output: OP_1 {witnessProgram}
35
+ function p2tr(a, opts) {
36
+ var _a, _b, _c, _d;
37
+ if (!a.address && !a.pubkey && !a.pubkeys && !(a.redeems && a.redeems.length) && !a.output && !a.witness) {
38
+ throw new TypeError('Not enough data');
39
+ }
40
+ opts = Object.assign({ validate: true }, opts || {});
41
+ if (!opts.eccLib)
42
+ throw new Error('ECC Library is required for p2tr.');
43
+ const ecc = opts.eccLib;
44
+ typef({
45
+ network: typef.maybe(typef.Object),
46
+ address: typef.maybe(typef.String),
47
+ // the output script should be a fixed 34 bytes.
48
+ // 1 byte for OP_1 indicating segwit version 1, one byte for 0x20 to push
49
+ // the next 32 bytes, followed by the 32 byte witness program
50
+ output: typef.maybe(typef.BufferN(34)),
51
+ // a single pubkey
52
+ pubkey: typef.maybe(ecc.isXOnlyPoint),
53
+ // the pub key(s) used for keypath signing.
54
+ // aggregated with MuSig2* if > 1
55
+ pubkeys: typef.maybe(typef.anyOf(typef.arrayOf(ecc.isXOnlyPoint), typef.arrayOf(isPlainPubkey))),
56
+ redeems: typef.maybe(typef.arrayOf({
57
+ network: typef.maybe(typef.Object),
58
+ output: typef.maybe(typef.Buffer),
59
+ weight: typef.maybe(typef.Number),
60
+ depth: typef.maybe(typef.Number),
61
+ witness: typef.maybe(typef.arrayOf(typef.Buffer)),
62
+ })),
63
+ redeemIndex: typef.maybe(typef.Number),
64
+ signature: typef.maybe(bitcoinjs_lib_1.script.isCanonicalSchnorrSignature),
65
+ controlBlock: typef.maybe(typef.Buffer),
66
+ annex: typef.maybe(typef.Buffer),
67
+ }, a);
68
+ const _address = bitcoinjs_lib_1.lazy.value(() => {
69
+ if (!a.address)
70
+ return undefined;
71
+ const result = bech32m.decode(a.address);
72
+ const version = result.words.shift();
73
+ const data = bech32m.fromWords(result.words);
74
+ return {
75
+ version,
76
+ prefix: result.prefix,
77
+ data: Buffer.from(data),
78
+ };
79
+ });
80
+ const _outputPubkey = bitcoinjs_lib_1.lazy.value(() => {
81
+ // we remove the first two bytes (OP_1 0x20) from the output script to
82
+ // extract the 32 byte taproot pubkey (aka witness program)
83
+ return a.output && a.output.slice(2);
84
+ });
85
+ const network = a.network || BITCOIN_NETWORK;
86
+ const o = { network };
87
+ const _taprootPaths = bitcoinjs_lib_1.lazy.value(() => {
88
+ if (!a.redeems)
89
+ return;
90
+ if (o.tapTree) {
91
+ return taproot.getDepthFirstTaptree(o.tapTree);
92
+ }
93
+ const outputs = a.redeems.map(({ output }) => output);
94
+ if (!outputs.every((output) => output))
95
+ return;
96
+ return taproot.getHuffmanTaptree(outputs, a.redeems.map(({ weight }) => weight));
97
+ });
98
+ const _parsedWitness = bitcoinjs_lib_1.lazy.value(() => {
99
+ if (!a.witness)
100
+ return;
101
+ return taproot.parseTaprootWitness(a.witness);
102
+ });
103
+ const _parsedControlBlock = bitcoinjs_lib_1.lazy.value(() => {
104
+ // Can't use o.controlBlock, because it could be circular
105
+ if (a.controlBlock)
106
+ return taproot.parseControlBlock(ecc, a.controlBlock);
107
+ const parsedWitness = _parsedWitness();
108
+ if (parsedWitness && parsedWitness.spendType === 'Script') {
109
+ return taproot.parseControlBlock(ecc, parsedWitness.controlBlock);
110
+ }
111
+ });
112
+ bitcoinjs_lib_1.lazy.prop(o, 'internalPubkey', () => {
113
+ var _a;
114
+ if (a.pubkey) {
115
+ // single pubkey
116
+ return a.pubkey;
117
+ }
118
+ else if (a.pubkeys && a.pubkeys.length === 1) {
119
+ return a.pubkeys[0];
120
+ }
121
+ else if (a.pubkeys && a.pubkeys.length > 1) {
122
+ // multiple pubkeys
123
+ if (isPlainPubkeys(a.pubkeys)) {
124
+ return Buffer.from(noble_ecc_1.musig.getXOnlyPubkey(noble_ecc_1.musig.keyAgg(noble_ecc_1.musig.keySort(a.pubkeys))));
125
+ }
126
+ return Buffer.from(taproot.aggregateMuSigPubkeys(ecc, a.pubkeys));
127
+ }
128
+ else if (_parsedControlBlock()) {
129
+ return (_a = _parsedControlBlock()) === null || _a === void 0 ? void 0 : _a.internalPubkey;
130
+ }
131
+ else {
132
+ // If there is no key path spending condition, we use an internal key with unknown secret key.
133
+ // TODO: In order to avoid leaking the information that key path spending is not possible it
134
+ // is recommended to pick a fresh integer r in the range 0...n-1 uniformly at random and use
135
+ // H + rG as internal key. It is possible to prove that this internal key does not have a
136
+ // known discrete logarithm with respect to G by revealing r to a verifier who can then
137
+ // reconstruct how the internal key was created.
138
+ return H;
139
+ }
140
+ });
141
+ const _taprootPubkey = bitcoinjs_lib_1.lazy.value(() => {
142
+ var _a;
143
+ const parsedControlBlock = _parsedControlBlock();
144
+ const parsedWitness = _parsedWitness();
145
+ // Refuse to create an unspendable key
146
+ if (!a.pubkey && !(a.pubkeys && a.pubkeys.length) && !a.redeems && !parsedControlBlock) {
147
+ return;
148
+ }
149
+ let taptreeRoot;
150
+ // Prefer to get the root via the control block because not all redeems may
151
+ // be available
152
+ if (parsedControlBlock) {
153
+ let tapscript;
154
+ if (parsedWitness && parsedWitness.spendType === 'Script') {
155
+ tapscript = parsedWitness.tapscript;
156
+ }
157
+ else if (o.redeem && o.redeem.output) {
158
+ tapscript = o.redeem.output;
159
+ }
160
+ if (tapscript)
161
+ taptreeRoot = taproot.getTaptreeRoot(ecc, parsedControlBlock, tapscript);
162
+ }
163
+ if (!taptreeRoot && _taprootPaths())
164
+ taptreeRoot = (_a = _taprootPaths()) === null || _a === void 0 ? void 0 : _a.root;
165
+ return taproot.tapTweakPubkey(ecc, o === null || o === void 0 ? void 0 : o.internalPubkey, taptreeRoot);
166
+ });
167
+ bitcoinjs_lib_1.lazy.prop(o, 'tapTree', () => {
168
+ if (!a.redeems)
169
+ return;
170
+ if (a.redeems.find(({ depth }) => depth === undefined)) {
171
+ console.warn('Deprecation Warning: Weight-based tap tree construction will be removed in the future. ' +
172
+ 'Please use depth-first coding as specified in BIP-0371.');
173
+ return;
174
+ }
175
+ if (!a.redeems.every(({ output }) => output))
176
+ return;
177
+ return {
178
+ leaves: a.redeems.map(({ output, depth }) => {
179
+ return {
180
+ script: output,
181
+ leafVersion: taproot.INITIAL_TAPSCRIPT_VERSION,
182
+ depth,
183
+ };
184
+ }),
185
+ };
186
+ });
187
+ bitcoinjs_lib_1.lazy.prop(o, 'address', () => {
188
+ var _a;
189
+ const pubkey = _outputPubkey() || (_taprootPubkey() && ((_a = _taprootPubkey()) === null || _a === void 0 ? void 0 : _a.xOnlyPubkey));
190
+ // only encode the 32 byte witness program as bech32m
191
+ const words = bech32m.toWords(pubkey);
192
+ words.unshift(0x01);
193
+ return bech32m.encode(network.bech32, words);
194
+ });
195
+ bitcoinjs_lib_1.lazy.prop(o, 'controlBlock', () => {
196
+ const parsedWitness = _parsedWitness();
197
+ if (parsedWitness && parsedWitness.spendType === 'Script') {
198
+ return parsedWitness.controlBlock;
199
+ }
200
+ const taprootPubkey = _taprootPubkey();
201
+ const taprootPaths = _taprootPaths();
202
+ if (!taprootPaths || !taprootPubkey || a.redeemIndex === undefined)
203
+ return;
204
+ return taproot.getControlBlock(taprootPubkey.parity, o.internalPubkey, taprootPaths.paths[a.redeemIndex]);
205
+ });
206
+ bitcoinjs_lib_1.lazy.prop(o, 'signature', () => {
207
+ const parsedWitness = _parsedWitness();
208
+ if (parsedWitness && parsedWitness.spendType === 'Key') {
209
+ return parsedWitness.signature;
210
+ }
211
+ });
212
+ bitcoinjs_lib_1.lazy.prop(o, 'annex', () => {
213
+ if (!_parsedWitness())
214
+ return;
215
+ return _parsedWitness().annex;
216
+ });
217
+ bitcoinjs_lib_1.lazy.prop(o, 'output', () => {
218
+ if (a.address) {
219
+ const { data } = _address();
220
+ return bitcoinjs_lib_1.script.compile([OPS.OP_1, data]);
221
+ }
222
+ const taprootPubkey = _taprootPubkey();
223
+ if (!taprootPubkey)
224
+ return;
225
+ // OP_1 indicates segwit version 1
226
+ return bitcoinjs_lib_1.script.compile([OPS.OP_1, Buffer.from(taprootPubkey.xOnlyPubkey)]);
227
+ });
228
+ bitcoinjs_lib_1.lazy.prop(o, 'witness', () => {
229
+ if (!a.redeems) {
230
+ if (a.signature)
231
+ return [a.signature]; // Keypath spend
232
+ return;
233
+ }
234
+ else if (!o.redeem) {
235
+ return; // No chosen redeem script, can't make witness
236
+ }
237
+ else if (!o.controlBlock) {
238
+ return;
239
+ }
240
+ let redeemWitness;
241
+ // some callers may provide witness elements in the input script
242
+ if (o.redeem.input && o.redeem.input.length > 0 && o.redeem.output && o.redeem.output.length > 0) {
243
+ // transform redeem input to witness stack
244
+ redeemWitness = bitcoinjs_lib_1.script.toStack(bitcoinjs_lib_1.script.decompile(o.redeem.input));
245
+ // assigns a new object to o.redeem
246
+ o.redeems[a.redeemIndex] = Object.assign({ witness: redeemWitness }, o.redeem);
247
+ o.redeem.input = EMPTY_BUFFER;
248
+ }
249
+ else if (o.redeem.output && o.redeem.output.length > 0 && o.redeem.witness && o.redeem.witness.length > 0) {
250
+ redeemWitness = o.redeem.witness;
251
+ }
252
+ else {
253
+ return;
254
+ }
255
+ const witness = [...redeemWitness, o.redeem.output, o.controlBlock];
256
+ if (a.annex) {
257
+ witness.push(a.annex);
258
+ }
259
+ return witness;
260
+ });
261
+ bitcoinjs_lib_1.lazy.prop(o, 'name', () => {
262
+ const nameParts = ['p2tr'];
263
+ return nameParts.join('-');
264
+ });
265
+ bitcoinjs_lib_1.lazy.prop(o, 'redeem', () => {
266
+ if (a.redeems) {
267
+ if (a.redeemIndex === undefined)
268
+ return;
269
+ return a.redeems[a.redeemIndex];
270
+ }
271
+ const parsedWitness = _parsedWitness();
272
+ if (parsedWitness && parsedWitness.spendType === 'Script') {
273
+ return {
274
+ witness: parsedWitness.scriptSig,
275
+ output: parsedWitness.tapscript,
276
+ };
277
+ }
278
+ });
279
+ // extended validation
280
+ if (opts.validate) {
281
+ const taprootPubkey = _taprootPubkey();
282
+ if (a.output) {
283
+ if (a.output[0] !== OPS.OP_1 || a.output[1] !== 0x20) {
284
+ throw new TypeError('Output is invalid');
285
+ }
286
+ // if we're passed both an output script and an address, ensure they match
287
+ if (a.address && _outputPubkey && !((_a = _outputPubkey()) === null || _a === void 0 ? void 0 : _a.equals((_b = _address()) === null || _b === void 0 ? void 0 : _b.data))) {
288
+ throw new TypeError('mismatch between address & output');
289
+ }
290
+ if (taprootPubkey && _outputPubkey && !((_c = _outputPubkey()) === null || _c === void 0 ? void 0 : _c.equals(taprootPubkey.xOnlyPubkey))) {
291
+ throw new TypeError('mismatch between output and taproot pubkey');
292
+ }
293
+ }
294
+ if (a.address) {
295
+ if (taprootPubkey && !((_d = _address()) === null || _d === void 0 ? void 0 : _d.data.equals(taprootPubkey.xOnlyPubkey))) {
296
+ throw new TypeError('mismatch between address and taproot pubkey');
297
+ }
298
+ }
299
+ const parsedControlBlock = _parsedControlBlock();
300
+ if (parsedControlBlock) {
301
+ if (!parsedControlBlock.internalPubkey.equals(o === null || o === void 0 ? void 0 : o.internalPubkey)) {
302
+ throw new TypeError('Internal pubkey mismatch');
303
+ }
304
+ if (taprootPubkey && parsedControlBlock.parity !== taprootPubkey.parity) {
305
+ throw new TypeError('Parity mismatch');
306
+ }
307
+ }
308
+ if (a.redeems) {
309
+ if (!a.redeems.length)
310
+ throw new TypeError('Empty redeems');
311
+ if (a.redeemIndex !== undefined && (a.redeemIndex < 0 || a.redeemIndex >= a.redeems.length)) {
312
+ throw new TypeError('invalid redeem index');
313
+ }
314
+ a.redeems.forEach((redeem) => {
315
+ if (redeem.network && redeem.network !== network) {
316
+ throw new TypeError('Network mismatch');
317
+ }
318
+ });
319
+ }
320
+ const chosenRedeem = a.redeems && a.redeemIndex !== undefined && a.redeems[a.redeemIndex];
321
+ const parsedWitness = _parsedWitness();
322
+ if (parsedWitness && parsedWitness.spendType === 'Key') {
323
+ if (a.controlBlock) {
324
+ throw new TypeError('unexpected control block for key path');
325
+ }
326
+ if (a.signature && !a.signature.equals(parsedWitness.signature)) {
327
+ throw new TypeError('mismatch between witness & signature');
328
+ }
329
+ }
330
+ if (parsedWitness && parsedWitness.spendType === 'Script') {
331
+ if (a.signature) {
332
+ throw new TypeError('unexpected signature with script path witness');
333
+ }
334
+ if (a.controlBlock && !a.controlBlock.equals(parsedWitness.controlBlock)) {
335
+ throw new TypeError('control block mismatch');
336
+ }
337
+ if (a.annex && parsedWitness.annex && !a.annex.equals(parsedWitness.annex)) {
338
+ throw new TypeError('annex mismatch');
339
+ }
340
+ if (chosenRedeem && chosenRedeem.output && !chosenRedeem.output.equals(parsedWitness.tapscript)) {
341
+ throw new TypeError('tapscript mismatch');
342
+ }
343
+ }
344
+ }
345
+ return Object.assign(o, a);
346
+ }
347
+ exports.p2tr = p2tr;
348
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"p2tr.js","sourceRoot":"","sources":["../../../src/payments/p2tr.ts"],"names":[],"mappings":"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","sourcesContent":["// SegWit version 1 P2TR output type for Taproot defined in\n// https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki\n\nimport { networks } from '../networks';\nimport { script as bscript, Payment, PaymentOpts, lazy } from 'bitcoinjs-lib';\nimport * as taproot from '../taproot';\nimport { musig } from '../noble_ecc';\nimport * as necc from '@noble/secp256k1';\nconst typef = require('typeforce');\nconst OPS = bscript.OPS;\n\nconst { bech32m } = require('bech32');\n\nconst BITCOIN_NETWORK = networks.bitcoin;\n\n/**\n * A secp256k1 x coordinate with unknown discrete logarithm used for eliminating\n * keypath spends, equal to SHA256(uncompressedDER(SECP256K1_GENERATOR_POINT)).\n */\nconst H = Buffer.from('50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0', 'hex');\nconst EMPTY_BUFFER = Buffer.alloc(0);\n\nfunction isPlainPubkey(pubKey: Uint8Array): boolean {\n  if (pubKey.length !== 33) return false;\n  try {\n    return !!necc.Point.fromHex(pubKey);\n  } catch (e) {\n    return false;\n  }\n}\n\nfunction isPlainPubkeys(pubkeys: Buffer[]) {\n  return pubkeys.every(isPlainPubkey);\n}\n\n// output: OP_1 {witnessProgram}\nexport function p2tr(a: Payment, opts?: PaymentOpts): Payment {\n  if (!a.address && !a.pubkey && !a.pubkeys && !(a.redeems && a.redeems.length) && !a.output && !a.witness) {\n    throw new TypeError('Not enough data');\n  }\n  opts = Object.assign({ validate: true }, opts || {});\n\n  if (!opts.eccLib) throw new Error('ECC Library is required for p2tr.');\n  const ecc = opts.eccLib;\n\n  typef(\n    {\n      network: typef.maybe(typef.Object),\n\n      address: typef.maybe(typef.String),\n      // the output script should be a fixed 34 bytes.\n      // 1 byte for OP_1 indicating segwit version 1, one byte for 0x20 to push\n      // the next 32 bytes, followed by the 32 byte witness program\n      output: typef.maybe(typef.BufferN(34)),\n      // a single pubkey\n      pubkey: typef.maybe(ecc.isXOnlyPoint),\n      // the pub key(s) used for keypath signing.\n      // aggregated with MuSig2* if > 1\n      pubkeys: typef.maybe(typef.anyOf(typef.arrayOf(ecc.isXOnlyPoint), typef.arrayOf(isPlainPubkey))),\n\n      redeems: typef.maybe(\n        typef.arrayOf({\n          network: typef.maybe(typef.Object),\n          output: typef.maybe(typef.Buffer),\n          weight: typef.maybe(typef.Number),\n          depth: typef.maybe(typef.Number),\n          witness: typef.maybe(typef.arrayOf(typef.Buffer)),\n        })\n      ),\n      redeemIndex: typef.maybe(typef.Number), // Selects the redeem to spend\n\n      signature: typef.maybe(bscript.isCanonicalSchnorrSignature),\n      controlBlock: typef.maybe(typef.Buffer),\n      annex: typef.maybe(typef.Buffer),\n    },\n    a\n  );\n\n  const _address = lazy.value(() => {\n    if (!a.address) return undefined;\n\n    const result = bech32m.decode(a.address);\n    const version = result.words.shift();\n    const data = bech32m.fromWords(result.words);\n    return {\n      version,\n      prefix: result.prefix,\n      data: Buffer.from(data),\n    };\n  });\n  const _outputPubkey = lazy.value(() => {\n    // we remove the first two bytes (OP_1 0x20) from the output script to\n    // extract the 32 byte taproot pubkey (aka witness program)\n    return a.output && a.output.slice(2);\n  });\n\n  const network = a.network || BITCOIN_NETWORK;\n\n  const o: Payment = { network };\n\n  const _taprootPaths = lazy.value(() => {\n    if (!a.redeems) return;\n    if (o.tapTree) {\n      return taproot.getDepthFirstTaptree(o.tapTree);\n    }\n    const outputs: Array<Buffer | undefined> = a.redeems.map(({ output }) => output);\n    if (!outputs.every((output) => output)) return;\n    return taproot.getHuffmanTaptree(\n      outputs as Buffer[],\n      a.redeems.map(({ weight }) => weight)\n    );\n  });\n  const _parsedWitness = lazy.value(() => {\n    if (!a.witness) return;\n    return taproot.parseTaprootWitness(a.witness);\n  });\n  const _parsedControlBlock = lazy.value(() => {\n    // Can't use o.controlBlock, because it could be circular\n    if (a.controlBlock) return taproot.parseControlBlock(ecc, a.controlBlock);\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return taproot.parseControlBlock(ecc, parsedWitness.controlBlock);\n    }\n  });\n\n  lazy.prop(o, 'internalPubkey', () => {\n    if (a.pubkey) {\n      // single pubkey\n      return a.pubkey;\n    } else if (a.pubkeys && a.pubkeys.length === 1) {\n      return a.pubkeys[0];\n    } else if (a.pubkeys && a.pubkeys.length > 1) {\n      // multiple pubkeys\n      if (isPlainPubkeys(a.pubkeys)) {\n        return Buffer.from(musig.getXOnlyPubkey(musig.keyAgg(musig.keySort(a.pubkeys))));\n      }\n\n      return Buffer.from(taproot.aggregateMuSigPubkeys(ecc, a.pubkeys));\n    } else if (_parsedControlBlock()) {\n      return _parsedControlBlock()?.internalPubkey;\n    } else {\n      // If there is no key path spending condition, we use an internal key with unknown secret key.\n      // TODO: In order to avoid leaking the information that key path spending is not possible it\n      // is recommended to pick a fresh integer r in the range 0...n-1 uniformly at random and use\n      // H + rG as internal key. It is possible to prove that this internal key does not have a\n      // known discrete logarithm with respect to G by revealing r to a verifier who can then\n      // reconstruct how the internal key was created.\n      return H;\n    }\n  });\n\n  const _taprootPubkey = lazy.value(() => {\n    const parsedControlBlock = _parsedControlBlock();\n    const parsedWitness = _parsedWitness();\n    // Refuse to create an unspendable key\n    if (!a.pubkey && !(a.pubkeys && a.pubkeys.length) && !a.redeems && !parsedControlBlock) {\n      return;\n    }\n    let taptreeRoot;\n    // Prefer to get the root via the control block because not all redeems may\n    // be available\n    if (parsedControlBlock) {\n      let tapscript;\n      if (parsedWitness && parsedWitness.spendType === 'Script') {\n        tapscript = parsedWitness.tapscript;\n      } else if (o.redeem && o.redeem.output) {\n        tapscript = o.redeem.output;\n      }\n      if (tapscript) taptreeRoot = taproot.getTaptreeRoot(ecc, parsedControlBlock, tapscript);\n    }\n    if (!taptreeRoot && _taprootPaths()) taptreeRoot = _taprootPaths()?.root;\n\n    return taproot.tapTweakPubkey(ecc, o?.internalPubkey as Uint8Array, taptreeRoot);\n  });\n\n  lazy.prop(o, 'tapTree', () => {\n    if (!a.redeems) return;\n    if (a.redeems.find(({ depth }) => depth === undefined)) {\n      console.warn(\n        'Deprecation Warning: Weight-based tap tree construction will be removed in the future. ' +\n          'Please use depth-first coding as specified in BIP-0371.'\n      );\n      return;\n    }\n    if (!a.redeems.every(({ output }) => output)) return;\n    return {\n      leaves: a.redeems.map(({ output, depth }) => {\n        return {\n          script: output,\n          leafVersion: taproot.INITIAL_TAPSCRIPT_VERSION,\n          depth,\n        };\n      }),\n    };\n  });\n  lazy.prop(o, 'address', () => {\n    const pubkey = _outputPubkey() || (_taprootPubkey() && _taprootPubkey()?.xOnlyPubkey);\n    // only encode the 32 byte witness program as bech32m\n    const words = bech32m.toWords(pubkey);\n    words.unshift(0x01);\n    return bech32m.encode(network.bech32, words);\n  });\n  lazy.prop(o, 'controlBlock', () => {\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return parsedWitness.controlBlock;\n    }\n    const taprootPubkey = _taprootPubkey();\n    const taprootPaths = _taprootPaths();\n    if (!taprootPaths || !taprootPubkey || a.redeemIndex === undefined) return;\n    return taproot.getControlBlock(taprootPubkey.parity, o.internalPubkey!, taprootPaths.paths[a.redeemIndex]);\n  });\n  lazy.prop(o, 'signature', () => {\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Key') {\n      return parsedWitness.signature;\n    }\n  });\n  lazy.prop(o, 'annex', () => {\n    if (!_parsedWitness()) return;\n    return _parsedWitness()!.annex;\n  });\n  lazy.prop(o, 'output', () => {\n    if (a.address) {\n      const { data } = _address()!;\n      return bscript.compile([OPS.OP_1, data]);\n    }\n\n    const taprootPubkey = _taprootPubkey();\n    if (!taprootPubkey) return;\n\n    // OP_1 indicates segwit version 1\n    return bscript.compile([OPS.OP_1, Buffer.from(taprootPubkey.xOnlyPubkey)]);\n  });\n  lazy.prop(o, 'witness', () => {\n    if (!a.redeems) {\n      if (a.signature) return [a.signature]; // Keypath spend\n      return;\n    } else if (!o.redeem) {\n      return; // No chosen redeem script, can't make witness\n    } else if (!o.controlBlock) {\n      return;\n    }\n\n    let redeemWitness;\n    // some callers may provide witness elements in the input script\n    if (o.redeem.input && o.redeem.input.length > 0 && o.redeem.output && o.redeem.output.length > 0) {\n      // transform redeem input to witness stack\n      redeemWitness = bscript.toStack(bscript.decompile(o.redeem.input)!);\n\n      // assigns a new object to o.redeem\n      o.redeems![a.redeemIndex!] = Object.assign({ witness: redeemWitness }, o.redeem);\n      o.redeem.input = EMPTY_BUFFER;\n    } else if (o.redeem.output && o.redeem.output.length > 0 && o.redeem.witness && o.redeem.witness.length > 0) {\n      redeemWitness = o.redeem.witness;\n    } else {\n      return;\n    }\n\n    const witness = [...redeemWitness, o.redeem.output, o.controlBlock];\n\n    if (a.annex) {\n      witness.push(a.annex);\n    }\n\n    return witness;\n  });\n  lazy.prop(o, 'name', () => {\n    const nameParts = ['p2tr'];\n    return nameParts.join('-');\n  });\n  lazy.prop(o, 'redeem', () => {\n    if (a.redeems) {\n      if (a.redeemIndex === undefined) return;\n      return a.redeems[a.redeemIndex];\n    }\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return {\n        witness: parsedWitness.scriptSig,\n        output: parsedWitness.tapscript,\n      };\n    }\n  });\n\n  // extended validation\n  if (opts.validate) {\n    const taprootPubkey = _taprootPubkey();\n\n    if (a.output) {\n      if (a.output[0] !== OPS.OP_1 || a.output[1] !== 0x20) {\n        throw new TypeError('Output is invalid');\n      }\n\n      // if we're passed both an output script and an address, ensure they match\n      if (a.address && _outputPubkey && !_outputPubkey()?.equals(_address()?.data as Buffer)) {\n        throw new TypeError('mismatch between address & output');\n      }\n\n      if (taprootPubkey && _outputPubkey && !_outputPubkey()?.equals(taprootPubkey.xOnlyPubkey)) {\n        throw new TypeError('mismatch between output and taproot pubkey');\n      }\n    }\n\n    if (a.address) {\n      if (taprootPubkey && !_address()?.data.equals(taprootPubkey.xOnlyPubkey)) {\n        throw new TypeError('mismatch between address and taproot pubkey');\n      }\n    }\n\n    const parsedControlBlock = _parsedControlBlock();\n    if (parsedControlBlock) {\n      if (!parsedControlBlock.internalPubkey.equals(o?.internalPubkey as Uint8Array)) {\n        throw new TypeError('Internal pubkey mismatch');\n      }\n      if (taprootPubkey && parsedControlBlock.parity !== taprootPubkey.parity) {\n        throw new TypeError('Parity mismatch');\n      }\n    }\n\n    if (a.redeems) {\n      if (!a.redeems.length) throw new TypeError('Empty redeems');\n      if (a.redeemIndex !== undefined && (a.redeemIndex < 0 || a.redeemIndex >= a.redeems.length)) {\n        throw new TypeError('invalid redeem index');\n      }\n      a.redeems.forEach((redeem) => {\n        if (redeem.network && redeem.network !== network) {\n          throw new TypeError('Network mismatch');\n        }\n      });\n    }\n\n    const chosenRedeem = a.redeems && a.redeemIndex !== undefined && a.redeems[a.redeemIndex];\n\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Key') {\n      if (a.controlBlock) {\n        throw new TypeError('unexpected control block for key path');\n      }\n\n      if (a.signature && !a.signature.equals(parsedWitness.signature)) {\n        throw new TypeError('mismatch between witness & signature');\n      }\n    }\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      if (a.signature) {\n        throw new TypeError('unexpected signature with script path witness');\n      }\n\n      if (a.controlBlock && !a.controlBlock.equals(parsedWitness.controlBlock)) {\n        throw new TypeError('control block mismatch');\n      }\n\n      if (a.annex && parsedWitness.annex && !a.annex.equals(parsedWitness.annex)) {\n        throw new TypeError('annex mismatch');\n      }\n\n      if (chosenRedeem && chosenRedeem.output && !chosenRedeem.output.equals(parsedWitness.tapscript)) {\n        throw new TypeError('tapscript mismatch');\n      }\n    }\n  }\n\n  return Object.assign(o, a);\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { Payment, PaymentOpts } from 'bitcoinjs-lib';
2
+ export declare function p2tr_ns(a: Payment, opts?: PaymentOpts): Payment;
3
+ //# sourceMappingURL=p2tr_ns.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"p2tr_ns.d.ts","sourceRoot":"","sources":["../../../src/payments/p2tr_ns.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,OAAO,EAAE,WAAW,EAAe,MAAM,eAAe,CAAC;AAiBrF,wBAAgB,OAAO,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,WAAW,GAAG,OAAO,CAgI/D"}