utxo-lib 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (249) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +59 -0
  3. package/dist/src/address.d.ts +11 -0
  4. package/dist/src/address.d.ts.map +1 -0
  5. package/dist/src/address.js +37 -0
  6. package/dist/src/addressFormat.d.ts +53 -0
  7. package/dist/src/addressFormat.d.ts.map +1 -0
  8. package/dist/src/addressFormat.js +110 -0
  9. package/dist/src/bitgo/Musig2.d.ts +51 -0
  10. package/dist/src/bitgo/Musig2.d.ts.map +1 -0
  11. package/dist/src/bitgo/Musig2.js +175 -0
  12. package/dist/src/bitgo/Unspent.d.ts +95 -0
  13. package/dist/src/bitgo/Unspent.d.ts.map +1 -0
  14. package/dist/src/bitgo/Unspent.js +138 -0
  15. package/dist/src/bitgo/UtxoPsbt.d.ts +132 -0
  16. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -0
  17. package/dist/src/bitgo/UtxoPsbt.js +469 -0
  18. package/dist/src/bitgo/UtxoTransaction.d.ts +22 -0
  19. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -0
  20. package/dist/src/bitgo/UtxoTransaction.js +97 -0
  21. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +26 -0
  22. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -0
  23. package/dist/src/bitgo/UtxoTransactionBuilder.js +67 -0
  24. package/dist/src/bitgo/bbc/DashPsbt.d.ts +12 -0
  25. package/dist/src/bitgo/bbc/DashPsbt.d.ts.map +1 -0
  26. package/dist/src/bitgo/bbc/DashPsbt.js +27 -0
  27. package/dist/src/bitgo/bbc/DashTransaction.d.ts +39 -0
  28. package/dist/src/bitgo/bbc/DashTransaction.d.ts.map +1 -0
  29. package/dist/src/bitgo/bbc/DashTransaction.js +109 -0
  30. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts +14 -0
  31. package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts.map +1 -0
  32. package/dist/src/bitgo/bbc/DashTransactionBuilder.js +28 -0
  33. package/dist/src/bitgo/bbc/index.d.ts +4 -0
  34. package/dist/src/bitgo/bbc/index.d.ts.map +1 -0
  35. package/dist/src/bitgo/bbc/index.js +16 -0
  36. package/dist/src/bitgo/bitcoincash/address.d.ts +35 -0
  37. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -0
  38. package/dist/src/bitgo/bitcoincash/address.js +151 -0
  39. package/dist/src/bitgo/bitcoincash/index.d.ts +2 -0
  40. package/dist/src/bitgo/bitcoincash/index.d.ts.map +1 -0
  41. package/dist/src/bitgo/bitcoincash/index.js +14 -0
  42. package/dist/src/bitgo/dash/DashPsbt.d.ts +12 -0
  43. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -0
  44. package/dist/src/bitgo/dash/DashPsbt.js +27 -0
  45. package/dist/src/bitgo/dash/DashTransaction.d.ts +39 -0
  46. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -0
  47. package/dist/src/bitgo/dash/DashTransaction.js +109 -0
  48. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +14 -0
  49. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -0
  50. package/dist/src/bitgo/dash/DashTransactionBuilder.js +28 -0
  51. package/dist/src/bitgo/dash/index.d.ts +4 -0
  52. package/dist/src/bitgo/dash/index.d.ts.map +1 -0
  53. package/dist/src/bitgo/dash/index.js +16 -0
  54. package/dist/src/bitgo/index.d.ts +17 -0
  55. package/dist/src/bitgo/index.d.ts.map +1 -0
  56. package/dist/src/bitgo/index.js +30 -0
  57. package/dist/src/bitgo/keyutil.d.ts +17 -0
  58. package/dist/src/bitgo/keyutil.d.ts.map +1 -0
  59. package/dist/src/bitgo/keyutil.js +37 -0
  60. package/dist/src/bitgo/nonStandardHalfSigned.d.ts +7 -0
  61. package/dist/src/bitgo/nonStandardHalfSigned.d.ts.map +1 -0
  62. package/dist/src/bitgo/nonStandardHalfSigned.js +56 -0
  63. package/dist/src/bitgo/outputScripts.d.ts +84 -0
  64. package/dist/src/bitgo/outputScripts.d.ts.map +1 -0
  65. package/dist/src/bitgo/outputScripts.js +297 -0
  66. package/dist/src/bitgo/parseInput.d.ts +92 -0
  67. package/dist/src/bitgo/parseInput.d.ts.map +1 -0
  68. package/dist/src/bitgo/parseInput.js +344 -0
  69. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +24 -0
  70. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -0
  71. package/dist/src/bitgo/psbt/fromHalfSigned.js +91 -0
  72. package/dist/src/bitgo/psbt/scriptTypes.d.ts +6 -0
  73. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -0
  74. package/dist/src/bitgo/psbt/scriptTypes.js +23 -0
  75. package/dist/src/bitgo/signature.d.ts +84 -0
  76. package/dist/src/bitgo/signature.d.ts.map +1 -0
  77. package/dist/src/bitgo/signature.js +222 -0
  78. package/dist/src/bitgo/tnumber.d.ts +9 -0
  79. package/dist/src/bitgo/tnumber.d.ts.map +1 -0
  80. package/dist/src/bitgo/tnumber.js +31 -0
  81. package/dist/src/bitgo/transaction.d.ts +29 -0
  82. package/dist/src/bitgo/transaction.d.ts.map +1 -0
  83. package/dist/src/bitgo/transaction.js +247 -0
  84. package/dist/src/bitgo/types.d.ts +5 -0
  85. package/dist/src/bitgo/types.d.ts.map +1 -0
  86. package/dist/src/bitgo/types.js +12 -0
  87. package/dist/src/bitgo/wallet/Psbt.d.ts +47 -0
  88. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -0
  89. package/dist/src/bitgo/wallet/Psbt.js +232 -0
  90. package/dist/src/bitgo/wallet/Unspent.d.ts +47 -0
  91. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -0
  92. package/dist/src/bitgo/wallet/Unspent.js +154 -0
  93. package/dist/src/bitgo/wallet/WalletKeys.d.ts +72 -0
  94. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -0
  95. package/dist/src/bitgo/wallet/WalletKeys.js +104 -0
  96. package/dist/src/bitgo/wallet/WalletOutput.d.ts +18 -0
  97. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -0
  98. package/dist/src/bitgo/wallet/WalletOutput.js +69 -0
  99. package/dist/src/bitgo/wallet/WalletScripts.d.ts +7 -0
  100. package/dist/src/bitgo/wallet/WalletScripts.d.ts.map +1 -0
  101. package/dist/src/bitgo/wallet/WalletScripts.js +15 -0
  102. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts +19 -0
  103. package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts.map +1 -0
  104. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +47 -0
  105. package/dist/src/bitgo/wallet/chains.d.ts +57 -0
  106. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -0
  107. package/dist/src/bitgo/wallet/chains.js +106 -0
  108. package/dist/src/bitgo/wallet/index.d.ts +8 -0
  109. package/dist/src/bitgo/wallet/index.d.ts.map +1 -0
  110. package/dist/src/bitgo/wallet/index.js +20 -0
  111. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +26 -0
  112. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -0
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.js +157 -0
  114. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +36 -0
  115. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -0
  116. package/dist/src/bitgo/zcash/ZcashPsbt.js +146 -0
  117. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +61 -0
  118. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -0
  119. package/dist/src/bitgo/zcash/ZcashTransaction.js +341 -0
  120. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +21 -0
  121. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -0
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +105 -0
  123. package/dist/src/bitgo/zcash/address.d.ts +8 -0
  124. package/dist/src/bitgo/zcash/address.d.ts.map +1 -0
  125. package/dist/src/bitgo/zcash/address.js +57 -0
  126. package/dist/src/bitgo/zcash/hashZip0244.d.ts +27 -0
  127. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -0
  128. package/dist/src/bitgo/zcash/hashZip0244.js +184 -0
  129. package/dist/src/bitgo/zcash/index.d.ts +4 -0
  130. package/dist/src/bitgo/zcash/index.d.ts.map +1 -0
  131. package/dist/src/bitgo/zcash/index.js +16 -0
  132. package/dist/src/classify.d.ts +19 -0
  133. package/dist/src/classify.d.ts.map +1 -0
  134. package/dist/src/classify.js +89 -0
  135. package/dist/src/index.d.ts +13 -0
  136. package/dist/src/index.d.ts.map +1 -0
  137. package/dist/src/index.js +36 -0
  138. package/dist/src/networks.d.ts +119 -0
  139. package/dist/src/networks.d.ts.map +1 -0
  140. package/dist/src/networks.js +477 -0
  141. package/dist/src/noble_ecc.d.ts +28 -0
  142. package/dist/src/noble_ecc.d.ts.map +1 -0
  143. package/dist/src/noble_ecc.js +168 -0
  144. package/dist/src/payments/index.d.ts +4 -0
  145. package/dist/src/payments/index.d.ts.map +1 -0
  146. package/dist/src/payments/index.js +8 -0
  147. package/dist/src/payments/p2tr.d.ts +3 -0
  148. package/dist/src/payments/p2tr.d.ts.map +1 -0
  149. package/dist/src/payments/p2tr.js +348 -0
  150. package/dist/src/payments/p2tr_ns.d.ts +3 -0
  151. package/dist/src/payments/p2tr_ns.d.ts.map +1 -0
  152. package/dist/src/payments/p2tr_ns.js +134 -0
  153. package/dist/src/taproot.d.ts +141 -0
  154. package/dist/src/taproot.d.ts.map +1 -0
  155. package/dist/src/taproot.js +384 -0
  156. package/dist/src/templates/multisig/index.d.ts +4 -0
  157. package/dist/src/templates/multisig/index.d.ts.map +1 -0
  158. package/dist/src/templates/multisig/index.js +8 -0
  159. package/dist/src/templates/multisig/input.d.ts +7 -0
  160. package/dist/src/templates/multisig/input.d.ts.map +1 -0
  161. package/dist/src/templates/multisig/input.js +25 -0
  162. package/dist/src/templates/multisig/output.d.ts +7 -0
  163. package/dist/src/templates/multisig/output.d.ts.map +1 -0
  164. package/dist/src/templates/multisig/output.js +38 -0
  165. package/dist/src/templates/nulldata.d.ts +10 -0
  166. package/dist/src/templates/nulldata.d.ts.map +1 -0
  167. package/dist/src/templates/nulldata.js +17 -0
  168. package/dist/src/templates/pubkey/index.d.ts +4 -0
  169. package/dist/src/templates/pubkey/index.d.ts.map +1 -0
  170. package/dist/src/templates/pubkey/index.js +8 -0
  171. package/dist/src/templates/pubkey/input.d.ts +7 -0
  172. package/dist/src/templates/pubkey/input.d.ts.map +1 -0
  173. package/dist/src/templates/pubkey/input.js +14 -0
  174. package/dist/src/templates/pubkey/output.d.ts +7 -0
  175. package/dist/src/templates/pubkey/output.d.ts.map +1 -0
  176. package/dist/src/templates/pubkey/output.js +15 -0
  177. package/dist/src/templates/pubkeyhash/index.d.ts +4 -0
  178. package/dist/src/templates/pubkeyhash/index.d.ts.map +1 -0
  179. package/dist/src/templates/pubkeyhash/index.js +8 -0
  180. package/dist/src/templates/pubkeyhash/input.d.ts +7 -0
  181. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -0
  182. package/dist/src/templates/pubkeyhash/input.js +16 -0
  183. package/dist/src/templates/pubkeyhash/output.d.ts +6 -0
  184. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -0
  185. package/dist/src/templates/pubkeyhash/output.js +20 -0
  186. package/dist/src/templates/scripthash/index.d.ts +4 -0
  187. package/dist/src/templates/scripthash/index.d.ts.map +1 -0
  188. package/dist/src/templates/scripthash/index.js +8 -0
  189. package/dist/src/templates/scripthash/input.d.ts +6 -0
  190. package/dist/src/templates/scripthash/input.d.ts.map +1 -0
  191. package/dist/src/templates/scripthash/input.js +43 -0
  192. package/dist/src/templates/scripthash/output.d.ts +6 -0
  193. package/dist/src/templates/scripthash/output.d.ts.map +1 -0
  194. package/dist/src/templates/scripthash/output.js +15 -0
  195. package/dist/src/templates/taproot/index.d.ts +4 -0
  196. package/dist/src/templates/taproot/index.d.ts.map +1 -0
  197. package/dist/src/templates/taproot/index.js +8 -0
  198. package/dist/src/templates/taproot/input.d.ts +6 -0
  199. package/dist/src/templates/taproot/input.d.ts.map +1 -0
  200. package/dist/src/templates/taproot/input.js +23 -0
  201. package/dist/src/templates/taproot/output.d.ts +6 -0
  202. package/dist/src/templates/taproot/output.d.ts.map +1 -0
  203. package/dist/src/templates/taproot/output.js +15 -0
  204. package/dist/src/templates/taprootnofn/index.d.ts +4 -0
  205. package/dist/src/templates/taprootnofn/index.d.ts.map +1 -0
  206. package/dist/src/templates/taprootnofn/index.js +8 -0
  207. package/dist/src/templates/taprootnofn/input.d.ts +7 -0
  208. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -0
  209. package/dist/src/templates/taprootnofn/input.js +24 -0
  210. package/dist/src/templates/taprootnofn/output.d.ts +7 -0
  211. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -0
  212. package/dist/src/templates/taprootnofn/output.js +28 -0
  213. package/dist/src/templates/witnesscommitment/index.d.ts +3 -0
  214. package/dist/src/templates/witnesscommitment/index.d.ts.map +1 -0
  215. package/dist/src/templates/witnesscommitment/index.js +6 -0
  216. package/dist/src/templates/witnesscommitment/output.d.ts +8 -0
  217. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -0
  218. package/dist/src/templates/witnesscommitment/output.js +31 -0
  219. package/dist/src/templates/witnesspubkeyhash/index.d.ts +4 -0
  220. package/dist/src/templates/witnesspubkeyhash/index.d.ts.map +1 -0
  221. package/dist/src/templates/witnesspubkeyhash/index.js +8 -0
  222. package/dist/src/templates/witnesspubkeyhash/input.d.ts +7 -0
  223. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -0
  224. package/dist/src/templates/witnesspubkeyhash/input.js +19 -0
  225. package/dist/src/templates/witnesspubkeyhash/output.d.ts +6 -0
  226. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -0
  227. package/dist/src/templates/witnesspubkeyhash/output.js +15 -0
  228. package/dist/src/templates/witnessscripthash/index.d.ts +4 -0
  229. package/dist/src/templates/witnessscripthash/index.d.ts.map +1 -0
  230. package/dist/src/templates/witnessscripthash/index.js +8 -0
  231. package/dist/src/templates/witnessscripthash/input.d.ts +6 -0
  232. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -0
  233. package/dist/src/templates/witnessscripthash/input.js +35 -0
  234. package/dist/src/templates/witnessscripthash/output.d.ts +6 -0
  235. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -0
  236. package/dist/src/templates/witnessscripthash/output.js +15 -0
  237. package/dist/src/testutil/index.d.ts +3 -0
  238. package/dist/src/testutil/index.d.ts.map +1 -0
  239. package/dist/src/testutil/index.js +15 -0
  240. package/dist/src/testutil/keys.d.ts +10 -0
  241. package/dist/src/testutil/keys.d.ts.map +1 -0
  242. package/dist/src/testutil/keys.js +40 -0
  243. package/dist/src/testutil/mock.d.ts +21 -0
  244. package/dist/src/testutil/mock.d.ts.map +1 -0
  245. package/dist/src/testutil/mock.js +86 -0
  246. package/dist/src/transaction_builder.d.ts +47 -0
  247. package/dist/src/transaction_builder.d.ts.map +1 -0
  248. package/dist/src/transaction_builder.js +1084 -0
  249. package/package.json +87 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nonStandardHalfSigned.d.ts","sourceRoot":"","sources":["../../../src/bitgo/nonStandardHalfSigned.ts"],"names":[],"mappings":"AAEA,OAAO,EAA+B,OAAO,EAAE,MAAM,KAAK,CAAC;AAE3D;;;GAGG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,GAAG,IAAI,CAgD3E"}
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.padInputScript = void 0;
4
+ const assert = require("assert");
5
+ const opcodes = require("bitcoin-ops");
6
+ const __1 = require("../");
7
+ /**
8
+ * @param input - Input of non-standard half-signed transaction created with `tx.build()` instead of `tx.buildIncomplete()`.
9
+ * @param signatureIndex - Position to map the existing signatures to. Other signatures will be padded with OP_0.
10
+ */
11
+ function padInputScript(input, signatureIndex) {
12
+ if (![0, 1, 2].includes(signatureIndex)) {
13
+ /* istanbul ignore next */
14
+ throw new Error(`invalid signature index: must be one of [0, 1, 2]`);
15
+ }
16
+ let decompiledSigScript;
17
+ if (input.witness && input.witness.length > 0) {
18
+ decompiledSigScript = input.witness;
19
+ }
20
+ else {
21
+ decompiledSigScript = __1.script.decompile(input.script);
22
+ }
23
+ // The shape of a non-standard half-signed input is
24
+ // OP_0 <signature> <p2ms>
25
+ if (!decompiledSigScript || decompiledSigScript.length !== 3) {
26
+ /* istanbul ignore next */
27
+ return;
28
+ }
29
+ const [op0, signatureBuffer, sigScript] = decompiledSigScript;
30
+ if (op0 !== opcodes.OP_0 && !(Buffer.isBuffer(op0) && op0.length === 0)) {
31
+ /* istanbul ignore next */
32
+ return;
33
+ }
34
+ if (!Buffer.isBuffer(sigScript)) {
35
+ /* istanbul ignore next */
36
+ return;
37
+ }
38
+ if (__1.classify.output(sigScript) !== __1.classify.types.P2MS) {
39
+ /* istanbul ignore next */
40
+ return;
41
+ }
42
+ const paddedSigScript = [
43
+ op0,
44
+ ...[0, 1, 2].map((i) => (i === signatureIndex ? signatureBuffer : Buffer.from([]))),
45
+ sigScript,
46
+ ];
47
+ if (input.witness.length) {
48
+ paddedSigScript.forEach((b) => assert(Buffer.isBuffer(b)));
49
+ input.witness = paddedSigScript;
50
+ }
51
+ else {
52
+ input.script = __1.script.compile(paddedSigScript);
53
+ }
54
+ }
55
+ exports.padInputScript = padInputScript;
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9uU3RhbmRhcmRIYWxmU2lnbmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL25vblN0YW5kYXJkSGFsZlNpZ25lZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLDJCQUEyRDtBQUUzRDs7O0dBR0c7QUFDSCxTQUFnQixjQUFjLENBQUMsS0FBYyxFQUFFLGNBQXNCO0lBQ25FLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxFQUFFO1FBQ3ZDLDBCQUEwQjtRQUMxQixNQUFNLElBQUksS0FBSyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7S0FDdEU7SUFFRCxJQUFJLG1CQUFtQixDQUFDO0lBQ3hCLElBQUksS0FBSyxDQUFDLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDN0MsbUJBQW1CLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQztLQUNyQztTQUFNO1FBQ0wsbUJBQW1CLEdBQUcsVUFBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7S0FDdkQ7SUFFRCxtREFBbUQ7SUFDbkQsNEJBQTRCO0lBQzVCLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxtQkFBbUIsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQzVELDBCQUEwQjtRQUMxQixPQUFPO0tBQ1I7SUFFRCxNQUFNLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxTQUFTLENBQUMsR0FBRyxtQkFBbUIsQ0FBQztJQUM5RCxJQUFJLEdBQUcsS0FBSyxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLEVBQUU7UUFDdkUsMEJBQTBCO1FBQzFCLE9BQU87S0FDUjtJQUVELElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQy9CLDBCQUEwQjtRQUMxQixPQUFPO0tBQ1I7SUFFRCxJQUFJLFlBQVEsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLEtBQUssWUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUU7UUFDdEQsMEJBQTBCO1FBQzFCLE9BQU87S0FDUjtJQUVELE1BQU0sZUFBZSxHQUFHO1FBQ3RCLEdBQUc7UUFDSCxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLGNBQWMsQ0FBQyxDQUFDLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbkYsU0FBUztLQUNWLENBQUM7SUFFRixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFO1FBQ3hCLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMzRCxLQUFLLENBQUMsT0FBTyxHQUFHLGVBQTJCLENBQUM7S0FDN0M7U0FBTTtRQUNMLEtBQUssQ0FBQyxNQUFNLEdBQUcsVUFBTyxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQztLQUNqRDtBQUNILENBQUM7QUFoREQsd0NBZ0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgKiBhcyBvcGNvZGVzIGZyb20gJ2JpdGNvaW4tb3BzJztcbmltcG9ydCB7IGNsYXNzaWZ5LCBzY3JpcHQgYXMgYnNjcmlwdCwgVHhJbnB1dCB9IGZyb20gJy4uLyc7XG5cbi8qKlxuICogQHBhcmFtIGlucHV0IC0gSW5wdXQgb2Ygbm9uLXN0YW5kYXJkIGhhbGYtc2lnbmVkIHRyYW5zYWN0aW9uIGNyZWF0ZWQgd2l0aCBgdHguYnVpbGQoKWAgaW5zdGVhZCBvZiBgdHguYnVpbGRJbmNvbXBsZXRlKClgLlxuICogQHBhcmFtIHNpZ25hdHVyZUluZGV4IC0gUG9zaXRpb24gdG8gbWFwIHRoZSBleGlzdGluZyBzaWduYXR1cmVzIHRvLiBPdGhlciBzaWduYXR1cmVzIHdpbGwgYmUgcGFkZGVkIHdpdGggT1BfMC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHBhZElucHV0U2NyaXB0KGlucHV0OiBUeElucHV0LCBzaWduYXR1cmVJbmRleDogbnVtYmVyKTogdm9pZCB7XG4gIGlmICghWzAsIDEsIDJdLmluY2x1ZGVzKHNpZ25hdHVyZUluZGV4KSkge1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIHNpZ25hdHVyZSBpbmRleDogbXVzdCBiZSBvbmUgb2YgWzAsIDEsIDJdYCk7XG4gIH1cblxuICBsZXQgZGVjb21waWxlZFNpZ1NjcmlwdDtcbiAgaWYgKGlucHV0LndpdG5lc3MgJiYgaW5wdXQud2l0bmVzcy5sZW5ndGggPiAwKSB7XG4gICAgZGVjb21waWxlZFNpZ1NjcmlwdCA9IGlucHV0LndpdG5lc3M7XG4gIH0gZWxzZSB7XG4gICAgZGVjb21waWxlZFNpZ1NjcmlwdCA9IGJzY3JpcHQuZGVjb21waWxlKGlucHV0LnNjcmlwdCk7XG4gIH1cblxuICAvLyBUaGUgc2hhcGUgb2YgYSBub24tc3RhbmRhcmQgaGFsZi1zaWduZWQgaW5wdXQgaXNcbiAgLy8gICBPUF8wIDxzaWduYXR1cmU+IDxwMm1zPlxuICBpZiAoIWRlY29tcGlsZWRTaWdTY3JpcHQgfHwgZGVjb21waWxlZFNpZ1NjcmlwdC5sZW5ndGggIT09IDMpIHtcbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IFtvcDAsIHNpZ25hdHVyZUJ1ZmZlciwgc2lnU2NyaXB0XSA9IGRlY29tcGlsZWRTaWdTY3JpcHQ7XG4gIGlmIChvcDAgIT09IG9wY29kZXMuT1BfMCAmJiAhKEJ1ZmZlci5pc0J1ZmZlcihvcDApICYmIG9wMC5sZW5ndGggPT09IDApKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoIUJ1ZmZlci5pc0J1ZmZlcihzaWdTY3JpcHQpKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoY2xhc3NpZnkub3V0cHV0KHNpZ1NjcmlwdCkgIT09IGNsYXNzaWZ5LnR5cGVzLlAyTVMpIHtcbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHBhZGRlZFNpZ1NjcmlwdCA9IFtcbiAgICBvcDAsXG4gICAgLi4uWzAsIDEsIDJdLm1hcCgoaSkgPT4gKGkgPT09IHNpZ25hdHVyZUluZGV4ID8gc2lnbmF0dXJlQnVmZmVyIDogQnVmZmVyLmZyb20oW10pKSksXG4gICAgc2lnU2NyaXB0LFxuICBdO1xuXG4gIGlmIChpbnB1dC53aXRuZXNzLmxlbmd0aCkge1xuICAgIHBhZGRlZFNpZ1NjcmlwdC5mb3JFYWNoKChiKSA9PiBhc3NlcnQoQnVmZmVyLmlzQnVmZmVyKGIpKSk7XG4gICAgaW5wdXQud2l0bmVzcyA9IHBhZGRlZFNpZ1NjcmlwdCBhcyBCdWZmZXJbXTtcbiAgfSBlbHNlIHtcbiAgICBpbnB1dC5zY3JpcHQgPSBic2NyaXB0LmNvbXBpbGUocGFkZGVkU2lnU2NyaXB0KTtcbiAgfVxufVxuIl19
@@ -0,0 +1,84 @@
1
+ /// <reference types="node" />
2
+ import * as bitcoinjs from 'bitcoinjs-lib';
3
+ import { Network } from '..';
4
+ import { Triple, Tuple } from './types';
5
+ export { scriptTypeForChain } from './wallet/chains';
6
+ export declare const scriptTypeP2shP2pk = "p2shP2pk";
7
+ export declare type ScriptTypeP2shP2pk = typeof scriptTypeP2shP2pk;
8
+ export declare const scriptTypes2Of3: readonly ["p2sh", "p2shP2wsh", "p2wsh", "p2tr", "p2trMusig2"];
9
+ export declare type ScriptType2Of3 = typeof scriptTypes2Of3[number];
10
+ export declare function isScriptType2Of3(t: string): t is ScriptType2Of3;
11
+ export declare type ScriptType = ScriptTypeP2shP2pk | ScriptType2Of3;
12
+ /**
13
+ * @return true iff scriptType requires witness data
14
+ */
15
+ export declare function hasWitnessData(scriptType: ScriptType): scriptType is 'p2shP2wsh' | 'p2wsh' | 'p2tr' | 'p2trMusig2';
16
+ /**
17
+ * @param network
18
+ * @param scriptType
19
+ * @return true iff script type is supported for network
20
+ */
21
+ export declare function isSupportedScriptType(network: Network, scriptType: ScriptType): boolean;
22
+ /**
23
+ * @param t
24
+ * @return string prevOut as defined in PREVOUT_TYPES (bitcoinjs-lib/.../transaction_builder.js)
25
+ */
26
+ export declare function scriptType2Of3AsPrevOutType(t: ScriptType2Of3): string;
27
+ export declare type SpendableScript = {
28
+ scriptPubKey: Buffer;
29
+ redeemScript?: Buffer;
30
+ witnessScript?: Buffer;
31
+ };
32
+ export declare type SpendScriptP2tr = {
33
+ controlBlock: Buffer;
34
+ witnessScript: Buffer;
35
+ leafVersion: number;
36
+ leafHash: Buffer;
37
+ };
38
+ /**
39
+ * Tweak data holder for P2tr Musig2 key path.
40
+ */
41
+ export declare type KeyPathP2trMusig2 = {
42
+ internalPubkey: Buffer;
43
+ outputPubkey: Buffer;
44
+ taptreeRoot: Buffer;
45
+ };
46
+ /**
47
+ * Return scripts for p2sh-p2pk (used for BCH/BSV replay protection)
48
+ * @param pubkey
49
+ */
50
+ export declare function createOutputScriptP2shP2pk(pubkey: Buffer): SpendableScript;
51
+ /**
52
+ * Return scripts for 2-of-3 multisig output
53
+ * @param pubkeys - the key triple for multisig
54
+ * @param scriptType
55
+ * @param network - if set, performs sanity check for scriptType support
56
+ * @returns {{redeemScript, witnessScript, scriptPubKey}}
57
+ */
58
+ export declare function createOutputScript2of3(pubkeys: Buffer[], scriptType: ScriptType2Of3, network?: Network): SpendableScript;
59
+ export declare function toXOnlyPublicKey(b: Buffer): Buffer;
60
+ /**
61
+ * Validates size of the pub key for 32 bytes and returns the same iff true.
62
+ */
63
+ export declare function checkXOnlyPublicKey(b: Buffer): Buffer;
64
+ /**
65
+ * Validates size of the pub key for 32 bytes and returns the same iff true.
66
+ */
67
+ export declare function checkPlainPublicKey(b: Buffer): Buffer;
68
+ export declare function createPaymentP2tr(pubkeys: Triple<Buffer>, redeemIndex?: number | {
69
+ signer: Buffer;
70
+ cosigner: Buffer;
71
+ }): bitcoinjs.Payment;
72
+ export declare function createPaymentP2trMusig2(pubkeys: Triple<Buffer>, redeemIndex?: number | {
73
+ signer: Buffer;
74
+ cosigner: Buffer;
75
+ }): bitcoinjs.Payment;
76
+ export declare function getLeafHash(params: bitcoinjs.Payment | {
77
+ publicKeys: Triple<Buffer>;
78
+ signer: Buffer;
79
+ cosigner: Buffer;
80
+ }): Buffer;
81
+ export declare function createKeyPathP2trMusig2(pubkeys: Triple<Buffer>): KeyPathP2trMusig2;
82
+ export declare function createSpendScriptP2tr(pubkeys: Triple<Buffer>, keyCombination: Tuple<Buffer>): SpendScriptP2tr;
83
+ export declare function createSpendScriptP2trMusig2(pubkeys: Triple<Buffer>, keyCombination: Tuple<Buffer>): SpendScriptP2tr;
84
+ //# sourceMappingURL=outputScripts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"outputScripts.d.ts","sourceRoot":"","sources":["../../../src/bitgo/outputScripts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,297 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createSpendScriptP2trMusig2 = exports.createSpendScriptP2tr = exports.createKeyPathP2trMusig2 = exports.getLeafHash = exports.createPaymentP2trMusig2 = exports.createPaymentP2tr = exports.checkPlainPublicKey = exports.checkXOnlyPublicKey = exports.toXOnlyPublicKey = exports.createOutputScript2of3 = exports.createOutputScriptP2shP2pk = exports.scriptType2Of3AsPrevOutType = exports.isSupportedScriptType = exports.hasWitnessData = exports.isScriptType2Of3 = exports.scriptTypes2Of3 = exports.scriptTypeP2shP2pk = exports.scriptTypeForChain = void 0;
4
+ const assert = require("assert");
5
+ const bitcoinjs = require("bitcoinjs-lib");
6
+ const __1 = require("..");
7
+ const types_1 = require("./types");
8
+ const noble_ecc_1 = require("../noble_ecc");
9
+ const taproot_1 = require("../taproot");
10
+ var chains_1 = require("./wallet/chains");
11
+ Object.defineProperty(exports, "scriptTypeForChain", { enumerable: true, get: function () { return chains_1.scriptTypeForChain; } });
12
+ exports.scriptTypeP2shP2pk = 'p2shP2pk';
13
+ exports.scriptTypes2Of3 = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2'];
14
+ function isScriptType2Of3(t) {
15
+ return exports.scriptTypes2Of3.includes(t);
16
+ }
17
+ exports.isScriptType2Of3 = isScriptType2Of3;
18
+ /**
19
+ * @return true iff scriptType requires witness data
20
+ */
21
+ function hasWitnessData(scriptType) {
22
+ return ['p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2'].includes(scriptType);
23
+ }
24
+ exports.hasWitnessData = hasWitnessData;
25
+ /**
26
+ * @param network
27
+ * @param scriptType
28
+ * @return true iff script type is supported for network
29
+ */
30
+ function isSupportedScriptType(network, scriptType) {
31
+ switch (scriptType) {
32
+ case 'p2sh':
33
+ case 'p2shP2pk':
34
+ return true;
35
+ case 'p2shP2wsh':
36
+ case 'p2wsh':
37
+ return __1.supportsSegwit(network);
38
+ case 'p2tr':
39
+ case 'p2trMusig2':
40
+ return __1.supportsTaproot(network);
41
+ }
42
+ /* istanbul ignore next */
43
+ throw new Error(`unexpected script type ${scriptType}`);
44
+ }
45
+ exports.isSupportedScriptType = isSupportedScriptType;
46
+ /**
47
+ * @param t
48
+ * @return string prevOut as defined in PREVOUT_TYPES (bitcoinjs-lib/.../transaction_builder.js)
49
+ */
50
+ function scriptType2Of3AsPrevOutType(t) {
51
+ switch (t) {
52
+ case 'p2sh':
53
+ return 'p2sh-p2ms';
54
+ case 'p2shP2wsh':
55
+ return 'p2sh-p2wsh-p2ms';
56
+ case 'p2wsh':
57
+ return 'p2wsh-p2ms';
58
+ case 'p2tr':
59
+ return 'p2tr-p2ns';
60
+ case 'p2trMusig2':
61
+ return 'p2tr';
62
+ }
63
+ /* istanbul ignore next */
64
+ throw new Error(`unsupported script type ${t}`);
65
+ }
66
+ exports.scriptType2Of3AsPrevOutType = scriptType2Of3AsPrevOutType;
67
+ /**
68
+ * Return scripts for p2sh-p2pk (used for BCH/BSV replay protection)
69
+ * @param pubkey
70
+ */
71
+ function createOutputScriptP2shP2pk(pubkey) {
72
+ const p2pk = bitcoinjs.payments.p2pk({ pubkey });
73
+ const p2sh = bitcoinjs.payments.p2sh({ redeem: p2pk });
74
+ if (!p2sh.output || !p2pk.output) {
75
+ throw new Error(`invalid state`);
76
+ }
77
+ return {
78
+ scriptPubKey: p2sh.output,
79
+ redeemScript: p2pk.output,
80
+ };
81
+ }
82
+ exports.createOutputScriptP2shP2pk = createOutputScriptP2shP2pk;
83
+ /**
84
+ * Return scripts for 2-of-3 multisig output
85
+ * @param pubkeys - the key triple for multisig
86
+ * @param scriptType
87
+ * @param network - if set, performs sanity check for scriptType support
88
+ * @returns {{redeemScript, witnessScript, scriptPubKey}}
89
+ */
90
+ function createOutputScript2of3(pubkeys, scriptType, network) {
91
+ if (network) {
92
+ if (!isSupportedScriptType(network, scriptType)) {
93
+ throw new Error(`unsupported script type ${scriptType} for network`);
94
+ }
95
+ }
96
+ if (!types_1.isTriple(pubkeys)) {
97
+ throw new Error(`must provide pubkey triple`);
98
+ }
99
+ pubkeys.forEach((key) => {
100
+ if (key.length !== 33) {
101
+ throw new Error(`Unexpected key length ${key.length}. Must use compressed keys.`);
102
+ }
103
+ });
104
+ if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {
105
+ // p2tr/p2trMusig2 addresses use a combination of 2 of 2 multisig scripts distinct from
106
+ // the 2 of 3 multisig used for other script types
107
+ return createTaprootScript2of3(scriptType, pubkeys);
108
+ }
109
+ const script2of3 = bitcoinjs.payments.p2ms({ m: 2, pubkeys });
110
+ assert(script2of3.output);
111
+ let scriptPubKey;
112
+ let redeemScript;
113
+ let witnessScript;
114
+ switch (scriptType) {
115
+ case 'p2sh':
116
+ redeemScript = script2of3;
117
+ scriptPubKey = bitcoinjs.payments.p2sh({ redeem: script2of3 });
118
+ break;
119
+ case 'p2shP2wsh':
120
+ witnessScript = script2of3;
121
+ redeemScript = bitcoinjs.payments.p2wsh({ redeem: script2of3 });
122
+ scriptPubKey = bitcoinjs.payments.p2sh({ redeem: redeemScript });
123
+ break;
124
+ case 'p2wsh':
125
+ witnessScript = script2of3;
126
+ scriptPubKey = bitcoinjs.payments.p2wsh({ redeem: witnessScript });
127
+ break;
128
+ default:
129
+ throw new Error(`unknown multisig script type ${scriptType}`);
130
+ }
131
+ assert(scriptPubKey);
132
+ assert(scriptPubKey.output);
133
+ return {
134
+ scriptPubKey: scriptPubKey.output,
135
+ redeemScript: redeemScript === null || redeemScript === void 0 ? void 0 : redeemScript.output,
136
+ witnessScript: witnessScript === null || witnessScript === void 0 ? void 0 : witnessScript.output,
137
+ };
138
+ }
139
+ exports.createOutputScript2of3 = createOutputScript2of3;
140
+ function toXOnlyPublicKey(b) {
141
+ if (b.length === 33) {
142
+ return b.slice(1);
143
+ }
144
+ if (b.length === 32) {
145
+ return b;
146
+ }
147
+ throw new Error(`invalid key size ${b.length}`);
148
+ }
149
+ exports.toXOnlyPublicKey = toXOnlyPublicKey;
150
+ /**
151
+ * Validates size of the pub key for 32 bytes and returns the same iff true.
152
+ */
153
+ function checkXOnlyPublicKey(b) {
154
+ if (b.length === 32) {
155
+ return b;
156
+ }
157
+ throw new Error(`invalid key size ${b.length}. Must use x-only key.`);
158
+ }
159
+ exports.checkXOnlyPublicKey = checkXOnlyPublicKey;
160
+ /**
161
+ * Validates size of the pub key for 32 bytes and returns the same iff true.
162
+ */
163
+ function checkPlainPublicKey(b) {
164
+ if (b.length === 33) {
165
+ return b;
166
+ }
167
+ throw new Error(`invalid key size ${b.length}. Must use plain keys.`);
168
+ }
169
+ exports.checkPlainPublicKey = checkPlainPublicKey;
170
+ function getTaptreeKeyCombinations(scriptType, keys) {
171
+ const [userKey, backupKey, bitGoKey] = keys.map((k) => toXOnlyPublicKey(k));
172
+ return scriptType === 'p2tr'
173
+ ? [
174
+ [userKey, bitGoKey],
175
+ [userKey, backupKey],
176
+ [backupKey, bitGoKey],
177
+ ]
178
+ : [
179
+ [userKey, backupKey],
180
+ [backupKey, bitGoKey],
181
+ ];
182
+ }
183
+ function getKeyPathCombination(scriptType, keys) {
184
+ const sanitizePublicKey = scriptType === 'p2tr' ? toXOnlyPublicKey : checkPlainPublicKey;
185
+ return [sanitizePublicKey(keys[0]), sanitizePublicKey(keys[2])];
186
+ }
187
+ function getRedeemIndex(keyCombinations, signer, cosigner) {
188
+ signer = toXOnlyPublicKey(signer);
189
+ cosigner = toXOnlyPublicKey(cosigner);
190
+ const i = keyCombinations.findIndex(([a, b]) => {
191
+ if (a.length !== signer.length || b.length !== cosigner.length) {
192
+ throw new Error(`invalid comparison`);
193
+ }
194
+ return (a.equals(signer) && b.equals(cosigner)) || (a.equals(cosigner) && b.equals(signer));
195
+ });
196
+ if (0 <= i) {
197
+ return i;
198
+ }
199
+ throw new Error(`could not find singer/cosigner combination`);
200
+ }
201
+ function createPaymentP2trCommon(scriptType, pubkeys, redeemIndex) {
202
+ const keyCombinations2of2 = getTaptreeKeyCombinations(scriptType, pubkeys);
203
+ if (typeof redeemIndex === 'object') {
204
+ redeemIndex = getRedeemIndex(keyCombinations2of2, redeemIndex.signer, redeemIndex.cosigner);
205
+ }
206
+ const redeems = keyCombinations2of2.map((pubkeys, index) => __1.p2trPayments.p2tr_ns({
207
+ pubkeys,
208
+ depth: scriptType === 'p2trMusig2' || index === 0 ? 1 : 2,
209
+ }, { eccLib: noble_ecc_1.ecc }));
210
+ return __1.p2trPayments.p2tr({
211
+ pubkeys: getKeyPathCombination(scriptType, pubkeys),
212
+ redeems,
213
+ redeemIndex,
214
+ }, { eccLib: noble_ecc_1.ecc });
215
+ }
216
+ function createPaymentP2tr(pubkeys, redeemIndex) {
217
+ return createPaymentP2trCommon('p2tr', pubkeys, redeemIndex);
218
+ }
219
+ exports.createPaymentP2tr = createPaymentP2tr;
220
+ function createPaymentP2trMusig2(pubkeys, redeemIndex) {
221
+ return createPaymentP2trCommon('p2trMusig2', pubkeys, redeemIndex);
222
+ }
223
+ exports.createPaymentP2trMusig2 = createPaymentP2trMusig2;
224
+ function getLeafHashCommon(scriptType, params) {
225
+ if ('publicKeys' in params) {
226
+ params = createPaymentP2trCommon(scriptType, params.publicKeys, params);
227
+ }
228
+ const { output, controlBlock, redeem } = params;
229
+ if (!output || !controlBlock || !redeem || !redeem.output) {
230
+ throw new Error(`invalid state`);
231
+ }
232
+ return __1.taproot.getTapleafHash(noble_ecc_1.ecc, controlBlock, redeem.output);
233
+ }
234
+ function getLeafHash(params) {
235
+ return getLeafHashCommon('p2tr', params);
236
+ }
237
+ exports.getLeafHash = getLeafHash;
238
+ function createKeyPathP2trMusig2(pubkeys) {
239
+ const payment = createPaymentP2trCommon('p2trMusig2', pubkeys);
240
+ assert(payment.internalPubkey);
241
+ assert(payment.tapTree);
242
+ return {
243
+ internalPubkey: payment.internalPubkey,
244
+ outputPubkey: taproot_1.getTweakedOutputKey(payment),
245
+ taptreeRoot: taproot_1.getDepthFirstTaptree(payment.tapTree).root,
246
+ };
247
+ }
248
+ exports.createKeyPathP2trMusig2 = createKeyPathP2trMusig2;
249
+ function createSpendScriptP2trCommon(scriptType, pubkeys, keyCombination) {
250
+ const keyCombinations = getTaptreeKeyCombinations(scriptType, pubkeys);
251
+ const [a, b] = keyCombination.map((k) => toXOnlyPublicKey(k));
252
+ const redeemIndex = keyCombinations.findIndex(([c, d]) => (a.equals(c) && b.equals(d)) || (a.equals(d) && b.equals(c)));
253
+ if (redeemIndex < 0) {
254
+ throw new Error(`could not find redeemIndex for key combination`);
255
+ }
256
+ const payment = createPaymentP2trCommon(scriptType, pubkeys, redeemIndex);
257
+ const { controlBlock } = payment;
258
+ assert(Buffer.isBuffer(controlBlock));
259
+ assert(payment.redeem);
260
+ const leafScript = payment.redeem.output;
261
+ assert(Buffer.isBuffer(leafScript));
262
+ const parsedControlBlock = __1.taproot.parseControlBlock(noble_ecc_1.ecc, controlBlock);
263
+ const { leafVersion } = parsedControlBlock;
264
+ const leafHash = __1.taproot.getTapleafHash(noble_ecc_1.ecc, parsedControlBlock, leafScript);
265
+ return {
266
+ controlBlock,
267
+ witnessScript: leafScript,
268
+ leafVersion,
269
+ leafHash,
270
+ };
271
+ }
272
+ function createSpendScriptP2tr(pubkeys, keyCombination) {
273
+ return createSpendScriptP2trCommon('p2tr', pubkeys, keyCombination);
274
+ }
275
+ exports.createSpendScriptP2tr = createSpendScriptP2tr;
276
+ function createSpendScriptP2trMusig2(pubkeys, keyCombination) {
277
+ return createSpendScriptP2trCommon('p2trMusig2', pubkeys, keyCombination);
278
+ }
279
+ exports.createSpendScriptP2trMusig2 = createSpendScriptP2trMusig2;
280
+ /**
281
+ * Creates and returns a taproot output script using the user+bitgo keys for the aggregate
282
+ * public key using MuSig2 and a taptree containing either of the following depends on scriptType.
283
+ * p2tr type: a user+bitgo 2-of-2 script at the first depth level of the tree and user+backup
284
+ * and bitgo+backup 2-of-2 scripts one level deeper.
285
+ * p2trMusig2 type: user+backup and bitgo+backup 2-of-2 scripts at the first depth level of the
286
+ * tree.
287
+ * @param pubkeys - a pubkey array containing the user key, backup key, and bitgo key in that order
288
+ * @returns {{scriptPubKey}}
289
+ */
290
+ function createTaprootScript2of3(scriptType, pubkeys) {
291
+ const { output } = createPaymentP2trCommon(scriptType, pubkeys);
292
+ assert(Buffer.isBuffer(output));
293
+ return {
294
+ scriptPubKey: output,
295
+ };
296
+ }
297
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outputScripts.js","sourceRoot":"","sources":["../../../src/bitgo/outputScripts.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport * as bitcoinjs from 'bitcoinjs-lib';\n\nimport { Network, p2trPayments, supportsSegwit, supportsTaproot, taproot } from '..';\n\nimport { isTriple, Triple, Tuple } from './types';\n\nimport { ecc as eccLib } from '../noble_ecc';\nimport { getDepthFirstTaptree, getTweakedOutputKey } from '../taproot';\n\nexport { scriptTypeForChain } from './wallet/chains';\n\nexport const scriptTypeP2shP2pk = 'p2shP2pk';\nexport type ScriptTypeP2shP2pk = typeof scriptTypeP2shP2pk;\n\nexport const scriptTypes2Of3 = ['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2'] as const;\nexport type ScriptType2Of3 = typeof scriptTypes2Of3[number];\n\nexport function isScriptType2Of3(t: string): t is ScriptType2Of3 {\n  return scriptTypes2Of3.includes(t as ScriptType2Of3);\n}\n\nexport type ScriptType = ScriptTypeP2shP2pk | ScriptType2Of3;\n\n/**\n * @return true iff scriptType requires witness data\n */\nexport function hasWitnessData(scriptType: ScriptType): scriptType is 'p2shP2wsh' | 'p2wsh' | 'p2tr' | 'p2trMusig2' {\n  return ['p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2'].includes(scriptType);\n}\n\n/**\n * @param network\n * @param scriptType\n * @return true iff script type is supported for network\n */\nexport function isSupportedScriptType(network: Network, scriptType: ScriptType): boolean {\n  switch (scriptType) {\n    case 'p2sh':\n    case 'p2shP2pk':\n      return true;\n    case 'p2shP2wsh':\n    case 'p2wsh':\n      return supportsSegwit(network);\n    case 'p2tr':\n    case 'p2trMusig2':\n      return supportsTaproot(network);\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`unexpected script type ${scriptType}`);\n}\n\n/**\n * @param t\n * @return string prevOut as defined in PREVOUT_TYPES (bitcoinjs-lib/.../transaction_builder.js)\n */\nexport function scriptType2Of3AsPrevOutType(t: ScriptType2Of3): string {\n  switch (t) {\n    case 'p2sh':\n      return 'p2sh-p2ms';\n    case 'p2shP2wsh':\n      return 'p2sh-p2wsh-p2ms';\n    case 'p2wsh':\n      return 'p2wsh-p2ms';\n    case 'p2tr':\n      return 'p2tr-p2ns';\n    case 'p2trMusig2':\n      return 'p2tr';\n  }\n\n  /* istanbul ignore next */\n  throw new Error(`unsupported script type ${t}`);\n}\n\nexport type SpendableScript = {\n  scriptPubKey: Buffer;\n  redeemScript?: Buffer;\n  witnessScript?: Buffer;\n};\n\nexport type SpendScriptP2tr = {\n  controlBlock: Buffer;\n  witnessScript: Buffer;\n  leafVersion: number;\n  leafHash: Buffer;\n};\n\n/**\n * Tweak data holder for P2tr Musig2 key path.\n */\nexport type KeyPathP2trMusig2 = {\n  internalPubkey: Buffer;\n  outputPubkey: Buffer;\n  taptreeRoot: Buffer;\n};\n\n/**\n * Return scripts for p2sh-p2pk (used for BCH/BSV replay protection)\n * @param pubkey\n */\nexport function createOutputScriptP2shP2pk(pubkey: Buffer): SpendableScript {\n  const p2pk = bitcoinjs.payments.p2pk({ pubkey });\n  const p2sh = bitcoinjs.payments.p2sh({ redeem: p2pk });\n  if (!p2sh.output || !p2pk.output) {\n    throw new Error(`invalid state`);\n  }\n  return {\n    scriptPubKey: p2sh.output,\n    redeemScript: p2pk.output,\n  };\n}\n\n/**\n * Return scripts for 2-of-3 multisig output\n * @param pubkeys - the key triple for multisig\n * @param scriptType\n * @param network - if set, performs sanity check for scriptType support\n * @returns {{redeemScript, witnessScript, scriptPubKey}}\n */\nexport function createOutputScript2of3(\n  pubkeys: Buffer[],\n  scriptType: ScriptType2Of3,\n  network?: Network\n): SpendableScript {\n  if (network) {\n    if (!isSupportedScriptType(network, scriptType)) {\n      throw new Error(`unsupported script type ${scriptType} for network`);\n    }\n  }\n\n  if (!isTriple(pubkeys)) {\n    throw new Error(`must provide pubkey triple`);\n  }\n\n  pubkeys.forEach((key) => {\n    if (key.length !== 33) {\n      throw new Error(`Unexpected key length ${key.length}. Must use compressed keys.`);\n    }\n  });\n\n  if (scriptType === 'p2tr' || scriptType === 'p2trMusig2') {\n    // p2tr/p2trMusig2 addresses use a combination of 2 of 2 multisig scripts distinct from\n    // the 2 of 3 multisig used for other script types\n    return createTaprootScript2of3(scriptType, pubkeys);\n  }\n\n  const script2of3 = bitcoinjs.payments.p2ms({ m: 2, pubkeys });\n  assert(script2of3.output);\n\n  let scriptPubKey: bitcoinjs.Payment;\n  let redeemScript: bitcoinjs.Payment | undefined;\n  let witnessScript: bitcoinjs.Payment | undefined;\n  switch (scriptType) {\n    case 'p2sh':\n      redeemScript = script2of3;\n      scriptPubKey = bitcoinjs.payments.p2sh({ redeem: script2of3 });\n      break;\n    case 'p2shP2wsh':\n      witnessScript = script2of3;\n      redeemScript = bitcoinjs.payments.p2wsh({ redeem: script2of3 });\n      scriptPubKey = bitcoinjs.payments.p2sh({ redeem: redeemScript });\n      break;\n    case 'p2wsh':\n      witnessScript = script2of3;\n      scriptPubKey = bitcoinjs.payments.p2wsh({ redeem: witnessScript });\n      break;\n    default:\n      throw new Error(`unknown multisig script type ${scriptType}`);\n  }\n\n  assert(scriptPubKey);\n  assert(scriptPubKey.output);\n\n  return {\n    scriptPubKey: scriptPubKey.output,\n    redeemScript: redeemScript?.output,\n    witnessScript: witnessScript?.output,\n  };\n}\n\nexport function toXOnlyPublicKey(b: Buffer): Buffer {\n  if (b.length === 33) {\n    return b.slice(1);\n  }\n  if (b.length === 32) {\n    return b;\n  }\n  throw new Error(`invalid key size ${b.length}`);\n}\n\n/**\n * Validates size of the pub key for 32 bytes and returns the same iff true.\n */\nexport function checkXOnlyPublicKey(b: Buffer): Buffer {\n  if (b.length === 32) {\n    return b;\n  }\n  throw new Error(`invalid key size ${b.length}. Must use x-only key.`);\n}\n\n/**\n * Validates size of the pub key for 32 bytes and returns the same iff true.\n */\nexport function checkPlainPublicKey(b: Buffer): Buffer {\n  if (b.length === 33) {\n    return b;\n  }\n  throw new Error(`invalid key size ${b.length}. Must use plain keys.`);\n}\n\nfunction getTaptreeKeyCombinations(scriptType: 'p2tr' | 'p2trMusig2', keys: Triple<Buffer>): Tuple<Buffer>[] {\n  const [userKey, backupKey, bitGoKey] = keys.map((k) => toXOnlyPublicKey(k));\n  return scriptType === 'p2tr'\n    ? [\n        [userKey, bitGoKey],\n        [userKey, backupKey],\n        [backupKey, bitGoKey],\n      ]\n    : [\n        [userKey, backupKey],\n        [backupKey, bitGoKey],\n      ];\n}\n\nfunction getKeyPathCombination(scriptType: 'p2tr' | 'p2trMusig2', keys: Triple<Buffer>): Tuple<Buffer> {\n  const sanitizePublicKey = scriptType === 'p2tr' ? toXOnlyPublicKey : checkPlainPublicKey;\n  return [sanitizePublicKey(keys[0]), sanitizePublicKey(keys[2])];\n}\n\nfunction getRedeemIndex(keyCombinations: [Buffer, Buffer][], signer: Buffer, cosigner: Buffer): number {\n  signer = toXOnlyPublicKey(signer);\n  cosigner = toXOnlyPublicKey(cosigner);\n  const i = keyCombinations.findIndex(([a, b]) => {\n    if (a.length !== signer.length || b.length !== cosigner.length) {\n      throw new Error(`invalid comparison`);\n    }\n    return (a.equals(signer) && b.equals(cosigner)) || (a.equals(cosigner) && b.equals(signer));\n  });\n  if (0 <= i) {\n    return i;\n  }\n  throw new Error(`could not find singer/cosigner combination`);\n}\n\nfunction createPaymentP2trCommon(\n  scriptType: 'p2tr' | 'p2trMusig2',\n  pubkeys: Triple<Buffer>,\n  redeemIndex?: number | { signer: Buffer; cosigner: Buffer }\n): bitcoinjs.Payment {\n  const keyCombinations2of2 = getTaptreeKeyCombinations(scriptType, pubkeys);\n  if (typeof redeemIndex === 'object') {\n    redeemIndex = getRedeemIndex(keyCombinations2of2, redeemIndex.signer, redeemIndex.cosigner);\n  }\n  const redeems = keyCombinations2of2.map((pubkeys, index) =>\n    p2trPayments.p2tr_ns(\n      {\n        pubkeys,\n        depth: scriptType === 'p2trMusig2' || index === 0 ? 1 : 2,\n      },\n      { eccLib }\n    )\n  );\n\n  return p2trPayments.p2tr(\n    {\n      pubkeys: getKeyPathCombination(scriptType, pubkeys),\n      redeems,\n      redeemIndex,\n    },\n    { eccLib }\n  );\n}\n\nexport function createPaymentP2tr(\n  pubkeys: Triple<Buffer>,\n  redeemIndex?: number | { signer: Buffer; cosigner: Buffer }\n): bitcoinjs.Payment {\n  return createPaymentP2trCommon('p2tr', pubkeys, redeemIndex);\n}\n\nexport function createPaymentP2trMusig2(\n  pubkeys: Triple<Buffer>,\n  redeemIndex?: number | { signer: Buffer; cosigner: Buffer }\n): bitcoinjs.Payment {\n  return createPaymentP2trCommon('p2trMusig2', pubkeys, redeemIndex);\n}\n\nfunction getLeafHashCommon(\n  scriptType: 'p2tr' | 'p2trMusig2',\n  params: bitcoinjs.Payment | { publicKeys: Triple<Buffer>; signer: Buffer; cosigner: Buffer }\n): Buffer {\n  if ('publicKeys' in params) {\n    params = createPaymentP2trCommon(scriptType, params.publicKeys, params);\n  }\n  const { output, controlBlock, redeem } = params;\n  if (!output || !controlBlock || !redeem || !redeem.output) {\n    throw new Error(`invalid state`);\n  }\n  return taproot.getTapleafHash(eccLib, controlBlock, redeem.output);\n}\n\nexport function getLeafHash(\n  params: bitcoinjs.Payment | { publicKeys: Triple<Buffer>; signer: Buffer; cosigner: Buffer }\n): Buffer {\n  return getLeafHashCommon('p2tr', params);\n}\n\nexport function createKeyPathP2trMusig2(pubkeys: Triple<Buffer>): KeyPathP2trMusig2 {\n  const payment = createPaymentP2trCommon('p2trMusig2', pubkeys);\n  assert(payment.internalPubkey);\n  assert(payment.tapTree);\n  return {\n    internalPubkey: payment.internalPubkey,\n    outputPubkey: getTweakedOutputKey(payment),\n    taptreeRoot: getDepthFirstTaptree(payment.tapTree).root,\n  };\n}\n\nfunction createSpendScriptP2trCommon(\n  scriptType: 'p2tr' | 'p2trMusig2',\n  pubkeys: Triple<Buffer>,\n  keyCombination: Tuple<Buffer>\n): SpendScriptP2tr {\n  const keyCombinations = getTaptreeKeyCombinations(scriptType, pubkeys);\n  const [a, b] = keyCombination.map((k) => toXOnlyPublicKey(k));\n  const redeemIndex = keyCombinations.findIndex(\n    ([c, d]) => (a.equals(c) && b.equals(d)) || (a.equals(d) && b.equals(c))\n  );\n\n  if (redeemIndex < 0) {\n    throw new Error(`could not find redeemIndex for key combination`);\n  }\n\n  const payment = createPaymentP2trCommon(scriptType, pubkeys, redeemIndex);\n  const { controlBlock } = payment;\n  assert(Buffer.isBuffer(controlBlock));\n\n  assert(payment.redeem);\n  const leafScript = payment.redeem.output;\n  assert(Buffer.isBuffer(leafScript));\n\n  const parsedControlBlock = taproot.parseControlBlock(eccLib, controlBlock);\n  const { leafVersion } = parsedControlBlock;\n  const leafHash = taproot.getTapleafHash(eccLib, parsedControlBlock, leafScript);\n\n  return {\n    controlBlock,\n    witnessScript: leafScript,\n    leafVersion,\n    leafHash,\n  };\n}\n\nexport function createSpendScriptP2tr(pubkeys: Triple<Buffer>, keyCombination: Tuple<Buffer>): SpendScriptP2tr {\n  return createSpendScriptP2trCommon('p2tr', pubkeys, keyCombination);\n}\n\nexport function createSpendScriptP2trMusig2(pubkeys: Triple<Buffer>, keyCombination: Tuple<Buffer>): SpendScriptP2tr {\n  return createSpendScriptP2trCommon('p2trMusig2', pubkeys, keyCombination);\n}\n\n/**\n * Creates and returns a taproot output script using the user+bitgo keys for the aggregate\n * public key using MuSig2 and a taptree containing either of the following depends on scriptType.\n * p2tr type: a user+bitgo 2-of-2 script at the first depth level of the tree and user+backup\n * and bitgo+backup 2-of-2 scripts one level deeper.\n * p2trMusig2 type: user+backup and bitgo+backup 2-of-2 scripts at the first depth level of the\n * tree.\n * @param pubkeys - a pubkey array containing the user key, backup key, and bitgo key in that order\n * @returns {{scriptPubKey}}\n */\nfunction createTaprootScript2of3(scriptType: 'p2tr' | 'p2trMusig2', pubkeys: Triple<Buffer>): SpendableScript {\n  const { output } = createPaymentP2trCommon(scriptType, pubkeys);\n  assert(Buffer.isBuffer(output));\n  return {\n    scriptPubKey: output,\n  };\n}\n"]}
@@ -0,0 +1,92 @@
1
+ /// <reference types="node" />
2
+ import { TxInput } from 'bitcoinjs-lib';
3
+ import { ScriptType, ScriptType2Of3 } from './outputScripts';
4
+ export declare function isPlaceholderSignature(v: number | Buffer): boolean;
5
+ /**
6
+ * @return true iff P2TR script path's control block matches BitGo's need
7
+ */
8
+ export declare function isValidControlBock(controlBlock: Buffer): boolean;
9
+ /**
10
+ * @return script path level for P2TR control block
11
+ */
12
+ export declare function calculateScriptPathLevel(controlBlock: Buffer): number;
13
+ /**
14
+ * @return leaf version for P2TR control block.
15
+ */
16
+ export declare function getScriptPathLevel(controlBlock: Buffer): number;
17
+ interface ParsedScript {
18
+ scriptType: ScriptType;
19
+ }
20
+ export declare type ParsedPubScript = ParsedScript;
21
+ export declare type ParsedSignatureScript = ParsedScript;
22
+ export interface ParsedSignatureScriptP2shP2pk extends ParsedSignatureScript {
23
+ scriptType: 'p2shP2pk';
24
+ publicKeys: [Buffer];
25
+ signatures: [Buffer];
26
+ }
27
+ export interface ParsedPubScriptTaprootScriptPath extends ParsedPubScript {
28
+ scriptType: 'p2tr';
29
+ publicKeys: [Buffer, Buffer];
30
+ pubScript: Buffer;
31
+ }
32
+ export interface ParsedPubScript2Of3 extends ParsedPubScript {
33
+ scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';
34
+ publicKeys: [Buffer, Buffer, Buffer];
35
+ pubScript: Buffer;
36
+ redeemScript: Buffer | undefined;
37
+ witnessScript: Buffer | undefined;
38
+ }
39
+ export interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {
40
+ scriptType: 'p2sh' | 'p2shP2wsh' | 'p2wsh';
41
+ publicKeys: [Buffer, Buffer, Buffer];
42
+ signatures: [Buffer, Buffer] | [Buffer | 0, Buffer | 0, Buffer | 0];
43
+ pubScript: Buffer;
44
+ redeemScript: Buffer | undefined;
45
+ witnessScript: Buffer | undefined;
46
+ }
47
+ /**
48
+ * Keypath spends only have a single pubkey and single signature
49
+ */
50
+ export interface ParsedSignatureScriptTaprootKeyPath extends ParsedSignatureScript {
51
+ scriptType: 'p2tr';
52
+ publicKeys: [Buffer];
53
+ signatures: [Buffer];
54
+ pubScript: Buffer;
55
+ }
56
+ /**
57
+ * Taproot Scriptpath spends are more similar to regular p2ms spends and have two public keys and
58
+ * two signatures
59
+ */
60
+ export interface ParsedSignatureScriptTaprootScriptPath extends ParsedSignatureScript {
61
+ scriptType: 'p2tr';
62
+ publicKeys: [Buffer, Buffer];
63
+ signatures: [Buffer, Buffer];
64
+ controlBlock: Buffer;
65
+ leafVersion: number;
66
+ /** Indicates the level inside the taptree. */
67
+ scriptPathLevel: number;
68
+ pubScript: Buffer;
69
+ }
70
+ export declare type ParsedSignatureScriptTaproot = ParsedSignatureScriptTaprootKeyPath | ParsedSignatureScriptTaprootScriptPath;
71
+ export declare type InputPubScript = Buffer;
72
+ /**
73
+ * Parse a transaction's signature script to obtain public keys, signatures, the sig script,
74
+ * and other properties.
75
+ *
76
+ * Only supports script types used in BitGo transactions.
77
+ *
78
+ * @param input
79
+ * @returns ParsedSignatureScript
80
+ */
81
+ export declare function parseSignatureScript(input: TxInput): ParsedSignatureScriptP2shP2pk | ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot;
82
+ export declare function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 | ParsedSignatureScriptTaproot;
83
+ /**
84
+ * @return pubScript (scriptPubKey/redeemScript/witnessScript) is parsed.
85
+ * P2SH => scriptType, pubScript (redeemScript), redeemScript, public keys
86
+ * PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.
87
+ * P2SH-PW2SH => scriptType, pubScript (witnessScript), witnessScript, public keys.
88
+ * P2TR => scriptType, pubScript, controlBlock, scriptPathLevel, leafVersion, pub keys, signatures.
89
+ */
90
+ export declare function parsePubScript(inputPubScript: InputPubScript, scriptType: ScriptType2Of3): ParsedPubScript2Of3 | ParsedPubScriptTaprootScriptPath;
91
+ export {};
92
+ //# sourceMappingURL=parseInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseInput.d.ts","sourceRoot":"","sources":["../../../src/bitgo/parseInput.ts"],"names":[],"mappings":"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"}