utxo-lib 1.1.5 → 8.0.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of utxo-lib might be problematic. Click here for more details.

Files changed (250) hide show
  1. package/index.js +47 -0
  2. package/package.json +6 -80
  3. package/LICENSE +0 -21
  4. package/README.md +0 -59
  5. package/dist/src/address.d.ts +0 -11
  6. package/dist/src/address.d.ts.map +0 -1
  7. package/dist/src/address.js +0 -37
  8. package/dist/src/addressFormat.d.ts +0 -53
  9. package/dist/src/addressFormat.d.ts.map +0 -1
  10. package/dist/src/addressFormat.js +0 -110
  11. package/dist/src/bitgo/Musig2.d.ts +0 -51
  12. package/dist/src/bitgo/Musig2.d.ts.map +0 -1
  13. package/dist/src/bitgo/Musig2.js +0 -175
  14. package/dist/src/bitgo/Unspent.d.ts +0 -95
  15. package/dist/src/bitgo/Unspent.d.ts.map +0 -1
  16. package/dist/src/bitgo/Unspent.js +0 -138
  17. package/dist/src/bitgo/UtxoPsbt.d.ts +0 -132
  18. package/dist/src/bitgo/UtxoPsbt.d.ts.map +0 -1
  19. package/dist/src/bitgo/UtxoPsbt.js +0 -469
  20. package/dist/src/bitgo/UtxoTransaction.d.ts +0 -22
  21. package/dist/src/bitgo/UtxoTransaction.d.ts.map +0 -1
  22. package/dist/src/bitgo/UtxoTransaction.js +0 -97
  23. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +0 -26
  24. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +0 -1
  25. package/dist/src/bitgo/UtxoTransactionBuilder.js +0 -67
  26. package/dist/src/bitgo/bbc/DashPsbt.d.ts +0 -12
  27. package/dist/src/bitgo/bbc/DashPsbt.d.ts.map +0 -1
  28. package/dist/src/bitgo/bbc/DashPsbt.js +0 -27
  29. package/dist/src/bitgo/bbc/DashTransaction.d.ts +0 -39
  30. package/dist/src/bitgo/bbc/DashTransaction.d.ts.map +0 -1
  31. package/dist/src/bitgo/bbc/DashTransaction.js +0 -109
  32. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts +0 -14
  33. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts.map +0 -1
  34. package/dist/src/bitgo/bbc/DashTransactionBuilder.js +0 -28
  35. package/dist/src/bitgo/bbc/index.d.ts +0 -4
  36. package/dist/src/bitgo/bbc/index.d.ts.map +0 -1
  37. package/dist/src/bitgo/bbc/index.js +0 -16
  38. package/dist/src/bitgo/bitcoincash/address.d.ts +0 -35
  39. package/dist/src/bitgo/bitcoincash/address.d.ts.map +0 -1
  40. package/dist/src/bitgo/bitcoincash/address.js +0 -151
  41. package/dist/src/bitgo/bitcoincash/index.d.ts +0 -2
  42. package/dist/src/bitgo/bitcoincash/index.d.ts.map +0 -1
  43. package/dist/src/bitgo/bitcoincash/index.js +0 -14
  44. package/dist/src/bitgo/dash/DashPsbt.d.ts +0 -12
  45. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +0 -1
  46. package/dist/src/bitgo/dash/DashPsbt.js +0 -27
  47. package/dist/src/bitgo/dash/DashTransaction.d.ts +0 -39
  48. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +0 -1
  49. package/dist/src/bitgo/dash/DashTransaction.js +0 -109
  50. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +0 -14
  51. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +0 -1
  52. package/dist/src/bitgo/dash/DashTransactionBuilder.js +0 -28
  53. package/dist/src/bitgo/dash/index.d.ts +0 -4
  54. package/dist/src/bitgo/dash/index.d.ts.map +0 -1
  55. package/dist/src/bitgo/dash/index.js +0 -16
  56. package/dist/src/bitgo/index.d.ts +0 -17
  57. package/dist/src/bitgo/index.d.ts.map +0 -1
  58. package/dist/src/bitgo/index.js +0 -30
  59. package/dist/src/bitgo/keyutil.d.ts +0 -17
  60. package/dist/src/bitgo/keyutil.d.ts.map +0 -1
  61. package/dist/src/bitgo/keyutil.js +0 -37
  62. package/dist/src/bitgo/nonStandardHalfSigned.d.ts +0 -7
  63. package/dist/src/bitgo/nonStandardHalfSigned.d.ts.map +0 -1
  64. package/dist/src/bitgo/nonStandardHalfSigned.js +0 -56
  65. package/dist/src/bitgo/outputScripts.d.ts +0 -84
  66. package/dist/src/bitgo/outputScripts.d.ts.map +0 -1
  67. package/dist/src/bitgo/outputScripts.js +0 -297
  68. package/dist/src/bitgo/parseInput.d.ts +0 -92
  69. package/dist/src/bitgo/parseInput.d.ts.map +0 -1
  70. package/dist/src/bitgo/parseInput.js +0 -344
  71. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +0 -24
  72. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +0 -1
  73. package/dist/src/bitgo/psbt/fromHalfSigned.js +0 -91
  74. package/dist/src/bitgo/psbt/scriptTypes.d.ts +0 -6
  75. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +0 -1
  76. package/dist/src/bitgo/psbt/scriptTypes.js +0 -23
  77. package/dist/src/bitgo/signature.d.ts +0 -84
  78. package/dist/src/bitgo/signature.d.ts.map +0 -1
  79. package/dist/src/bitgo/signature.js +0 -222
  80. package/dist/src/bitgo/tnumber.d.ts +0 -9
  81. package/dist/src/bitgo/tnumber.d.ts.map +0 -1
  82. package/dist/src/bitgo/tnumber.js +0 -31
  83. package/dist/src/bitgo/transaction.d.ts +0 -29
  84. package/dist/src/bitgo/transaction.d.ts.map +0 -1
  85. package/dist/src/bitgo/transaction.js +0 -231
  86. package/dist/src/bitgo/types.d.ts +0 -5
  87. package/dist/src/bitgo/types.d.ts.map +0 -1
  88. package/dist/src/bitgo/types.js +0 -12
  89. package/dist/src/bitgo/wallet/Psbt.d.ts +0 -47
  90. package/dist/src/bitgo/wallet/Psbt.d.ts.map +0 -1
  91. package/dist/src/bitgo/wallet/Psbt.js +0 -232
  92. package/dist/src/bitgo/wallet/Unspent.d.ts +0 -47
  93. package/dist/src/bitgo/wallet/Unspent.d.ts.map +0 -1
  94. package/dist/src/bitgo/wallet/Unspent.js +0 -154
  95. package/dist/src/bitgo/wallet/WalletKeys.d.ts +0 -72
  96. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +0 -1
  97. package/dist/src/bitgo/wallet/WalletKeys.js +0 -104
  98. package/dist/src/bitgo/wallet/WalletOutput.d.ts +0 -18
  99. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +0 -1
  100. package/dist/src/bitgo/wallet/WalletOutput.js +0 -69
  101. package/dist/src/bitgo/wallet/WalletScripts.d.ts +0 -7
  102. package/dist/src/bitgo/wallet/WalletScripts.d.ts.map +0 -1
  103. package/dist/src/bitgo/wallet/WalletScripts.js +0 -15
  104. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts +0 -19
  105. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts.map +0 -1
  106. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +0 -47
  107. package/dist/src/bitgo/wallet/chains.d.ts +0 -57
  108. package/dist/src/bitgo/wallet/chains.d.ts.map +0 -1
  109. package/dist/src/bitgo/wallet/chains.js +0 -106
  110. package/dist/src/bitgo/wallet/index.d.ts +0 -8
  111. package/dist/src/bitgo/wallet/index.d.ts.map +0 -1
  112. package/dist/src/bitgo/wallet/index.js +0 -20
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +0 -26
  114. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +0 -1
  115. package/dist/src/bitgo/zcash/ZcashBufferutils.js +0 -157
  116. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +0 -36
  117. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +0 -1
  118. package/dist/src/bitgo/zcash/ZcashPsbt.js +0 -146
  119. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +0 -61
  120. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +0 -1
  121. package/dist/src/bitgo/zcash/ZcashTransaction.js +0 -341
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +0 -21
  123. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +0 -1
  124. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +0 -105
  125. package/dist/src/bitgo/zcash/address.d.ts +0 -8
  126. package/dist/src/bitgo/zcash/address.d.ts.map +0 -1
  127. package/dist/src/bitgo/zcash/address.js +0 -57
  128. package/dist/src/bitgo/zcash/hashZip0244.d.ts +0 -27
  129. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +0 -1
  130. package/dist/src/bitgo/zcash/hashZip0244.js +0 -184
  131. package/dist/src/bitgo/zcash/index.d.ts +0 -4
  132. package/dist/src/bitgo/zcash/index.d.ts.map +0 -1
  133. package/dist/src/bitgo/zcash/index.js +0 -16
  134. package/dist/src/classify.d.ts +0 -19
  135. package/dist/src/classify.d.ts.map +0 -1
  136. package/dist/src/classify.js +0 -89
  137. package/dist/src/index.d.ts +0 -13
  138. package/dist/src/index.d.ts.map +0 -1
  139. package/dist/src/index.js +0 -36
  140. package/dist/src/networks.d.ts +0 -115
  141. package/dist/src/networks.d.ts.map +0 -1
  142. package/dist/src/networks.js +0 -458
  143. package/dist/src/noble_ecc.d.ts +0 -28
  144. package/dist/src/noble_ecc.d.ts.map +0 -1
  145. package/dist/src/noble_ecc.js +0 -168
  146. package/dist/src/payments/index.d.ts +0 -4
  147. package/dist/src/payments/index.d.ts.map +0 -1
  148. package/dist/src/payments/index.js +0 -8
  149. package/dist/src/payments/p2tr.d.ts +0 -3
  150. package/dist/src/payments/p2tr.d.ts.map +0 -1
  151. package/dist/src/payments/p2tr.js +0 -348
  152. package/dist/src/payments/p2tr_ns.d.ts +0 -3
  153. package/dist/src/payments/p2tr_ns.d.ts.map +0 -1
  154. package/dist/src/payments/p2tr_ns.js +0 -134
  155. package/dist/src/taproot.d.ts +0 -141
  156. package/dist/src/taproot.d.ts.map +0 -1
  157. package/dist/src/taproot.js +0 -384
  158. package/dist/src/templates/multisig/index.d.ts +0 -4
  159. package/dist/src/templates/multisig/index.d.ts.map +0 -1
  160. package/dist/src/templates/multisig/index.js +0 -8
  161. package/dist/src/templates/multisig/input.d.ts +0 -7
  162. package/dist/src/templates/multisig/input.d.ts.map +0 -1
  163. package/dist/src/templates/multisig/input.js +0 -25
  164. package/dist/src/templates/multisig/output.d.ts +0 -7
  165. package/dist/src/templates/multisig/output.d.ts.map +0 -1
  166. package/dist/src/templates/multisig/output.js +0 -38
  167. package/dist/src/templates/nulldata.d.ts +0 -10
  168. package/dist/src/templates/nulldata.d.ts.map +0 -1
  169. package/dist/src/templates/nulldata.js +0 -17
  170. package/dist/src/templates/pubkey/index.d.ts +0 -4
  171. package/dist/src/templates/pubkey/index.d.ts.map +0 -1
  172. package/dist/src/templates/pubkey/index.js +0 -8
  173. package/dist/src/templates/pubkey/input.d.ts +0 -7
  174. package/dist/src/templates/pubkey/input.d.ts.map +0 -1
  175. package/dist/src/templates/pubkey/input.js +0 -14
  176. package/dist/src/templates/pubkey/output.d.ts +0 -7
  177. package/dist/src/templates/pubkey/output.d.ts.map +0 -1
  178. package/dist/src/templates/pubkey/output.js +0 -15
  179. package/dist/src/templates/pubkeyhash/index.d.ts +0 -4
  180. package/dist/src/templates/pubkeyhash/index.d.ts.map +0 -1
  181. package/dist/src/templates/pubkeyhash/index.js +0 -8
  182. package/dist/src/templates/pubkeyhash/input.d.ts +0 -7
  183. package/dist/src/templates/pubkeyhash/input.d.ts.map +0 -1
  184. package/dist/src/templates/pubkeyhash/input.js +0 -16
  185. package/dist/src/templates/pubkeyhash/output.d.ts +0 -6
  186. package/dist/src/templates/pubkeyhash/output.d.ts.map +0 -1
  187. package/dist/src/templates/pubkeyhash/output.js +0 -20
  188. package/dist/src/templates/scripthash/index.d.ts +0 -4
  189. package/dist/src/templates/scripthash/index.d.ts.map +0 -1
  190. package/dist/src/templates/scripthash/index.js +0 -8
  191. package/dist/src/templates/scripthash/input.d.ts +0 -6
  192. package/dist/src/templates/scripthash/input.d.ts.map +0 -1
  193. package/dist/src/templates/scripthash/input.js +0 -43
  194. package/dist/src/templates/scripthash/output.d.ts +0 -6
  195. package/dist/src/templates/scripthash/output.d.ts.map +0 -1
  196. package/dist/src/templates/scripthash/output.js +0 -15
  197. package/dist/src/templates/taproot/index.d.ts +0 -4
  198. package/dist/src/templates/taproot/index.d.ts.map +0 -1
  199. package/dist/src/templates/taproot/index.js +0 -8
  200. package/dist/src/templates/taproot/input.d.ts +0 -6
  201. package/dist/src/templates/taproot/input.d.ts.map +0 -1
  202. package/dist/src/templates/taproot/input.js +0 -23
  203. package/dist/src/templates/taproot/output.d.ts +0 -6
  204. package/dist/src/templates/taproot/output.d.ts.map +0 -1
  205. package/dist/src/templates/taproot/output.js +0 -15
  206. package/dist/src/templates/taprootnofn/index.d.ts +0 -4
  207. package/dist/src/templates/taprootnofn/index.d.ts.map +0 -1
  208. package/dist/src/templates/taprootnofn/index.js +0 -8
  209. package/dist/src/templates/taprootnofn/input.d.ts +0 -7
  210. package/dist/src/templates/taprootnofn/input.d.ts.map +0 -1
  211. package/dist/src/templates/taprootnofn/input.js +0 -24
  212. package/dist/src/templates/taprootnofn/output.d.ts +0 -7
  213. package/dist/src/templates/taprootnofn/output.d.ts.map +0 -1
  214. package/dist/src/templates/taprootnofn/output.js +0 -28
  215. package/dist/src/templates/witnesscommitment/index.d.ts +0 -3
  216. package/dist/src/templates/witnesscommitment/index.d.ts.map +0 -1
  217. package/dist/src/templates/witnesscommitment/index.js +0 -6
  218. package/dist/src/templates/witnesscommitment/output.d.ts +0 -8
  219. package/dist/src/templates/witnesscommitment/output.d.ts.map +0 -1
  220. package/dist/src/templates/witnesscommitment/output.js +0 -31
  221. package/dist/src/templates/witnesspubkeyhash/index.d.ts +0 -4
  222. package/dist/src/templates/witnesspubkeyhash/index.d.ts.map +0 -1
  223. package/dist/src/templates/witnesspubkeyhash/index.js +0 -8
  224. package/dist/src/templates/witnesspubkeyhash/input.d.ts +0 -7
  225. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +0 -1
  226. package/dist/src/templates/witnesspubkeyhash/input.js +0 -19
  227. package/dist/src/templates/witnesspubkeyhash/output.d.ts +0 -6
  228. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +0 -1
  229. package/dist/src/templates/witnesspubkeyhash/output.js +0 -15
  230. package/dist/src/templates/witnessscripthash/index.d.ts +0 -4
  231. package/dist/src/templates/witnessscripthash/index.d.ts.map +0 -1
  232. package/dist/src/templates/witnessscripthash/index.js +0 -8
  233. package/dist/src/templates/witnessscripthash/input.d.ts +0 -6
  234. package/dist/src/templates/witnessscripthash/input.d.ts.map +0 -1
  235. package/dist/src/templates/witnessscripthash/input.js +0 -35
  236. package/dist/src/templates/witnessscripthash/output.d.ts +0 -6
  237. package/dist/src/templates/witnessscripthash/output.d.ts.map +0 -1
  238. package/dist/src/templates/witnessscripthash/output.js +0 -15
  239. package/dist/src/testutil/index.d.ts +0 -3
  240. package/dist/src/testutil/index.d.ts.map +0 -1
  241. package/dist/src/testutil/index.js +0 -15
  242. package/dist/src/testutil/keys.d.ts +0 -10
  243. package/dist/src/testutil/keys.d.ts.map +0 -1
  244. package/dist/src/testutil/keys.js +0 -40
  245. package/dist/src/testutil/mock.d.ts +0 -21
  246. package/dist/src/testutil/mock.d.ts.map +0 -1
  247. package/dist/src/testutil/mock.js +0 -86
  248. package/dist/src/transaction_builder.d.ts +0 -47
  249. package/dist/src/transaction_builder.d.ts.map +0 -1
  250. package/dist/src/transaction_builder.js +0 -1084
