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,21 @@
1
+ /// <reference types="node" />
2
+ import * as bitcoinjs from 'bitcoinjs-lib';
3
+ import { Network } from '../..';
4
+ import { ZcashNetwork, ZcashTransaction } from './ZcashTransaction';
5
+ import { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';
6
+ export declare class ZcashTransactionBuilder<TNumber extends number | bigint = number> extends UtxoTransactionBuilder<TNumber, ZcashTransaction<TNumber>> {
7
+ constructor(network: ZcashNetwork);
8
+ protected createInitialTransaction(network: Network): ZcashTransaction<TNumber>;
9
+ static fromTransaction<TNumber extends number | bigint = number>(transaction: ZcashTransaction<TNumber>, network?: Network, prevOutput?: bitcoinjs.TxOutput<TNumber>[]): ZcashTransactionBuilder<TNumber>;
10
+ setVersion(version: number, overwinter?: boolean): void;
11
+ setDefaultsForVersion(network: Network, version: number): void;
12
+ private hasSignatures;
13
+ private setPropertyCheckSignatures;
14
+ setConsensusBranchId(consensusBranchId: number): void;
15
+ setVersionGroupId(versionGroupId: number): void;
16
+ setExpiryHeight(expiryHeight: number): void;
17
+ build(): ZcashTransaction<TNumber>;
18
+ buildIncomplete(): ZcashTransaction<TNumber>;
19
+ addOutput(scriptPubKey: string | Buffer, value: TNumber): number;
20
+ }
21
+ //# sourceMappingURL=ZcashTransactionBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ZcashTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransactionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,SAAS,MAAM,eAAe,CAAC;AAI3C,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAGL,YAAY,EACZ,gBAAgB,EACjB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAGnE,qBAAa,uBAAuB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,sBAAsB,CAC3G,OAAO,EACP,gBAAgB,CAAC,OAAO,CAAC,CAC1B;gBACa,OAAO,EAAE,YAAY;IAIjC,SAAS,CAAC,wBAAwB,CAAC,OAAO,EAAE,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC;IAI/E,MAAM,CAAC,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,EAC7D,WAAW,EAAE,gBAAgB,CAAC,OAAO,CAAC,EACtC,OAAO,CAAC,EAAE,OAAO,EACjB,UAAU,CAAC,EAAE,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,GACzC,uBAAuB,CAAC,OAAO,CAAC;IAiCnC,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,UAAO,GAAG,IAAI;IAMpD,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAmB9D,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,0BAA0B;IAUlC,oBAAoB,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI;IAKrD,iBAAiB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAK/C,eAAe,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI;IAK3C,KAAK,IAAI,gBAAgB,CAAC,OAAO,CAAC;IAIlC,eAAe,IAAI,gBAAgB,CAAC,OAAO,CAAC;IAI5C,SAAS,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,MAAM;CAQjE"}
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ZcashTransactionBuilder = void 0;
4
+ const types = require("bitcoinjs-lib/src/types");
5
+ const typeforce = require('typeforce');
6
+ const ZcashTransaction_1 = require("./ZcashTransaction");
7
+ const UtxoTransactionBuilder_1 = require("../UtxoTransactionBuilder");
8
+ const address_1 = require("./address");
9
+ class ZcashTransactionBuilder extends UtxoTransactionBuilder_1.UtxoTransactionBuilder {
10
+ constructor(network) {
11
+ super(network);
12
+ }
13
+ createInitialTransaction(network) {
14
+ return new ZcashTransaction_1.ZcashTransaction(network);
15
+ }
16
+ static fromTransaction(transaction, network, prevOutput) {
17
+ const txb = new ZcashTransactionBuilder(transaction.network);
18
+ // Copy transaction fields
19
+ txb.setVersion(transaction.version, !!transaction.overwintered);
20
+ txb.setLockTime(transaction.locktime);
21
+ // Copy Zcash overwinter fields. Omitted if the transaction builder is not for Zcash.
22
+ if (txb.tx.isOverwinterCompatible()) {
23
+ txb.setVersionGroupId(transaction.versionGroupId);
24
+ txb.setExpiryHeight(transaction.expiryHeight);
25
+ }
26
+ txb.setConsensusBranchId(transaction.consensusBranchId);
27
+ // Copy outputs (done first to avoid signature invalidation)
28
+ transaction.outs.forEach(function (txOut) {
29
+ txb.addOutput(txOut.script, txOut.value);
30
+ });
31
+ // Copy inputs
32
+ transaction.ins.forEach(function (txIn) {
33
+ txb.__addInputUnsafe(txIn.hash, txIn.index, {
34
+ sequence: txIn.sequence,
35
+ script: txIn.script,
36
+ witness: txIn.witness,
37
+ value: txIn.value,
38
+ });
39
+ });
40
+ return txb;
41
+ }
42
+ setVersion(version, overwinter = true) {
43
+ typeforce(types.UInt32, version);
44
+ this.tx.overwintered = overwinter ? 1 : 0;
45
+ this.tx.version = version;
46
+ }
47
+ setDefaultsForVersion(network, version) {
48
+ switch (version) {
49
+ case 4:
50
+ case ZcashTransaction_1.ZcashTransaction.VERSION4_BRANCH_CANOPY:
51
+ case ZcashTransaction_1.ZcashTransaction.VERSION4_BRANCH_NU5:
52
+ this.setVersion(4);
53
+ break;
54
+ case 5:
55
+ case ZcashTransaction_1.ZcashTransaction.VERSION5_BRANCH_NU5:
56
+ this.setVersion(5);
57
+ break;
58
+ default:
59
+ throw new Error(`invalid version ${version}`);
60
+ }
61
+ this.tx.versionGroupId = ZcashTransaction_1.getDefaultVersionGroupIdForVersion(version);
62
+ this.tx.consensusBranchId = ZcashTransaction_1.getDefaultConsensusBranchIdForVersion(network, version);
63
+ }
64
+ hasSignatures() {
65
+ return this.__INPUTS.some(function (input) {
66
+ return input.signatures !== undefined;
67
+ });
68
+ }
69
+ setPropertyCheckSignatures(propName, value) {
70
+ if (this.tx[propName] === value) {
71
+ return;
72
+ }
73
+ if (this.hasSignatures()) {
74
+ throw new Error(`Changing property ${propName} for a partially signed transaction would invalidate signatures`);
75
+ }
76
+ this.tx[propName] = value;
77
+ }
78
+ setConsensusBranchId(consensusBranchId) {
79
+ typeforce(types.UInt32, consensusBranchId);
80
+ this.setPropertyCheckSignatures('consensusBranchId', consensusBranchId);
81
+ }
82
+ setVersionGroupId(versionGroupId) {
83
+ typeforce(types.UInt32, versionGroupId);
84
+ this.setPropertyCheckSignatures('versionGroupId', versionGroupId);
85
+ }
86
+ setExpiryHeight(expiryHeight) {
87
+ typeforce(types.UInt32, expiryHeight);
88
+ this.setPropertyCheckSignatures('expiryHeight', expiryHeight);
89
+ }
90
+ build() {
91
+ return super.build();
92
+ }
93
+ buildIncomplete() {
94
+ return super.buildIncomplete();
95
+ }
96
+ addOutput(scriptPubKey, value) {
97
+ // Attempt to get a script if it's a base58 or bech32 address string
98
+ if (typeof scriptPubKey === 'string') {
99
+ scriptPubKey = address_1.toOutputScript(scriptPubKey, this.network);
100
+ }
101
+ return super.addOutput(scriptPubKey, value);
102
+ }
103
+ }
104
+ exports.ZcashTransactionBuilder = ZcashTransactionBuilder;
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ZcashTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/ZcashTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as bitcoinjs from 'bitcoinjs-lib';\nimport * as types from 'bitcoinjs-lib/src/types';\nconst typeforce = require('typeforce');\n\nimport { Network } from '../..';\nimport {\n  getDefaultConsensusBranchIdForVersion,\n  getDefaultVersionGroupIdForVersion,\n  ZcashNetwork,\n  ZcashTransaction,\n} from './ZcashTransaction';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport { toOutputScript } from './address';\n\nexport class ZcashTransactionBuilder<TNumber extends number | bigint = number> extends UtxoTransactionBuilder<\n  TNumber,\n  ZcashTransaction<TNumber>\n> {\n  constructor(network: ZcashNetwork) {\n    super(network);\n  }\n\n  protected createInitialTransaction(network: Network): ZcashTransaction<TNumber> {\n    return new ZcashTransaction<TNumber>(network as ZcashNetwork);\n  }\n\n  static fromTransaction<TNumber extends number | bigint = number>(\n    transaction: ZcashTransaction<TNumber>,\n    network?: Network,\n    prevOutput?: bitcoinjs.TxOutput<TNumber>[]\n  ): ZcashTransactionBuilder<TNumber> {\n    const txb = new ZcashTransactionBuilder<TNumber>(transaction.network);\n\n    // Copy transaction fields\n    txb.setVersion(transaction.version, !!transaction.overwintered);\n    txb.setLockTime(transaction.locktime);\n\n    // Copy Zcash overwinter fields. Omitted if the transaction builder is not for Zcash.\n    if (txb.tx.isOverwinterCompatible()) {\n      txb.setVersionGroupId(transaction.versionGroupId);\n      txb.setExpiryHeight(transaction.expiryHeight);\n    }\n\n    txb.setConsensusBranchId(transaction.consensusBranchId);\n\n    // Copy outputs (done first to avoid signature invalidation)\n    transaction.outs.forEach(function (txOut) {\n      txb.addOutput(txOut.script, txOut.value);\n    });\n\n    // Copy inputs\n    transaction.ins.forEach(function (txIn) {\n      (txb as any).__addInputUnsafe(txIn.hash, txIn.index, {\n        sequence: txIn.sequence,\n        script: txIn.script,\n        witness: txIn.witness,\n        value: (txIn as any).value,\n      });\n    });\n\n    return txb;\n  }\n\n  setVersion(version: number, overwinter = true): void {\n    typeforce(types.UInt32, version);\n    this.tx.overwintered = overwinter ? 1 : 0;\n    this.tx.version = version;\n  }\n\n  setDefaultsForVersion(network: Network, version: number): void {\n    switch (version) {\n      case 4:\n      case ZcashTransaction.VERSION4_BRANCH_CANOPY:\n      case ZcashTransaction.VERSION4_BRANCH_NU5:\n        this.setVersion(4);\n        break;\n      case 5:\n      case ZcashTransaction.VERSION5_BRANCH_NU5:\n        this.setVersion(5);\n        break;\n      default:\n        throw new Error(`invalid version ${version}`);\n    }\n\n    this.tx.versionGroupId = getDefaultVersionGroupIdForVersion(version);\n    this.tx.consensusBranchId = getDefaultConsensusBranchIdForVersion(network, version);\n  }\n\n  private hasSignatures(): boolean {\n    return (this as any).__INPUTS.some(function (input: { signatures: unknown }) {\n      return input.signatures !== undefined;\n    });\n  }\n\n  private setPropertyCheckSignatures(propName: keyof ZcashTransaction<TNumber>, value: unknown) {\n    if (this.tx[propName] === value) {\n      return;\n    }\n    if (this.hasSignatures()) {\n      throw new Error(`Changing property ${propName} for a partially signed transaction would invalidate signatures`);\n    }\n    this.tx[propName] = value as any;\n  }\n\n  setConsensusBranchId(consensusBranchId: number): void {\n    typeforce(types.UInt32, consensusBranchId);\n    this.setPropertyCheckSignatures('consensusBranchId', consensusBranchId);\n  }\n\n  setVersionGroupId(versionGroupId: number): void {\n    typeforce(types.UInt32, versionGroupId);\n    this.setPropertyCheckSignatures('versionGroupId', versionGroupId);\n  }\n\n  setExpiryHeight(expiryHeight: number): void {\n    typeforce(types.UInt32, expiryHeight);\n    this.setPropertyCheckSignatures('expiryHeight', expiryHeight);\n  }\n\n  build(): ZcashTransaction<TNumber> {\n    return super.build() as ZcashTransaction<TNumber>;\n  }\n\n  buildIncomplete(): ZcashTransaction<TNumber> {\n    return super.buildIncomplete() as ZcashTransaction<TNumber>;\n  }\n\n  addOutput(scriptPubKey: string | Buffer, value: TNumber): number {\n    // Attempt to get a script if it's a base58 or bech32 address string\n    if (typeof scriptPubKey === 'string') {\n      scriptPubKey = toOutputScript(scriptPubKey, this.network as Network);\n    }\n\n    return super.addOutput(scriptPubKey, value);\n  }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ /// <reference types="node" />
2
+ import { Base58CheckResult } from 'bitcoinjs-lib/src/address';
3
+ import { Network } from '../../networks';
4
+ export declare function fromBase58Check(address: string): Base58CheckResult;
5
+ export declare function toBase58Check(hash: Buffer, version: number): string;
6
+ export declare function fromOutputScript(outputScript: Buffer, network: Network): string;
7
+ export declare function toOutputScript(address: string, network: Network): Buffer;
8
+ //# sourceMappingURL=address.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"address.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/address.ts"],"names":[],"mappings":";AAGA,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAW,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAIlD,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,iBAAiB,CAKlE;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,CAOnE;AAED,wBAAgB,gBAAgB,CAAC,YAAY,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,MAAM,CAgB/E;AAED,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,MAAM,CAUxE"}
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toOutputScript = exports.fromOutputScript = exports.toBase58Check = exports.fromBase58Check = void 0;
4
+ const assert = require("assert");
5
+ const bitcoinjs_lib_1 = require("bitcoinjs-lib");
6
+ const types = require("bitcoinjs-lib/src/types");
7
+ const networks_1 = require("../../networks");
8
+ const bs58check = require('bs58check');
9
+ const typeforce = require('typeforce');
10
+ function fromBase58Check(address) {
11
+ const payload = bs58check.decode(address);
12
+ const version = payload.readUInt16BE(0);
13
+ const hash = payload.slice(2);
14
+ return { version, hash };
15
+ }
16
+ exports.fromBase58Check = fromBase58Check;
17
+ function toBase58Check(hash, version) {
18
+ typeforce(types.tuple(types.Hash160bit, types.Number), arguments);
19
+ const payload = Buffer.allocUnsafe(22);
20
+ payload.writeUInt16BE(version, 0);
21
+ hash.copy(payload, 2);
22
+ return bs58check.encode(payload);
23
+ }
24
+ exports.toBase58Check = toBase58Check;
25
+ function fromOutputScript(outputScript, network) {
26
+ assert(networks_1.isZcash(network));
27
+ let o;
28
+ let prefix;
29
+ try {
30
+ o = bitcoinjs_lib_1.payments.p2pkh({ output: outputScript });
31
+ prefix = network.pubKeyHash;
32
+ }
33
+ catch (e) { }
34
+ try {
35
+ o = bitcoinjs_lib_1.payments.p2sh({ output: outputScript });
36
+ prefix = network.scriptHash;
37
+ }
38
+ catch (e) { }
39
+ if (!o || !o.hash || prefix === undefined) {
40
+ throw new Error(`unsupported outputScript`);
41
+ }
42
+ return toBase58Check(o.hash, prefix);
43
+ }
44
+ exports.fromOutputScript = fromOutputScript;
45
+ function toOutputScript(address, network) {
46
+ assert(networks_1.isZcash(network));
47
+ const { version, hash } = fromBase58Check(address);
48
+ if (version === network.pubKeyHash) {
49
+ return bitcoinjs_lib_1.payments.p2pkh({ hash }).output;
50
+ }
51
+ if (version === network.scriptHash) {
52
+ return bitcoinjs_lib_1.payments.p2sh({ hash }).output;
53
+ }
54
+ throw new Error(address + ' has no matching Script');
55
+ }
56
+ exports.toOutputScript = toOutputScript;
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkcmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iaXRnby96Y2FzaC9hZGRyZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlDQUFpQztBQUNqQyxpREFBeUM7QUFDekMsaURBQWlEO0FBRWpELDZDQUFrRDtBQUNsRCxNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7QUFDdkMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBRXZDLFNBQWdCLGVBQWUsQ0FBQyxPQUFlO0lBQzdDLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDMUMsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN4QyxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzlCLE9BQU8sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7QUFDM0IsQ0FBQztBQUxELDBDQUtDO0FBRUQsU0FBZ0IsYUFBYSxDQUFDLElBQVksRUFBRSxPQUFlO0lBQ3pELFNBQVMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBRWxFLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDdkMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbEMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDdEIsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQ25DLENBQUM7QUFQRCxzQ0FPQztBQUVELFNBQWdCLGdCQUFnQixDQUFDLFlBQW9CLEVBQUUsT0FBZ0I7SUFDckUsTUFBTSxDQUFDLGtCQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUN6QixJQUFJLENBQUMsQ0FBQztJQUNOLElBQUksTUFBTSxDQUFDO0lBQ1gsSUFBSTtRQUNGLENBQUMsR0FBRyx3QkFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDO0tBQzdCO0lBQUMsT0FBTyxDQUFDLEVBQUUsR0FBRTtJQUNkLElBQUk7UUFDRixDQUFDLEdBQUcsd0JBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztRQUM1QyxNQUFNLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQztLQUM3QjtJQUFDLE9BQU8sQ0FBQyxFQUFFLEdBQUU7SUFDZCxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksSUFBSSxNQUFNLEtBQUssU0FBUyxFQUFFO1FBQ3pDLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLENBQUMsQ0FBQztLQUM3QztJQUNELE9BQU8sYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7QUFDdkMsQ0FBQztBQWhCRCw0Q0FnQkM7QUFFRCxTQUFnQixjQUFjLENBQUMsT0FBZSxFQUFFLE9BQWdCO0lBQzlELE1BQU0sQ0FBQyxrQkFBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDekIsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbkQsSUFBSSxPQUFPLEtBQUssT0FBTyxDQUFDLFVBQVUsRUFBRTtRQUNsQyxPQUFPLHdCQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFnQixDQUFDO0tBQ2xEO0lBQ0QsSUFBSSxPQUFPLEtBQUssT0FBTyxDQUFDLFVBQVUsRUFBRTtRQUNsQyxPQUFPLHdCQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFnQixDQUFDO0tBQ2pEO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxPQUFPLEdBQUcseUJBQXlCLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBVkQsd0NBVUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcbmltcG9ydCB7IHBheW1lbnRzIH0gZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgKiBhcyB0eXBlcyBmcm9tICdiaXRjb2luanMtbGliL3NyYy90eXBlcyc7XG5pbXBvcnQgeyBCYXNlNThDaGVja1Jlc3VsdCB9IGZyb20gJ2JpdGNvaW5qcy1saWIvc3JjL2FkZHJlc3MnO1xuaW1wb3J0IHsgaXNaY2FzaCwgTmV0d29yayB9IGZyb20gJy4uLy4uL25ldHdvcmtzJztcbmNvbnN0IGJzNThjaGVjayA9IHJlcXVpcmUoJ2JzNThjaGVjaycpO1xuY29uc3QgdHlwZWZvcmNlID0gcmVxdWlyZSgndHlwZWZvcmNlJyk7XG5cbmV4cG9ydCBmdW5jdGlvbiBmcm9tQmFzZTU4Q2hlY2soYWRkcmVzczogc3RyaW5nKTogQmFzZTU4Q2hlY2tSZXN1bHQge1xuICBjb25zdCBwYXlsb2FkID0gYnM1OGNoZWNrLmRlY29kZShhZGRyZXNzKTtcbiAgY29uc3QgdmVyc2lvbiA9IHBheWxvYWQucmVhZFVJbnQxNkJFKDApO1xuICBjb25zdCBoYXNoID0gcGF5bG9hZC5zbGljZSgyKTtcbiAgcmV0dXJuIHsgdmVyc2lvbiwgaGFzaCB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9CYXNlNThDaGVjayhoYXNoOiBCdWZmZXIsIHZlcnNpb246IG51bWJlcik6IHN0cmluZyB7XG4gIHR5cGVmb3JjZSh0eXBlcy50dXBsZSh0eXBlcy5IYXNoMTYwYml0LCB0eXBlcy5OdW1iZXIpLCBhcmd1bWVudHMpO1xuXG4gIGNvbnN0IHBheWxvYWQgPSBCdWZmZXIuYWxsb2NVbnNhZmUoMjIpO1xuICBwYXlsb2FkLndyaXRlVUludDE2QkUodmVyc2lvbiwgMCk7XG4gIGhhc2guY29weShwYXlsb2FkLCAyKTtcbiAgcmV0dXJuIGJzNThjaGVjay5lbmNvZGUocGF5bG9hZCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmcm9tT3V0cHV0U2NyaXB0KG91dHB1dFNjcmlwdDogQnVmZmVyLCBuZXR3b3JrOiBOZXR3b3JrKTogc3RyaW5nIHtcbiAgYXNzZXJ0KGlzWmNhc2gobmV0d29yaykpO1xuICBsZXQgbztcbiAgbGV0IHByZWZpeDtcbiAgdHJ5IHtcbiAgICBvID0gcGF5bWVudHMucDJwa2goeyBvdXRwdXQ6IG91dHB1dFNjcmlwdCB9KTtcbiAgICBwcmVmaXggPSBuZXR3b3JrLnB1YktleUhhc2g7XG4gIH0gY2F0Y2ggKGUpIHt9XG4gIHRyeSB7XG4gICAgbyA9IHBheW1lbnRzLnAyc2goeyBvdXRwdXQ6IG91dHB1dFNjcmlwdCB9KTtcbiAgICBwcmVmaXggPSBuZXR3b3JrLnNjcmlwdEhhc2g7XG4gIH0gY2F0Y2ggKGUpIHt9XG4gIGlmICghbyB8fCAhby5oYXNoIHx8IHByZWZpeCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGB1bnN1cHBvcnRlZCBvdXRwdXRTY3JpcHRgKTtcbiAgfVxuICByZXR1cm4gdG9CYXNlNThDaGVjayhvLmhhc2gsIHByZWZpeCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b091dHB1dFNjcmlwdChhZGRyZXNzOiBzdHJpbmcsIG5ldHdvcms6IE5ldHdvcmspOiBCdWZmZXIge1xuICBhc3NlcnQoaXNaY2FzaChuZXR3b3JrKSk7XG4gIGNvbnN0IHsgdmVyc2lvbiwgaGFzaCB9ID0gZnJvbUJhc2U1OENoZWNrKGFkZHJlc3MpO1xuICBpZiAodmVyc2lvbiA9PT0gbmV0d29yay5wdWJLZXlIYXNoKSB7XG4gICAgcmV0dXJuIHBheW1lbnRzLnAycGtoKHsgaGFzaCB9KS5vdXRwdXQgYXMgQnVmZmVyO1xuICB9XG4gIGlmICh2ZXJzaW9uID09PSBuZXR3b3JrLnNjcmlwdEhhc2gpIHtcbiAgICByZXR1cm4gcGF5bWVudHMucDJzaCh7IGhhc2ggfSkub3V0cHV0IGFzIEJ1ZmZlcjtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoYWRkcmVzcyArICcgaGFzIG5vIG1hdGNoaW5nIFNjcmlwdCcpO1xufVxuIl19
@@ -0,0 +1,27 @@
1
+ /// <reference types="node" />
2
+ /**
3
+ * Implements hashing methods described in https://zips.z.cash/zip-0244.
4
+ * Only supports full transparent transactions without shielded inputs or outputs.
5
+ */
6
+ import { TxInput, TxOutput } from 'bitcoinjs-lib';
7
+ import { ZcashTransaction } from './ZcashTransaction';
8
+ declare type SignatureParams<TNumber extends number | bigint = number> = {
9
+ inIndex?: number;
10
+ prevOutScript: Buffer;
11
+ value: TNumber;
12
+ hashType: number;
13
+ };
14
+ /**
15
+ * Blake2b hashing algorithm for Zcash
16
+ * @param buffer
17
+ * @param personalization
18
+ * @returns 256-bit BLAKE2b hash
19
+ */
20
+ export declare function getBlake2bHash(buffer: Buffer, personalization: string | Buffer): Buffer;
21
+ export declare function getPrevoutsDigest<TNumber extends number | bigint>(ins: TxInput[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
22
+ export declare function getSequenceDigest<TNumber extends number | bigint>(ins: TxInput[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
23
+ export declare function getOutputsDigest<TNumber extends number | bigint>(outs: TxOutput<TNumber>[], tag?: string, sigParams?: SignatureParams<TNumber>): Buffer;
24
+ export declare function getTxidDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer;
25
+ export declare function getSignatureDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>, inIndex: number | undefined, prevOutScript: Buffer, value: TNumber, hashType: number): Buffer;
26
+ export {};
27
+ //# sourceMappingURL=hashZip0244.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hashZip0244.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/hashZip0244.ts"],"names":[],"mappings":";AAAA;;;GAGG;AACH,OAAO,EAAe,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAK/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,aAAK,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI;IAC/D,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAIvF;AAcD,wBAAgB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC/D,GAAG,EAAE,OAAO,EAAE,EACd,GAAG,SAAqB,EACxB,SAAS,CAAC,EAAE,eAAe,CAAC,OAAO,CAAC,GACnC,MAAM,CAaR;AAED,wBAAgB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC/D,GAAG,EAAE,OAAO,EAAE,EACd,GAAG,SAAqB,EACxB,SAAS,CAAC,EAAE,eAAe,CAAC,OAAO,CAAC,GACnC,MAAM,CAsBR;AAED,wBAAgB,gBAAgB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC9D,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE,EACzB,GAAG,SAAqB,EACxB,SAAS,CAAC,EAAE,eAAe,CAAC,OAAO,CAAC,GACnC,MAAM,CAsCR;AAoFD,wBAAgB,aAAa,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,EAAE,EAAE,gBAAgB,CAAC,OAAO,CAAC,GAAG,MAAM,CAGpG;AAED,wBAAgB,kBAAkB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAChE,EAAE,EAAE,gBAAgB,CAAC,OAAO,CAAC,EAC7B,OAAO,EAAE,MAAM,GAAG,SAAS,EAC3B,aAAa,EAAE,MAAM,EACrB,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,MAAM,GACf,MAAM,CAQR"}
@@ -0,0 +1,184 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getSignatureDigest = exports.getTxidDigest = exports.getOutputsDigest = exports.getSequenceDigest = exports.getPrevoutsDigest = exports.getBlake2bHash = void 0;
4
+ /**
5
+ * Implements hashing methods described in https://zips.z.cash/zip-0244.
6
+ * Only supports full transparent transactions without shielded inputs or outputs.
7
+ */
8
+ const bitcoinjs_lib_1 = require("bitcoinjs-lib");
9
+ const bufferutils_1 = require("bitcoinjs-lib/src/bufferutils");
10
+ const blake2b = require('@bitgo/blake2b');
11
+ const UtxoTransaction_1 = require("../UtxoTransaction");
12
+ /**
13
+ * Blake2b hashing algorithm for Zcash
14
+ * @param buffer
15
+ * @param personalization
16
+ * @returns 256-bit BLAKE2b hash
17
+ */
18
+ function getBlake2bHash(buffer, personalization) {
19
+ const out = Buffer.allocUnsafe(32);
20
+ personalization = Buffer.from(personalization);
21
+ return blake2b(out.length, null, null, personalization).update(buffer).digest(out);
22
+ }
23
+ exports.getBlake2bHash = getBlake2bHash;
24
+ function getHeaderDigest(tx) {
25
+ // https://zips.z.cash/zip-0244#t-1-header-digest
26
+ const mask = tx.overwintered ? 1 : 0;
27
+ const writer = bufferutils_1.BufferWriter.withCapacity(4 * 5);
28
+ writer.writeInt32(tx.version | (mask << 31)); // Set overwinter bit
29
+ writer.writeUInt32(tx.versionGroupId);
30
+ writer.writeUInt32(tx.consensusBranchId);
31
+ writer.writeUInt32(tx.locktime);
32
+ writer.writeUInt32(tx.expiryHeight);
33
+ return getBlake2bHash(writer.end(), 'ZTxIdHeadersHash');
34
+ }
35
+ function getPrevoutsDigest(ins, tag = 'ZTxIdPrevoutHash', sigParams) {
36
+ if (sigParams) {
37
+ if (sigParams.hashType & bitcoinjs_lib_1.Transaction.SIGHASH_ANYONECANPAY) {
38
+ return getPrevoutsDigest([]);
39
+ }
40
+ }
41
+ const bufferWriter = new bufferutils_1.BufferWriter(Buffer.allocUnsafe(36 * ins.length));
42
+ ins.forEach(function (txIn) {
43
+ bufferWriter.writeSlice(txIn.hash);
44
+ bufferWriter.writeUInt32(txIn.index);
45
+ });
46
+ return getBlake2bHash(bufferWriter.end(), tag);
47
+ }
48
+ exports.getPrevoutsDigest = getPrevoutsDigest;
49
+ function getSequenceDigest(ins, tag = 'ZTxIdSequencHash', sigParams) {
50
+ // txid: https://zips.z.cash/zip-0244#t-2b-sequence-digest
51
+ // sig: https://zips.z.cash/zip-0244#s-2b-sequence-sig-digest
52
+ // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L263
53
+ if (sigParams) {
54
+ const { hashType } = sigParams;
55
+ if (hashType & bitcoinjs_lib_1.Transaction.SIGHASH_ANYONECANPAY ||
56
+ (hashType & 0x1f) === bitcoinjs_lib_1.Transaction.SIGHASH_SINGLE ||
57
+ (hashType & 0x1f) === bitcoinjs_lib_1.Transaction.SIGHASH_NONE) {
58
+ return getSequenceDigest([]);
59
+ }
60
+ }
61
+ const bufferWriter = new bufferutils_1.BufferWriter(Buffer.allocUnsafe(4 * ins.length));
62
+ ins.forEach(function (txIn) {
63
+ bufferWriter.writeUInt32(txIn.sequence);
64
+ });
65
+ return getBlake2bHash(bufferWriter.end(), tag);
66
+ }
67
+ exports.getSequenceDigest = getSequenceDigest;
68
+ function getOutputsDigest(outs, tag = 'ZTxIdOutputsHash', sigParams) {
69
+ // txid: https://zips.z.cash/zip-0244#t-2c-outputs-digest
70
+ // sig: https://zips.z.cash/zip-0244#s-2c-outputs-sig-digest
71
+ // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L275
72
+ if (sigParams) {
73
+ let { hashType } = sigParams;
74
+ hashType = hashType & 0x1f;
75
+ if (hashType === bitcoinjs_lib_1.Transaction.SIGHASH_SINGLE) {
76
+ if (sigParams.inIndex === undefined) {
77
+ throw new Error();
78
+ }
79
+ if (outs[sigParams.inIndex] === undefined) {
80
+ return getOutputsDigest(outs);
81
+ }
82
+ return getOutputsDigest([outs[sigParams.inIndex]]);
83
+ }
84
+ if (hashType === bitcoinjs_lib_1.Transaction.SIGHASH_NONE) {
85
+ return getOutputsDigest([]);
86
+ }
87
+ return getOutputsDigest(outs, tag);
88
+ }
89
+ // Find out the size of the outputs and write them
90
+ const txOutsSize = outs.reduce(function (sum, output) {
91
+ return sum + 8 + UtxoTransaction_1.varSliceSize(output.script);
92
+ }, 0);
93
+ const bufferWriter = new bufferutils_1.BufferWriter(Buffer.allocUnsafe(txOutsSize));
94
+ outs.forEach(function (out) {
95
+ bufferWriter.writeUInt64(out.value);
96
+ bufferWriter.writeVarSlice(out.script);
97
+ });
98
+ return getBlake2bHash(bufferWriter.end(), tag);
99
+ }
100
+ exports.getOutputsDigest = getOutputsDigest;
101
+ function getTxinDigest(input, sigParams) {
102
+ // https://zips.z.cash/zip-0244#s-2d-txin-sig-digest
103
+ // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L291
104
+ const writer = bufferutils_1.BufferWriter.withCapacity(32 /* prevout hash */ +
105
+ 4 /* prevout vin */ +
106
+ UtxoTransaction_1.varSliceSize(sigParams.prevOutScript) +
107
+ 8 /* value */ +
108
+ 4 /* sequence */);
109
+ writer.writeSlice(input.hash);
110
+ writer.writeUInt32(input.index);
111
+ writer.writeVarSlice(sigParams.prevOutScript);
112
+ writer.writeUInt64(sigParams.value);
113
+ writer.writeUInt32(input.sequence);
114
+ return getBlake2bHash(writer.end(), 'Zcash___TxInHash');
115
+ }
116
+ function getTransparentDigest(tx, sigParams) {
117
+ // txid: https://zips.z.cash/zip-0244#t-2-transparent-digest
118
+ // sig: https://zips.z.cash/zip-0244#s-2a-prevouts-sig-digest
119
+ if (sigParams) {
120
+ if (sigParams.inIndex === undefined) {
121
+ return getTransparentDigest(tx);
122
+ }
123
+ }
124
+ let buffer;
125
+ if (tx.ins.length || tx.outs.length) {
126
+ const writer = bufferutils_1.BufferWriter.withCapacity(32 * (sigParams ? 4 : 3));
127
+ writer.writeSlice(getPrevoutsDigest(tx.ins, undefined, sigParams));
128
+ writer.writeSlice(getSequenceDigest(tx.ins, undefined, sigParams));
129
+ writer.writeSlice(getOutputsDigest(tx.outs, undefined, sigParams));
130
+ if (sigParams) {
131
+ if (sigParams.inIndex === undefined) {
132
+ throw new Error();
133
+ }
134
+ writer.writeSlice(getTxinDigest(tx.ins[sigParams.inIndex], sigParams));
135
+ }
136
+ buffer = writer.end();
137
+ }
138
+ else {
139
+ buffer = Buffer.of();
140
+ }
141
+ return getBlake2bHash(buffer, 'ZTxIdTranspaHash');
142
+ }
143
+ function getSaplingDigest(tx) {
144
+ // https://zips.z.cash/zip-0244#t-3-sapling-digest
145
+ return getBlake2bHash(Buffer.of(), 'ZTxIdSaplingHash');
146
+ }
147
+ function getOrchardDigest(tx) {
148
+ // https://zips.z.cash/zip-0244#t-4-orchard-digest
149
+ return getBlake2bHash(Buffer.of(), 'ZTxIdOrchardHash');
150
+ }
151
+ /**
152
+ * @param tx
153
+ * @param signatureParams - calculates txid when undefined
154
+ */
155
+ function getDigest(tx, signatureParams) {
156
+ // txid: https://zips.z.cash/zip-0244#id4
157
+ // sig: https://zips.z.cash/zip-0244#id13
158
+ const writer = bufferutils_1.BufferWriter.withCapacity(32 * 4);
159
+ writer.writeSlice(getHeaderDigest(tx));
160
+ writer.writeSlice(getTransparentDigest(tx, signatureParams));
161
+ writer.writeSlice(getSaplingDigest(tx));
162
+ writer.writeSlice(getOrchardDigest(tx));
163
+ const tag = 'ZcashTxHash_';
164
+ const personalization = bufferutils_1.BufferWriter.withCapacity(tag.length + 4 /* UInt32 */);
165
+ personalization.writeSlice(Buffer.from(tag));
166
+ personalization.writeUInt32(tx.consensusBranchId);
167
+ return getBlake2bHash(writer.end(), personalization.end());
168
+ }
169
+ function getTxidDigest(tx) {
170
+ // https://zips.z.cash/zip-0244#id4
171
+ return getDigest(tx);
172
+ }
173
+ exports.getTxidDigest = getTxidDigest;
174
+ function getSignatureDigest(tx, inIndex, prevOutScript, value, hashType) {
175
+ // https://zips.z.cash/zip-0244#id13
176
+ return getDigest(tx, {
177
+ inIndex,
178
+ prevOutScript,
179
+ value,
180
+ hashType,
181
+ });
182
+ }
183
+ exports.getSignatureDigest = getSignatureDigest;
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hashZip0244.js","sourceRoot":"","sources":["../../../../src/bitgo/zcash/hashZip0244.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Implements hashing methods described in https://zips.z.cash/zip-0244.\n * Only supports full transparent transactions without shielded inputs or outputs.\n */\nimport { Transaction, TxInput, TxOutput } from 'bitcoinjs-lib';\nimport { BufferWriter } from 'bitcoinjs-lib/src/bufferutils';\n\nconst blake2b = require('@bitgo/blake2b');\n\nimport { ZcashTransaction } from './ZcashTransaction';\nimport { varSliceSize } from '../UtxoTransaction';\n\ntype SignatureParams<TNumber extends number | bigint = number> = {\n  inIndex?: number;\n  prevOutScript: Buffer;\n  value: TNumber;\n  hashType: number;\n};\n\n/**\n * Blake2b hashing algorithm for Zcash\n * @param buffer\n * @param personalization\n * @returns 256-bit BLAKE2b hash\n */\nexport function getBlake2bHash(buffer: Buffer, personalization: string | Buffer): Buffer {\n  const out = Buffer.allocUnsafe(32);\n  personalization = Buffer.from(personalization);\n  return blake2b(out.length, null, null, personalization).update(buffer).digest(out);\n}\n\nfunction getHeaderDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-1-header-digest\n  const mask = tx.overwintered ? 1 : 0;\n  const writer = BufferWriter.withCapacity(4 * 5);\n  writer.writeInt32(tx.version | (mask << 31)); // Set overwinter bit\n  writer.writeUInt32(tx.versionGroupId);\n  writer.writeUInt32(tx.consensusBranchId);\n  writer.writeUInt32(tx.locktime);\n  writer.writeUInt32(tx.expiryHeight);\n  return getBlake2bHash(writer.end(), 'ZTxIdHeadersHash');\n}\n\nexport function getPrevoutsDigest<TNumber extends number | bigint>(\n  ins: TxInput[],\n  tag = 'ZTxIdPrevoutHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  if (sigParams) {\n    if (sigParams.hashType & Transaction.SIGHASH_ANYONECANPAY) {\n      return getPrevoutsDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(36 * ins.length));\n  ins.forEach(function (txIn) {\n    bufferWriter.writeSlice(txIn.hash);\n    bufferWriter.writeUInt32(txIn.index);\n  });\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getSequenceDigest<TNumber extends number | bigint>(\n  ins: TxInput[],\n  tag = 'ZTxIdSequencHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2b-sequence-digest\n  // sig: https://zips.z.cash/zip-0244#s-2b-sequence-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L263\n  if (sigParams) {\n    const { hashType } = sigParams;\n    if (\n      hashType & Transaction.SIGHASH_ANYONECANPAY ||\n      (hashType & 0x1f) === Transaction.SIGHASH_SINGLE ||\n      (hashType & 0x1f) === Transaction.SIGHASH_NONE\n    ) {\n      return getSequenceDigest([]);\n    }\n  }\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(4 * ins.length));\n\n  ins.forEach(function (txIn) {\n    bufferWriter.writeUInt32(txIn.sequence);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nexport function getOutputsDigest<TNumber extends number | bigint>(\n  outs: TxOutput<TNumber>[],\n  tag = 'ZTxIdOutputsHash',\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2c-outputs-digest\n  // sig: https://zips.z.cash/zip-0244#s-2c-outputs-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L275\n  if (sigParams) {\n    let { hashType } = sigParams;\n    hashType = hashType & 0x1f;\n\n    if (hashType === Transaction.SIGHASH_SINGLE) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      if (outs[sigParams.inIndex] === undefined) {\n        return getOutputsDigest(outs);\n      }\n      return getOutputsDigest([outs[sigParams.inIndex]]);\n    }\n\n    if (hashType === Transaction.SIGHASH_NONE) {\n      return getOutputsDigest([]);\n    }\n\n    return getOutputsDigest(outs, tag);\n  }\n\n  // Find out the size of the outputs and write them\n  const txOutsSize = outs.reduce(function (sum, output) {\n    return sum + 8 + varSliceSize(output.script);\n  }, 0);\n\n  const bufferWriter = new BufferWriter(Buffer.allocUnsafe(txOutsSize));\n\n  outs.forEach(function (out) {\n    bufferWriter.writeUInt64(out.value);\n    bufferWriter.writeVarSlice(out.script);\n  });\n\n  return getBlake2bHash(bufferWriter.end(), tag);\n}\n\nfunction getTxinDigest<TNumber extends number | bigint>(input: TxInput, sigParams: SignatureParams<TNumber>) {\n  // https://zips.z.cash/zip-0244#s-2d-txin-sig-digest\n  // https://github.com/zcash-hackworks/zcash-test-vectors/blob/dd8fdb/zip_0244.py#L291\n  const writer = BufferWriter.withCapacity(\n    32 /* prevout hash */ +\n      4 /* prevout vin */ +\n      varSliceSize(sigParams.prevOutScript) +\n      8 /* value */ +\n      4 /* sequence */\n  );\n  writer.writeSlice(input.hash);\n  writer.writeUInt32(input.index);\n  writer.writeVarSlice(sigParams.prevOutScript);\n  writer.writeUInt64(sigParams.value);\n  writer.writeUInt32(input.sequence);\n  return getBlake2bHash(writer.end(), 'Zcash___TxInHash');\n}\n\nfunction getTransparentDigest<TNumber extends number | bigint>(\n  tx: { ins: TxInput[]; outs: TxOutput<TNumber>[] },\n  sigParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#t-2-transparent-digest\n  // sig: https://zips.z.cash/zip-0244#s-2a-prevouts-sig-digest\n  if (sigParams) {\n    if (sigParams.inIndex === undefined) {\n      return getTransparentDigest(tx);\n    }\n  }\n\n  let buffer;\n  if (tx.ins.length || tx.outs.length) {\n    const writer = BufferWriter.withCapacity(32 * (sigParams ? 4 : 3));\n    writer.writeSlice(getPrevoutsDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getSequenceDigest(tx.ins, undefined, sigParams));\n    writer.writeSlice(getOutputsDigest(tx.outs, undefined, sigParams));\n    if (sigParams) {\n      if (sigParams.inIndex === undefined) {\n        throw new Error();\n      }\n      writer.writeSlice(getTxinDigest(tx.ins[sigParams.inIndex], sigParams));\n    }\n    buffer = writer.end();\n  } else {\n    buffer = Buffer.of();\n  }\n  return getBlake2bHash(buffer, 'ZTxIdTranspaHash');\n}\n\nfunction getSaplingDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-3-sapling-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdSaplingHash');\n}\n\nfunction getOrchardDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#t-4-orchard-digest\n  return getBlake2bHash(Buffer.of(), 'ZTxIdOrchardHash');\n}\n\n/**\n * @param tx\n * @param signatureParams - calculates txid when undefined\n */\nfunction getDigest<TNumber extends number | bigint>(\n  tx: ZcashTransaction<TNumber>,\n  signatureParams?: SignatureParams<TNumber>\n): Buffer {\n  // txid: https://zips.z.cash/zip-0244#id4\n  // sig: https://zips.z.cash/zip-0244#id13\n  const writer = BufferWriter.withCapacity(32 * 4);\n  writer.writeSlice(getHeaderDigest(tx));\n  writer.writeSlice(getTransparentDigest(tx, signatureParams));\n  writer.writeSlice(getSaplingDigest(tx));\n  writer.writeSlice(getOrchardDigest(tx));\n\n  const tag = 'ZcashTxHash_';\n  const personalization = BufferWriter.withCapacity(tag.length + 4 /* UInt32 */);\n  personalization.writeSlice(Buffer.from(tag));\n  personalization.writeUInt32(tx.consensusBranchId);\n  return getBlake2bHash(writer.end(), personalization.end());\n}\n\nexport function getTxidDigest<TNumber extends number | bigint>(tx: ZcashTransaction<TNumber>): Buffer {\n  // https://zips.z.cash/zip-0244#id4\n  return getDigest(tx);\n}\n\nexport function getSignatureDigest<TNumber extends number | bigint>(\n  tx: ZcashTransaction<TNumber>,\n  inIndex: number | undefined,\n  prevOutScript: Buffer,\n  value: TNumber,\n  hashType: number\n): Buffer {\n  // https://zips.z.cash/zip-0244#id13\n  return getDigest(tx, {\n    inIndex,\n    prevOutScript,\n    value,\n    hashType,\n  });\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export * from './ZcashPsbt';
2
+ export * from './ZcashTransaction';
3
+ export * from './ZcashTransactionBuilder';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/zcash/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,oBAAoB,CAAC;AACnC,cAAc,2BAA2B,CAAC"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./ZcashPsbt"), exports);
14
+ __exportStar(require("./ZcashTransaction"), exports);
15
+ __exportStar(require("./ZcashTransactionBuilder"), exports);
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vemNhc2gvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsOENBQTRCO0FBQzVCLHFEQUFtQztBQUNuQyw0REFBMEMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL1pjYXNoUHNidCc7XG5leHBvcnQgKiBmcm9tICcuL1pjYXNoVHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9aY2FzaFRyYW5zYWN0aW9uQnVpbGRlcic7XG4iXX0=
@@ -0,0 +1,19 @@
1
+ /// <reference types="node" />
2
+ declare const types: {
3
+ P2MS: string;
4
+ NONSTANDARD: string;
5
+ NULLDATA: string;
6
+ P2PK: string;
7
+ P2PKH: string;
8
+ P2SH: string;
9
+ P2WPKH: string;
10
+ P2WSH: string;
11
+ P2TR: string;
12
+ P2TR_NS: string;
13
+ WITNESS_COMMITMENT: string;
14
+ };
15
+ declare function classifyOutput(script: Buffer): string;
16
+ declare function classifyInput(script: Buffer, allowIncomplete?: boolean): string;
17
+ declare function classifyWitness(script: Buffer[], allowIncomplete?: boolean): string;
18
+ export { classifyInput as input, classifyOutput as output, classifyWitness as witness, types };
19
+ //# sourceMappingURL=classify.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"classify.d.ts","sourceRoot":"","sources":["../../src/classify.ts"],"names":[],"mappings":";AAYA,QAAA,MAAM,KAAK;;;;;;;;;;;;CAYV,CAAC;AAEF,iBAAS,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAkB9C;AAED,iBAAS,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,MAAM,CAYxE;AAED,iBAAS,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,MAAM,CAU5E;AAED,OAAO,EAAE,aAAa,IAAI,KAAK,EAAE,cAAc,IAAI,MAAM,EAAE,eAAe,IAAI,OAAO,EAAE,KAAK,EAAE,CAAC"}