@bitgo-beta/abstract-utxo 1.6.1-alpha.42 → 1.6.1-alpha.420

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (738) hide show
  1. package/README.md +76 -0
  2. package/dist/cjs/src/abstractUtxoCoin.d.ts +464 -0
  3. package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -0
  4. package/dist/cjs/src/abstractUtxoCoin.js +639 -0
  5. package/dist/cjs/src/address/fixedScript.d.ts +51 -0
  6. package/dist/cjs/src/address/fixedScript.d.ts.map +1 -0
  7. package/dist/cjs/src/address/fixedScript.js +150 -0
  8. package/dist/cjs/src/address/index.d.ts +2 -0
  9. package/dist/cjs/src/address/index.d.ts.map +1 -0
  10. package/dist/cjs/src/address/index.js +8 -0
  11. package/dist/cjs/src/config.d.ts.map +1 -0
  12. package/dist/cjs/src/config.js +14 -0
  13. package/dist/cjs/src/descriptor/NamedDescriptor.d.ts +20 -0
  14. package/dist/cjs/src/descriptor/NamedDescriptor.d.ts.map +1 -0
  15. package/dist/cjs/src/descriptor/NamedDescriptor.js +79 -0
  16. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  17. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  18. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.js +66 -0
  19. package/dist/cjs/src/descriptor/builder/builder.d.ts +13 -0
  20. package/dist/cjs/src/descriptor/builder/builder.d.ts.map +1 -0
  21. package/dist/cjs/src/descriptor/builder/builder.js +37 -0
  22. package/dist/cjs/src/descriptor/builder/index.d.ts +3 -0
  23. package/dist/cjs/src/descriptor/builder/index.d.ts.map +1 -0
  24. package/dist/cjs/src/descriptor/builder/index.js +8 -0
  25. package/dist/cjs/src/descriptor/builder/parse.d.ts +5 -0
  26. package/dist/cjs/src/descriptor/builder/parse.d.ts.map +1 -0
  27. package/dist/cjs/src/descriptor/builder/parse.js +116 -0
  28. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  29. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  30. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.js +41 -0
  31. package/dist/cjs/src/descriptor/createWallet/createDescriptors.d.ts +12 -0
  32. package/dist/cjs/src/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  33. package/dist/cjs/src/descriptor/createWallet/createDescriptors.js +33 -0
  34. package/dist/cjs/src/descriptor/createWallet/index.d.ts +3 -0
  35. package/dist/cjs/src/descriptor/createWallet/index.d.ts.map +1 -0
  36. package/dist/cjs/src/descriptor/createWallet/index.js +19 -0
  37. package/dist/cjs/src/descriptor/descriptorWallet.d.ts +19 -0
  38. package/dist/cjs/src/descriptor/descriptorWallet.d.ts.map +1 -0
  39. package/dist/cjs/src/descriptor/descriptorWallet.js +54 -0
  40. package/dist/cjs/src/descriptor/index.d.ts +8 -0
  41. package/dist/cjs/src/descriptor/index.d.ts.map +1 -0
  42. package/dist/cjs/src/descriptor/index.js +53 -0
  43. package/dist/cjs/src/descriptor/validatePolicy.d.ts +22 -0
  44. package/dist/cjs/src/descriptor/validatePolicy.d.ts.map +1 -0
  45. package/dist/cjs/src/descriptor/validatePolicy.js +92 -0
  46. package/dist/cjs/src/impl/bch/bch.d.ts +20 -0
  47. package/dist/cjs/src/impl/bch/bch.d.ts.map +1 -0
  48. package/dist/cjs/src/impl/bch/bch.js +70 -0
  49. package/dist/cjs/src/impl/bch/index.d.ts +3 -0
  50. package/dist/cjs/src/impl/bch/index.d.ts.map +1 -0
  51. package/dist/cjs/src/impl/bch/index.js +19 -0
  52. package/dist/cjs/src/impl/bch/tbch.d.ts +10 -0
  53. package/dist/cjs/src/impl/bch/tbch.d.ts.map +1 -0
  54. package/dist/cjs/src/impl/bch/tbch.js +48 -0
  55. package/dist/cjs/src/impl/bcha/bcha.d.ts +9 -0
  56. package/dist/cjs/src/impl/bcha/bcha.d.ts.map +1 -0
  57. package/dist/cjs/src/impl/bcha/bcha.js +58 -0
  58. package/dist/cjs/src/impl/bcha/index.d.ts +3 -0
  59. package/dist/cjs/src/impl/bcha/index.d.ts.map +1 -0
  60. package/dist/cjs/src/impl/bcha/index.js +19 -0
  61. package/dist/cjs/src/impl/bcha/tbcha.d.ts +10 -0
  62. package/dist/cjs/src/impl/bcha/tbcha.d.ts.map +1 -0
  63. package/dist/cjs/src/impl/bcha/tbcha.js +48 -0
  64. package/dist/cjs/src/impl/bsv/bsv.d.ts +8 -0
  65. package/dist/cjs/src/impl/bsv/bsv.d.ts.map +1 -0
  66. package/dist/cjs/src/impl/bsv/bsv.js +48 -0
  67. package/dist/cjs/src/impl/bsv/index.d.ts +3 -0
  68. package/dist/cjs/src/impl/bsv/index.d.ts.map +1 -0
  69. package/dist/cjs/src/impl/bsv/index.js +19 -0
  70. package/dist/cjs/src/impl/bsv/tbsv.d.ts +10 -0
  71. package/dist/cjs/src/impl/bsv/tbsv.d.ts.map +1 -0
  72. package/dist/cjs/src/impl/bsv/tbsv.js +48 -0
  73. package/dist/cjs/src/impl/btc/btc.d.ts +13 -0
  74. package/dist/cjs/src/impl/btc/btc.d.ts.map +1 -0
  75. package/dist/cjs/src/impl/btc/btc.js +55 -0
  76. package/dist/cjs/src/impl/btc/index.d.ts +7 -0
  77. package/dist/cjs/src/impl/btc/index.d.ts.map +1 -0
  78. package/dist/cjs/src/impl/btc/index.js +23 -0
  79. package/dist/cjs/src/impl/btc/inscriptionBuilder.d.ts +51 -0
  80. package/dist/cjs/src/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  81. package/dist/cjs/src/impl/btc/inscriptionBuilder.js +183 -0
  82. package/dist/cjs/src/impl/btc/tbtc.d.ts +10 -0
  83. package/dist/cjs/src/impl/btc/tbtc.d.ts.map +1 -0
  84. package/dist/cjs/src/impl/btc/tbtc.js +48 -0
  85. package/dist/cjs/src/impl/btc/tbtc4.d.ts +10 -0
  86. package/dist/cjs/src/impl/btc/tbtc4.d.ts.map +1 -0
  87. package/dist/cjs/src/impl/btc/tbtc4.js +48 -0
  88. package/dist/cjs/src/impl/btc/tbtcbgsig.d.ts +10 -0
  89. package/dist/cjs/src/impl/btc/tbtcbgsig.d.ts.map +1 -0
  90. package/dist/cjs/src/impl/btc/tbtcbgsig.js +48 -0
  91. package/dist/cjs/src/impl/btc/tbtcsig.d.ts +10 -0
  92. package/dist/cjs/src/impl/btc/tbtcsig.d.ts.map +1 -0
  93. package/dist/cjs/src/impl/btc/tbtcsig.js +48 -0
  94. package/dist/cjs/src/impl/btg/btg.d.ts +7 -0
  95. package/dist/cjs/src/impl/btg/btg.d.ts.map +1 -0
  96. package/dist/cjs/src/impl/btg/btg.js +48 -0
  97. package/dist/cjs/src/impl/btg/index.d.ts +2 -0
  98. package/dist/cjs/src/impl/btg/index.d.ts.map +1 -0
  99. package/dist/cjs/src/impl/btg/index.js +18 -0
  100. package/dist/cjs/src/impl/dash/dash.d.ts +7 -0
  101. package/dist/cjs/src/impl/dash/dash.d.ts.map +1 -0
  102. package/dist/cjs/src/impl/dash/dash.js +48 -0
  103. package/dist/cjs/src/impl/dash/index.d.ts +3 -0
  104. package/dist/cjs/src/impl/dash/index.d.ts.map +1 -0
  105. package/dist/cjs/src/impl/dash/index.js +19 -0
  106. package/dist/cjs/src/impl/dash/tdash.d.ts +10 -0
  107. package/dist/cjs/src/impl/dash/tdash.d.ts.map +1 -0
  108. package/dist/cjs/src/impl/dash/tdash.js +48 -0
  109. package/dist/cjs/src/impl/doge/doge.d.ts +31 -0
  110. package/dist/cjs/src/impl/doge/doge.d.ts.map +1 -0
  111. package/dist/cjs/src/impl/doge/doge.js +79 -0
  112. package/dist/cjs/src/impl/doge/index.d.ts +3 -0
  113. package/dist/cjs/src/impl/doge/index.d.ts.map +1 -0
  114. package/dist/cjs/src/impl/doge/index.js +19 -0
  115. package/dist/cjs/src/impl/doge/tdoge.d.ts +10 -0
  116. package/dist/cjs/src/impl/doge/tdoge.d.ts.map +1 -0
  117. package/dist/cjs/src/impl/doge/tdoge.js +48 -0
  118. package/dist/cjs/src/impl/index.d.ts +10 -0
  119. package/dist/cjs/src/impl/index.d.ts.map +1 -0
  120. package/dist/cjs/src/impl/index.js +46 -0
  121. package/dist/cjs/src/impl/ltc/index.d.ts +3 -0
  122. package/dist/cjs/src/impl/ltc/index.d.ts.map +1 -0
  123. package/dist/cjs/src/impl/ltc/index.js +19 -0
  124. package/dist/cjs/src/impl/ltc/ltc.d.ts +7 -0
  125. package/dist/cjs/src/impl/ltc/ltc.d.ts.map +1 -0
  126. package/dist/cjs/src/impl/ltc/ltc.js +52 -0
  127. package/dist/cjs/src/impl/ltc/tltc.d.ts +7 -0
  128. package/dist/cjs/src/impl/ltc/tltc.d.ts.map +1 -0
  129. package/dist/cjs/src/impl/ltc/tltc.js +51 -0
  130. package/dist/cjs/src/impl/zec/index.d.ts +3 -0
  131. package/dist/cjs/src/impl/zec/index.d.ts.map +1 -0
  132. package/dist/cjs/src/impl/zec/index.js +19 -0
  133. package/dist/cjs/src/impl/zec/tzec.d.ts +7 -0
  134. package/dist/cjs/src/impl/zec/tzec.d.ts.map +1 -0
  135. package/dist/cjs/src/impl/zec/tzec.js +48 -0
  136. package/dist/cjs/src/impl/zec/zec.d.ts +10 -0
  137. package/dist/cjs/src/impl/zec/zec.d.ts.map +1 -0
  138. package/dist/cjs/src/impl/zec/zec.js +48 -0
  139. package/dist/cjs/src/index.d.ts +21 -0
  140. package/dist/cjs/src/index.d.ts.map +1 -0
  141. package/dist/cjs/src/index.js +60 -0
  142. package/dist/cjs/src/keychains.d.ts +48 -0
  143. package/dist/cjs/src/keychains.d.ts.map +1 -0
  144. package/dist/cjs/src/keychains.js +104 -0
  145. package/dist/cjs/src/names.d.ts +26 -0
  146. package/dist/cjs/src/names.d.ts.map +1 -0
  147. package/dist/cjs/src/names.js +214 -0
  148. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  149. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  150. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.js +26 -0
  151. package/dist/cjs/src/offlineVault/OfflineVaultSignable.d.ts +46 -0
  152. package/dist/cjs/src/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  153. package/dist/cjs/src/offlineVault/OfflineVaultSignable.js +55 -0
  154. package/dist/cjs/src/offlineVault/TransactionExplanation.d.ts +15 -0
  155. package/dist/cjs/src/offlineVault/TransactionExplanation.d.ts.map +1 -0
  156. package/dist/cjs/src/offlineVault/TransactionExplanation.js +16 -0
  157. package/dist/cjs/src/offlineVault/descriptor/index.d.ts +2 -0
  158. package/dist/cjs/src/offlineVault/descriptor/index.d.ts.map +1 -0
  159. package/dist/cjs/src/offlineVault/descriptor/index.js +18 -0
  160. package/dist/cjs/src/offlineVault/descriptor/transaction.d.ts +38 -0
  161. package/dist/cjs/src/offlineVault/descriptor/transaction.d.ts.map +1 -0
  162. package/dist/cjs/src/offlineVault/descriptor/transaction.js +80 -0
  163. package/dist/cjs/src/offlineVault/index.d.ts +6 -0
  164. package/dist/cjs/src/offlineVault/index.d.ts.map +1 -0
  165. package/dist/cjs/src/offlineVault/index.js +44 -0
  166. package/dist/{src → cjs/src}/recovery/RecoveryProvider.d.ts +1 -1
  167. package/dist/cjs/src/recovery/RecoveryProvider.d.ts.map +1 -0
  168. package/dist/cjs/src/recovery/RecoveryProvider.js +22 -0
  169. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts +88 -0
  170. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts.map +1 -0
  171. package/dist/cjs/src/recovery/backupKeyRecovery.js +370 -0
  172. package/dist/{src → cjs/src}/recovery/baseApi.d.ts +3 -6
  173. package/dist/cjs/src/recovery/baseApi.d.ts.map +1 -0
  174. package/dist/cjs/src/recovery/baseApi.js +73 -0
  175. package/dist/{src → cjs/src}/recovery/coingeckoApi.d.ts +0 -3
  176. package/dist/cjs/src/recovery/coingeckoApi.d.ts.map +1 -0
  177. package/dist/cjs/src/recovery/coingeckoApi.js +44 -0
  178. package/dist/{src → cjs/src}/recovery/crossChainRecovery.d.ts +5 -4
  179. package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -0
  180. package/dist/cjs/src/recovery/crossChainRecovery.js +364 -0
  181. package/dist/{src → cjs/src}/recovery/index.d.ts +0 -1
  182. package/dist/cjs/src/recovery/index.d.ts.map +1 -0
  183. package/dist/{src → cjs/src}/recovery/index.js +6 -3
  184. package/dist/cjs/src/recovery/mempoolApi.d.ts.map +1 -0
  185. package/dist/cjs/src/recovery/mempoolApi.js +36 -0
  186. package/dist/{src → cjs/src}/replayProtection.d.ts +1 -0
  187. package/dist/cjs/src/replayProtection.d.ts.map +1 -0
  188. package/dist/cjs/src/replayProtection.js +58 -0
  189. package/dist/{src → cjs/src}/sign.d.ts +31 -8
  190. package/dist/cjs/src/sign.d.ts.map +1 -0
  191. package/dist/cjs/src/sign.js +205 -0
  192. package/dist/cjs/src/transaction/bip322.d.ts +27 -0
  193. package/dist/cjs/src/transaction/bip322.d.ts.map +1 -0
  194. package/dist/cjs/src/transaction/bip322.js +125 -0
  195. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts +2 -0
  196. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  197. package/dist/cjs/src/transaction/common/verifyPayGoAmount.js +3 -0
  198. package/dist/cjs/src/transaction/descriptor/explainPsbt.d.ts +5 -0
  199. package/dist/cjs/src/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  200. package/dist/cjs/src/transaction/descriptor/explainPsbt.js +80 -0
  201. package/dist/cjs/src/transaction/descriptor/index.d.ts +7 -0
  202. package/dist/cjs/src/transaction/descriptor/index.d.ts.map +1 -0
  203. package/dist/cjs/src/transaction/descriptor/index.js +14 -0
  204. package/dist/cjs/src/transaction/descriptor/parse.d.ts +15 -0
  205. package/dist/cjs/src/transaction/descriptor/parse.d.ts.map +1 -0
  206. package/dist/cjs/src/transaction/descriptor/parse.js +116 -0
  207. package/dist/cjs/src/transaction/descriptor/parseToAmountType.d.ts +13 -0
  208. package/dist/cjs/src/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  209. package/dist/cjs/src/transaction/descriptor/parseToAmountType.js +60 -0
  210. package/dist/cjs/src/transaction/descriptor/recipient.d.ts +5 -0
  211. package/dist/cjs/src/transaction/descriptor/recipient.d.ts.map +1 -0
  212. package/dist/cjs/src/transaction/descriptor/recipient.js +3 -0
  213. package/dist/cjs/src/transaction/descriptor/signPsbt.d.ts +25 -0
  214. package/dist/cjs/src/transaction/descriptor/signPsbt.d.ts.map +1 -0
  215. package/dist/cjs/src/transaction/descriptor/signPsbt.js +43 -0
  216. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts +35 -0
  217. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  218. package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +108 -0
  219. package/dist/cjs/src/transaction/explainTransaction.d.ts +18 -0
  220. package/dist/cjs/src/transaction/explainTransaction.d.ts.map +1 -0
  221. package/dist/cjs/src/transaction/explainTransaction.js +88 -0
  222. package/dist/cjs/src/transaction/fetchInputs.d.ts +26 -0
  223. package/dist/cjs/src/transaction/fetchInputs.d.ts.map +1 -0
  224. package/dist/cjs/src/transaction/fetchInputs.js +109 -0
  225. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +10 -0
  226. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  227. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +43 -0
  228. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts +63 -0
  229. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  230. package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +321 -0
  231. package/dist/cjs/src/transaction/fixedScript/index.d.ts +7 -0
  232. package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -0
  233. package/dist/cjs/src/transaction/fixedScript/index.js +15 -0
  234. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts +26 -0
  235. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  236. package/dist/cjs/src/transaction/fixedScript/parseOutput.js +213 -0
  237. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts +7 -0
  238. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  239. package/dist/cjs/src/transaction/fixedScript/parseTransaction.js +203 -0
  240. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts +18 -0
  241. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  242. package/dist/cjs/src/transaction/fixedScript/signTransaction.js +101 -0
  243. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  244. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  245. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +198 -0
  246. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  247. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  248. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.js +53 -0
  249. package/dist/cjs/src/transaction/index.d.ts +7 -0
  250. package/dist/cjs/src/transaction/index.d.ts.map +1 -0
  251. package/dist/cjs/src/transaction/index.js +49 -0
  252. package/dist/cjs/src/transaction/outputDifference.d.ts +40 -0
  253. package/dist/cjs/src/transaction/outputDifference.d.ts.map +1 -0
  254. package/dist/cjs/src/transaction/outputDifference.js +47 -0
  255. package/dist/cjs/src/transaction/parseTransaction.d.ts +3 -0
  256. package/dist/cjs/src/transaction/parseTransaction.d.ts.map +1 -0
  257. package/dist/cjs/src/transaction/parseTransaction.js +48 -0
  258. package/dist/cjs/src/transaction/recipient.d.ts +29 -0
  259. package/dist/cjs/src/transaction/recipient.d.ts.map +1 -0
  260. package/dist/cjs/src/transaction/recipient.js +88 -0
  261. package/dist/cjs/src/transaction/signTransaction.d.ts +6 -0
  262. package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -0
  263. package/dist/cjs/src/transaction/signTransaction.js +102 -0
  264. package/dist/cjs/src/transaction/verifyTransaction.d.ts +4 -0
  265. package/dist/cjs/src/transaction/verifyTransaction.d.ts.map +1 -0
  266. package/dist/cjs/src/transaction/verifyTransaction.js +50 -0
  267. package/dist/cjs/src/verifyKey.d.ts +28 -0
  268. package/dist/cjs/src/verifyKey.d.ts.map +1 -0
  269. package/dist/cjs/src/verifyKey.js +164 -0
  270. package/dist/cjs/src/wallet.d.ts +15 -0
  271. package/dist/cjs/src/wallet.d.ts.map +1 -0
  272. package/dist/cjs/src/wallet.js +8 -0
  273. package/dist/cjs/test/integration/impl/bch/bch.d.ts +2 -0
  274. package/dist/cjs/test/integration/impl/bch/bch.d.ts.map +1 -0
  275. package/dist/cjs/test/integration/impl/bch/bch.js +74 -0
  276. package/dist/cjs/test/unit/address.d.ts +2 -0
  277. package/dist/cjs/test/unit/address.d.ts.map +1 -0
  278. package/dist/cjs/test/unit/address.js +182 -0
  279. package/dist/cjs/test/unit/bip322.d.ts +2 -0
  280. package/dist/cjs/test/unit/bip322.d.ts.map +1 -0
  281. package/dist/cjs/test/unit/bip322.js +45 -0
  282. package/dist/cjs/test/unit/coins.d.ts +2 -0
  283. package/dist/cjs/test/unit/coins.d.ts.map +1 -0
  284. package/dist/cjs/test/unit/coins.js +97 -0
  285. package/dist/cjs/test/unit/customChangeWallet.d.ts +2 -0
  286. package/dist/cjs/test/unit/customChangeWallet.d.ts.map +1 -0
  287. package/dist/cjs/test/unit/customChangeWallet.js +154 -0
  288. package/dist/cjs/test/unit/customSigner.d.ts +3 -0
  289. package/dist/cjs/test/unit/customSigner.d.ts.map +1 -0
  290. package/dist/cjs/test/unit/customSigner.js +108 -0
  291. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts +2 -0
  292. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts.map +1 -0
  293. package/dist/cjs/test/unit/descriptor/NamedDescriptor.js +18 -0
  294. package/dist/cjs/test/unit/descriptor/builder.d.ts +2 -0
  295. package/dist/cjs/test/unit/descriptor/builder.d.ts.map +1 -0
  296. package/dist/cjs/test/unit/descriptor/builder.js +72 -0
  297. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts +2 -0
  298. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  299. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.js +20 -0
  300. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts +2 -0
  301. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts.map +1 -0
  302. package/dist/cjs/test/unit/descriptor/descriptorWallet.js +28 -0
  303. package/dist/cjs/test/unit/descriptorAddress.d.ts +3 -0
  304. package/dist/cjs/test/unit/descriptorAddress.d.ts.map +1 -0
  305. package/dist/cjs/test/unit/descriptorAddress.js +102 -0
  306. package/dist/cjs/test/unit/explainTransaction.d.ts +2 -0
  307. package/dist/cjs/test/unit/explainTransaction.d.ts.map +1 -0
  308. package/dist/cjs/test/unit/explainTransaction.js +74 -0
  309. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts +15 -0
  310. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts.map +1 -0
  311. package/dist/cjs/test/unit/fixtures/bip322/fixtures.js +51 -0
  312. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts +4 -0
  313. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts.map +1 -0
  314. package/dist/cjs/test/unit/fixtures/psbtHexProof.js +9 -0
  315. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts +2 -0
  316. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts.map +1 -0
  317. package/dist/cjs/test/unit/impl/bch/unit/bch.js +138 -0
  318. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts +2 -0
  319. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts.map +1 -0
  320. package/dist/cjs/test/unit/impl/bcha/unit/index.js +47 -0
  321. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts +2 -0
  322. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts.map +1 -0
  323. package/dist/cjs/test/unit/impl/bsv/unit/index.js +32 -0
  324. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts +2 -0
  325. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts.map +1 -0
  326. package/dist/cjs/test/unit/impl/btc/unit/btc.js +220 -0
  327. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts +4 -0
  328. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts.map +1 -0
  329. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.js +10 -0
  330. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts +2 -0
  331. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts.map +1 -0
  332. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.js +18 -0
  333. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts +2 -0
  334. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts.map +1 -0
  335. package/dist/cjs/test/unit/impl/btg/unit/index.js +29 -0
  336. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts +2 -0
  337. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts.map +1 -0
  338. package/dist/cjs/test/unit/impl/dash/unit/index.js +32 -0
  339. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts +2 -0
  340. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts.map +1 -0
  341. package/dist/cjs/test/unit/impl/doge/unit/index.js +32 -0
  342. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts +2 -0
  343. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts.map +1 -0
  344. package/dist/cjs/test/unit/impl/ltc/unit/index.js +39 -0
  345. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts +2 -0
  346. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts.map +1 -0
  347. package/dist/cjs/test/unit/impl/zec/unit/index.js +29 -0
  348. package/dist/cjs/test/unit/keySignatures.d.ts +2 -0
  349. package/dist/cjs/test/unit/keySignatures.d.ts.map +1 -0
  350. package/dist/cjs/test/unit/keySignatures.js +54 -0
  351. package/dist/cjs/test/unit/keychains.d.ts +2 -0
  352. package/dist/cjs/test/unit/keychains.d.ts.map +1 -0
  353. package/dist/cjs/test/unit/keychains.js +49 -0
  354. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts +2 -0
  355. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts.map +1 -0
  356. package/dist/cjs/test/unit/offlineVault/halfSigned.js +124 -0
  357. package/dist/cjs/test/unit/parseTransaction.d.ts +2 -0
  358. package/dist/cjs/test/unit/parseTransaction.d.ts.map +1 -0
  359. package/dist/cjs/test/unit/parseTransaction.js +125 -0
  360. package/dist/cjs/test/unit/prebuildAndSign.d.ts +6 -0
  361. package/dist/cjs/test/unit/prebuildAndSign.d.ts.map +1 -0
  362. package/dist/cjs/test/unit/prebuildAndSign.js +270 -0
  363. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts +2 -0
  364. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts.map +1 -0
  365. package/dist/cjs/test/unit/recovery/backupKeyRecovery.js +285 -0
  366. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts +2 -0
  367. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts.map +1 -0
  368. package/dist/cjs/test/unit/recovery/crossChainRecovery.js +283 -0
  369. package/dist/cjs/test/unit/recovery/mock.d.ts +30 -0
  370. package/dist/cjs/test/unit/recovery/mock.d.ts.map +1 -0
  371. package/dist/cjs/test/unit/recovery/mock.js +138 -0
  372. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts +2 -0
  373. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  374. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.js +30 -0
  375. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts +6 -0
  376. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts.map +1 -0
  377. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.js +17 -0
  378. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts +2 -0
  379. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts.map +1 -0
  380. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.js +76 -0
  381. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts +2 -0
  382. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts.map +1 -0
  383. package/dist/cjs/test/unit/transaction/descriptor/parse.js +135 -0
  384. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts +2 -0
  385. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts.map +1 -0
  386. package/dist/cjs/test/unit/transaction/descriptor/sign.js +32 -0
  387. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts +2 -0
  388. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts.map +1 -0
  389. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.js +48 -0
  390. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts +2 -0
  391. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts.map +1 -0
  392. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +108 -0
  393. package/dist/cjs/test/unit/transaction.d.ts +2 -0
  394. package/dist/cjs/test/unit/transaction.d.ts.map +1 -0
  395. package/dist/cjs/test/unit/transaction.js +501 -0
  396. package/dist/cjs/test/unit/txFormat.d.ts +30 -0
  397. package/dist/cjs/test/unit/txFormat.d.ts.map +1 -0
  398. package/dist/cjs/test/unit/txFormat.js +162 -0
  399. package/dist/cjs/test/unit/util/fixtures.d.ts +14 -0
  400. package/dist/cjs/test/unit/util/fixtures.d.ts.map +1 -0
  401. package/dist/cjs/test/unit/util/fixtures.js +102 -0
  402. package/dist/cjs/test/unit/util/index.d.ts +7 -0
  403. package/dist/cjs/test/unit/util/index.d.ts.map +1 -0
  404. package/dist/cjs/test/unit/util/index.js +23 -0
  405. package/dist/cjs/test/unit/util/keychains.d.ts +26 -0
  406. package/dist/cjs/test/unit/util/keychains.d.ts.map +1 -0
  407. package/dist/cjs/test/unit/util/keychains.js +72 -0
  408. package/dist/cjs/test/unit/util/nockBitGo.d.ts +3 -0
  409. package/dist/cjs/test/unit/util/nockBitGo.d.ts.map +1 -0
  410. package/dist/cjs/test/unit/util/nockBitGo.js +11 -0
  411. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts +8 -0
  412. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts.map +1 -0
  413. package/dist/cjs/test/unit/util/nockIndexerAPI.js +56 -0
  414. package/dist/cjs/test/unit/util/transaction.d.ts +24 -0
  415. package/dist/cjs/test/unit/util/transaction.d.ts.map +1 -0
  416. package/dist/cjs/test/unit/util/transaction.js +107 -0
  417. package/dist/cjs/test/unit/util/unspents.d.ts +13 -0
  418. package/dist/cjs/test/unit/util/unspents.d.ts.map +1 -0
  419. package/dist/cjs/test/unit/util/unspents.js +106 -0
  420. package/dist/cjs/test/unit/util/utxoCoins.d.ts +8 -0
  421. package/dist/cjs/test/unit/util/utxoCoins.d.ts.map +1 -0
  422. package/dist/cjs/test/unit/util/utxoCoins.js +95 -0
  423. package/dist/cjs/test/unit/util/wallet.d.ts +4 -0
  424. package/dist/cjs/test/unit/util/wallet.d.ts.map +1 -0
  425. package/dist/cjs/test/unit/util/wallet.js +9 -0
  426. package/dist/cjs/test/unit/verifyTransaction.d.ts +2 -0
  427. package/dist/cjs/test/unit/verifyTransaction.d.ts.map +1 -0
  428. package/dist/cjs/test/unit/verifyTransaction.js +327 -0
  429. package/dist/cjs/test/unit/wallet.d.ts +2 -0
  430. package/dist/cjs/test/unit/wallet.d.ts.map +1 -0
  431. package/dist/cjs/test/unit/wallet.js +248 -0
  432. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  433. package/dist/esm/abstractUtxoCoin.d.ts +464 -0
  434. package/dist/esm/abstractUtxoCoin.d.ts.map +1 -0
  435. package/dist/esm/abstractUtxoCoin.js +598 -0
  436. package/dist/esm/address/fixedScript.d.ts +51 -0
  437. package/dist/esm/address/fixedScript.d.ts.map +1 -0
  438. package/dist/esm/address/fixedScript.js +109 -0
  439. package/dist/esm/address/index.d.ts +2 -0
  440. package/dist/esm/address/index.d.ts.map +1 -0
  441. package/dist/esm/address/index.js +2 -0
  442. package/dist/esm/config.d.ts +9 -0
  443. package/dist/esm/config.js +11 -0
  444. package/dist/esm/descriptor/NamedDescriptor.d.ts +20 -0
  445. package/dist/esm/descriptor/NamedDescriptor.d.ts.map +1 -0
  446. package/dist/esm/descriptor/NamedDescriptor.js +39 -0
  447. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  448. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  449. package/dist/esm/descriptor/assertDescriptorWalletAddress.js +27 -0
  450. package/dist/esm/descriptor/builder/builder.d.ts +13 -0
  451. package/dist/esm/descriptor/builder/builder.d.ts.map +1 -0
  452. package/dist/esm/descriptor/builder/builder.js +34 -0
  453. package/dist/esm/descriptor/builder/index.d.ts +3 -0
  454. package/dist/esm/descriptor/builder/index.d.ts.map +1 -0
  455. package/dist/esm/descriptor/builder/index.js +3 -0
  456. package/dist/esm/descriptor/builder/parse.d.ts +5 -0
  457. package/dist/esm/descriptor/builder/parse.d.ts.map +1 -0
  458. package/dist/esm/descriptor/builder/parse.js +112 -0
  459. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  460. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  461. package/dist/esm/descriptor/createWallet/createDescriptorWallet.js +37 -0
  462. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts +12 -0
  463. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  464. package/dist/esm/descriptor/createWallet/createDescriptors.js +29 -0
  465. package/dist/esm/descriptor/createWallet/index.d.ts +3 -0
  466. package/dist/esm/descriptor/createWallet/index.d.ts.map +1 -0
  467. package/dist/esm/descriptor/createWallet/index.js +3 -0
  468. package/dist/esm/descriptor/descriptorWallet.d.ts +19 -0
  469. package/dist/esm/descriptor/descriptorWallet.d.ts.map +1 -0
  470. package/dist/esm/descriptor/descriptorWallet.js +16 -0
  471. package/dist/esm/descriptor/index.d.ts +8 -0
  472. package/dist/esm/descriptor/index.d.ts.map +1 -0
  473. package/dist/esm/descriptor/index.js +7 -0
  474. package/dist/esm/descriptor/validatePolicy.d.ts +22 -0
  475. package/dist/esm/descriptor/validatePolicy.d.ts.map +1 -0
  476. package/dist/esm/descriptor/validatePolicy.js +80 -0
  477. package/dist/esm/impl/bch/bch.d.ts +20 -0
  478. package/dist/esm/impl/bch/bch.d.ts.map +1 -0
  479. package/dist/esm/impl/bch/bch.js +33 -0
  480. package/dist/esm/impl/bch/index.d.ts +3 -0
  481. package/dist/esm/impl/bch/index.d.ts.map +1 -0
  482. package/dist/esm/impl/bch/index.js +3 -0
  483. package/dist/esm/impl/bch/tbch.d.ts +10 -0
  484. package/dist/esm/impl/bch/tbch.d.ts.map +1 -0
  485. package/dist/esm/impl/bch/tbch.js +11 -0
  486. package/dist/esm/impl/bcha/bcha.d.ts +9 -0
  487. package/dist/esm/impl/bcha/bcha.d.ts.map +1 -0
  488. package/dist/esm/impl/bcha/bcha.js +21 -0
  489. package/dist/esm/impl/bcha/index.d.ts +3 -0
  490. package/dist/esm/impl/bcha/index.d.ts.map +1 -0
  491. package/dist/esm/impl/bcha/index.js +3 -0
  492. package/dist/esm/impl/bcha/tbcha.d.ts +10 -0
  493. package/dist/esm/impl/bcha/tbcha.d.ts.map +1 -0
  494. package/dist/esm/impl/bcha/tbcha.js +11 -0
  495. package/dist/esm/impl/bsv/bsv.d.ts +8 -0
  496. package/dist/esm/impl/bsv/bsv.d.ts.map +1 -0
  497. package/dist/esm/impl/bsv/bsv.js +11 -0
  498. package/dist/esm/impl/bsv/index.d.ts +3 -0
  499. package/dist/esm/impl/bsv/index.d.ts.map +1 -0
  500. package/dist/esm/impl/bsv/index.js +3 -0
  501. package/dist/esm/impl/bsv/tbsv.d.ts +10 -0
  502. package/dist/esm/impl/bsv/tbsv.d.ts.map +1 -0
  503. package/dist/esm/impl/bsv/tbsv.js +11 -0
  504. package/dist/esm/impl/btc/btc.d.ts +13 -0
  505. package/dist/esm/impl/btc/btc.d.ts.map +1 -0
  506. package/dist/esm/impl/btc/btc.js +18 -0
  507. package/dist/esm/impl/btc/index.d.ts +7 -0
  508. package/dist/esm/impl/btc/index.d.ts.map +1 -0
  509. package/dist/esm/impl/btc/index.js +7 -0
  510. package/dist/esm/impl/btc/inscriptionBuilder.d.ts +51 -0
  511. package/dist/esm/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  512. package/dist/esm/impl/btc/inscriptionBuilder.js +143 -0
  513. package/dist/esm/impl/btc/tbtc.d.ts +10 -0
  514. package/dist/esm/impl/btc/tbtc.d.ts.map +1 -0
  515. package/dist/esm/impl/btc/tbtc.js +11 -0
  516. package/dist/esm/impl/btc/tbtc4.d.ts +10 -0
  517. package/dist/esm/impl/btc/tbtc4.d.ts.map +1 -0
  518. package/dist/esm/impl/btc/tbtc4.js +11 -0
  519. package/dist/esm/impl/btc/tbtcbgsig.d.ts +10 -0
  520. package/dist/esm/impl/btc/tbtcbgsig.d.ts.map +1 -0
  521. package/dist/esm/impl/btc/tbtcbgsig.js +11 -0
  522. package/dist/esm/impl/btc/tbtcsig.d.ts +10 -0
  523. package/dist/esm/impl/btc/tbtcsig.d.ts.map +1 -0
  524. package/dist/esm/impl/btc/tbtcsig.js +11 -0
  525. package/dist/esm/impl/btg/btg.d.ts +7 -0
  526. package/dist/esm/impl/btg/btg.d.ts.map +1 -0
  527. package/dist/esm/impl/btg/btg.js +11 -0
  528. package/dist/esm/impl/btg/index.d.ts +2 -0
  529. package/dist/esm/impl/btg/index.d.ts.map +1 -0
  530. package/dist/esm/impl/btg/index.js +2 -0
  531. package/dist/esm/impl/dash/dash.d.ts +7 -0
  532. package/dist/esm/impl/dash/dash.d.ts.map +1 -0
  533. package/dist/esm/impl/dash/dash.js +11 -0
  534. package/dist/esm/impl/dash/index.d.ts +3 -0
  535. package/dist/esm/impl/dash/index.d.ts.map +1 -0
  536. package/dist/esm/impl/dash/index.js +3 -0
  537. package/dist/esm/impl/dash/tdash.d.ts +10 -0
  538. package/dist/esm/impl/dash/tdash.d.ts.map +1 -0
  539. package/dist/esm/impl/dash/tdash.js +11 -0
  540. package/dist/esm/impl/doge/doge.d.ts +31 -0
  541. package/dist/esm/impl/doge/doge.d.ts.map +1 -0
  542. package/dist/esm/impl/doge/doge.js +75 -0
  543. package/dist/esm/impl/doge/index.d.ts +3 -0
  544. package/dist/esm/impl/doge/index.d.ts.map +1 -0
  545. package/dist/esm/impl/doge/index.js +3 -0
  546. package/dist/esm/impl/doge/tdoge.d.ts +10 -0
  547. package/dist/esm/impl/doge/tdoge.d.ts.map +1 -0
  548. package/dist/esm/impl/doge/tdoge.js +11 -0
  549. package/dist/esm/impl/index.d.ts +10 -0
  550. package/dist/esm/impl/index.d.ts.map +1 -0
  551. package/dist/esm/impl/index.js +10 -0
  552. package/dist/esm/impl/ltc/index.d.ts +3 -0
  553. package/dist/esm/impl/ltc/index.d.ts.map +1 -0
  554. package/dist/esm/impl/ltc/index.js +3 -0
  555. package/dist/esm/impl/ltc/ltc.d.ts +7 -0
  556. package/dist/esm/impl/ltc/ltc.d.ts.map +1 -0
  557. package/dist/esm/impl/ltc/ltc.js +15 -0
  558. package/dist/esm/impl/ltc/tltc.d.ts +7 -0
  559. package/dist/esm/impl/ltc/tltc.d.ts.map +1 -0
  560. package/dist/esm/impl/ltc/tltc.js +14 -0
  561. package/dist/esm/impl/zec/index.d.ts +3 -0
  562. package/dist/esm/impl/zec/index.d.ts.map +1 -0
  563. package/dist/esm/impl/zec/index.js +3 -0
  564. package/dist/esm/impl/zec/tzec.d.ts +7 -0
  565. package/dist/esm/impl/zec/tzec.d.ts.map +1 -0
  566. package/dist/esm/impl/zec/tzec.js +11 -0
  567. package/dist/esm/impl/zec/zec.d.ts +10 -0
  568. package/dist/esm/impl/zec/zec.d.ts.map +1 -0
  569. package/dist/esm/impl/zec/zec.js +11 -0
  570. package/dist/esm/index.d.ts +21 -0
  571. package/dist/esm/index.d.ts.map +1 -0
  572. package/dist/esm/index.js +21 -0
  573. package/dist/esm/keychains.d.ts +48 -0
  574. package/dist/esm/keychains.d.ts.map +1 -0
  575. package/dist/esm/keychains.js +61 -0
  576. package/dist/esm/names.d.ts +26 -0
  577. package/dist/esm/names.d.ts.map +1 -0
  578. package/dist/esm/names.js +171 -0
  579. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  580. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  581. package/dist/esm/offlineVault/OfflineVaultHalfSigned.js +23 -0
  582. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts +46 -0
  583. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  584. package/dist/esm/offlineVault/OfflineVaultSignable.js +18 -0
  585. package/dist/esm/offlineVault/TransactionExplanation.d.ts +15 -0
  586. package/dist/esm/offlineVault/TransactionExplanation.d.ts.map +1 -0
  587. package/dist/esm/offlineVault/TransactionExplanation.js +13 -0
  588. package/dist/esm/offlineVault/descriptor/index.d.ts +2 -0
  589. package/dist/esm/offlineVault/descriptor/index.d.ts.map +1 -0
  590. package/dist/esm/offlineVault/descriptor/index.js +2 -0
  591. package/dist/esm/offlineVault/descriptor/transaction.d.ts +38 -0
  592. package/dist/esm/offlineVault/descriptor/transaction.d.ts.map +1 -0
  593. package/dist/esm/offlineVault/descriptor/transaction.js +41 -0
  594. package/dist/esm/offlineVault/index.d.ts +6 -0
  595. package/dist/esm/offlineVault/index.d.ts.map +1 -0
  596. package/dist/esm/offlineVault/index.js +4 -0
  597. package/dist/esm/recovery/RecoveryProvider.d.ts +22 -0
  598. package/dist/{src → esm}/recovery/RecoveryProvider.d.ts.map +1 -1
  599. package/dist/esm/recovery/RecoveryProvider.js +19 -0
  600. package/dist/esm/recovery/backupKeyRecovery.d.ts +88 -0
  601. package/dist/esm/recovery/backupKeyRecovery.d.ts.map +1 -0
  602. package/dist/esm/recovery/backupKeyRecovery.js +329 -0
  603. package/dist/esm/recovery/baseApi.d.ts +24 -0
  604. package/dist/esm/recovery/baseApi.d.ts.map +1 -0
  605. package/dist/esm/recovery/baseApi.js +64 -0
  606. package/dist/esm/recovery/coingeckoApi.d.ts +6 -0
  607. package/dist/esm/recovery/coingeckoApi.d.ts.map +1 -0
  608. package/dist/esm/recovery/coingeckoApi.js +40 -0
  609. package/dist/esm/recovery/crossChainRecovery.d.ts +86 -0
  610. package/dist/{src → esm}/recovery/crossChainRecovery.d.ts.map +1 -1
  611. package/dist/esm/recovery/crossChainRecovery.js +325 -0
  612. package/dist/esm/recovery/index.d.ts +7 -0
  613. package/dist/{src → esm}/recovery/index.d.ts.map +1 -1
  614. package/dist/esm/recovery/index.js +7 -0
  615. package/dist/esm/recovery/mempoolApi.d.ts +7 -0
  616. package/dist/{src → esm}/recovery/mempoolApi.d.ts.map +1 -1
  617. package/dist/esm/recovery/mempoolApi.js +29 -0
  618. package/dist/esm/replayProtection.d.ts +5 -0
  619. package/dist/esm/replayProtection.d.ts.map +1 -0
  620. package/dist/esm/replayProtection.js +20 -0
  621. package/dist/esm/sign.d.ts +54 -0
  622. package/dist/esm/sign.d.ts.map +1 -0
  623. package/dist/esm/sign.js +162 -0
  624. package/dist/esm/transaction/bip322.d.ts +27 -0
  625. package/dist/esm/transaction/bip322.d.ts.map +1 -0
  626. package/dist/esm/transaction/bip322.js +86 -0
  627. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts +1 -0
  628. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  629. package/dist/esm/transaction/common/verifyPayGoAmount.js +1 -0
  630. package/dist/esm/transaction/descriptor/explainPsbt.d.ts +5 -0
  631. package/dist/esm/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  632. package/dist/esm/transaction/descriptor/explainPsbt.js +44 -0
  633. package/dist/esm/transaction/descriptor/index.d.ts +7 -0
  634. package/dist/esm/transaction/descriptor/index.d.ts.map +1 -0
  635. package/dist/esm/transaction/descriptor/index.js +6 -0
  636. package/dist/esm/transaction/descriptor/parse.d.ts +15 -0
  637. package/dist/esm/transaction/descriptor/parse.d.ts.map +1 -0
  638. package/dist/esm/transaction/descriptor/parse.js +79 -0
  639. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts +13 -0
  640. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  641. package/dist/esm/transaction/descriptor/parseToAmountType.js +55 -0
  642. package/dist/esm/transaction/descriptor/recipient.d.ts +5 -0
  643. package/dist/esm/transaction/descriptor/recipient.d.ts.map +1 -0
  644. package/dist/esm/transaction/descriptor/recipient.js +2 -0
  645. package/dist/esm/transaction/descriptor/signPsbt.d.ts +25 -0
  646. package/dist/esm/transaction/descriptor/signPsbt.d.ts.map +1 -0
  647. package/dist/esm/transaction/descriptor/signPsbt.js +38 -0
  648. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts +35 -0
  649. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  650. package/dist/esm/transaction/descriptor/verifyTransaction.js +65 -0
  651. package/dist/esm/transaction/explainTransaction.d.ts +18 -0
  652. package/dist/esm/transaction/explainTransaction.d.ts.map +1 -0
  653. package/dist/esm/transaction/explainTransaction.js +52 -0
  654. package/dist/esm/transaction/fetchInputs.d.ts +26 -0
  655. package/dist/esm/transaction/fetchInputs.d.ts.map +1 -0
  656. package/dist/esm/transaction/fetchInputs.js +72 -0
  657. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +10 -0
  658. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  659. package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +40 -0
  660. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts +63 -0
  661. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  662. package/dist/esm/transaction/fixedScript/explainTransaction.js +284 -0
  663. package/dist/esm/transaction/fixedScript/index.d.ts +7 -0
  664. package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -0
  665. package/dist/esm/transaction/fixedScript/index.js +6 -0
  666. package/dist/esm/transaction/fixedScript/parseOutput.d.ts +26 -0
  667. package/dist/esm/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  668. package/dist/esm/transaction/fixedScript/parseOutput.js +207 -0
  669. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts +7 -0
  670. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  671. package/dist/esm/transaction/fixedScript/parseTransaction.js +164 -0
  672. package/dist/esm/transaction/fixedScript/signTransaction.d.ts +18 -0
  673. package/dist/esm/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  674. package/dist/esm/transaction/fixedScript/signTransaction.js +95 -0
  675. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  676. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  677. package/dist/esm/transaction/fixedScript/verifyTransaction.js +159 -0
  678. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  679. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  680. package/dist/esm/transaction/getPayGoVerificationPubkey.js +17 -0
  681. package/dist/esm/transaction/index.d.ts +7 -0
  682. package/dist/esm/transaction/index.d.ts.map +1 -0
  683. package/dist/esm/transaction/index.js +7 -0
  684. package/dist/esm/transaction/outputDifference.d.ts +40 -0
  685. package/dist/esm/transaction/outputDifference.d.ts.map +1 -0
  686. package/dist/esm/transaction/outputDifference.js +42 -0
  687. package/dist/esm/transaction/parseTransaction.d.ts +3 -0
  688. package/dist/esm/transaction/parseTransaction.d.ts.map +1 -0
  689. package/dist/esm/transaction/parseTransaction.js +12 -0
  690. package/dist/esm/transaction/recipient.d.ts +29 -0
  691. package/dist/esm/transaction/recipient.d.ts.map +1 -0
  692. package/dist/esm/transaction/recipient.js +48 -0
  693. package/dist/esm/transaction/signTransaction.d.ts +6 -0
  694. package/dist/esm/transaction/signTransaction.d.ts.map +1 -0
  695. package/dist/esm/transaction/signTransaction.js +63 -0
  696. package/dist/esm/transaction/verifyTransaction.d.ts +4 -0
  697. package/dist/esm/transaction/verifyTransaction.d.ts.map +1 -0
  698. package/dist/esm/transaction/verifyTransaction.js +14 -0
  699. package/dist/esm/verifyKey.d.ts +28 -0
  700. package/dist/esm/verifyKey.d.ts.map +1 -0
  701. package/dist/esm/verifyKey.js +123 -0
  702. package/dist/esm/wallet.d.ts +15 -0
  703. package/dist/esm/wallet.d.ts.map +1 -0
  704. package/dist/esm/wallet.js +5 -0
  705. package/package.json +48 -18
  706. package/.eslintignore +0 -5
  707. package/CHANGELOG.md +0 -235
  708. package/dist/src/abstractUtxoCoin.d.ts +0 -392
  709. package/dist/src/abstractUtxoCoin.d.ts.map +0 -1
  710. package/dist/src/abstractUtxoCoin.js +0 -931
  711. package/dist/src/config.js +0 -14
  712. package/dist/src/index.d.ts +0 -6
  713. package/dist/src/index.d.ts.map +0 -1
  714. package/dist/src/index.js +0 -18
  715. package/dist/src/parseOutput.d.ts +0 -22
  716. package/dist/src/parseOutput.d.ts.map +0 -1
  717. package/dist/src/parseOutput.js +0 -181
  718. package/dist/src/recovery/RecoveryProvider.js +0 -24
  719. package/dist/src/recovery/backupKeyRecovery.d.ts +0 -62
  720. package/dist/src/recovery/backupKeyRecovery.d.ts.map +0 -1
  721. package/dist/src/recovery/backupKeyRecovery.js +0 -293
  722. package/dist/src/recovery/baseApi.d.ts.map +0 -1
  723. package/dist/src/recovery/baseApi.js +0 -73
  724. package/dist/src/recovery/coingeckoApi.d.ts.map +0 -1
  725. package/dist/src/recovery/coingeckoApi.js +0 -47
  726. package/dist/src/recovery/crossChainRecovery.js +0 -294
  727. package/dist/src/recovery/mempoolApi.js +0 -33
  728. package/dist/src/recovery/smartbitApi.d.ts +0 -11
  729. package/dist/src/recovery/smartbitApi.d.ts.map +0 -1
  730. package/dist/src/recovery/smartbitApi.js +0 -36
  731. package/dist/src/replayProtection.d.ts.map +0 -1
  732. package/dist/src/replayProtection.js +0 -21
  733. package/dist/src/sign.d.ts.map +0 -1
  734. package/dist/src/sign.js +0 -104
  735. package/dist/tsconfig.tsbuildinfo +0 -8041
  736. /package/dist/{src → cjs/src}/config.d.ts +0 -0
  737. /package/dist/{src → cjs/src}/recovery/mempoolApi.d.ts +0 -0
  738. /package/dist/{src → esm}/config.d.ts.map +0 -0
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.parseTransaction = parseTransaction;
37
+ const descriptor_1 = require("../descriptor");
38
+ const descriptor = __importStar(require("./descriptor"));
39
+ const fixedScript = __importStar(require("./fixedScript"));
40
+ async function parseTransaction(coin, params) {
41
+ if ((0, descriptor_1.isDescriptorWallet)(params.wallet)) {
42
+ return descriptor.parseToAmountType(coin, params.wallet, params);
43
+ }
44
+ else {
45
+ return fixedScript.parseTransaction(coin, params);
46
+ }
47
+ }
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VUcmFuc2FjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy90cmFuc2FjdGlvbi9wYXJzZVRyYW5zYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBTUEsNENBU0M7QUFkRCw4Q0FBbUQ7QUFFbkQseURBQTJDO0FBQzNDLDJEQUE2QztBQUV0QyxLQUFLLFVBQVUsZ0JBQWdCLENBQ3BDLElBQXNCLEVBQ3RCLE1BQXdDO0lBRXhDLElBQUksSUFBQSwrQkFBa0IsRUFBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUN0QyxPQUFPLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNuRSxDQUFDO1NBQU0sQ0FBQztRQUNOLE9BQU8sV0FBVyxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNwRCxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIFBhcnNlZFRyYW5zYWN0aW9uLCBQYXJzZVRyYW5zYWN0aW9uT3B0aW9ucyB9IGZyb20gJy4uL2Fic3RyYWN0VXR4b0NvaW4nO1xuaW1wb3J0IHsgaXNEZXNjcmlwdG9yV2FsbGV0IH0gZnJvbSAnLi4vZGVzY3JpcHRvcic7XG5cbmltcG9ydCAqIGFzIGRlc2NyaXB0b3IgZnJvbSAnLi9kZXNjcmlwdG9yJztcbmltcG9ydCAqIGFzIGZpeGVkU2NyaXB0IGZyb20gJy4vZml4ZWRTY3JpcHQnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcGFyc2VUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgYmlnaW50IHwgbnVtYmVyPihcbiAgY29pbjogQWJzdHJhY3RVdHhvQ29pbixcbiAgcGFyYW1zOiBQYXJzZVRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTxQYXJzZWRUcmFuc2FjdGlvbjxUTnVtYmVyPj4ge1xuICBpZiAoaXNEZXNjcmlwdG9yV2FsbGV0KHBhcmFtcy53YWxsZXQpKSB7XG4gICAgcmV0dXJuIGRlc2NyaXB0b3IucGFyc2VUb0Ftb3VudFR5cGUoY29pbiwgcGFyYW1zLndhbGxldCwgcGFyYW1zKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gZml4ZWRTY3JpcHQucGFyc2VUcmFuc2FjdGlvbihjb2luLCBwYXJhbXMpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,29 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ /**
3
+ * Check if the address is a script recipient (starts with `scriptPubKey:`).
4
+ * @param address
5
+ */
6
+ export declare function isScriptRecipient(address: string): boolean;
7
+ /**
8
+ * An extended address is one that encodes either a regular address or a hex encoded script with the prefix `scriptPubKey:`.
9
+ * This function converts the extended address format to either a script or an address.
10
+ * @param extendedAddress
11
+ */
12
+ export declare function fromExtendedAddressFormat(extendedAddress: string): {
13
+ address: string;
14
+ } | {
15
+ script: string;
16
+ };
17
+ export declare function fromExtendedAddressFormatToScript(extendedAddress: string, network: utxolib.Network): Buffer;
18
+ /**
19
+ * Convert a script or address to the extended address format.
20
+ * @param script
21
+ * @param network
22
+ * @returns if the script is an OP_RETURN script, then it will be prefixed with `scriptPubKey:`, otherwise it will be converted to an address.
23
+ */
24
+ export declare function toExtendedAddressFormat(script: Buffer, network: utxolib.Network): string;
25
+ export declare function assertValidTransactionRecipient(output: {
26
+ amount: bigint | number | string;
27
+ address?: string;
28
+ }): void;
29
+ //# sourceMappingURL=recipient.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"recipient.d.ts","sourceRoot":"","sources":["../../../../src/transaction/recipient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAIhD;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAE1D;AAED;;;;GAIG;AACH,wBAAgB,yBAAyB,CAAC,eAAe,EAAE,MAAM,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,GAAG;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAK3G;AAED,wBAAgB,iCAAiC,CAAC,eAAe,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAM3G;AAED;;;;;GAKG;AACH,wBAAgB,uBAAuB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAIxF;AAED,wBAAgB,+BAA+B,CAAC,MAAM,EAAE;IAAE,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,IAAI,CAQpH"}
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.isScriptRecipient = isScriptRecipient;
37
+ exports.fromExtendedAddressFormat = fromExtendedAddressFormat;
38
+ exports.fromExtendedAddressFormatToScript = fromExtendedAddressFormatToScript;
39
+ exports.toExtendedAddressFormat = toExtendedAddressFormat;
40
+ exports.assertValidTransactionRecipient = assertValidTransactionRecipient;
41
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
42
+ const ScriptRecipientPrefix = 'scriptPubKey:';
43
+ /**
44
+ * Check if the address is a script recipient (starts with `scriptPubKey:`).
45
+ * @param address
46
+ */
47
+ function isScriptRecipient(address) {
48
+ return address.toLowerCase().startsWith(ScriptRecipientPrefix.toLowerCase());
49
+ }
50
+ /**
51
+ * An extended address is one that encodes either a regular address or a hex encoded script with the prefix `scriptPubKey:`.
52
+ * This function converts the extended address format to either a script or an address.
53
+ * @param extendedAddress
54
+ */
55
+ function fromExtendedAddressFormat(extendedAddress) {
56
+ if (isScriptRecipient(extendedAddress)) {
57
+ return { script: extendedAddress.slice(ScriptRecipientPrefix.length) };
58
+ }
59
+ return { address: extendedAddress };
60
+ }
61
+ function fromExtendedAddressFormatToScript(extendedAddress, network) {
62
+ const result = fromExtendedAddressFormat(extendedAddress);
63
+ if ('script' in result) {
64
+ return Buffer.from(result.script, 'hex');
65
+ }
66
+ return utxolib.addressFormat.toOutputScriptTryFormats(result.address, network);
67
+ }
68
+ /**
69
+ * Convert a script or address to the extended address format.
70
+ * @param script
71
+ * @param network
72
+ * @returns if the script is an OP_RETURN script, then it will be prefixed with `scriptPubKey:`, otherwise it will be converted to an address.
73
+ */
74
+ function toExtendedAddressFormat(script, network) {
75
+ return script[0] === utxolib.opcodes.OP_RETURN
76
+ ? `${ScriptRecipientPrefix}${script.toString('hex')}`
77
+ : utxolib.address.fromOutputScript(script, network);
78
+ }
79
+ function assertValidTransactionRecipient(output) {
80
+ // In the case that this is an OP_RETURN output or another non-encodable scriptPubkey, we dont have an address.
81
+ // We will verify that the amount is zero, and if it isnt then we will throw an error.
82
+ if (!output.address || isScriptRecipient(output.address)) {
83
+ if (output.amount.toString() !== '0') {
84
+ throw new Error(`Only zero amounts allowed for non-encodeable scriptPubkeys: ${JSON.stringify(output)}`);
85
+ }
86
+ }
87
+ }
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjaXBpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3JlY2lwaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFBLDhDQUVDO0FBT0QsOERBS0M7QUFFRCw4RUFNQztBQVFELDBEQUlDO0FBRUQsMEVBUUM7QUFwREQsOERBQWdEO0FBRWhELE1BQU0scUJBQXFCLEdBQUcsZUFBZSxDQUFDO0FBRTlDOzs7R0FHRztBQUNILFNBQWdCLGlCQUFpQixDQUFDLE9BQWU7SUFDL0MsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUMsVUFBVSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7QUFDL0UsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQix5QkFBeUIsQ0FBQyxlQUF1QjtJQUMvRCxJQUFJLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUM7UUFDdkMsT0FBTyxFQUFFLE1BQU0sRUFBRSxlQUFlLENBQUMsS0FBSyxDQUFDLHFCQUFxQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7SUFDekUsQ0FBQztJQUNELE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLENBQUM7QUFDdEMsQ0FBQztBQUVELFNBQWdCLGlDQUFpQyxDQUFDLGVBQXVCLEVBQUUsT0FBd0I7SUFDakcsTUFBTSxNQUFNLEdBQUcseUJBQXlCLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDMUQsSUFBSSxRQUFRLElBQUksTUFBTSxFQUFFLENBQUM7UUFDdkIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUNELE9BQU8sT0FBTyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ2pGLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLHVCQUF1QixDQUFDLE1BQWMsRUFBRSxPQUF3QjtJQUM5RSxPQUFPLE1BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsT0FBTyxDQUFDLFNBQVM7UUFDNUMsQ0FBQyxDQUFDLEdBQUcscUJBQXFCLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNyRCxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDeEQsQ0FBQztBQUVELFNBQWdCLCtCQUErQixDQUFDLE1BQThEO0lBQzVHLCtHQUErRztJQUMvRyxzRkFBc0Y7SUFDdEYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLElBQUksaUJBQWlCLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDekQsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxLQUFLLEdBQUcsRUFBRSxDQUFDO1lBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsK0RBQStELElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzNHLENBQUM7SUFDSCxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5jb25zdCBTY3JpcHRSZWNpcGllbnRQcmVmaXggPSAnc2NyaXB0UHViS2V5Oic7XG5cbi8qKlxuICogQ2hlY2sgaWYgdGhlIGFkZHJlc3MgaXMgYSBzY3JpcHQgcmVjaXBpZW50IChzdGFydHMgd2l0aCBgc2NyaXB0UHViS2V5OmApLlxuICogQHBhcmFtIGFkZHJlc3NcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzU2NyaXB0UmVjaXBpZW50KGFkZHJlc3M6IHN0cmluZyk6IGJvb2xlYW4ge1xuICByZXR1cm4gYWRkcmVzcy50b0xvd2VyQ2FzZSgpLnN0YXJ0c1dpdGgoU2NyaXB0UmVjaXBpZW50UHJlZml4LnRvTG93ZXJDYXNlKCkpO1xufVxuXG4vKipcbiAqIEFuIGV4dGVuZGVkIGFkZHJlc3MgaXMgb25lIHRoYXQgZW5jb2RlcyBlaXRoZXIgYSByZWd1bGFyIGFkZHJlc3Mgb3IgYSBoZXggZW5jb2RlZCBzY3JpcHQgd2l0aCB0aGUgcHJlZml4IGBzY3JpcHRQdWJLZXk6YC5cbiAqIFRoaXMgZnVuY3Rpb24gY29udmVydHMgdGhlIGV4dGVuZGVkIGFkZHJlc3MgZm9ybWF0IHRvIGVpdGhlciBhIHNjcmlwdCBvciBhbiBhZGRyZXNzLlxuICogQHBhcmFtIGV4dGVuZGVkQWRkcmVzc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZnJvbUV4dGVuZGVkQWRkcmVzc0Zvcm1hdChleHRlbmRlZEFkZHJlc3M6IHN0cmluZyk6IHsgYWRkcmVzczogc3RyaW5nIH0gfCB7IHNjcmlwdDogc3RyaW5nIH0ge1xuICBpZiAoaXNTY3JpcHRSZWNpcGllbnQoZXh0ZW5kZWRBZGRyZXNzKSkge1xuICAgIHJldHVybiB7IHNjcmlwdDogZXh0ZW5kZWRBZGRyZXNzLnNsaWNlKFNjcmlwdFJlY2lwaWVudFByZWZpeC5sZW5ndGgpIH07XG4gIH1cbiAgcmV0dXJuIHsgYWRkcmVzczogZXh0ZW5kZWRBZGRyZXNzIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmcm9tRXh0ZW5kZWRBZGRyZXNzRm9ybWF0VG9TY3JpcHQoZXh0ZW5kZWRBZGRyZXNzOiBzdHJpbmcsIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IEJ1ZmZlciB7XG4gIGNvbnN0IHJlc3VsdCA9IGZyb21FeHRlbmRlZEFkZHJlc3NGb3JtYXQoZXh0ZW5kZWRBZGRyZXNzKTtcbiAgaWYgKCdzY3JpcHQnIGluIHJlc3VsdCkge1xuICAgIHJldHVybiBCdWZmZXIuZnJvbShyZXN1bHQuc2NyaXB0LCAnaGV4Jyk7XG4gIH1cbiAgcmV0dXJuIHV0eG9saWIuYWRkcmVzc0Zvcm1hdC50b091dHB1dFNjcmlwdFRyeUZvcm1hdHMocmVzdWx0LmFkZHJlc3MsIG5ldHdvcmspO1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzY3JpcHQgb3IgYWRkcmVzcyB0byB0aGUgZXh0ZW5kZWQgYWRkcmVzcyBmb3JtYXQuXG4gKiBAcGFyYW0gc2NyaXB0XG4gKiBAcGFyYW0gbmV0d29ya1xuICogQHJldHVybnMgaWYgdGhlIHNjcmlwdCBpcyBhbiBPUF9SRVRVUk4gc2NyaXB0LCB0aGVuIGl0IHdpbGwgYmUgcHJlZml4ZWQgd2l0aCBgc2NyaXB0UHViS2V5OmAsIG90aGVyd2lzZSBpdCB3aWxsIGJlIGNvbnZlcnRlZCB0byBhbiBhZGRyZXNzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9FeHRlbmRlZEFkZHJlc3NGb3JtYXQoc2NyaXB0OiBCdWZmZXIsIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IHN0cmluZyB7XG4gIHJldHVybiBzY3JpcHRbMF0gPT09IHV0eG9saWIub3Bjb2Rlcy5PUF9SRVRVUk5cbiAgICA/IGAke1NjcmlwdFJlY2lwaWVudFByZWZpeH0ke3NjcmlwdC50b1N0cmluZygnaGV4Jyl9YFxuICAgIDogdXR4b2xpYi5hZGRyZXNzLmZyb21PdXRwdXRTY3JpcHQoc2NyaXB0LCBuZXR3b3JrKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkVHJhbnNhY3Rpb25SZWNpcGllbnQob3V0cHV0OiB7IGFtb3VudDogYmlnaW50IHwgbnVtYmVyIHwgc3RyaW5nOyBhZGRyZXNzPzogc3RyaW5nIH0pOiB2b2lkIHtcbiAgLy8gSW4gdGhlIGNhc2UgdGhhdCB0aGlzIGlzIGFuIE9QX1JFVFVSTiBvdXRwdXQgb3IgYW5vdGhlciBub24tZW5jb2RhYmxlIHNjcmlwdFB1YmtleSwgd2UgZG9udCBoYXZlIGFuIGFkZHJlc3MuXG4gIC8vIFdlIHdpbGwgdmVyaWZ5IHRoYXQgdGhlIGFtb3VudCBpcyB6ZXJvLCBhbmQgaWYgaXQgaXNudCB0aGVuIHdlIHdpbGwgdGhyb3cgYW4gZXJyb3IuXG4gIGlmICghb3V0cHV0LmFkZHJlc3MgfHwgaXNTY3JpcHRSZWNpcGllbnQob3V0cHV0LmFkZHJlc3MpKSB7XG4gICAgaWYgKG91dHB1dC5hbW91bnQudG9TdHJpbmcoKSAhPT0gJzAnKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE9ubHkgemVybyBhbW91bnRzIGFsbG93ZWQgZm9yIG5vbi1lbmNvZGVhYmxlIHNjcmlwdFB1YmtleXM6ICR7SlNPTi5zdHJpbmdpZnkob3V0cHV0KX1gKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,6 @@
1
+ import { BitGoBase } from '@bitgo-beta/sdk-core';
2
+ import { AbstractUtxoCoin, SignTransactionOptions } from '../abstractUtxoCoin';
3
+ export declare function signTransaction<TNumber extends number | bigint>(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: SignTransactionOptions<TNumber>): Promise<{
4
+ txHex: string;
5
+ }>;
6
+ //# sourceMappingURL=signTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/signTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAKjD,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAwB/E,wBAAsB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACnE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,sBAAsB,CAAC,OAAO,CAAC,GACtC,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAyC5B"}
@@ -0,0 +1,102 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.signTransaction = signTransaction;
40
+ const lodash_1 = __importDefault(require("lodash"));
41
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
42
+ const secp256k1_1 = require("@bitgo-beta/secp256k1");
43
+ const debug_1 = __importDefault(require("debug"));
44
+ const descriptor_1 = require("../descriptor");
45
+ const keychains_1 = require("../keychains");
46
+ const fixedScript = __importStar(require("./fixedScript"));
47
+ const descriptor = __importStar(require("./descriptor"));
48
+ const debug = (0, debug_1.default)('bitgo:abstract-utxo:transaction:signTransaction');
49
+ function getSignerKeychain(userPrv) {
50
+ if (userPrv === undefined) {
51
+ return undefined;
52
+ }
53
+ if (typeof userPrv !== 'string') {
54
+ throw new Error('expected user private key to be a string');
55
+ }
56
+ const signerKeychain = secp256k1_1.bip32.fromBase58(userPrv, utxolib.networks.bitcoin);
57
+ if (signerKeychain.isNeutered()) {
58
+ throw new Error('expected user private key but received public key');
59
+ }
60
+ debug(`Here is the public key of the xprv you used to sign: ${signerKeychain.neutered().toBase58()}`);
61
+ return signerKeychain;
62
+ }
63
+ async function signTransaction(coin, bitgo, params) {
64
+ const txPrebuild = params.txPrebuild;
65
+ if (lodash_1.default.isUndefined(txPrebuild) || !lodash_1.default.isObject(txPrebuild)) {
66
+ if (!lodash_1.default.isUndefined(txPrebuild) && !lodash_1.default.isObject(txPrebuild)) {
67
+ throw new Error(`txPrebuild must be an object, got type ${typeof txPrebuild}`);
68
+ }
69
+ throw new Error('missing txPrebuild parameter');
70
+ }
71
+ const tx = coin.decodeTransactionFromPrebuild(params.txPrebuild);
72
+ const signerKeychain = getSignerKeychain(params.prv);
73
+ const { wallet } = params;
74
+ if (wallet && (0, descriptor_1.isDescriptorWallet)(wallet)) {
75
+ if (!signerKeychain) {
76
+ throw new Error('missing signer');
77
+ }
78
+ const walletKeys = (0, keychains_1.toBip32Triple)(await (0, keychains_1.fetchKeychains)(coin, wallet));
79
+ const descriptorMap = (0, descriptor_1.getDescriptorMapFromWallet)(wallet, walletKeys, (0, descriptor_1.getPolicyForEnv)(bitgo.env));
80
+ if (tx instanceof utxolib.bitgo.UtxoPsbt) {
81
+ descriptor.signPsbt(tx, descriptorMap, signerKeychain, {
82
+ onUnknownInput: 'throw',
83
+ });
84
+ return { txHex: tx.toHex() };
85
+ }
86
+ else {
87
+ throw new Error('expected a UtxoPsbt object');
88
+ }
89
+ }
90
+ else {
91
+ return fixedScript.signTransaction(coin, tx, getSignerKeychain(params.prv), {
92
+ walletId: params.txPrebuild.walletId,
93
+ txInfo: params.txPrebuild.txInfo,
94
+ isLastSignature: params.isLastSignature ?? false,
95
+ signingStep: params.signingStep,
96
+ allowNonSegwitSigningWithoutPrevTx: params.allowNonSegwitSigningWithoutPrevTx ?? false,
97
+ pubs: params.pubs,
98
+ cosignerPub: params.cosignerPub,
99
+ });
100
+ }
101
+ }
102
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQThCQSwwQ0E2Q0M7QUEzRUQsb0RBQXVCO0FBRXZCLDhEQUFnRDtBQUNoRCxxREFBOEM7QUFDOUMsa0RBQStCO0FBRy9CLDhDQUFnRztBQUNoRyw0Q0FBNkQ7QUFFN0QsMkRBQTZDO0FBQzdDLHlEQUEyQztBQUUzQyxNQUFNLEtBQUssR0FBRyxJQUFBLGVBQVUsRUFBQyxpREFBaUQsQ0FBQyxDQUFDO0FBRTVFLFNBQVMsaUJBQWlCLENBQUMsT0FBZ0I7SUFDekMsSUFBSSxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7UUFDMUIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUNELElBQUksT0FBTyxPQUFPLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDaEMsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFDRCxNQUFNLGNBQWMsR0FBRyxpQkFBSyxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzRSxJQUFJLGNBQWMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsS0FBSyxDQUFDLHdEQUF3RCxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RHLE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUM7QUFFTSxLQUFLLFVBQVUsZUFBZSxDQUNuQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF1QztJQUV2QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO0lBRXJDLElBQUksZ0JBQUMsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBQyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1FBQ3pELElBQUksQ0FBQyxnQkFBQyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGdCQUFDLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDMUQsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsT0FBTyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBQ2pGLENBQUM7UUFDRCxNQUFNLElBQUksS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFakUsTUFBTSxjQUFjLEdBQUcsaUJBQWlCLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXJELE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFMUIsSUFBSSxNQUFNLElBQUksSUFBQSwrQkFBa0IsRUFBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUNELE1BQU0sVUFBVSxHQUFHLElBQUEseUJBQWEsRUFBQyxNQUFNLElBQUEsMEJBQWMsRUFBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNyRSxNQUFNLGFBQWEsR0FBRyxJQUFBLHVDQUEwQixFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsSUFBQSw0QkFBZSxFQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pHLElBQUksRUFBRSxZQUFZLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDekMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRTtnQkFDckQsY0FBYyxFQUFFLE9BQU87YUFDeEIsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUMvQixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztRQUNoRCxDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDTixPQUFPLFdBQVcsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDMUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUMsUUFBUTtZQUNwQyxNQUFNLEVBQUUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNO1lBQ2hDLGVBQWUsRUFBRSxNQUFNLENBQUMsZUFBZSxJQUFJLEtBQUs7WUFDaEQsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXO1lBQy9CLGtDQUFrQyxFQUFFLE1BQU0sQ0FBQyxrQ0FBa0MsSUFBSSxLQUFLO1lBQ3RGLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSTtZQUNqQixXQUFXLEVBQUUsTUFBTSxDQUFDLFdBQVc7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBiaXAzMiB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgYnVpbGREZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5cbmltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMgfSBmcm9tICcuLi9hYnN0cmFjdFV0eG9Db2luJztcbmltcG9ydCB7IGdldERlc2NyaXB0b3JNYXBGcm9tV2FsbGV0LCBnZXRQb2xpY3lGb3JFbnYsIGlzRGVzY3JpcHRvcldhbGxldCB9IGZyb20gJy4uL2Rlc2NyaXB0b3InO1xuaW1wb3J0IHsgZmV0Y2hLZXljaGFpbnMsIHRvQmlwMzJUcmlwbGUgfSBmcm9tICcuLi9rZXljaGFpbnMnO1xuXG5pbXBvcnQgKiBhcyBmaXhlZFNjcmlwdCBmcm9tICcuL2ZpeGVkU2NyaXB0JztcbmltcG9ydCAqIGFzIGRlc2NyaXB0b3IgZnJvbSAnLi9kZXNjcmlwdG9yJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnRyYW5zYWN0aW9uOnNpZ25UcmFuc2FjdGlvbicpO1xuXG5mdW5jdGlvbiBnZXRTaWduZXJLZXljaGFpbih1c2VyUHJ2OiB1bmtub3duKTogdXR4b2xpYi5CSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCB7XG4gIGlmICh1c2VyUHJ2ID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG4gIGlmICh0eXBlb2YgdXNlclBydiAhPT0gJ3N0cmluZycpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2V4cGVjdGVkIHVzZXIgcHJpdmF0ZSBrZXkgdG8gYmUgYSBzdHJpbmcnKTtcbiAgfVxuICBjb25zdCBzaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgodXNlclBydiwgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luKTtcbiAgaWYgKHNpZ25lcktleWNoYWluLmlzTmV1dGVyZWQoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgdXNlciBwcml2YXRlIGtleSBidXQgcmVjZWl2ZWQgcHVibGljIGtleScpO1xuICB9XG4gIGRlYnVnKGBIZXJlIGlzIHRoZSBwdWJsaWMga2V5IG9mIHRoZSB4cHJ2IHlvdSB1c2VkIHRvIHNpZ246ICR7c2lnbmVyS2V5Y2hhaW4ubmV1dGVyZWQoKS50b0Jhc2U1OCgpfWApO1xuICByZXR1cm4gc2lnbmVyS2V5Y2hhaW47XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIGJpdGdvOiBCaXRHb0Jhc2UsXG4gIHBhcmFtczogU2lnblRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTx7IHR4SGV4OiBzdHJpbmcgfT4ge1xuICBjb25zdCB0eFByZWJ1aWxkID0gcGFyYW1zLnR4UHJlYnVpbGQ7XG5cbiAgaWYgKF8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgfHwgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICBpZiAoIV8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgJiYgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdHhQcmVidWlsZCBtdXN0IGJlIGFuIG9iamVjdCwgZ290IHR5cGUgJHt0eXBlb2YgdHhQcmVidWlsZH1gKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHR4UHJlYnVpbGQgcGFyYW1ldGVyJyk7XG4gIH1cblxuICBjb25zdCB0eCA9IGNvaW4uZGVjb2RlVHJhbnNhY3Rpb25Gcm9tUHJlYnVpbGQocGFyYW1zLnR4UHJlYnVpbGQpO1xuXG4gIGNvbnN0IHNpZ25lcktleWNoYWluID0gZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydik7XG5cbiAgY29uc3QgeyB3YWxsZXQgfSA9IHBhcmFtcztcblxuICBpZiAod2FsbGV0ICYmIGlzRGVzY3JpcHRvcldhbGxldCh3YWxsZXQpKSB7XG4gICAgaWYgKCFzaWduZXJLZXljaGFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHNpZ25lcicpO1xuICAgIH1cbiAgICBjb25zdCB3YWxsZXRLZXlzID0gdG9CaXAzMlRyaXBsZShhd2FpdCBmZXRjaEtleWNoYWlucyhjb2luLCB3YWxsZXQpKTtcbiAgICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvck1hcEZyb21XYWxsZXQod2FsbGV0LCB3YWxsZXRLZXlzLCBnZXRQb2xpY3lGb3JFbnYoYml0Z28uZW52KSk7XG4gICAgaWYgKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkge1xuICAgICAgZGVzY3JpcHRvci5zaWduUHNidCh0eCwgZGVzY3JpcHRvck1hcCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgICAgb25Vbmtub3duSW5wdXQ6ICd0aHJvdycsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7IHR4SGV4OiB0eC50b0hleCgpIH07XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgYSBVdHhvUHNidCBvYmplY3QnKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGZpeGVkU2NyaXB0LnNpZ25UcmFuc2FjdGlvbihjb2luLCB0eCwgZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydiksIHtcbiAgICAgIHdhbGxldElkOiBwYXJhbXMudHhQcmVidWlsZC53YWxsZXRJZCxcbiAgICAgIHR4SW5mbzogcGFyYW1zLnR4UHJlYnVpbGQudHhJbmZvLFxuICAgICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlID8/IGZhbHNlLFxuICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IHBhcmFtcy5hbGxvd05vblNlZ3dpdFNpZ25pbmdXaXRob3V0UHJldlR4ID8/IGZhbHNlLFxuICAgICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgICBjb3NpZ25lclB1YjogcGFyYW1zLmNvc2lnbmVyUHViLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,4 @@
1
+ import { BitGoBase } from '@bitgo-beta/sdk-core';
2
+ import { AbstractUtxoCoin, VerifyTransactionOptions } from '../abstractUtxoCoin';
3
+ export declare function verifyTransaction<TNumber extends bigint | number>(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: VerifyTransactionOptions<TNumber>): Promise<boolean>;
4
+ //# sourceMappingURL=verifyTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/verifyTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AAOjF,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,CAWlB"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.verifyTransaction = verifyTransaction;
37
+ const descriptor_1 = require("../descriptor");
38
+ const keychains_1 = require("../keychains");
39
+ const fixedScript = __importStar(require("./fixedScript"));
40
+ const descriptor = __importStar(require("./descriptor"));
41
+ async function verifyTransaction(coin, bitgo, params) {
42
+ if ((0, descriptor_1.isDescriptorWallet)(params.wallet)) {
43
+ const walletKeys = (0, keychains_1.toBip32Triple)(await (0, keychains_1.fetchKeychains)(coin, params.wallet));
44
+ return descriptor.verifyTransaction(coin, params, (0, descriptor_1.getDescriptorMapFromWallet)(params.wallet, walletKeys, (0, descriptor_1.getPolicyForEnv)(bitgo.env)));
45
+ }
46
+ else {
47
+ return fixedScript.verifyTransaction(coin, bitgo, params);
48
+ }
49
+ }
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5VHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vdmVyaWZ5VHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFTQSw4Q0FlQztBQXJCRCw4Q0FBZ0c7QUFDaEcsNENBQTZEO0FBRTdELDJEQUE2QztBQUM3Qyx5REFBMkM7QUFFcEMsS0FBSyxVQUFVLGlCQUFpQixDQUNyQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF5QztJQUV6QyxJQUFJLElBQUEsK0JBQWtCLEVBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDdEMsTUFBTSxVQUFVLEdBQUcsSUFBQSx5QkFBYSxFQUFDLE1BQU0sSUFBQSwwQkFBYyxFQUFDLElBQUksRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUM1RSxPQUFPLFVBQVUsQ0FBQyxpQkFBaUIsQ0FDakMsSUFBSSxFQUNKLE1BQU0sRUFDTixJQUFBLHVDQUEwQixFQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLElBQUEsNEJBQWUsRUFBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FDbEYsQ0FBQztJQUNKLENBQUM7U0FBTSxDQUFDO1FBQ04sT0FBTyxXQUFXLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztJQUM1RCxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpdEdvQmFzZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcblxuaW1wb3J0IHsgQWJzdHJhY3RVdHhvQ29pbiwgVmVyaWZ5VHJhbnNhY3Rpb25PcHRpb25zIH0gZnJvbSAnLi4vYWJzdHJhY3RVdHhvQ29pbic7XG5pbXBvcnQgeyBnZXREZXNjcmlwdG9yTWFwRnJvbVdhbGxldCwgaXNEZXNjcmlwdG9yV2FsbGV0LCBnZXRQb2xpY3lGb3JFbnYgfSBmcm9tICcuLi9kZXNjcmlwdG9yJztcbmltcG9ydCB7IGZldGNoS2V5Y2hhaW5zLCB0b0JpcDMyVHJpcGxlIH0gZnJvbSAnLi4va2V5Y2hhaW5zJztcblxuaW1wb3J0ICogYXMgZml4ZWRTY3JpcHQgZnJvbSAnLi9maXhlZFNjcmlwdCc7XG5pbXBvcnQgKiBhcyBkZXNjcmlwdG9yIGZyb20gJy4vZGVzY3JpcHRvcic7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB2ZXJpZnlUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgYmlnaW50IHwgbnVtYmVyPihcbiAgY29pbjogQWJzdHJhY3RVdHhvQ29pbixcbiAgYml0Z286IEJpdEdvQmFzZSxcbiAgcGFyYW1zOiBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnM8VE51bWJlcj5cbik6IFByb21pc2U8Ym9vbGVhbj4ge1xuICBpZiAoaXNEZXNjcmlwdG9yV2FsbGV0KHBhcmFtcy53YWxsZXQpKSB7XG4gICAgY29uc3Qgd2FsbGV0S2V5cyA9IHRvQmlwMzJUcmlwbGUoYXdhaXQgZmV0Y2hLZXljaGFpbnMoY29pbiwgcGFyYW1zLndhbGxldCkpO1xuICAgIHJldHVybiBkZXNjcmlwdG9yLnZlcmlmeVRyYW5zYWN0aW9uKFxuICAgICAgY29pbixcbiAgICAgIHBhcmFtcyxcbiAgICAgIGdldERlc2NyaXB0b3JNYXBGcm9tV2FsbGV0KHBhcmFtcy53YWxsZXQsIHdhbGxldEtleXMsIGdldFBvbGljeUZvckVudihiaXRnby5lbnYpKVxuICAgICk7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGZpeGVkU2NyaXB0LnZlcmlmeVRyYW5zYWN0aW9uKGNvaW4sIGJpdGdvLCBwYXJhbXMpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,28 @@
1
+ import { BitGoBase } from '@bitgo-beta/sdk-core';
2
+ import { ParsedTransaction, VerifyKeySignaturesOptions, VerifyUserPublicKeyOptions } from './abstractUtxoCoin';
3
+ import { UtxoKeychain } from './keychains';
4
+ /**
5
+ * Verify signatures produced by the user key over the backup and bitgo keys.
6
+ *
7
+ * If set, these signatures ensure that the wallet keys cannot be changed after the wallet has been created.
8
+ * @param {VerifyKeySignaturesOptions} params
9
+ * @return {{backup: boolean, bitgo: boolean}}
10
+ */
11
+ export declare function verifyKeySignature(params: VerifyKeySignaturesOptions): boolean;
12
+ /**
13
+ * Verify signatures against the user private key over the change wallet extended keys
14
+ * @param {ParsedTransaction} tx
15
+ * @param {Keychain} userKeychain
16
+ * @return {boolean}
17
+ * @protected
18
+ */
19
+ export declare function verifyCustomChangeKeySignatures<TNumber extends number | bigint>(tx: ParsedTransaction<TNumber>, userKeychain: UtxoKeychain): boolean;
20
+ /**
21
+ * Decrypt the wallet's user private key and verify that the claimed public key matches
22
+ * @param {BitGoBase} bitgo
23
+ * @param {VerifyUserPublicKeyOptions} params
24
+ * @return {boolean}
25
+ * @protected
26
+ */
27
+ export declare function verifyUserPublicKey(bitgo: BitGoBase, params: VerifyUserPublicKeyOptions): boolean;
28
+ //# sourceMappingURL=verifyKey.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifyKey.d.ts","sourceRoot":"","sources":["../../../src/verifyKey.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,SAAS,EAAyC,MAAM,sBAAsB,CAAC;AAExF,OAAO,EAAE,iBAAiB,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,MAAM,oBAAoB,CAAC;AAC/G,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAI3C;;;;;;GAMG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,0BAA0B,GAAG,OAAO,CAuC9E;AAED;;;;;;GAMG;AACH,wBAAgB,+BAA+B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC7E,EAAE,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAC9B,YAAY,EAAE,YAAY,GACzB,OAAO,CAyBT;AAED;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,0BAA0B,GAAG,OAAO,CAiCjG"}
@@ -0,0 +1,164 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.verifyKeySignature = verifyKeySignature;
40
+ exports.verifyCustomChangeKeySignatures = verifyCustomChangeKeySignatures;
41
+ exports.verifyUserPublicKey = verifyUserPublicKey;
42
+ /*
43
+
44
+ These are actually not utxo-specific and belong in a more general module.
45
+
46
+ */
47
+ const assert_1 = __importDefault(require("assert"));
48
+ const debug_1 = __importDefault(require("debug"));
49
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
50
+ const secp256k1_1 = require("@bitgo-beta/secp256k1");
51
+ const bitcoinMessage = __importStar(require("bitcoinjs-message"));
52
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
53
+ const debug = (0, debug_1.default)('bitgo:abstract-utxo:verifyKey');
54
+ /**
55
+ * Verify signatures produced by the user key over the backup and bitgo keys.
56
+ *
57
+ * If set, these signatures ensure that the wallet keys cannot be changed after the wallet has been created.
58
+ * @param {VerifyKeySignaturesOptions} params
59
+ * @return {{backup: boolean, bitgo: boolean}}
60
+ */
61
+ function verifyKeySignature(params) {
62
+ // first, let's verify the integrity of the user key, whose public key is used for subsequent verifications
63
+ const { userKeychain, keychainToVerify, keySignature } = params;
64
+ if (!userKeychain) {
65
+ throw new Error('user keychain is required');
66
+ }
67
+ if (!keychainToVerify) {
68
+ throw new Error('keychain to verify is required');
69
+ }
70
+ if (!keySignature) {
71
+ throw new Error('key signature is required');
72
+ }
73
+ // verify the signature against the user public key
74
+ (0, assert_1.default)(userKeychain.pub);
75
+ const publicKey = secp256k1_1.bip32.fromBase58(userKeychain.pub).publicKey;
76
+ // Due to interface of `bitcoinMessage`, we need to convert the public key to an address.
77
+ // Note that this address has no relationship to on-chain transactions. We are
78
+ // only interested in the address as a representation of the public key.
79
+ const signingAddress = utxolib.address.toBase58Check(utxolib.crypto.hash160(publicKey), utxolib.networks.bitcoin.pubKeyHash,
80
+ // we do not pass `this.network` here because it would fail for zcash
81
+ // the bitcoinMessage library decodes the address and throws away the first byte
82
+ // because zcash has a two-byte prefix, verify() decodes zcash addresses to an invalid pubkey hash
83
+ utxolib.networks.bitcoin);
84
+ // BG-5703: use BTC mainnet prefix for all key signature operations
85
+ // (this means do not pass a prefix parameter, and let it use the default prefix instead)
86
+ (0, assert_1.default)(keychainToVerify.pub);
87
+ try {
88
+ return bitcoinMessage.verify(keychainToVerify.pub, signingAddress, Buffer.from(keySignature, 'hex'));
89
+ }
90
+ catch (e) {
91
+ debug('error thrown from bitcoinmessage while verifying key signature', e);
92
+ return false;
93
+ }
94
+ }
95
+ /**
96
+ * Verify signatures against the user private key over the change wallet extended keys
97
+ * @param {ParsedTransaction} tx
98
+ * @param {Keychain} userKeychain
99
+ * @return {boolean}
100
+ * @protected
101
+ */
102
+ function verifyCustomChangeKeySignatures(tx, userKeychain) {
103
+ if (!tx.customChange) {
104
+ throw new Error('parsed transaction is missing required custom change verification data');
105
+ }
106
+ if (!Array.isArray(tx.customChange.keys) || !Array.isArray(tx.customChange.signatures)) {
107
+ throw new Error('customChange property is missing keys or signatures');
108
+ }
109
+ for (const keyIndex of [sdk_core_1.KeyIndices.USER, sdk_core_1.KeyIndices.BACKUP, sdk_core_1.KeyIndices.BITGO]) {
110
+ const keychainToVerify = tx.customChange.keys[keyIndex];
111
+ const keySignature = tx.customChange.signatures[keyIndex];
112
+ if (!keychainToVerify) {
113
+ throw new Error(`missing required custom change ${sdk_core_1.KeyIndices[keyIndex].toLowerCase()} keychain public key`);
114
+ }
115
+ if (!keySignature) {
116
+ throw new Error(`missing required custom change ${sdk_core_1.KeyIndices[keyIndex].toLowerCase()} keychain signature`);
117
+ }
118
+ if (!verifyKeySignature({ userKeychain, keychainToVerify, keySignature })) {
119
+ debug('failed to verify custom change %s key signature!', sdk_core_1.KeyIndices[keyIndex].toLowerCase());
120
+ return false;
121
+ }
122
+ }
123
+ return true;
124
+ }
125
+ /**
126
+ * Decrypt the wallet's user private key and verify that the claimed public key matches
127
+ * @param {BitGoBase} bitgo
128
+ * @param {VerifyUserPublicKeyOptions} params
129
+ * @return {boolean}
130
+ * @protected
131
+ */
132
+ function verifyUserPublicKey(bitgo, params) {
133
+ const { userKeychain, txParams, disableNetworking } = params;
134
+ if (!userKeychain) {
135
+ throw new Error('user keychain is required');
136
+ }
137
+ const userPub = userKeychain.pub;
138
+ // decrypt the user private key, so we can verify that the claimed public key is a match
139
+ let userPrv = userKeychain.prv;
140
+ if (!userPrv && txParams.walletPassphrase) {
141
+ userPrv = (0, sdk_core_1.decryptKeychainPrivateKey)(bitgo, userKeychain, txParams.walletPassphrase);
142
+ }
143
+ if (!userPrv) {
144
+ const errorMessage = 'user private key unavailable for verification';
145
+ if (disableNetworking) {
146
+ console.log(errorMessage);
147
+ return false;
148
+ }
149
+ else {
150
+ throw new Error(errorMessage);
151
+ }
152
+ }
153
+ else {
154
+ const userPrivateKey = secp256k1_1.bip32.fromBase58(userPrv);
155
+ if (userPrivateKey.toBase58() === userPrivateKey.neutered().toBase58()) {
156
+ throw new Error('user private key is only public');
157
+ }
158
+ if (userPrivateKey.neutered().toBase58() !== userPub) {
159
+ throw new Error('user private key does not match public key');
160
+ }
161
+ }
162
+ return true;
163
+ }
164
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5S2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3ZlcmlmeUtleS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXlCQSxnREF1Q0M7QUFTRCwwRUE0QkM7QUFTRCxrREFpQ0M7QUEvSUQ7Ozs7R0FJRztBQUNILG9EQUE0QjtBQUU1QixrREFBK0I7QUFDL0IsOERBQWdEO0FBQ2hELHFEQUE4QztBQUM5QyxrRUFBb0Q7QUFDcEQsbURBQXdGO0FBS3hGLE1BQU0sS0FBSyxHQUFHLElBQUEsZUFBVSxFQUFDLCtCQUErQixDQUFDLENBQUM7QUFFMUQ7Ozs7OztHQU1HO0FBQ0gsU0FBZ0Isa0JBQWtCLENBQUMsTUFBa0M7SUFDbkUsMkdBQTJHO0lBQzNHLE1BQU0sRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQ2hFLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLDJCQUEyQixDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ2xCLE1BQU0sSUFBSSxLQUFLLENBQUMsMkJBQTJCLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQsbURBQW1EO0lBQ25ELElBQUEsZ0JBQU0sRUFBQyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekIsTUFBTSxTQUFTLEdBQUcsaUJBQUssQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUMvRCx5RkFBeUY7SUFDekYsOEVBQThFO0lBQzlFLHdFQUF3RTtJQUN4RSxNQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FDbEQsT0FBTyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQ2pDLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFVBQVU7SUFDbkMscUVBQXFFO0lBQ3JFLGdGQUFnRjtJQUNoRixrR0FBa0c7SUFDbEcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQ3pCLENBQUM7SUFFRixtRUFBbUU7SUFDbkUseUZBQXlGO0lBQ3pGLElBQUEsZ0JBQU0sRUFBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3QixJQUFJLENBQUM7UUFDSCxPQUFPLGNBQWMsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxFQUFFLGNBQWMsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3ZHLENBQUM7SUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1FBQ1gsS0FBSyxDQUFDLGdFQUFnRSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzNFLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztBQUNILENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQiwrQkFBK0IsQ0FDN0MsRUFBOEIsRUFDOUIsWUFBMEI7SUFFMUIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLHdFQUF3RSxDQUFDLENBQUM7SUFDNUYsQ0FBQztJQUVELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztRQUN2RixNQUFNLElBQUksS0FBSyxDQUFDLHFEQUFxRCxDQUFDLENBQUM7SUFDekUsQ0FBQztJQUVELEtBQUssTUFBTSxRQUFRLElBQUksQ0FBQyxxQkFBVSxDQUFDLElBQUksRUFBRSxxQkFBVSxDQUFDLE1BQU0sRUFBRSxxQkFBVSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDOUUsTUFBTSxnQkFBZ0IsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUN4RCxNQUFNLFlBQVksR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxRCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztZQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxxQkFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxzQkFBc0IsQ0FBQyxDQUFDO1FBQzlHLENBQUM7UUFDRCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDbEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQ0FBa0MscUJBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLEVBQUUscUJBQXFCLENBQUMsQ0FBQztRQUM3RyxDQUFDO1FBQ0QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUMxRSxLQUFLLENBQUMsa0RBQWtELEVBQUUscUJBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1lBQzlGLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixtQkFBbUIsQ0FBQyxLQUFnQixFQUFFLE1BQWtDO0lBQ3RGLE1BQU0sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLGlCQUFpQixFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQzdELElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLDJCQUEyQixDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELE1BQU0sT0FBTyxHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUM7SUFFakMsd0ZBQXdGO0lBQ3hGLElBQUksT0FBTyxHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUM7SUFDL0IsSUFBSSxDQUFDLE9BQU8sSUFBSSxRQUFRLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUMxQyxPQUFPLEdBQUcsSUFBQSxvQ0FBeUIsRUFBQyxLQUFLLEVBQUUsWUFBWSxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFFRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixNQUFNLFlBQVksR0FBRywrQ0FBK0MsQ0FBQztRQUNyRSxJQUFJLGlCQUFpQixFQUFFLENBQUM7WUFDdEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMxQixPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNoQyxDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDTixNQUFNLGNBQWMsR0FBRyxpQkFBSyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNqRCxJQUFJLGNBQWMsQ0FBQyxRQUFRLEVBQUUsS0FBSyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQztZQUN2RSxNQUFNLElBQUksS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7UUFDckQsQ0FBQztRQUNELElBQUksY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsRUFBRSxLQUFLLE9BQU8sRUFBRSxDQUFDO1lBQ3JELE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQTRDLENBQUMsQ0FBQztRQUNoRSxDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG5cblRoZXNlIGFyZSBhY3R1YWxseSBub3QgdXR4by1zcGVjaWZpYyBhbmQgYmVsb25nIGluIGEgbW9yZSBnZW5lcmFsIG1vZHVsZS5cblxuICovXG5pbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCBidWlsZERlYnVnIGZyb20gJ2RlYnVnJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgYmlwMzIgfSBmcm9tICdAYml0Z28tYmV0YS9zZWNwMjU2azEnO1xuaW1wb3J0ICogYXMgYml0Y29pbk1lc3NhZ2UgZnJvbSAnYml0Y29pbmpzLW1lc3NhZ2UnO1xuaW1wb3J0IHsgQml0R29CYXNlLCBkZWNyeXB0S2V5Y2hhaW5Qcml2YXRlS2V5LCBLZXlJbmRpY2VzIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuXG5pbXBvcnQgeyBQYXJzZWRUcmFuc2FjdGlvbiwgVmVyaWZ5S2V5U2lnbmF0dXJlc09wdGlvbnMsIFZlcmlmeVVzZXJQdWJsaWNLZXlPcHRpb25zIH0gZnJvbSAnLi9hYnN0cmFjdFV0eG9Db2luJztcbmltcG9ydCB7IFV0eG9LZXljaGFpbiB9IGZyb20gJy4va2V5Y2hhaW5zJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnZlcmlmeUtleScpO1xuXG4vKipcbiAqIFZlcmlmeSBzaWduYXR1cmVzIHByb2R1Y2VkIGJ5IHRoZSB1c2VyIGtleSBvdmVyIHRoZSBiYWNrdXAgYW5kIGJpdGdvIGtleXMuXG4gKlxuICogSWYgc2V0LCB0aGVzZSBzaWduYXR1cmVzIGVuc3VyZSB0aGF0IHRoZSB3YWxsZXQga2V5cyBjYW5ub3QgYmUgY2hhbmdlZCBhZnRlciB0aGUgd2FsbGV0IGhhcyBiZWVuIGNyZWF0ZWQuXG4gKiBAcGFyYW0ge1ZlcmlmeUtleVNpZ25hdHVyZXNPcHRpb25zfSBwYXJhbXNcbiAqIEByZXR1cm4ge3tiYWNrdXA6IGJvb2xlYW4sIGJpdGdvOiBib29sZWFufX1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeUtleVNpZ25hdHVyZShwYXJhbXM6IFZlcmlmeUtleVNpZ25hdHVyZXNPcHRpb25zKTogYm9vbGVhbiB7XG4gIC8vIGZpcnN0LCBsZXQncyB2ZXJpZnkgdGhlIGludGVncml0eSBvZiB0aGUgdXNlciBrZXksIHdob3NlIHB1YmxpYyBrZXkgaXMgdXNlZCBmb3Igc3Vic2VxdWVudCB2ZXJpZmljYXRpb25zXG4gIGNvbnN0IHsgdXNlcktleWNoYWluLCBrZXljaGFpblRvVmVyaWZ5LCBrZXlTaWduYXR1cmUgfSA9IHBhcmFtcztcbiAgaWYgKCF1c2VyS2V5Y2hhaW4pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZXIga2V5Y2hhaW4gaXMgcmVxdWlyZWQnKTtcbiAgfVxuXG4gIGlmICgha2V5Y2hhaW5Ub1ZlcmlmeSkge1xuICAgIHRocm93IG5ldyBFcnJvcigna2V5Y2hhaW4gdG8gdmVyaWZ5IGlzIHJlcXVpcmVkJyk7XG4gIH1cblxuICBpZiAoIWtleVNpZ25hdHVyZSkge1xuICAgIHRocm93IG5ldyBFcnJvcigna2V5IHNpZ25hdHVyZSBpcyByZXF1aXJlZCcpO1xuICB9XG5cbiAgLy8gdmVyaWZ5IHRoZSBzaWduYXR1cmUgYWdhaW5zdCB0aGUgdXNlciBwdWJsaWMga2V5XG4gIGFzc2VydCh1c2VyS2V5Y2hhaW4ucHViKTtcbiAgY29uc3QgcHVibGljS2V5ID0gYmlwMzIuZnJvbUJhc2U1OCh1c2VyS2V5Y2hhaW4ucHViKS5wdWJsaWNLZXk7XG4gIC8vIER1ZSB0byBpbnRlcmZhY2Ugb2YgYGJpdGNvaW5NZXNzYWdlYCwgd2UgbmVlZCB0byBjb252ZXJ0IHRoZSBwdWJsaWMga2V5IHRvIGFuIGFkZHJlc3MuXG4gIC8vIE5vdGUgdGhhdCB0aGlzIGFkZHJlc3MgaGFzIG5vIHJlbGF0aW9uc2hpcCB0byBvbi1jaGFpbiB0cmFuc2FjdGlvbnMuIFdlIGFyZVxuICAvLyBvbmx5IGludGVyZXN0ZWQgaW4gdGhlIGFkZHJlc3MgYXMgYSByZXByZXNlbnRhdGlvbiBvZiB0aGUgcHVibGljIGtleS5cbiAgY29uc3Qgc2lnbmluZ0FkZHJlc3MgPSB1dHhvbGliLmFkZHJlc3MudG9CYXNlNThDaGVjayhcbiAgICB1dHhvbGliLmNyeXB0by5oYXNoMTYwKHB1YmxpY0tleSksXG4gICAgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luLnB1YktleUhhc2gsXG4gICAgLy8gd2UgZG8gbm90IHBhc3MgYHRoaXMubmV0d29ya2AgaGVyZSBiZWNhdXNlIGl0IHdvdWxkIGZhaWwgZm9yIHpjYXNoXG4gICAgLy8gdGhlIGJpdGNvaW5NZXNzYWdlIGxpYnJhcnkgZGVjb2RlcyB0aGUgYWRkcmVzcyBhbmQgdGhyb3dzIGF3YXkgdGhlIGZpcnN0IGJ5dGVcbiAgICAvLyBiZWNhdXNlIHpjYXNoIGhhcyBhIHR3by1ieXRlIHByZWZpeCwgdmVyaWZ5KCkgZGVjb2RlcyB6Y2FzaCBhZGRyZXNzZXMgdG8gYW4gaW52YWxpZCBwdWJrZXkgaGFzaFxuICAgIHV0eG9saWIubmV0d29ya3MuYml0Y29pblxuICApO1xuXG4gIC8vIEJHLTU3MDM6IHVzZSBCVEMgbWFpbm5ldCBwcmVmaXggZm9yIGFsbCBrZXkgc2lnbmF0dXJlIG9wZXJhdGlvbnNcbiAgLy8gKHRoaXMgbWVhbnMgZG8gbm90IHBhc3MgYSBwcmVmaXggcGFyYW1ldGVyLCBhbmQgbGV0IGl0IHVzZSB0aGUgZGVmYXVsdCBwcmVmaXggaW5zdGVhZClcbiAgYXNzZXJ0KGtleWNoYWluVG9WZXJpZnkucHViKTtcbiAgdHJ5IHtcbiAgICByZXR1cm4gYml0Y29pbk1lc3NhZ2UudmVyaWZ5KGtleWNoYWluVG9WZXJpZnkucHViLCBzaWduaW5nQWRkcmVzcywgQnVmZmVyLmZyb20oa2V5U2lnbmF0dXJlLCAnaGV4JykpO1xuICB9IGNhdGNoIChlKSB7XG4gICAgZGVidWcoJ2Vycm9yIHRocm93biBmcm9tIGJpdGNvaW5tZXNzYWdlIHdoaWxlIHZlcmlmeWluZyBrZXkgc2lnbmF0dXJlJywgZSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogVmVyaWZ5IHNpZ25hdHVyZXMgYWdhaW5zdCB0aGUgdXNlciBwcml2YXRlIGtleSBvdmVyIHRoZSBjaGFuZ2Ugd2FsbGV0IGV4dGVuZGVkIGtleXNcbiAqIEBwYXJhbSB7UGFyc2VkVHJhbnNhY3Rpb259IHR4XG4gKiBAcGFyYW0ge0tleWNoYWlufSB1c2VyS2V5Y2hhaW5cbiAqIEByZXR1cm4ge2Jvb2xlYW59XG4gKiBAcHJvdGVjdGVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB2ZXJpZnlDdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVzPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KFxuICB0eDogUGFyc2VkVHJhbnNhY3Rpb248VE51bWJlcj4sXG4gIHVzZXJLZXljaGFpbjogVXR4b0tleWNoYWluXG4pOiBib29sZWFuIHtcbiAgaWYgKCF0eC5jdXN0b21DaGFuZ2UpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3BhcnNlZCB0cmFuc2FjdGlvbiBpcyBtaXNzaW5nIHJlcXVpcmVkIGN1c3RvbSBjaGFuZ2UgdmVyaWZpY2F0aW9uIGRhdGEnKTtcbiAgfVxuXG4gIGlmICghQXJyYXkuaXNBcnJheSh0eC5jdXN0b21DaGFuZ2Uua2V5cykgfHwgIUFycmF5LmlzQXJyYXkodHguY3VzdG9tQ2hhbmdlLnNpZ25hdHVyZXMpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdjdXN0b21DaGFuZ2UgcHJvcGVydHkgaXMgbWlzc2luZyBrZXlzIG9yIHNpZ25hdHVyZXMnKTtcbiAgfVxuXG4gIGZvciAoY29uc3Qga2V5SW5kZXggb2YgW0tleUluZGljZXMuVVNFUiwgS2V5SW5kaWNlcy5CQUNLVVAsIEtleUluZGljZXMuQklUR09dKSB7XG4gICAgY29uc3Qga2V5Y2hhaW5Ub1ZlcmlmeSA9IHR4LmN1c3RvbUNoYW5nZS5rZXlzW2tleUluZGV4XTtcbiAgICBjb25zdCBrZXlTaWduYXR1cmUgPSB0eC5jdXN0b21DaGFuZ2Uuc2lnbmF0dXJlc1trZXlJbmRleF07XG4gICAgaWYgKCFrZXljaGFpblRvVmVyaWZ5KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYG1pc3NpbmcgcmVxdWlyZWQgY3VzdG9tIGNoYW5nZSAke0tleUluZGljZXNba2V5SW5kZXhdLnRvTG93ZXJDYXNlKCl9IGtleWNoYWluIHB1YmxpYyBrZXlgKTtcbiAgICB9XG4gICAgaWYgKCFrZXlTaWduYXR1cmUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgbWlzc2luZyByZXF1aXJlZCBjdXN0b20gY2hhbmdlICR7S2V5SW5kaWNlc1trZXlJbmRleF0udG9Mb3dlckNhc2UoKX0ga2V5Y2hhaW4gc2lnbmF0dXJlYCk7XG4gICAgfVxuICAgIGlmICghdmVyaWZ5S2V5U2lnbmF0dXJlKHsgdXNlcktleWNoYWluLCBrZXljaGFpblRvVmVyaWZ5LCBrZXlTaWduYXR1cmUgfSkpIHtcbiAgICAgIGRlYnVnKCdmYWlsZWQgdG8gdmVyaWZ5IGN1c3RvbSBjaGFuZ2UgJXMga2V5IHNpZ25hdHVyZSEnLCBLZXlJbmRpY2VzW2tleUluZGV4XS50b0xvd2VyQ2FzZSgpKTtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuLyoqXG4gKiBEZWNyeXB0IHRoZSB3YWxsZXQncyB1c2VyIHByaXZhdGUga2V5IGFuZCB2ZXJpZnkgdGhhdCB0aGUgY2xhaW1lZCBwdWJsaWMga2V5IG1hdGNoZXNcbiAqIEBwYXJhbSB7Qml0R29CYXNlfSBiaXRnb1xuICogQHBhcmFtIHtWZXJpZnlVc2VyUHVibGljS2V5T3B0aW9uc30gcGFyYW1zXG4gKiBAcmV0dXJuIHtib29sZWFufVxuICogQHByb3RlY3RlZFxuICovXG5leHBvcnQgZnVuY3Rpb24gdmVyaWZ5VXNlclB1YmxpY0tleShiaXRnbzogQml0R29CYXNlLCBwYXJhbXM6IFZlcmlmeVVzZXJQdWJsaWNLZXlPcHRpb25zKTogYm9vbGVhbiB7XG4gIGNvbnN0IHsgdXNlcktleWNoYWluLCB0eFBhcmFtcywgZGlzYWJsZU5ldHdvcmtpbmcgfSA9IHBhcmFtcztcbiAgaWYgKCF1c2VyS2V5Y2hhaW4pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZXIga2V5Y2hhaW4gaXMgcmVxdWlyZWQnKTtcbiAgfVxuXG4gIGNvbnN0IHVzZXJQdWIgPSB1c2VyS2V5Y2hhaW4ucHViO1xuXG4gIC8vIGRlY3J5cHQgdGhlIHVzZXIgcHJpdmF0ZSBrZXksIHNvIHdlIGNhbiB2ZXJpZnkgdGhhdCB0aGUgY2xhaW1lZCBwdWJsaWMga2V5IGlzIGEgbWF0Y2hcbiAgbGV0IHVzZXJQcnYgPSB1c2VyS2V5Y2hhaW4ucHJ2O1xuICBpZiAoIXVzZXJQcnYgJiYgdHhQYXJhbXMud2FsbGV0UGFzc3BocmFzZSkge1xuICAgIHVzZXJQcnYgPSBkZWNyeXB0S2V5Y2hhaW5Qcml2YXRlS2V5KGJpdGdvLCB1c2VyS2V5Y2hhaW4sIHR4UGFyYW1zLndhbGxldFBhc3NwaHJhc2UpO1xuICB9XG5cbiAgaWYgKCF1c2VyUHJ2KSB7XG4gICAgY29uc3QgZXJyb3JNZXNzYWdlID0gJ3VzZXIgcHJpdmF0ZSBrZXkgdW5hdmFpbGFibGUgZm9yIHZlcmlmaWNhdGlvbic7XG4gICAgaWYgKGRpc2FibGVOZXR3b3JraW5nKSB7XG4gICAgICBjb25zb2xlLmxvZyhlcnJvck1lc3NhZ2UpO1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoZXJyb3JNZXNzYWdlKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgY29uc3QgdXNlclByaXZhdGVLZXkgPSBiaXAzMi5mcm9tQmFzZTU4KHVzZXJQcnYpO1xuICAgIGlmICh1c2VyUHJpdmF0ZUtleS50b0Jhc2U1OCgpID09PSB1c2VyUHJpdmF0ZUtleS5uZXV0ZXJlZCgpLnRvQmFzZTU4KCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigndXNlciBwcml2YXRlIGtleSBpcyBvbmx5IHB1YmxpYycpO1xuICAgIH1cbiAgICBpZiAodXNlclByaXZhdGVLZXkubmV1dGVyZWQoKS50b0Jhc2U1OCgpICE9PSB1c2VyUHViKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZXIgcHJpdmF0ZSBrZXkgZG9lcyBub3QgbWF0Y2ggcHVibGljIGtleScpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuIl19
@@ -0,0 +1,15 @@
1
+ import { Wallet, WalletData } from '@bitgo-beta/sdk-core';
2
+ import { UtxoCoinName } from './names';
3
+ export interface UtxoWalletData extends WalletData {
4
+ coin: UtxoCoinName;
5
+ customChangeKeySignatures: {
6
+ user: string;
7
+ backup: string;
8
+ bitgo: string;
9
+ };
10
+ }
11
+ export declare function isUtxoWalletData(obj: WalletData): obj is UtxoWalletData;
12
+ export interface UtxoWallet extends Wallet {
13
+ _wallet: UtxoWalletData;
14
+ }
15
+ //# sourceMappingURL=wallet.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../../src/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAE1D,OAAO,EAAkB,YAAY,EAAE,MAAM,SAAS,CAAC;AAGvD,MAAM,WAAW,cAAe,SAAQ,UAAU;IAChD,IAAI,EAAE,YAAY,CAAC;IACnB,yBAAyB,EAAE;QACzB,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;CACH;AAED,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,UAAU,GAAG,GAAG,IAAI,cAAc,CAEvE;AAED,MAAM,WAAW,UAAW,SAAQ,MAAM;IACxC,OAAO,EAAE,cAAc,CAAC;CACzB"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isUtxoWalletData = isUtxoWalletData;
4
+ const names_1 = require("./names");
5
+ function isUtxoWalletData(obj) {
6
+ return (0, names_1.isUtxoCoinName)(obj.coin);
7
+ }
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2FsbGV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3dhbGxldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQWNBLDRDQUVDO0FBZEQsbUNBQXVEO0FBWXZELFNBQWdCLGdCQUFnQixDQUFDLEdBQWU7SUFDOUMsT0FBTyxJQUFBLHNCQUFjLEVBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ2xDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXYWxsZXQsIFdhbGxldERhdGEgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5cbmltcG9ydCB7IGlzVXR4b0NvaW5OYW1lLCBVdHhvQ29pbk5hbWUgfSBmcm9tICcuL25hbWVzJztcblxuLy8gcGFyc2VUcmFuc2FjdGlvbnMnIHJldHVybiB0eXBlIG1ha2VzIHVzZSBvZiBXYWxsZXREYXRhJ3MgdHlwZSBidXQgd2l0aCBjdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVzIGFzIHJlcXVpcmVkLlxuZXhwb3J0IGludGVyZmFjZSBVdHhvV2FsbGV0RGF0YSBleHRlbmRzIFdhbGxldERhdGEge1xuICBjb2luOiBVdHhvQ29pbk5hbWU7XG4gIGN1c3RvbUNoYW5nZUtleVNpZ25hdHVyZXM6IHtcbiAgICB1c2VyOiBzdHJpbmc7XG4gICAgYmFja3VwOiBzdHJpbmc7XG4gICAgYml0Z286IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzVXR4b1dhbGxldERhdGEob2JqOiBXYWxsZXREYXRhKTogb2JqIGlzIFV0eG9XYWxsZXREYXRhIHtcbiAgcmV0dXJuIGlzVXR4b0NvaW5OYW1lKG9iai5jb2luKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVdHhvV2FsbGV0IGV4dGVuZHMgV2FsbGV0IHtcbiAgX3dhbGxldDogVXR4b1dhbGxldERhdGE7XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ import 'should-http';
2
+ //# sourceMappingURL=bch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bch.d.ts","sourceRoot":"","sources":["../../../../../../test/integration/impl/bch/bch.ts"],"names":[],"mappings":"AACA,OAAO,aAAa,CAAC"}