@@ -1,1084 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TransactionBuilder = void 0;
4
- const types = require("bitcoinjs-lib/src/types");
5
- const _1 = require("./");
6
- const bufferutils = require("bitcoinjs-lib/src/bufferutils");
7
- const classify = require("./classify");
8
- const _2 = require("./");
9
- const _3 = require("./");
10
- const _4 = require("./");
11
- const _5 = require("./");
12
- const _6 = require("./");
13
- const _7 = require("./");
14
- const _8 = require("./");
15
- const noble_ecc_1 = require("./noble_ecc");
16
- const typeforce = require('typeforce');
17
- const tfFullSigner = (obj) => {
18
- return typeforce.Buffer(obj.publicKey) && typeof obj.sign === 'function' && typeof obj.signSchnorr === 'function';
19
- };
20
- const SCRIPT_TYPES = classify.types;
21
- const PREVOUT_TYPES = new Set([
22
- // Raw
23
- 'p2pkh',
24
- 'p2pk',
25
- 'p2wpkh',
26
- 'p2ms',
27
- // P2SH wrapped
28
- 'p2sh-p2pkh',
29
- 'p2sh-p2pk',
30
- 'p2sh-p2wpkh',
31
- 'p2sh-p2ms',
32
- // P2WSH wrapped
33
- 'p2wsh-p2pkh',
34
- 'p2wsh-p2pk',
35
- 'p2wsh-p2ms',
36
- // P2SH-P2WSH wrapper
37
- 'p2sh-p2wsh-p2pkh',
38
- 'p2sh-p2wsh-p2pk',
39
- 'p2sh-p2wsh-p2ms',
40
- // P2TR KeyPath
41
- 'p2tr',
42
- // P2TR ScriptPath
43
- 'p2tr-p2ns',
44
- ]);
45
- function tfMessage(type, value, message) {
46
- try {
47
- typeforce(type, value);
48
- }
49
- catch (err) {
50
- throw new Error(message);
51
- }
52
- }
53
- function txIsString(tx) {
54
- return typeof tx === 'string' || tx instanceof String;
55
- }
56
- function txIsTransaction(tx) {
57
- return tx instanceof _8.Transaction;
58
- }
59
- class TransactionBuilder {
60
- // WARNING: maximumFeeRate is __NOT__ to be relied on,
61
- // it's just another potential safety mechanism (safety in-depth)
62
- constructor(network = _3.networks.bitcoin, maximumFeeRate = 2500) {
63
- this.network = network;
64
- this.maximumFeeRate = maximumFeeRate;
65
- this.__PREV_TX_SET = {};
66
- this.__INPUTS = [];
67
- this.__TX = new _8.Transaction();
68
- this.__TX.version = 2;
69
- this.__USE_LOW_R = false;
70
- console.warn('Deprecation Warning: TransactionBuilder will be removed in the future. ' +
71
- '(v6.x.x or later) Please use the Psbt class instead. Examples of usage ' +
72
- 'are available in the transactions-psbt.js integration test file on our ' +
73
- 'Github. A high level explanation is available in the psbt.ts and psbt.js ' +
74
- 'files as well.');
75
- }
76
- static fromTransaction(transaction, network, prevOutputs) {
77
- const txb = new TransactionBuilder(network);
78
- // Copy transaction fields
79
- txb.setVersion(transaction.version);
80
- txb.setLockTime(transaction.locktime);
81
- // Copy outputs (done first to avoid signature invalidation)
82
- transaction.outs.forEach((txOut) => {
83
- txb.addOutput(txOut.script, txOut.value);
84
- });
85
- // Copy inputs
86
- transaction.ins.forEach((txIn) => {
87
- txb.__addInputUnsafe(txIn.hash, txIn.index, {
88
- sequence: txIn.sequence,
89
- script: txIn.script,
90
- witness: txIn.witness,
91
- });
92
- });
93
- // fix some things not possible through the public API
94
- txb.__INPUTS.forEach((input, i) => {
95
- fixMultisigOrder(input, transaction, i, prevOutputs);
96
- });
97
- return txb;
98
- }
99
- setLowR(setting) {
100
- typeforce(typeforce.maybe(typeforce.Boolean), setting);
101
- if (setting === undefined) {
102
- setting = true;
103
- }
104
- this.__USE_LOW_R = setting;
105
- return setting;
106
- }
107
- setLockTime(locktime) {
108
- typeforce(types.UInt32, locktime);
109
- // if any signatures exist, throw
110
- if (this.__INPUTS.some((input) => {
111
- if (!input.signatures)
112
- return false;
113
- return input.signatures.some((s) => s !== undefined);
114
- })) {
115
- throw new Error('No, this would invalidate signatures');
116
- }
117
- this.__TX.locktime = locktime;
118
- }
119
- setVersion(version) {
120
- typeforce(types.UInt32, version);
121
- // XXX: this might eventually become more complex depending on what the versions represent
122
- this.__TX.version = version;
123
- }
124
- addInput(txHash, vout, sequence, prevOutScript, value) {
125
- if (!this.__canModifyInputs()) {
126
- throw new Error('No, this would invalidate signatures');
127
- }
128
- // is it a hex string?
129
- if (txIsString(txHash)) {
130
- // transaction hashs's are displayed in reverse order, un-reverse it
131
- txHash = bufferutils.reverseBuffer(Buffer.from(txHash, 'hex'));
132
- // is it a Transaction object?
133
- }
134
- else if (txIsTransaction(txHash)) {
135
- const txOut = txHash.outs[vout];
136
- prevOutScript = txOut.script;
137
- value = txOut.value;
138
- txHash = txHash.getHash(false);
139
- }
140
- return this.__addInputUnsafe(txHash, vout, {
141
- sequence,
142
- prevOutScript,
143
- value,
144
- });
145
- }
146
- addOutput(scriptPubKey, value) {
147
- if (!this.__canModifyOutputs()) {
148
- throw new Error('No, this would invalidate signatures');
149
- }
150
- // Attempt to get a script if it's a base58 or bech32 address string
151
- if (typeof scriptPubKey === 'string') {
152
- scriptPubKey = _1.address.toOutputScript(scriptPubKey, this.network);
153
- }
154
- return this.__TX.addOutput(scriptPubKey, value);
155
- }
156
- build() {
157
- return this.__build(false);
158
- }
159
- buildIncomplete() {
160
- return this.__build(true);
161
- }
162
- sign(signParams, keyPair, redeemScript, hashType, witnessValue, witnessScript, controlBlock, annex) {
163
- trySign(getSigningData(this.network, this.__INPUTS, this.__needsOutputs.bind(this), this.__TX, signParams, keyPair, redeemScript, hashType, witnessValue, witnessScript, controlBlock, annex, this.__USE_LOW_R));
164
- }
165
- __addInputUnsafe(txHash, vout, options) {
166
- if (_8.Transaction.isCoinbaseHash(txHash)) {
167
- throw new Error('coinbase inputs not supported');
168
- }
169
- const prevTxOut = txHash.toString('hex') + ':' + vout;
170
- if (this.__PREV_TX_SET[prevTxOut] !== undefined)
171
- throw new Error('Duplicate TxOut: ' + prevTxOut);
172
- let input = {};
173
- // derive what we can from the scriptSig
174
- if (options.script !== undefined || options.witness !== undefined) {
175
- input = expandInput(options.script, options.witness);
176
- }
177
- // if an input value was given, retain it
178
- if (options.value !== undefined) {
179
- input.value = options.value;
180
- }
181
- // derive what we can from the previous transactions output script
182
- if (!input.prevOutScript && options.prevOutScript) {
183
- let prevOutType;
184
- if (!input.pubkeys && !input.signatures) {
185
- const expanded = expandOutput(options.prevOutScript);
186
- if (expanded.pubkeys) {
187
- input.pubkeys = expanded.pubkeys;
188
- input.signatures = expanded.signatures;
189
- }
190
- prevOutType = expanded.type;
191
- }
192
- input.prevOutScript = options.prevOutScript;
193
- input.prevOutType = prevOutType || classify.output(options.prevOutScript);
194
- }
195
- const vin = this.__TX.addInput(txHash, vout, options.sequence, options.scriptSig);
196
- this.__INPUTS[vin] = input;
197
- this.__PREV_TX_SET[prevTxOut] = true;
198
- return vin;
199
- }
200
- __build(allowIncomplete) {
201
- if (!allowIncomplete) {
202
- if (!this.__TX.ins.length)
203
- throw new Error('Transaction has no inputs');
204
- if (!this.__TX.outs.length)
205
- throw new Error('Transaction has no outputs');
206
- }
207
- const tx = this.__TX.clone();
208
- // create script signatures from inputs
209
- this.__INPUTS.forEach((input, i) => {
210
- if (!input.prevOutType && !allowIncomplete)
211
- throw new Error('Transaction is not complete');
212
- const result = build(input.prevOutType, input, allowIncomplete);
213
- if (!result) {
214
- if (!allowIncomplete && input.prevOutType === SCRIPT_TYPES.NONSTANDARD)
215
- throw new Error('Unknown input type');
216
- if (!allowIncomplete)
217
- throw new Error('Not enough information');
218
- return;
219
- }
220
- if (result.input) {
221
- tx.setInputScript(i, result.input);
222
- }
223
- tx.setWitness(i, result.witness);
224
- });
225
- if (!allowIncomplete) {
226
- // do not rely on this, its merely a last resort
227
- if (this.__overMaximumFees(tx.virtualSize())) {
228
- throw new Error('Transaction has absurd fees');
229
- }
230
- }
231
- return tx;
232
- }
233
- __canModifyInputs() {
234
- return this.__INPUTS.every((input) => {
235
- if (!input.signatures)
236
- return true;
237
- return input.signatures.every((signature) => {
238
- if (!signature)
239
- return true;
240
- const hashType = signatureHashType(signature);
241
- // if SIGHASH_ANYONECANPAY is set, signatures would not
242
- // be invalidated by more inputs
243
- return (hashType & _8.Transaction.SIGHASH_ANYONECANPAY) !== 0;
244
- });
245
- });
246
- }
247
- __needsOutputs(signingHashType) {
248
- if (signingHashType === _8.Transaction.SIGHASH_ALL || signingHashType === _8.Transaction.SIGHASH_DEFAULT) {
249
- return this.__TX.outs.length === 0;
250
- }
251
- // if inputs are being signed with SIGHASH_NONE, we don't strictly need outputs
252
- // .build() will fail, but .buildIncomplete() is OK
253
- return (this.__TX.outs.length === 0 &&
254
- this.__INPUTS.some((input) => {
255
- if (!input.signatures)
256
- return false;
257
- return input.signatures.some((signature) => {
258
- if (!signature)
259
- return false; // no signature, no issue
260
- const hashType = signatureHashType(signature);
261
- if (hashType & _8.Transaction.SIGHASH_NONE)
262
- return false; // SIGHASH_NONE doesn't care about outputs
263
- return true; // SIGHASH_* does care
264
- });
265
- }));
266
- }
267
- __canModifyOutputs() {
268
- const nInputs = this.__TX.ins.length;
269
- const nOutputs = this.__TX.outs.length;
270
- return this.__INPUTS.every((input) => {
271
- if (input.signatures === undefined)
272
- return true;
273
- return input.signatures.every((signature) => {
274
- if (!signature)
275
- return true;
276
- const hashType = signatureHashType(signature);
277
- const hashTypeMod = hashType & 0x1f;
278
- if (hashTypeMod === _8.Transaction.SIGHASH_NONE)
279
- return true;
280
- if (hashTypeMod === _8.Transaction.SIGHASH_SINGLE) {
281
- // if SIGHASH_SINGLE is set, and nInputs > nOutputs
282
- // some signatures would be invalidated by the addition
283
- // of more outputs
284
- return nInputs <= nOutputs;
285
- }
286
- return false;
287
- });
288
- });
289
- }
290
- __overMaximumFees(bytes) {
291
- // not all inputs will have .value defined
292
- const incoming = this.__INPUTS.reduce((a, x) => a + (typeof x.value !== 'undefined' ? BigInt(x.value) : BigInt(0)), BigInt(0));
293
- // but all outputs do, and if we have any input value
294
- // we can immediately determine if the outputs are too small
295
- const outgoing = this.__TX.outs.reduce((a, x) => a + BigInt(x.value), BigInt(0));
296
- const fee = incoming - outgoing;
297
- const feeRate = Number(fee) / bytes; // assume fee fits within number
298
- return feeRate > this.maximumFeeRate;
299
- }
300
- }
301
- exports.TransactionBuilder = TransactionBuilder;
302
- function expandInput(scriptSig, witnessStack = [], type, scriptPubKey) {
303
- if (scriptSig && scriptSig.length === 0 && witnessStack.length === 0)
304
- return {};
305
- if (!type) {
306
- let ssType = scriptSig ? classify.input(scriptSig, true) : undefined;
307
- let wsType = classify.witness(witnessStack, true);
308
- if (ssType === SCRIPT_TYPES.NONSTANDARD)
309
- ssType = undefined;
310
- if (wsType === SCRIPT_TYPES.NONSTANDARD)
311
- wsType = undefined;
312
- type = ssType || wsType;
313
- }
314
- switch (type) {
315
- case SCRIPT_TYPES.P2WPKH: {
316
- const { output, pubkey, signature } = _4.payments.p2wpkh({
317
- witness: witnessStack,
318
- });
319
- return {
320
- prevOutScript: output,
321
- prevOutType: SCRIPT_TYPES.P2WPKH,
322
- pubkeys: [pubkey],
323
- signatures: [signature],
324
- };
325
- }
326
- case SCRIPT_TYPES.P2PKH: {
327
- const { output, pubkey, signature } = _4.payments.p2pkh({
328
- input: scriptSig,
329
- });
330
- return {
331
- prevOutScript: output,
332
- prevOutType: SCRIPT_TYPES.P2PKH,
333
- pubkeys: [pubkey],
334
- signatures: [signature],
335
- };
336
- }
337
- case SCRIPT_TYPES.P2PK: {
338
- const { signature } = _4.payments.p2pk({ input: scriptSig });
339
- return {
340
- prevOutType: SCRIPT_TYPES.P2PK,
341
- pubkeys: [undefined],
342
- signatures: [signature],
343
- };
344
- }
345
- case SCRIPT_TYPES.P2MS: {
346
- const { m, pubkeys, signatures } = _4.payments.p2ms({
347
- input: scriptSig,
348
- output: scriptPubKey,
349
- }, { allowIncomplete: true });
350
- return {
351
- prevOutType: SCRIPT_TYPES.P2MS,
352
- pubkeys,
353
- signatures,
354
- maxSignatures: m,
355
- };
356
- }
357
- case SCRIPT_TYPES.P2TR_NS: {
358
- const { n, pubkeys, signatures } = _1.p2trPayments.p2tr_ns({
359
- // Witness signatures are reverse of pubkeys, because it's a stack
360
- signatures: witnessStack.length ? witnessStack.reverse() : undefined,
361
- output: scriptPubKey,
362
- }, { allowIncomplete: true, eccLib: noble_ecc_1.ecc });
363
- return {
364
- prevOutType: SCRIPT_TYPES.P2TR_NS,
365
- pubkeys,
366
- signatures,
367
- maxSignatures: n,
368
- };
369
- }
370
- }
371
- if (type === SCRIPT_TYPES.P2SH) {
372
- const { output, redeem } = _4.payments.p2sh({
373
- input: scriptSig,
374
- witness: witnessStack,
375
- });
376
- const outputType = classify.output(redeem.output);
377
- const expanded = expandInput(redeem.input, redeem.witness, outputType, redeem.output);
378
- if (!expanded.prevOutType)
379
- return {};
380
- return {
381
- prevOutScript: output,
382
- prevOutType: SCRIPT_TYPES.P2SH,
383
- redeemScript: redeem.output,
384
- redeemScriptType: expanded.prevOutType,
385
- witnessScript: expanded.witnessScript,
386
- witnessScriptType: expanded.witnessScriptType,
387
- pubkeys: expanded.pubkeys,
388
- signatures: expanded.signatures,
389
- };
390
- }
391
- if (type === SCRIPT_TYPES.P2WSH) {
392
- const { output, redeem } = _4.payments.p2wsh({
393
- input: scriptSig,
394
- witness: witnessStack,
395
- });
396
- const outputType = classify.output(redeem.output);
397
- let expanded;
398
- if (outputType === SCRIPT_TYPES.P2WPKH) {
399
- expanded = expandInput(redeem.input, redeem.witness, outputType);
400
- }
401
- else {
402
- expanded = expandInput(_5.script.compile(redeem.witness), [], outputType, redeem.output);
403
- }
404
- if (!expanded.prevOutType)
405
- return {};
406
- return {
407
- prevOutScript: output,
408
- prevOutType: SCRIPT_TYPES.P2WSH,
409
- witnessScript: redeem.output,
410
- witnessScriptType: expanded.prevOutType,
411
- pubkeys: expanded.pubkeys,
412
- signatures: expanded.signatures,
413
- };
414
- }
415
- if (type === SCRIPT_TYPES.P2TR) {
416
- const parsedWitness = _7.taproot.parseTaprootWitness(witnessStack);
417
- if (parsedWitness.spendType === 'Key') {
418
- // key path spend, nothing to expand
419
- const { signature, annex } = parsedWitness;
420
- return {
421
- prevOutType: SCRIPT_TYPES.P2TR,
422
- signatures: [signature],
423
- annex,
424
- };
425
- }
426
- else {
427
- // script path spend
428
- const { tapscript, controlBlock, annex } = parsedWitness;
429
- const prevOutScript = _1.p2trPayments.p2tr({
430
- redeems: [{ output: tapscript }],
431
- redeemIndex: 0,
432
- controlBlock,
433
- annex,
434
- }, { eccLib: noble_ecc_1.ecc }).output;
435
- const witnessScriptType = classify.output(tapscript);
436
- const { pubkeys, signatures } = expandInput(undefined, parsedWitness.scriptSig, witnessScriptType, tapscript);
437
- return {
438
- prevOutScript,
439
- prevOutType: SCRIPT_TYPES.P2TR,
440
- witnessScript: tapscript,
441
- witnessScriptType,
442
- controlBlock,
443
- annex,
444
- pubkeys,
445
- signatures,
446
- };
447
- }
448
- }
449
- return {
450
- prevOutType: SCRIPT_TYPES.NONSTANDARD,
451
- prevOutScript: scriptSig,
452
- };
453
- }
454
- // could be done in expandInput, but requires the original Transaction for hashForSignature
455
- function fixMultisigOrder(input, transaction, vin, prevOutputs) {
456
- if (input.redeemScriptType !== SCRIPT_TYPES.P2MS || !input.redeemScript)
457
- return;
458
- if (input.pubkeys.length === input.signatures.length)
459
- return;
460
- const prevOutput = prevOutputs && prevOutputs[vin];
461
- const unmatched = input.signatures.concat();
462
- input.signatures = input.pubkeys.map((pubKey) => {
463
- const keyPair = noble_ecc_1.ECPair.fromPublicKey(pubKey);
464
- let match;
465
- // check for a signature
466
- unmatched.some((signature, i) => {
467
- // skip if undefined || OP_0
468
- if (!signature)
469
- return false;
470
- // TODO: avoid O(n) hashForSignature
471
- const parsed = _5.script.signature.decode(signature);
472
- const hash = transaction.hashForSignature(vin, input.redeemScript, parsed.hashType, prevOutput === null || prevOutput === void 0 ? void 0 : prevOutput.value);
473
- // skip if signature does not match pubKey
474
- if (!keyPair.verify(hash, parsed.signature))
475
- return false;
476
- // remove matched signature from unmatched
477
- unmatched[i] = undefined;
478
- match = signature;
479
- return true;
480
- });
481
- return match;
482
- });
483
- }
484
- function expandOutput(script, ourPubKey, controlBlock) {
485
- typeforce(types.Buffer, script);
486
- const type = classify.output(script);
487
- switch (type) {
488
- case SCRIPT_TYPES.P2PKH: {
489
- if (!ourPubKey)
490
- return { type };
491
- // does our hash160(pubKey) match the output scripts?
492
- const pkh1 = _4.payments.p2pkh({ output: script }).hash;
493
- const pkh2 = _2.crypto.hash160(ourPubKey);
494
- if (!pkh1.equals(pkh2))
495
- return { type };
496
- return {
497
- type,
498
- pubkeys: [ourPubKey],
499
- signatures: [undefined],
500
- };
501
- }
502
- case SCRIPT_TYPES.P2WPKH: {
503
- if (!ourPubKey)
504
- return { type };
505
- // does our hash160(pubKey) match the output scripts?
506
- const wpkh1 = _4.payments.p2wpkh({ output: script }).hash;
507
- const wpkh2 = _2.crypto.hash160(ourPubKey);
508
- if (!wpkh1.equals(wpkh2))
509
- return { type };
510
- return {
511
- type,
512
- pubkeys: [ourPubKey],
513
- signatures: [undefined],
514
- };
515
- }
516
- case SCRIPT_TYPES.P2TR: {
517
- if (!ourPubKey)
518
- return { type };
519
- // HACK ourPubKey to BIP340-style
520
- if (ourPubKey.length === 33)
521
- ourPubKey = ourPubKey.slice(1);
522
- // TODO: support multiple pubkeys
523
- const p2tr = _1.p2trPayments.p2tr({ pubkey: ourPubKey, controlBlock }, { eccLib: noble_ecc_1.ecc });
524
- // Does tweaked output for a single pubkey match?
525
- if (!script.equals(p2tr.output))
526
- return { type };
527
- // P2TR KeyPath, single key
528
- return {
529
- type,
530
- pubkeys: [ourPubKey],
531
- signatures: [undefined],
532
- };
533
- }
534
- case SCRIPT_TYPES.P2TR_NS: {
535
- const p2trNs = _1.p2trPayments.p2tr_ns({ output: script }, { eccLib: noble_ecc_1.ecc });
536
- // P2TR ScriptPath
537
- return {
538
- type,
539
- pubkeys: p2trNs.pubkeys,
540
- signatures: p2trNs.pubkeys.map(() => undefined),
541
- maxSignatures: p2trNs.pubkeys.length,
542
- };
543
- }
544
- case SCRIPT_TYPES.P2PK: {
545
- const p2pk = _4.payments.p2pk({ output: script });
546
- return {
547
- type,
548
- pubkeys: [p2pk.pubkey],
549
- signatures: [undefined],
550
- };
551
- }
552
- case SCRIPT_TYPES.P2MS: {
553
- const p2ms = _4.payments.p2ms({ output: script });
554
- return {
555
- type,
556
- pubkeys: p2ms.pubkeys,
557
- signatures: p2ms.pubkeys.map(() => undefined),
558
- maxSignatures: p2ms.m,
559
- };
560
- }
561
- }
562
- return { type };
563
- }
564
- function prepareInput(input, ourPubKey, redeemScript, witnessScript, controlBlock, annex) {
565
- if (redeemScript && witnessScript) {
566
- const p2wsh = _4.payments.p2wsh({
567
- redeem: { output: witnessScript },
568
- });
569
- const p2wshAlt = _4.payments.p2wsh({ output: redeemScript });
570
- const p2sh = _4.payments.p2sh({ redeem: { output: redeemScript } });
571
- const p2shAlt = _4.payments.p2sh({ redeem: p2wsh });
572
- // enforces P2SH(P2WSH(...))
573
- if (!p2wsh.hash.equals(p2wshAlt.hash))
574
- throw new Error('Witness script inconsistent with prevOutScript');
575
- if (!p2sh.hash.equals(p2shAlt.hash))
576
- throw new Error('Redeem script inconsistent with prevOutScript');
577
- const expanded = expandOutput(p2wsh.redeem.output, ourPubKey);
578
- if (!expanded.pubkeys) {
579
- throw new Error(expanded.type + ' not supported as witnessScript (' + _5.script.toASM(witnessScript) + ')');
580
- }
581
- if (input.signatures && input.signatures.some((x) => x !== undefined)) {
582
- expanded.signatures = input.signatures;
583
- }
584
- const signScript = witnessScript;
585
- if (expanded.type === SCRIPT_TYPES.P2WPKH)
586
- throw new Error('P2SH(P2WSH(P2WPKH)) is a consensus failure');
587
- return {
588
- redeemScript,
589
- redeemScriptType: SCRIPT_TYPES.P2WSH,
590
- witnessScript,
591
- witnessScriptType: expanded.type,
592
- prevOutType: SCRIPT_TYPES.P2SH,
593
- prevOutScript: p2sh.output,
594
- witnessVersion: 0,
595
- signScript,
596
- signType: expanded.type,
597
- pubkeys: expanded.pubkeys,
598
- signatures: expanded.signatures,
599
- maxSignatures: expanded.maxSignatures,
600
- };
601
- }
602
- if (redeemScript) {
603
- const p2sh = _4.payments.p2sh({ redeem: { output: redeemScript } });
604
- if (input.prevOutScript) {
605
- let p2shAlt;
606
- try {
607
- p2shAlt = _4.payments.p2sh({ output: input.prevOutScript });
608
- }
609
- catch (e) {
610
- throw new Error('PrevOutScript must be P2SH');
611
- }
612
- if (!p2sh.hash.equals(p2shAlt.hash))
613
- throw new Error('Redeem script inconsistent with prevOutScript');
614
- }
615
- const expanded = expandOutput(p2sh.redeem.output, ourPubKey);
616
- if (!expanded.pubkeys) {
617
- throw new Error(expanded.type + ' not supported as redeemScript (' + _5.script.toASM(redeemScript) + ')');
618
- }
619
- if (input.signatures && input.signatures.some((x) => x !== undefined)) {
620
- expanded.signatures = input.signatures;
621
- }
622
- let signScript = redeemScript;
623
- if (expanded.type === SCRIPT_TYPES.P2WPKH) {
624
- signScript = _4.payments.p2pkh({ pubkey: expanded.pubkeys[0] }).output;
625
- }
626
- return {
627
- redeemScript,
628
- redeemScriptType: expanded.type,
629
- prevOutType: SCRIPT_TYPES.P2SH,
630
- prevOutScript: p2sh.output,
631
- witnessVersion: expanded.type === SCRIPT_TYPES.P2WPKH ? 0 : undefined,
632
- signScript,
633
- signType: expanded.type,
634
- pubkeys: expanded.pubkeys,
635
- signatures: expanded.signatures,
636
- maxSignatures: expanded.maxSignatures,
637
- };
638
- }
639
- if (witnessScript && controlBlock) {
640
- // P2TR ScriptPath
641
- /* tslint:disable-next-line:no-shadowed-variable */
642
- let prevOutScript = input.prevOutScript;
643
- if (!prevOutScript) {
644
- prevOutScript = _1.p2trPayments.p2tr({
645
- redeems: [{ output: witnessScript }],
646
- redeemIndex: 0,
647
- controlBlock,
648
- annex,
649
- }, { eccLib: noble_ecc_1.ecc }).output;
650
- }
651
- const expanded = expandOutput(witnessScript, ourPubKey);
652
- if (!expanded.pubkeys) {
653
- throw new Error(expanded.type + ' not supported as witnessScript (' + _5.script.toASM(witnessScript) + ')');
654
- }
655
- if (input.signatures && input.signatures.some((x) => x !== undefined)) {
656
- expanded.signatures = input.signatures;
657
- }
658
- return {
659
- witnessScript,
660
- witnessScriptType: expanded.type,
661
- prevOutType: SCRIPT_TYPES.P2TR,
662
- prevOutScript,
663
- witnessVersion: 1,
664
- signScript: witnessScript,
665
- signType: expanded.type,
666
- pubkeys: expanded.pubkeys,
667
- signatures: expanded.signatures,
668
- maxSignatures: expanded.maxSignatures,
669
- controlBlock,
670
- annex,
671
- };
672
- }
673
- if (witnessScript) {
674
- const p2wsh = _4.payments.p2wsh({ redeem: { output: witnessScript } });
675
- if (input.prevOutScript) {
676
- const p2wshAlt = _4.payments.p2wsh({ output: input.prevOutScript });
677
- if (!p2wsh.hash.equals(p2wshAlt.hash))
678
- throw new Error('Witness script inconsistent with prevOutScript');
679
- }
680
- const expanded = expandOutput(p2wsh.redeem.output, ourPubKey);
681
- if (!expanded.pubkeys) {
682
- throw new Error(expanded.type + ' not supported as witnessScript (' + _5.script.toASM(witnessScript) + ')');
683
- }
684
- if (input.signatures && input.signatures.some((x) => x !== undefined)) {
685
- expanded.signatures = input.signatures;
686
- }
687
- const signScript = witnessScript;
688
- if (expanded.type === SCRIPT_TYPES.P2WPKH)
689
- throw new Error('P2WSH(P2WPKH) is a consensus failure');
690
- return {
691
- witnessScript,
692
- witnessScriptType: expanded.type,
693
- prevOutType: SCRIPT_TYPES.P2WSH,
694
- prevOutScript: p2wsh.output,
695
- witnessVersion: 0,
696
- signScript,
697
- signType: expanded.type,
698
- pubkeys: expanded.pubkeys,
699
- signatures: expanded.signatures,
700
- maxSignatures: expanded.maxSignatures,
701
- };
702
- }
703
- if (input.prevOutType && input.prevOutScript) {
704
- // embedded scripts are not possible without extra information
705
- if (input.prevOutType === SCRIPT_TYPES.P2SH) {
706
- throw new Error('PrevOutScript is ' + input.prevOutType + ', requires redeemScript');
707
- }
708
- if (input.prevOutType === SCRIPT_TYPES.P2WSH) {
709
- throw new Error('PrevOutScript is ' + input.prevOutType + ', requires witnessScript');
710
- }
711
- const expanded = expandOutput(input.prevOutScript, ourPubKey);
712
- if (!expanded.pubkeys) {
713
- throw new Error(expanded.type + ' not supported (' + _5.script.toASM(input.prevOutScript) + ')');
714
- }
715
- if (input.signatures && input.signatures.some((x) => x !== undefined)) {
716
- expanded.signatures = input.signatures;
717
- }
718
- let signScript = input.prevOutScript;
719
- if (expanded.type === SCRIPT_TYPES.P2WPKH) {
720
- signScript = _4.payments.p2pkh({ pubkey: expanded.pubkeys[0] }).output;
721
- }
722
- let witnessVersion;
723
- if (expanded.type === SCRIPT_TYPES.P2WPKH) {
724
- witnessVersion = 0;
725
- }
726
- else if (expanded.type === SCRIPT_TYPES.P2TR) {
727
- witnessVersion = 1;
728
- }
729
- return {
730
- prevOutType: expanded.type,
731
- prevOutScript: input.prevOutScript,
732
- witnessVersion,
733
- signScript,
734
- signType: expanded.type,
735
- pubkeys: expanded.pubkeys,
736
- signatures: expanded.signatures,
737
- maxSignatures: expanded.maxSignatures,
738
- };
739
- }
740
- const prevOutScript = _4.payments.p2pkh({ pubkey: ourPubKey }).output;
741
- return {
742
- prevOutType: SCRIPT_TYPES.P2PKH,
743
- prevOutScript,
744
- signScript: prevOutScript,
745
- signType: SCRIPT_TYPES.P2PKH,
746
- pubkeys: [ourPubKey],
747
- signatures: [undefined],
748
- };
749
- }
750
- function build(type, input, allowIncomplete) {
751
- const pubkeys = (input.pubkeys || []);
752
- let signatures = (input.signatures || []);
753
- switch (type) {
754
- case SCRIPT_TYPES.P2PKH: {
755
- if (pubkeys.length === 0)
756
- break;
757
- if (signatures.length === 0)
758
- break;
759
- return _4.payments.p2pkh({ pubkey: pubkeys[0], signature: signatures[0] });
760
- }
761
- case SCRIPT_TYPES.P2WPKH: {
762
- if (pubkeys.length === 0)
763
- break;
764
- if (signatures.length === 0)
765
- break;
766
- return _4.payments.p2wpkh({ pubkey: pubkeys[0], signature: signatures[0] });
767
- }
768
- case SCRIPT_TYPES.P2PK: {
769
- if (pubkeys.length === 0)
770
- break;
771
- if (signatures.length === 0)
772
- break;
773
- return _4.payments.p2pk({ signature: signatures[0] });
774
- }
775
- case SCRIPT_TYPES.P2MS: {
776
- const m = input.maxSignatures;
777
- if (allowIncomplete) {
778
- signatures = signatures.map((x) => x || _6.opcodes.OP_0);
779
- }
780
- else {
781
- signatures = signatures.filter((x) => x);
782
- }
783
- // if the transaction is not not complete (complete), or if signatures.length === m, validate
784
- // otherwise, the number of OP_0's may be >= m, so don't validate (boo)
785
- const validate = !allowIncomplete || m === signatures.length;
786
- return _4.payments.p2ms({ m, pubkeys, signatures }, { allowIncomplete, validate });
787
- }
788
- case SCRIPT_TYPES.P2SH: {
789
- const redeem = build(input.redeemScriptType, input, allowIncomplete);
790
- if (!redeem)
791
- return;
792
- return _4.payments.p2sh({
793
- redeem: {
794
- output: redeem.output || input.redeemScript,
795
- input: redeem.input,
796
- witness: redeem.witness,
797
- },
798
- });
799
- }
800
- case SCRIPT_TYPES.P2WSH: {
801
- const redeem = build(input.witnessScriptType, input, allowIncomplete);
802
- if (!redeem)
803
- return;
804
- return _4.payments.p2wsh({
805
- redeem: {
806
- output: input.witnessScript,
807
- input: redeem.input,
808
- witness: redeem.witness,
809
- },
810
- });
811
- }
812
- case SCRIPT_TYPES.P2TR: {
813
- if (input.witnessScriptType === SCRIPT_TYPES.P2TR_NS) {
814
- // ScriptPath
815
- const redeem = build(input.witnessScriptType, input, allowIncomplete);
816
- return _1.p2trPayments.p2tr({
817
- output: input.prevOutScript,
818
- controlBlock: input.controlBlock,
819
- annex: input.annex,
820
- redeems: [redeem],
821
- redeemIndex: 0,
822
- }, { eccLib: noble_ecc_1.ecc });
823
- }
824
- // KeyPath
825
- if (signatures.length === 0)
826
- break;
827
- return _1.p2trPayments.p2tr({ pubkeys, signature: signatures[0] }, { eccLib: noble_ecc_1.ecc });
828
- }
829
- case SCRIPT_TYPES.P2TR_NS: {
830
- const m = input.maxSignatures;
831
- if (allowIncomplete) {
832
- signatures = signatures.map((x) => x || _6.opcodes.OP_0);
833
- }
834
- else {
835
- signatures = signatures.filter((x) => x);
836
- }
837
- // if the transaction is not not complete (complete), or if signatures.length === m, validate
838
- // otherwise, the number of OP_0's may be >= m, so don't validate (boo)
839
- const validate = !allowIncomplete || m === signatures.length;
840
- return _1.p2trPayments.p2tr_ns({ pubkeys, signatures }, { allowIncomplete, validate, eccLib: noble_ecc_1.ecc });
841
- }
842
- }
843
- }
844
- function canSign(input) {
845
- return (input.signScript !== undefined &&
846
- input.signType !== undefined &&
847
- input.pubkeys !== undefined &&
848
- input.signatures !== undefined &&
849
- input.signatures.length === input.pubkeys.length &&
850
- input.pubkeys.length > 0 &&
851
- (input.witnessVersion === undefined || input.value !== undefined));
852
- }
853
- function signatureHashType(buffer) {
854
- if (_5.script.isCanonicalSchnorrSignature(buffer) && buffer.length === 64) {
855
- return _8.Transaction.SIGHASH_DEFAULT;
856
- }
857
- return buffer.readUInt8(buffer.length - 1);
858
- }
859
- function checkSignArgs(inputs, signParams) {
860
- if (!PREVOUT_TYPES.has(signParams.prevOutScriptType)) {
861
- throw new TypeError(`Unknown prevOutScriptType "${signParams.prevOutScriptType}"`);
862
- }
863
- tfMessage(typeforce.Number, signParams.vin, `sign must include vin parameter as Number (input index)`);
864
- tfMessage(tfFullSigner, signParams.keyPair, `sign must include keyPair parameter as Signer interface`);
865
- tfMessage(typeforce.maybe(typeforce.Number), signParams.hashType, `sign hashType parameter must be a number`);
866
- const prevOutType = (inputs[signParams.vin] || []).prevOutType;
867
- const posType = signParams.prevOutScriptType;
868
- switch (posType) {
869
- case 'p2pkh':
870
- if (prevOutType && prevOutType !== 'pubkeyhash') {
871
- throw new TypeError(`input #${signParams.vin} is not of type p2pkh: ${prevOutType}`);
872
- }
873
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
874
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
875
- tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);
876
- break;
877
- case 'p2pk':
878
- if (prevOutType && prevOutType !== 'pubkey') {
879
- throw new TypeError(`input #${signParams.vin} is not of type p2pk: ${prevOutType}`);
880
- }
881
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
882
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
883
- tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);
884
- break;
885
- case 'p2wpkh':
886
- if (prevOutType && prevOutType !== 'witnesspubkeyhash') {
887
- throw new TypeError(`input #${signParams.vin} is not of type p2wpkh: ${prevOutType}`);
888
- }
889
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
890
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
891
- tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);
892
- break;
893
- case 'p2ms':
894
- if (prevOutType && prevOutType !== 'multisig') {
895
- throw new TypeError(`input #${signParams.vin} is not of type p2ms: ${prevOutType}`);
896
- }
897
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
898
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
899
- tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);
900
- break;
901
- case 'p2sh-p2wpkh':
902
- if (prevOutType && prevOutType !== 'scripthash') {
903
- throw new TypeError(`input #${signParams.vin} is not of type p2sh-p2wpkh: ${prevOutType}`);
904
- }
905
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
906
- tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires redeemScript`);
907
- tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);
908
- break;
909
- case 'p2sh-p2ms':
910
- case 'p2sh-p2pk':
911
- case 'p2sh-p2pkh':
912
- if (prevOutType && prevOutType !== 'scripthash') {
913
- throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);
914
- }
915
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
916
- tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires redeemScript`);
917
- tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);
918
- break;
919
- case 'p2wsh-p2ms':
920
- case 'p2wsh-p2pk':
921
- case 'p2wsh-p2pkh':
922
- if (prevOutType && prevOutType !== 'witnessscripthash') {
923
- throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);
924
- }
925
- tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);
926
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
927
- tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);
928
- break;
929
- case 'p2sh-p2wsh-p2ms':
930
- case 'p2sh-p2wsh-p2pk':
931
- case 'p2sh-p2wsh-p2pkh':
932
- if (prevOutType && prevOutType !== 'scripthash') {
933
- throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);
934
- }
935
- tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);
936
- tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires witnessScript`);
937
- tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessScript`);
938
- break;
939
- case 'p2tr':
940
- if (prevOutType && prevOutType !== 'taproot') {
941
- throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);
942
- }
943
- tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);
944
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
945
- tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);
946
- break;
947
- case 'p2tr-p2ns':
948
- if (prevOutType && prevOutType !== 'taproot') {
949
- throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);
950
- }
951
- inputs[signParams.vin].prevOutType = inputs[signParams.vin].prevOutType || 'taproot';
952
- tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);
953
- tfMessage(typeforce.Buffer, signParams.controlBlock, `${posType} requires controlBlock`);
954
- tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);
955
- break;
956
- }
957
- }
958
- function trySign({ input, ourPubKey, keyPair, signatureHash, hashType, useLowR, taptreeRoot, }) {
959
- if (input.witnessVersion === 1 && ourPubKey.length === 33)
960
- ourPubKey = ourPubKey.slice(1);
961
- // enforce in order signing of public keys
962
- let signed = false;
963
- for (const [i, pubKey] of input.pubkeys.entries()) {
964
- if (!ourPubKey.equals(pubKey))
965
- continue;
966
- if (input.signatures[i] && input.signatures[i].length > 0)
967
- throw new Error('Signature already exists');
968
- // TODO: add tests
969
- if (ourPubKey.length !== 33 && input.witnessVersion === 0) {
970
- throw new Error('BIP143 (Witness v0) inputs require compressed pubkeys');
971
- }
972
- else if (ourPubKey.length !== 32 && input.witnessVersion === 1) {
973
- throw new Error('BIP341 (Witness v1) inputs require x-only pubkeys');
974
- }
975
- if (input.witnessVersion === 1) {
976
- if (!input.witnessScript) {
977
- // FIXME: Workaround for not having proper tweaking support for key path
978
- if (!keyPair.privateKey) {
979
- throw new Error(`unexpected keypair`);
980
- }
981
- const privateKey = _7.taproot.tapTweakPrivkey(noble_ecc_1.ecc, ourPubKey, keyPair.privateKey, taptreeRoot);
982
- keyPair = noble_ecc_1.ECPair.fromPrivateKey(Buffer.from(privateKey));
983
- }
984
- // https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki#common-signature-message
985
- const signature = keyPair.signSchnorr(signatureHash);
986
- // SIGHASH_DEFAULT is omitted from the signature
987
- if (hashType === _8.Transaction.SIGHASH_DEFAULT) {
988
- input.signatures[i] = Buffer.from(signature);
989
- }
990
- else {
991
- input.signatures[i] = Buffer.concat([signature, Buffer.of(hashType)]);
992
- }
993
- }
994
- else {
995
- const signature = keyPair.sign(signatureHash, useLowR);
996
- input.signatures[i] = _5.script.signature.encode(signature, hashType);
997
- }
998
- signed = true;
999
- }
1000
- if (!signed)
1001
- throw new Error('Key pair cannot sign for this input');
1002
- }
1003
- function getSigningData(network, inputs, needsOutputs, tx, signParams, keyPair, redeemScript, hashType, witnessValue, witnessScript, controlBlock, annex, useLowR) {
1004
- let vin;
1005
- if (typeof signParams === 'number') {
1006
- console.warn('DEPRECATED: TransactionBuilder sign method arguments ' + 'will change in v6, please use the TxbSignArg interface');
1007
- vin = signParams;
1008
- }
1009
- else if (typeof signParams === 'object') {
1010
- checkSignArgs(inputs, signParams);
1011
- ({ vin, keyPair, redeemScript, hashType, witnessValue, witnessScript, controlBlock, annex } = signParams);
1012
- }
1013
- else {
1014
- throw new TypeError('TransactionBuilder sign first arg must be TxbSignArg or number');
1015
- }
1016
- if (keyPair === undefined) {
1017
- throw new Error('sign requires keypair');
1018
- }
1019
- if (!inputs[vin])
1020
- throw new Error('No input at index: ' + vin);
1021
- const input = inputs[vin];
1022
- // if redeemScript was previously provided, enforce consistency
1023
- if (input.redeemScript !== undefined && redeemScript && !input.redeemScript.equals(redeemScript)) {
1024
- throw new Error('Inconsistent redeemScript');
1025
- }
1026
- const ourPubKey = keyPair.publicKey || (keyPair.getPublicKey && keyPair.getPublicKey());
1027
- if (!canSign(input)) {
1028
- if (witnessValue !== undefined) {
1029
- if (input.value !== undefined && input.value !== witnessValue) {
1030
- throw new Error('Input did not match witnessValue');
1031
- }
1032
- typeforce(types.Satoshi, witnessValue);
1033
- input.value = witnessValue;
1034
- }
1035
- if (!canSign(input)) {
1036
- const prepared = prepareInput(input, ourPubKey, redeemScript, witnessScript, controlBlock, annex);
1037
- // updates inline
1038
- Object.assign(input, prepared);
1039
- }
1040
- if (!canSign(input))
1041
- throw Error(input.prevOutType + ' not supported');
1042
- }
1043
- // hashType can be 0 in Taproot, so can't use hashType || SIGHASH_ALL
1044
- if (input.witnessVersion === 1) {
1045
- hashType = hashType === undefined ? _8.Transaction.SIGHASH_DEFAULT : hashType;
1046
- }
1047
- else {
1048
- hashType = hashType || _8.Transaction.SIGHASH_ALL;
1049
- }
1050
- if (needsOutputs(hashType))
1051
- throw new Error('Transaction needs outputs');
1052
- // TODO: This is not the best place to do this, but might stick with it until PSBT
1053
- let leafHash;
1054
- let taptreeRoot;
1055
- if (controlBlock && witnessScript) {
1056
- leafHash = _7.taproot.getTapleafHash(noble_ecc_1.ecc, controlBlock, witnessScript);
1057
- taptreeRoot = _7.taproot.getTaptreeRoot(noble_ecc_1.ecc, controlBlock, witnessScript, leafHash);
1058
- }
1059
- // ready to sign
1060
- let signatureHash;
1061
- switch (input.witnessVersion) {
1062
- case undefined:
1063
- signatureHash = tx.hashForSignature(vin, input.signScript, hashType, input.value);
1064
- break;
1065
- case 0:
1066
- signatureHash = tx.hashForWitnessV0(vin, input.signScript, input.value, hashType);
1067
- break;
1068
- case 1:
1069
- signatureHash = tx.hashForWitnessV1(vin, inputs.map(({ prevOutScript }) => prevOutScript), inputs.map(({ value }) => value), hashType, leafHash);
1070
- break;
1071
- default:
1072
- throw new TypeError('Unsupported witness version');
1073
- }
1074
- return {
1075
- input,
1076
- ourPubKey,
1077
- keyPair,
1078
- signatureHash,
1079
- hashType,
1080
- useLowR: !!useLowR,
1081
- taptreeRoot,
1082
- };
1083
- }
1084
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction_builder.js","sourceRoot":"","sources":["../../src/transaction_builder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as types from 'bitcoinjs-lib/src/types';\nimport { address as baddress, p2trPayments } from './';\nimport * as bufferutils from 'bitcoinjs-lib/src/bufferutils';\nimport * as classify from './classify';\nimport { crypto as bcrypto } from './';\nimport { networks } from './';\nimport { Network } from './';\nimport { payments } from './';\nimport { Payment } from './';\nimport { script as bscript } from './';\nimport { opcodes as ops } from './';\nimport { taproot } from './';\nimport { TxOutput, Transaction } from './';\nimport { ECPair, ecc as eccLib } from './noble_ecc';\n\nexport interface Signer {\n  privateKey?: Buffer;\n  publicKey: Buffer;\n  getPublicKey?(): Buffer;\n  sign(hash: Buffer, lowR?: boolean): Buffer;\n  signSchnorr(hash: Buffer): Buffer;\n}\n\nconst typeforce = require('typeforce');\n\nconst tfFullSigner = (obj: any): boolean => {\n  return typeforce.Buffer(obj.publicKey) && typeof obj.sign === 'function' && typeof obj.signSchnorr === 'function';\n};\n\nconst SCRIPT_TYPES = classify.types;\n\nconst PREVOUT_TYPES: Set<string> = new Set([\n  // Raw\n  'p2pkh',\n  'p2pk',\n  'p2wpkh',\n  'p2ms',\n  // P2SH wrapped\n  'p2sh-p2pkh',\n  'p2sh-p2pk',\n  'p2sh-p2wpkh',\n  'p2sh-p2ms',\n  // P2WSH wrapped\n  'p2wsh-p2pkh',\n  'p2wsh-p2pk',\n  'p2wsh-p2ms',\n  // P2SH-P2WSH wrapper\n  'p2sh-p2wsh-p2pkh',\n  'p2sh-p2wsh-p2pk',\n  'p2sh-p2wsh-p2ms',\n  // P2TR KeyPath\n  'p2tr',\n  // P2TR ScriptPath\n  'p2tr-p2ns',\n]);\n\ntype MaybeBuffer = Buffer | undefined;\ntype TxbSignatures = Buffer[] | MaybeBuffer[];\ntype TxbPubkeys = MaybeBuffer[];\ntype TxbWitness = Buffer[];\ntype TxbScriptType = string;\ntype TxbScript = Buffer;\n\ninterface TxbInput<TNumber extends number | bigint = number> {\n  value?: TNumber;\n  witnessVersion?: number;\n  signScript?: TxbScript;\n  signType?: TxbScriptType;\n  prevOutScript?: TxbScript;\n  redeemScript?: TxbScript;\n  redeemScriptType?: TxbScriptType;\n  prevOutType?: TxbScriptType;\n  pubkeys?: TxbPubkeys;\n  signatures?: TxbSignatures;\n  witness?: TxbWitness;\n  witnessScript?: TxbScript;\n  witnessScriptType?: TxbScriptType;\n  controlBlock?: Buffer;\n  annex?: Buffer;\n  script?: TxbScript;\n  sequence?: number;\n  scriptSig?: TxbScript;\n  maxSignatures?: number;\n}\n\ninterface TxbOutput {\n  type: string;\n  pubkeys?: TxbPubkeys;\n  signatures?: TxbSignatures;\n  maxSignatures?: number;\n}\n\ninterface TxbSignArg<TNumber extends number | bigint = number> {\n  prevOutScriptType: string;\n  vin: number;\n  keyPair: Signer;\n  redeemScript?: Buffer;\n  hashType?: number;\n  witnessValue?: TNumber;\n  witnessScript?: Buffer;\n  controlBlock?: Buffer;\n  annex?: Buffer;\n}\n\nfunction tfMessage(type: any, value: any, message: string): void {\n  try {\n    typeforce(type, value);\n  } catch (err) {\n    throw new Error(message);\n  }\n}\n\nfunction txIsString<TNumber extends number | bigint = number>(\n  tx: Buffer | string | Transaction<TNumber>\n): tx is string {\n  return typeof tx === 'string' || tx instanceof String;\n}\n\nfunction txIsTransaction<TNumber extends number | bigint = number>(\n  tx: Buffer | string | Transaction<TNumber>\n): tx is Transaction<TNumber> {\n  return tx instanceof Transaction;\n}\n\nexport class TransactionBuilder<TNumber extends number | bigint = number> {\n  static fromTransaction<TNumber extends number | bigint = number>(\n    transaction: Transaction<TNumber>,\n    network?: Network,\n    prevOutputs?: TxOutput<TNumber>[]\n  ): TransactionBuilder<TNumber> {\n    const txb = new TransactionBuilder<TNumber>(network);\n\n    // Copy transaction fields\n    txb.setVersion(transaction.version);\n    txb.setLockTime(transaction.locktime);\n\n    // Copy outputs (done first to avoid signature invalidation)\n    transaction.outs.forEach((txOut) => {\n      txb.addOutput(txOut.script, (txOut as TxOutput<TNumber>).value);\n    });\n\n    // Copy inputs\n    transaction.ins.forEach((txIn) => {\n      txb.__addInputUnsafe(txIn.hash, txIn.index, {\n        sequence: txIn.sequence,\n        script: txIn.script,\n        witness: txIn.witness,\n      });\n    });\n\n    // fix some things not possible through the public API\n    txb.__INPUTS.forEach((input, i) => {\n      fixMultisigOrder<TNumber>(input, transaction, i, prevOutputs);\n    });\n\n    return txb;\n  }\n\n  private __PREV_TX_SET: { [index: string]: boolean };\n  private __INPUTS: Array<TxbInput<TNumber>>;\n  private __TX: Transaction<TNumber>;\n  private __USE_LOW_R: boolean;\n\n  // WARNING: maximumFeeRate is __NOT__ to be relied on,\n  //          it's just another potential safety mechanism (safety in-depth)\n  constructor(public network: Network = networks.bitcoin, public maximumFeeRate: number = 2500) {\n    this.__PREV_TX_SET = {};\n    this.__INPUTS = [];\n    this.__TX = new Transaction<TNumber>();\n    this.__TX.version = 2;\n    this.__USE_LOW_R = false;\n    console.warn(\n      'Deprecation Warning: TransactionBuilder will be removed in the future. ' +\n        '(v6.x.x or later) Please use the Psbt class instead. Examples of usage ' +\n        'are available in the transactions-psbt.js integration test file on our ' +\n        'Github. A high level explanation is available in the psbt.ts and psbt.js ' +\n        'files as well.'\n    );\n  }\n\n  setLowR(setting?: boolean): boolean {\n    typeforce(typeforce.maybe(typeforce.Boolean), setting);\n    if (setting === undefined) {\n      setting = true;\n    }\n    this.__USE_LOW_R = setting;\n    return setting;\n  }\n\n  setLockTime(locktime: number): void {\n    typeforce(types.UInt32, locktime);\n\n    // if any signatures exist, throw\n    if (\n      this.__INPUTS.some((input) => {\n        if (!input.signatures) return false;\n\n        return input.signatures.some((s) => s !== undefined);\n      })\n    ) {\n      throw new Error('No, this would invalidate signatures');\n    }\n\n    this.__TX.locktime = locktime;\n  }\n\n  setVersion(version: number): void {\n    typeforce(types.UInt32, version);\n\n    // XXX: this might eventually become more complex depending on what the versions represent\n    this.__TX.version = version;\n  }\n\n  addInput(\n    txHash: Buffer | string | Transaction<TNumber>,\n    vout: number,\n    sequence?: number,\n    prevOutScript?: Buffer,\n    value?: TNumber\n  ): number {\n    if (!this.__canModifyInputs()) {\n      throw new Error('No, this would invalidate signatures');\n    }\n\n    // is it a hex string?\n    if (txIsString(txHash)) {\n      // transaction hashs's are displayed in reverse order, un-reverse it\n      txHash = bufferutils.reverseBuffer(Buffer.from(txHash, 'hex'));\n\n      // is it a Transaction object?\n    } else if (txIsTransaction(txHash)) {\n      const txOut = txHash.outs[vout];\n      prevOutScript = txOut.script;\n      value = (txOut as TxOutput<TNumber>).value;\n\n      txHash = txHash.getHash(false) as Buffer;\n    }\n\n    return this.__addInputUnsafe(txHash, vout, {\n      sequence,\n      prevOutScript,\n      value,\n    });\n  }\n\n  addOutput(scriptPubKey: string | Buffer, value: TNumber): number {\n    if (!this.__canModifyOutputs()) {\n      throw new Error('No, this would invalidate signatures');\n    }\n\n    // Attempt to get a script if it's a base58 or bech32 address string\n    if (typeof scriptPubKey === 'string') {\n      scriptPubKey = baddress.toOutputScript(scriptPubKey, this.network);\n    }\n\n    return this.__TX.addOutput(scriptPubKey, value);\n  }\n\n  build(): Transaction<TNumber> {\n    return this.__build(false);\n  }\n\n  buildIncomplete(): Transaction<TNumber> {\n    return this.__build(true);\n  }\n\n  sign(\n    signParams: number | TxbSignArg<TNumber>,\n    keyPair?: Signer,\n    redeemScript?: Buffer,\n    hashType?: number,\n    witnessValue?: TNumber,\n    witnessScript?: Buffer,\n    controlBlock?: Buffer,\n    annex?: Buffer\n  ): void {\n    trySign<TNumber>(\n      getSigningData<TNumber>(\n        this.network,\n        this.__INPUTS,\n        this.__needsOutputs.bind(this),\n        this.__TX,\n        signParams,\n        keyPair,\n        redeemScript,\n        hashType,\n        witnessValue,\n        witnessScript,\n        controlBlock,\n        annex,\n        this.__USE_LOW_R\n      )\n    );\n  }\n\n  private __addInputUnsafe(txHash: Buffer, vout: number, options: TxbInput<TNumber>): number {\n    if (Transaction.isCoinbaseHash(txHash)) {\n      throw new Error('coinbase inputs not supported');\n    }\n\n    const prevTxOut = txHash.toString('hex') + ':' + vout;\n    if (this.__PREV_TX_SET[prevTxOut] !== undefined) throw new Error('Duplicate TxOut: ' + prevTxOut);\n\n    let input: TxbInput<TNumber> = {};\n\n    // derive what we can from the scriptSig\n    if (options.script !== undefined || options.witness !== undefined) {\n      input = expandInput<TNumber>(options.script, options.witness);\n    }\n\n    // if an input value was given, retain it\n    if (options.value !== undefined) {\n      input.value = options.value;\n    }\n\n    // derive what we can from the previous transactions output script\n    if (!input.prevOutScript && options.prevOutScript) {\n      let prevOutType;\n\n      if (!input.pubkeys && !input.signatures) {\n        const expanded = expandOutput(options.prevOutScript);\n        if (expanded.pubkeys) {\n          input.pubkeys = expanded.pubkeys;\n          input.signatures = expanded.signatures;\n        }\n\n        prevOutType = expanded.type;\n      }\n\n      input.prevOutScript = options.prevOutScript;\n      input.prevOutType = prevOutType || classify.output(options.prevOutScript);\n    }\n\n    const vin = this.__TX.addInput(txHash, vout, options.sequence, options.scriptSig);\n    this.__INPUTS[vin] = input;\n    this.__PREV_TX_SET[prevTxOut] = true;\n    return vin;\n  }\n\n  private __build(allowIncomplete?: boolean): Transaction<TNumber> {\n    if (!allowIncomplete) {\n      if (!this.__TX.ins.length) throw new Error('Transaction has no inputs');\n      if (!this.__TX.outs.length) throw new Error('Transaction has no outputs');\n    }\n\n    const tx = this.__TX.clone();\n\n    // create script signatures from inputs\n    this.__INPUTS.forEach((input, i) => {\n      if (!input.prevOutType && !allowIncomplete) throw new Error('Transaction is not complete');\n\n      const result = build<TNumber>(input.prevOutType!, input, allowIncomplete);\n      if (!result) {\n        if (!allowIncomplete && input.prevOutType === SCRIPT_TYPES.NONSTANDARD) throw new Error('Unknown input type');\n        if (!allowIncomplete) throw new Error('Not enough information');\n        return;\n      }\n\n      if (result.input) {\n        tx.setInputScript(i, result.input);\n      }\n      tx.setWitness(i, result.witness!);\n    });\n\n    if (!allowIncomplete) {\n      // do not rely on this, its merely a last resort\n      if (this.__overMaximumFees(tx.virtualSize())) {\n        throw new Error('Transaction has absurd fees');\n      }\n    }\n\n    return tx;\n  }\n\n  private __canModifyInputs(): boolean {\n    return this.__INPUTS.every((input) => {\n      if (!input.signatures) return true;\n\n      return input.signatures.every((signature) => {\n        if (!signature) return true;\n        const hashType = signatureHashType(signature);\n\n        // if SIGHASH_ANYONECANPAY is set, signatures would not\n        // be invalidated by more inputs\n        return (hashType & Transaction.SIGHASH_ANYONECANPAY) !== 0;\n      });\n    });\n  }\n\n  private __needsOutputs(signingHashType: number): boolean {\n    if (signingHashType === Transaction.SIGHASH_ALL || signingHashType === Transaction.SIGHASH_DEFAULT) {\n      return this.__TX.outs.length === 0;\n    }\n\n    // if inputs are being signed with SIGHASH_NONE, we don't strictly need outputs\n    // .build() will fail, but .buildIncomplete() is OK\n    return (\n      this.__TX.outs.length === 0 &&\n      this.__INPUTS.some((input) => {\n        if (!input.signatures) return false;\n\n        return input.signatures.some((signature) => {\n          if (!signature) return false; // no signature, no issue\n          const hashType = signatureHashType(signature);\n          if (hashType & Transaction.SIGHASH_NONE) return false; // SIGHASH_NONE doesn't care about outputs\n          return true; // SIGHASH_* does care\n        });\n      })\n    );\n  }\n\n  private __canModifyOutputs(): boolean {\n    const nInputs = this.__TX.ins.length;\n    const nOutputs = this.__TX.outs.length;\n\n    return this.__INPUTS.every((input) => {\n      if (input.signatures === undefined) return true;\n\n      return input.signatures.every((signature) => {\n        if (!signature) return true;\n        const hashType = signatureHashType(signature);\n\n        const hashTypeMod = hashType & 0x1f;\n        if (hashTypeMod === Transaction.SIGHASH_NONE) return true;\n        if (hashTypeMod === Transaction.SIGHASH_SINGLE) {\n          // if SIGHASH_SINGLE is set, and nInputs > nOutputs\n          // some signatures would be invalidated by the addition\n          // of more outputs\n          return nInputs <= nOutputs;\n        }\n        return false;\n      });\n    });\n  }\n\n  private __overMaximumFees(bytes: number): boolean {\n    // not all inputs will have .value defined\n    const incoming = this.__INPUTS.reduce(\n      (a, x) => a + (typeof x.value !== 'undefined' ? BigInt(x.value) : BigInt(0)),\n      BigInt(0)\n    );\n\n    // but all outputs do, and if we have any input value\n    // we can immediately determine if the outputs are too small\n    const outgoing = this.__TX.outs.reduce((a, x) => a + BigInt((x as TxOutput<TNumber>).value), BigInt(0));\n    const fee = incoming - outgoing;\n    const feeRate = Number(fee) / bytes; // assume fee fits within number\n\n    return feeRate > this.maximumFeeRate;\n  }\n}\n\nfunction expandInput<TNumber extends number | bigint = number>(\n  scriptSig?: Buffer,\n  witnessStack: Buffer[] = [],\n  type?: string,\n  scriptPubKey?: Buffer\n): TxbInput<TNumber> {\n  if (scriptSig && scriptSig.length === 0 && witnessStack.length === 0) return {};\n  if (!type) {\n    let ssType: string | undefined = scriptSig ? classify.input(scriptSig, true) : undefined;\n    let wsType: string | undefined = classify.witness(witnessStack, true);\n    if (ssType === SCRIPT_TYPES.NONSTANDARD) ssType = undefined;\n    if (wsType === SCRIPT_TYPES.NONSTANDARD) wsType = undefined;\n    type = ssType || wsType;\n  }\n\n  switch (type) {\n    case SCRIPT_TYPES.P2WPKH: {\n      const { output, pubkey, signature } = payments.p2wpkh({\n        witness: witnessStack,\n      });\n\n      return {\n        prevOutScript: output,\n        prevOutType: SCRIPT_TYPES.P2WPKH,\n        pubkeys: [pubkey],\n        signatures: [signature],\n      };\n    }\n\n    case SCRIPT_TYPES.P2PKH: {\n      const { output, pubkey, signature } = payments.p2pkh({\n        input: scriptSig,\n      });\n\n      return {\n        prevOutScript: output,\n        prevOutType: SCRIPT_TYPES.P2PKH,\n        pubkeys: [pubkey],\n        signatures: [signature],\n      };\n    }\n\n    case SCRIPT_TYPES.P2PK: {\n      const { signature } = payments.p2pk({ input: scriptSig });\n\n      return {\n        prevOutType: SCRIPT_TYPES.P2PK,\n        pubkeys: [undefined],\n        signatures: [signature],\n      };\n    }\n\n    case SCRIPT_TYPES.P2MS: {\n      const { m, pubkeys, signatures } = payments.p2ms(\n        {\n          input: scriptSig,\n          output: scriptPubKey,\n        },\n        { allowIncomplete: true }\n      );\n\n      return {\n        prevOutType: SCRIPT_TYPES.P2MS,\n        pubkeys,\n        signatures,\n        maxSignatures: m,\n      };\n    }\n\n    case SCRIPT_TYPES.P2TR_NS: {\n      const { n, pubkeys, signatures } = p2trPayments.p2tr_ns(\n        {\n          // Witness signatures are reverse of pubkeys, because it's a stack\n          signatures: witnessStack.length ? witnessStack.reverse() : undefined,\n          output: scriptPubKey,\n        },\n        { allowIncomplete: true, eccLib }\n      );\n\n      return {\n        prevOutType: SCRIPT_TYPES.P2TR_NS,\n        pubkeys,\n        signatures,\n        maxSignatures: n,\n      };\n    }\n  }\n\n  if (type === SCRIPT_TYPES.P2SH) {\n    const { output, redeem } = payments.p2sh({\n      input: scriptSig,\n      witness: witnessStack,\n    });\n\n    const outputType = classify.output(redeem!.output!);\n    const expanded = expandInput<TNumber>(redeem!.input!, redeem!.witness!, outputType, redeem!.output);\n    if (!expanded.prevOutType) return {};\n\n    return {\n      prevOutScript: output,\n      prevOutType: SCRIPT_TYPES.P2SH,\n      redeemScript: redeem!.output,\n      redeemScriptType: expanded.prevOutType,\n      witnessScript: expanded.witnessScript,\n      witnessScriptType: expanded.witnessScriptType,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n    };\n  }\n\n  if (type === SCRIPT_TYPES.P2WSH) {\n    const { output, redeem } = payments.p2wsh({\n      input: scriptSig,\n      witness: witnessStack,\n    });\n    const outputType = classify.output(redeem!.output!);\n    let expanded;\n    if (outputType === SCRIPT_TYPES.P2WPKH) {\n      expanded = expandInput<TNumber>(redeem!.input!, redeem!.witness!, outputType);\n    } else {\n      expanded = expandInput<TNumber>(bscript.compile(redeem!.witness!), [], outputType, redeem!.output);\n    }\n    if (!expanded.prevOutType) return {};\n\n    return {\n      prevOutScript: output,\n      prevOutType: SCRIPT_TYPES.P2WSH,\n      witnessScript: redeem!.output,\n      witnessScriptType: expanded.prevOutType,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n    };\n  }\n\n  if (type === SCRIPT_TYPES.P2TR) {\n    const parsedWitness = taproot.parseTaprootWitness(witnessStack);\n    if (parsedWitness.spendType === 'Key') {\n      // key path spend, nothing to expand\n      const { signature, annex } = parsedWitness;\n      return {\n        prevOutType: SCRIPT_TYPES.P2TR,\n        signatures: [signature],\n        annex,\n      };\n    } else {\n      // script path spend\n      const { tapscript, controlBlock, annex } = parsedWitness;\n      const prevOutScript = p2trPayments.p2tr(\n        {\n          redeems: [{ output: tapscript }],\n          redeemIndex: 0,\n          controlBlock,\n          annex,\n        },\n        { eccLib }\n      ).output;\n      const witnessScriptType = classify.output(tapscript);\n      const { pubkeys, signatures } = expandInput<TNumber>(\n        undefined,\n        parsedWitness.scriptSig,\n        witnessScriptType,\n        tapscript\n      );\n\n      return {\n        prevOutScript,\n        prevOutType: SCRIPT_TYPES.P2TR,\n        witnessScript: tapscript,\n        witnessScriptType,\n\n        controlBlock,\n        annex,\n\n        pubkeys,\n        signatures,\n      };\n    }\n  }\n\n  return {\n    prevOutType: SCRIPT_TYPES.NONSTANDARD,\n    prevOutScript: scriptSig,\n  };\n}\n\n// could be done in expandInput, but requires the original Transaction for hashForSignature\nfunction fixMultisigOrder<TNumber extends number | bigint = number>(\n  input: TxbInput<TNumber>,\n  transaction: Transaction<TNumber>,\n  vin: number,\n  prevOutputs?: TxOutput<TNumber>[]\n): void {\n  if (input.redeemScriptType !== SCRIPT_TYPES.P2MS || !input.redeemScript) return;\n  if (input.pubkeys!.length === input.signatures!.length) return;\n  const prevOutput = prevOutputs && prevOutputs[vin];\n\n  const unmatched = input.signatures!.concat();\n\n  input.signatures = input.pubkeys!.map((pubKey) => {\n    const keyPair = ECPair.fromPublicKey(pubKey!);\n    let match: Buffer | undefined;\n\n    // check for a signature\n    unmatched.some((signature, i) => {\n      // skip if undefined || OP_0\n      if (!signature) return false;\n\n      // TODO: avoid O(n) hashForSignature\n      const parsed = bscript.signature.decode(signature);\n      const hash = transaction.hashForSignature(vin, input.redeemScript!, parsed.hashType, prevOutput?.value);\n\n      // skip if signature does not match pubKey\n      if (!keyPair.verify(hash, parsed.signature)) return false;\n\n      // remove matched signature from unmatched\n      unmatched[i] = undefined;\n      match = signature;\n\n      return true;\n    });\n\n    return match;\n  });\n}\n\nfunction expandOutput(script: Buffer, ourPubKey?: Buffer, controlBlock?: Buffer): TxbOutput {\n  typeforce(types.Buffer, script);\n  const type = classify.output(script);\n\n  switch (type) {\n    case SCRIPT_TYPES.P2PKH: {\n      if (!ourPubKey) return { type };\n\n      // does our hash160(pubKey) match the output scripts?\n      const pkh1 = payments.p2pkh({ output: script }).hash;\n      const pkh2 = bcrypto.hash160(ourPubKey);\n      if (!pkh1!.equals(pkh2)) return { type };\n\n      return {\n        type,\n        pubkeys: [ourPubKey],\n        signatures: [undefined],\n      };\n    }\n\n    case SCRIPT_TYPES.P2WPKH: {\n      if (!ourPubKey) return { type };\n\n      // does our hash160(pubKey) match the output scripts?\n      const wpkh1 = payments.p2wpkh({ output: script }).hash;\n      const wpkh2 = bcrypto.hash160(ourPubKey);\n      if (!wpkh1!.equals(wpkh2)) return { type };\n\n      return {\n        type,\n        pubkeys: [ourPubKey],\n        signatures: [undefined],\n      };\n    }\n\n    case SCRIPT_TYPES.P2TR: {\n      if (!ourPubKey) return { type };\n      // HACK ourPubKey to BIP340-style\n      if (ourPubKey.length === 33) ourPubKey = ourPubKey.slice(1);\n      // TODO: support multiple pubkeys\n      const p2tr = p2trPayments.p2tr({ pubkey: ourPubKey, controlBlock }, { eccLib });\n\n      // Does tweaked output for a single pubkey match?\n      if (!script.equals(p2tr.output!)) return { type };\n\n      // P2TR KeyPath, single key\n      return {\n        type,\n        pubkeys: [ourPubKey],\n        signatures: [undefined],\n      };\n    }\n\n    case SCRIPT_TYPES.P2TR_NS: {\n      const p2trNs = p2trPayments.p2tr_ns({ output: script }, { eccLib });\n      // P2TR ScriptPath\n      return {\n        type,\n        pubkeys: p2trNs.pubkeys,\n        signatures: p2trNs.pubkeys!.map((): undefined => undefined),\n        maxSignatures: p2trNs.pubkeys!.length,\n      };\n    }\n\n    case SCRIPT_TYPES.P2PK: {\n      const p2pk = payments.p2pk({ output: script });\n      return {\n        type,\n        pubkeys: [p2pk.pubkey],\n        signatures: [undefined],\n      };\n    }\n\n    case SCRIPT_TYPES.P2MS: {\n      const p2ms = payments.p2ms({ output: script });\n      return {\n        type,\n        pubkeys: p2ms.pubkeys,\n        signatures: p2ms.pubkeys!.map((): undefined => undefined),\n        maxSignatures: p2ms.m,\n      };\n    }\n  }\n\n  return { type };\n}\n\nfunction prepareInput<TNumber extends number | bigint = number>(\n  input: TxbInput<TNumber>,\n  ourPubKey: Buffer,\n  redeemScript?: Buffer,\n  witnessScript?: Buffer,\n  controlBlock?: Buffer,\n  annex?: Buffer\n): TxbInput<TNumber> {\n  if (redeemScript && witnessScript) {\n    const p2wsh = payments.p2wsh({\n      redeem: { output: witnessScript },\n    }) as Payment;\n    const p2wshAlt = payments.p2wsh({ output: redeemScript }) as Payment;\n    const p2sh = payments.p2sh({ redeem: { output: redeemScript } }) as Payment;\n    const p2shAlt = payments.p2sh({ redeem: p2wsh }) as Payment;\n\n    // enforces P2SH(P2WSH(...))\n    if (!p2wsh.hash!.equals(p2wshAlt.hash!)) throw new Error('Witness script inconsistent with prevOutScript');\n    if (!p2sh.hash!.equals(p2shAlt.hash!)) throw new Error('Redeem script inconsistent with prevOutScript');\n\n    const expanded = expandOutput(p2wsh.redeem!.output!, ourPubKey);\n    if (!expanded.pubkeys) {\n      throw new Error(expanded.type + ' not supported as witnessScript (' + bscript.toASM(witnessScript) + ')');\n    }\n    if (input.signatures && input.signatures.some((x) => x !== undefined)) {\n      expanded.signatures = input.signatures;\n    }\n\n    const signScript = witnessScript;\n    if (expanded.type === SCRIPT_TYPES.P2WPKH) throw new Error('P2SH(P2WSH(P2WPKH)) is a consensus failure');\n\n    return {\n      redeemScript,\n      redeemScriptType: SCRIPT_TYPES.P2WSH,\n\n      witnessScript,\n      witnessScriptType: expanded.type,\n\n      prevOutType: SCRIPT_TYPES.P2SH,\n      prevOutScript: p2sh.output,\n\n      witnessVersion: 0,\n      signScript,\n      signType: expanded.type,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n      maxSignatures: expanded.maxSignatures,\n    };\n  }\n\n  if (redeemScript) {\n    const p2sh = payments.p2sh({ redeem: { output: redeemScript } }) as Payment;\n\n    if (input.prevOutScript) {\n      let p2shAlt;\n      try {\n        p2shAlt = payments.p2sh({ output: input.prevOutScript }) as Payment;\n      } catch (e) {\n        throw new Error('PrevOutScript must be P2SH');\n      }\n      if (!p2sh.hash!.equals(p2shAlt.hash!)) throw new Error('Redeem script inconsistent with prevOutScript');\n    }\n\n    const expanded = expandOutput(p2sh.redeem!.output!, ourPubKey);\n    if (!expanded.pubkeys) {\n      throw new Error(expanded.type + ' not supported as redeemScript (' + bscript.toASM(redeemScript) + ')');\n    }\n    if (input.signatures && input.signatures.some((x) => x !== undefined)) {\n      expanded.signatures = input.signatures;\n    }\n\n    let signScript = redeemScript;\n    if (expanded.type === SCRIPT_TYPES.P2WPKH) {\n      signScript = payments.p2pkh({ pubkey: expanded.pubkeys[0] }).output!;\n    }\n\n    return {\n      redeemScript,\n      redeemScriptType: expanded.type,\n\n      prevOutType: SCRIPT_TYPES.P2SH,\n      prevOutScript: p2sh.output,\n\n      witnessVersion: expanded.type === SCRIPT_TYPES.P2WPKH ? 0 : undefined,\n      signScript,\n      signType: expanded.type,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n      maxSignatures: expanded.maxSignatures,\n    };\n  }\n\n  if (witnessScript && controlBlock) {\n    // P2TR ScriptPath\n    /* tslint:disable-next-line:no-shadowed-variable */\n    let prevOutScript = input.prevOutScript;\n    if (!prevOutScript) {\n      prevOutScript = p2trPayments.p2tr(\n        {\n          redeems: [{ output: witnessScript }],\n          redeemIndex: 0,\n          controlBlock,\n          annex,\n        },\n        { eccLib }\n      ).output;\n    }\n\n    const expanded = expandOutput(witnessScript, ourPubKey);\n    if (!expanded.pubkeys) {\n      throw new Error(expanded.type + ' not supported as witnessScript (' + bscript.toASM(witnessScript) + ')');\n    }\n    if (input.signatures && input.signatures.some((x) => x !== undefined)) {\n      expanded.signatures = input.signatures;\n    }\n\n    return {\n      witnessScript,\n      witnessScriptType: expanded.type,\n\n      prevOutType: SCRIPT_TYPES.P2TR,\n      prevOutScript,\n\n      witnessVersion: 1,\n      signScript: witnessScript,\n      signType: expanded.type,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n      maxSignatures: expanded.maxSignatures,\n\n      controlBlock,\n      annex,\n    };\n  }\n\n  if (witnessScript) {\n    const p2wsh = payments.p2wsh({ redeem: { output: witnessScript } });\n\n    if (input.prevOutScript) {\n      const p2wshAlt = payments.p2wsh({ output: input.prevOutScript });\n      if (!p2wsh.hash!.equals(p2wshAlt.hash!)) throw new Error('Witness script inconsistent with prevOutScript');\n    }\n\n    const expanded = expandOutput(p2wsh.redeem!.output!, ourPubKey);\n    if (!expanded.pubkeys) {\n      throw new Error(expanded.type + ' not supported as witnessScript (' + bscript.toASM(witnessScript) + ')');\n    }\n    if (input.signatures && input.signatures.some((x) => x !== undefined)) {\n      expanded.signatures = input.signatures;\n    }\n\n    const signScript = witnessScript;\n    if (expanded.type === SCRIPT_TYPES.P2WPKH) throw new Error('P2WSH(P2WPKH) is a consensus failure');\n\n    return {\n      witnessScript,\n      witnessScriptType: expanded.type,\n\n      prevOutType: SCRIPT_TYPES.P2WSH,\n      prevOutScript: p2wsh.output,\n\n      witnessVersion: 0,\n      signScript,\n      signType: expanded.type,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n      maxSignatures: expanded.maxSignatures,\n    };\n  }\n\n  if (input.prevOutType && input.prevOutScript) {\n    // embedded scripts are not possible without extra information\n    if (input.prevOutType === SCRIPT_TYPES.P2SH) {\n      throw new Error('PrevOutScript is ' + input.prevOutType + ', requires redeemScript');\n    }\n    if (input.prevOutType === SCRIPT_TYPES.P2WSH) {\n      throw new Error('PrevOutScript is ' + input.prevOutType + ', requires witnessScript');\n    }\n\n    const expanded = expandOutput(input.prevOutScript, ourPubKey);\n    if (!expanded.pubkeys) {\n      throw new Error(expanded.type + ' not supported (' + bscript.toASM(input.prevOutScript) + ')');\n    }\n    if (input.signatures && input.signatures.some((x) => x !== undefined)) {\n      expanded.signatures = input.signatures;\n    }\n\n    let signScript = input.prevOutScript;\n    if (expanded.type === SCRIPT_TYPES.P2WPKH) {\n      signScript = payments.p2pkh({ pubkey: expanded.pubkeys[0] }).output as Buffer;\n    }\n\n    let witnessVersion;\n    if (expanded.type === SCRIPT_TYPES.P2WPKH) {\n      witnessVersion = 0;\n    } else if (expanded.type === SCRIPT_TYPES.P2TR) {\n      witnessVersion = 1;\n    }\n\n    return {\n      prevOutType: expanded.type,\n      prevOutScript: input.prevOutScript,\n\n      witnessVersion,\n      signScript,\n      signType: expanded.type,\n\n      pubkeys: expanded.pubkeys,\n      signatures: expanded.signatures,\n      maxSignatures: expanded.maxSignatures,\n    };\n  }\n\n  const prevOutScript = payments.p2pkh({ pubkey: ourPubKey }).output;\n  return {\n    prevOutType: SCRIPT_TYPES.P2PKH,\n    prevOutScript,\n\n    signScript: prevOutScript,\n    signType: SCRIPT_TYPES.P2PKH,\n\n    pubkeys: [ourPubKey],\n    signatures: [undefined],\n  };\n}\n\nfunction build<TNumber extends number | bigint = number>(\n  type: string,\n  input: TxbInput<TNumber>,\n  allowIncomplete?: boolean\n): Payment | undefined {\n  const pubkeys = (input.pubkeys || []) as Buffer[];\n  let signatures = (input.signatures || []) as Buffer[];\n\n  switch (type) {\n    case SCRIPT_TYPES.P2PKH: {\n      if (pubkeys.length === 0) break;\n      if (signatures.length === 0) break;\n\n      return payments.p2pkh({ pubkey: pubkeys[0], signature: signatures[0] });\n    }\n    case SCRIPT_TYPES.P2WPKH: {\n      if (pubkeys.length === 0) break;\n      if (signatures.length === 0) break;\n\n      return payments.p2wpkh({ pubkey: pubkeys[0], signature: signatures[0] });\n    }\n    case SCRIPT_TYPES.P2PK: {\n      if (pubkeys.length === 0) break;\n      if (signatures.length === 0) break;\n\n      return payments.p2pk({ signature: signatures[0] });\n    }\n    case SCRIPT_TYPES.P2MS: {\n      const m = input.maxSignatures;\n      if (allowIncomplete) {\n        signatures = signatures.map((x) => x || ops.OP_0);\n      } else {\n        signatures = signatures.filter((x) => x);\n      }\n\n      // if the transaction is not not complete (complete), or if signatures.length === m, validate\n      // otherwise, the number of OP_0's may be >= m, so don't validate (boo)\n      const validate = !allowIncomplete || m === signatures.length;\n      return payments.p2ms({ m, pubkeys, signatures }, { allowIncomplete, validate });\n    }\n    case SCRIPT_TYPES.P2SH: {\n      const redeem = build<TNumber>(input.redeemScriptType!, input, allowIncomplete);\n      if (!redeem) return;\n\n      return payments.p2sh({\n        redeem: {\n          output: redeem.output || input.redeemScript,\n          input: redeem.input,\n          witness: redeem.witness,\n        },\n      });\n    }\n    case SCRIPT_TYPES.P2WSH: {\n      const redeem = build<TNumber>(input.witnessScriptType!, input, allowIncomplete);\n      if (!redeem) return;\n\n      return payments.p2wsh({\n        redeem: {\n          output: input.witnessScript,\n          input: redeem.input,\n          witness: redeem.witness,\n        },\n      });\n    }\n    case SCRIPT_TYPES.P2TR: {\n      if (input.witnessScriptType === SCRIPT_TYPES.P2TR_NS) {\n        // ScriptPath\n        const redeem = build<TNumber>(input.witnessScriptType!, input, allowIncomplete);\n        return p2trPayments.p2tr(\n          {\n            output: input.prevOutScript,\n            controlBlock: input.controlBlock,\n            annex: input.annex,\n            redeems: [redeem!],\n            redeemIndex: 0,\n          },\n          { eccLib }\n        );\n      }\n\n      // KeyPath\n      if (signatures.length === 0) break;\n\n      return p2trPayments.p2tr({ pubkeys, signature: signatures[0] }, { eccLib });\n    }\n    case SCRIPT_TYPES.P2TR_NS: {\n      const m = input.maxSignatures;\n      if (allowIncomplete) {\n        signatures = signatures.map((x) => x || ops.OP_0);\n      } else {\n        signatures = signatures.filter((x) => x);\n      }\n\n      // if the transaction is not not complete (complete), or if signatures.length === m, validate\n      // otherwise, the number of OP_0's may be >= m, so don't validate (boo)\n      const validate = !allowIncomplete || m === signatures.length;\n      return p2trPayments.p2tr_ns({ pubkeys, signatures }, { allowIncomplete, validate, eccLib });\n    }\n  }\n}\n\nfunction canSign<TNumber extends number | bigint = number>(input: TxbInput<TNumber>): boolean {\n  return (\n    input.signScript !== undefined &&\n    input.signType !== undefined &&\n    input.pubkeys !== undefined &&\n    input.signatures !== undefined &&\n    input.signatures.length === input.pubkeys.length &&\n    input.pubkeys.length > 0 &&\n    (input.witnessVersion === undefined || input.value !== undefined)\n  );\n}\n\nfunction signatureHashType(buffer: Buffer): number {\n  if (bscript.isCanonicalSchnorrSignature(buffer) && buffer.length === 64) {\n    return Transaction.SIGHASH_DEFAULT;\n  }\n  return buffer.readUInt8(buffer.length - 1);\n}\n\nfunction checkSignArgs<TNumber extends number | bigint = number>(\n  inputs: Array<TxbInput<TNumber>>,\n  signParams: TxbSignArg<TNumber>\n): void {\n  if (!PREVOUT_TYPES.has(signParams.prevOutScriptType)) {\n    throw new TypeError(`Unknown prevOutScriptType \"${signParams.prevOutScriptType}\"`);\n  }\n  tfMessage(typeforce.Number, signParams.vin, `sign must include vin parameter as Number (input index)`);\n  tfMessage(tfFullSigner, signParams.keyPair, `sign must include keyPair parameter as Signer interface`);\n  tfMessage(typeforce.maybe(typeforce.Number), signParams.hashType, `sign hashType parameter must be a number`);\n  const prevOutType = (inputs[signParams.vin] || []).prevOutType;\n  const posType = signParams.prevOutScriptType;\n  switch (posType) {\n    case 'p2pkh':\n      if (prevOutType && prevOutType !== 'pubkeyhash') {\n        throw new TypeError(`input #${signParams.vin} is not of type p2pkh: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);\n      break;\n    case 'p2pk':\n      if (prevOutType && prevOutType !== 'pubkey') {\n        throw new TypeError(`input #${signParams.vin} is not of type p2pk: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);\n      break;\n    case 'p2wpkh':\n      if (prevOutType && prevOutType !== 'witnesspubkeyhash') {\n        throw new TypeError(`input #${signParams.vin} is not of type p2wpkh: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);\n      break;\n    case 'p2ms':\n      if (prevOutType && prevOutType !== 'multisig') {\n        throw new TypeError(`input #${signParams.vin} is not of type p2ms: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);\n      break;\n    case 'p2sh-p2wpkh':\n      if (prevOutType && prevOutType !== 'scripthash') {\n        throw new TypeError(`input #${signParams.vin} is not of type p2sh-p2wpkh: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires redeemScript`);\n      tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);\n      break;\n    case 'p2sh-p2ms':\n    case 'p2sh-p2pk':\n    case 'p2sh-p2pkh':\n      if (prevOutType && prevOutType !== 'scripthash') {\n        throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires redeemScript`);\n      tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);\n      break;\n    case 'p2wsh-p2ms':\n    case 'p2wsh-p2pk':\n    case 'p2wsh-p2pkh':\n      if (prevOutType && prevOutType !== 'witnessscripthash') {\n        throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);\n      }\n      tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessValue`);\n      break;\n    case 'p2sh-p2wsh-p2ms':\n    case 'p2sh-p2wsh-p2pk':\n    case 'p2sh-p2wsh-p2pkh':\n      if (prevOutType && prevOutType !== 'scripthash') {\n        throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);\n      }\n      tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);\n      tfMessage(typeforce.Buffer, signParams.redeemScript, `${posType} requires witnessScript`);\n      tfMessage(types.Satoshi, signParams.witnessValue, `${posType} requires witnessScript`);\n      break;\n    case 'p2tr':\n      if (prevOutType && prevOutType !== 'taproot') {\n        throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);\n      }\n      tfMessage(typeforce.value(undefined), signParams.witnessScript, `${posType} requires NO witnessScript`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      tfMessage(typeforce.value(undefined), signParams.witnessValue, `${posType} requires NO witnessValue`);\n      break;\n    case 'p2tr-p2ns':\n      if (prevOutType && prevOutType !== 'taproot') {\n        throw new TypeError(`input #${signParams.vin} is not of type ${posType}: ${prevOutType}`);\n      }\n      inputs[signParams.vin].prevOutType = inputs[signParams.vin].prevOutType || 'taproot';\n      tfMessage(typeforce.Buffer, signParams.witnessScript, `${posType} requires witnessScript`);\n      tfMessage(typeforce.Buffer, signParams.controlBlock, `${posType} requires controlBlock`);\n      tfMessage(typeforce.value(undefined), signParams.redeemScript, `${posType} requires NO redeemScript`);\n      break;\n  }\n}\n\nfunction trySign<TNumber extends number | bigint = number>({\n  input,\n  ourPubKey,\n  keyPair,\n  signatureHash,\n  hashType,\n  useLowR,\n  taptreeRoot,\n}: SigningData<TNumber>): void {\n  if (input.witnessVersion === 1 && ourPubKey.length === 33) ourPubKey = ourPubKey.slice(1);\n  // enforce in order signing of public keys\n  let signed = false;\n  for (const [i, pubKey] of input.pubkeys!.entries()) {\n    if (!ourPubKey.equals(pubKey!)) continue;\n    if (input.signatures![i] && input.signatures![i]!.length > 0) throw new Error('Signature already exists');\n\n    // TODO: add tests\n    if (ourPubKey.length !== 33 && input.witnessVersion === 0) {\n      throw new Error('BIP143 (Witness v0) inputs require compressed pubkeys');\n    } else if (ourPubKey.length !== 32 && input.witnessVersion === 1) {\n      throw new Error('BIP341 (Witness v1) inputs require x-only pubkeys');\n    }\n\n    if (input.witnessVersion === 1) {\n      if (!input.witnessScript) {\n        // FIXME: Workaround for not having proper tweaking support for key path\n        if (!keyPair.privateKey) {\n          throw new Error(`unexpected keypair`);\n        }\n        const privateKey = taproot.tapTweakPrivkey(eccLib, ourPubKey, keyPair.privateKey, taptreeRoot);\n        keyPair = ECPair.fromPrivateKey(Buffer.from(privateKey));\n      }\n      // https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki#common-signature-message\n      const signature = keyPair.signSchnorr(signatureHash);\n      // SIGHASH_DEFAULT is omitted from the signature\n      if (hashType === Transaction.SIGHASH_DEFAULT) {\n        input.signatures![i] = Buffer.from(signature);\n      } else {\n        input.signatures![i] = Buffer.concat([signature, Buffer.of(hashType)]);\n      }\n    } else {\n      const signature = keyPair.sign(signatureHash, useLowR);\n      input.signatures![i] = bscript.signature.encode(signature, hashType);\n    }\n    signed = true;\n  }\n\n  if (!signed) throw new Error('Key pair cannot sign for this input');\n}\n\ninterface SigningData<TNumber extends number | bigint = number> {\n  input: TxbInput<TNumber>;\n  ourPubKey: Buffer;\n  keyPair: Signer;\n  signatureHash: Buffer;\n  hashType: number;\n  useLowR: boolean;\n  taptreeRoot?: Buffer;\n}\n\ntype HashTypeCheck = (hashType: number) => boolean;\n\nfunction getSigningData<TNumber extends number | bigint = number>(\n  network: Network,\n  inputs: Array<TxbInput<TNumber>>,\n  needsOutputs: HashTypeCheck,\n  tx: Transaction<TNumber>,\n  signParams: number | TxbSignArg<TNumber>,\n  keyPair?: Signer,\n  redeemScript?: Buffer,\n  hashType?: number,\n  witnessValue?: TNumber,\n  witnessScript?: Buffer,\n  controlBlock?: Buffer,\n  annex?: Buffer,\n  useLowR?: boolean\n): SigningData<TNumber> {\n  let vin: number;\n  if (typeof signParams === 'number') {\n    console.warn(\n      'DEPRECATED: TransactionBuilder sign method arguments ' + 'will change in v6, please use the TxbSignArg interface'\n    );\n    vin = signParams;\n  } else if (typeof signParams === 'object') {\n    checkSignArgs<TNumber>(inputs, signParams);\n    ({ vin, keyPair, redeemScript, hashType, witnessValue, witnessScript, controlBlock, annex } = signParams);\n  } else {\n    throw new TypeError('TransactionBuilder sign first arg must be TxbSignArg or number');\n  }\n  if (keyPair === undefined) {\n    throw new Error('sign requires keypair');\n  }\n  if (!inputs[vin]) throw new Error('No input at index: ' + vin);\n\n  const input = inputs[vin];\n\n  // if redeemScript was previously provided, enforce consistency\n  if (input.redeemScript !== undefined && redeemScript && !input.redeemScript.equals(redeemScript)) {\n    throw new Error('Inconsistent redeemScript');\n  }\n\n  const ourPubKey = keyPair.publicKey || (keyPair.getPublicKey && keyPair.getPublicKey());\n  if (!canSign<TNumber>(input)) {\n    if (witnessValue !== undefined) {\n      if (input.value !== undefined && input.value !== witnessValue) {\n        throw new Error('Input did not match witnessValue');\n      }\n      typeforce(types.Satoshi, witnessValue);\n      input.value = witnessValue;\n    }\n\n    if (!canSign<TNumber>(input)) {\n      const prepared = prepareInput<TNumber>(input, ourPubKey, redeemScript, witnessScript, controlBlock, annex);\n\n      // updates inline\n      Object.assign(input, prepared);\n    }\n\n    if (!canSign<TNumber>(input)) throw Error(input.prevOutType + ' not supported');\n  }\n\n  // hashType can be 0 in Taproot, so can't use hashType || SIGHASH_ALL\n  if (input.witnessVersion === 1) {\n    hashType = hashType === undefined ? Transaction.SIGHASH_DEFAULT : hashType;\n  } else {\n    hashType = hashType || Transaction.SIGHASH_ALL;\n  }\n  if (needsOutputs(hashType)) throw new Error('Transaction needs outputs');\n\n  // TODO: This is not the best place to do this, but might stick with it until PSBT\n  let leafHash;\n  let taptreeRoot;\n  if (controlBlock && witnessScript) {\n    leafHash = taproot.getTapleafHash(eccLib, controlBlock, witnessScript);\n    taptreeRoot = taproot.getTaptreeRoot(eccLib, controlBlock, witnessScript, leafHash);\n  }\n\n  // ready to sign\n  let signatureHash: Buffer;\n  switch (input.witnessVersion) {\n    case undefined:\n      signatureHash = tx.hashForSignature(vin, input.signScript as Buffer, hashType, input.value);\n      break;\n    case 0:\n      signatureHash = tx.hashForWitnessV0(vin, input.signScript as Buffer, input.value as TNumber, hashType);\n      break;\n    case 1:\n      signatureHash = tx.hashForWitnessV1(\n        vin,\n        inputs.map(({ prevOutScript }) => prevOutScript as Buffer),\n        inputs.map(({ value }) => value as TNumber),\n        hashType,\n        leafHash\n      );\n      break;\n    default:\n      throw new TypeError('Unsupported witness version');\n  }\n\n  return {\n    input,\n    ourPubKey,\n    keyPair,\n    signatureHash,\n    hashType,\n    useLowR: !!useLowR,\n    taptreeRoot,\n  };\n}\n"]}