@bitgo-beta/abstract-utxo 1.6.1-alpha.45 → 1.6.1-alpha.451

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 (795) hide show
  1. package/README.md +76 -0
  2. package/dist/cjs/src/abstractUtxoCoin.d.ts +435 -0
  3. package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -0
  4. package/dist/cjs/src/abstractUtxoCoin.js +657 -0
  5. package/dist/cjs/src/address/fixedScript.d.ts +49 -0
  6. package/dist/cjs/src/address/fixedScript.d.ts.map +1 -0
  7. package/dist/cjs/src/address/fixedScript.js +135 -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 +74 -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 +8 -0
  56. package/dist/cjs/src/impl/bcha/bcha.d.ts.map +1 -0
  57. package/dist/cjs/src/impl/bcha/bcha.js +48 -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 +32 -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 +52 -0
  143. package/dist/cjs/src/keychains.d.ts.map +1 -0
  144. package/dist/cjs/src/keychains.js +136 -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 +89 -0
  170. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts.map +1 -0
  171. package/dist/cjs/src/recovery/backupKeyRecovery.js +361 -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 +18 -7
  179. package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -0
  180. package/dist/cjs/src/recovery/crossChainRecovery.js +391 -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/cjs/src/recovery/psbt.d.ts +84 -0
  187. package/dist/cjs/src/recovery/psbt.d.ts.map +1 -0
  188. package/dist/cjs/src/recovery/psbt.js +250 -0
  189. package/dist/cjs/src/transaction/bip322.d.ts +27 -0
  190. package/dist/cjs/src/transaction/bip322.d.ts.map +1 -0
  191. package/dist/cjs/src/transaction/bip322.js +125 -0
  192. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts +2 -0
  193. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  194. package/dist/cjs/src/transaction/common/verifyPayGoAmount.js +3 -0
  195. package/dist/cjs/src/transaction/decode.d.ts +11 -0
  196. package/dist/cjs/src/transaction/decode.d.ts.map +1 -0
  197. package/dist/cjs/src/transaction/decode.js +81 -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 +16 -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 +14 -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 +36 -0
  217. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  218. package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +109 -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/SigningError.d.ts +24 -0
  226. package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts.map +1 -0
  227. package/dist/cjs/src/transaction/fixedScript/SigningError.js +26 -0
  228. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +11 -0
  229. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  230. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +67 -0
  231. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts +73 -0
  232. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  233. package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +344 -0
  234. package/dist/cjs/src/transaction/fixedScript/index.d.ts +10 -0
  235. package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -0
  236. package/dist/cjs/src/transaction/fixedScript/index.js +32 -0
  237. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts +4 -0
  238. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts.map +1 -0
  239. package/dist/cjs/src/transaction/fixedScript/musig2.js +3 -0
  240. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts +28 -0
  241. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  242. package/dist/cjs/src/transaction/fixedScript/parseOutput.js +220 -0
  243. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts +8 -0
  244. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  245. package/dist/cjs/src/transaction/fixedScript/parseTransaction.js +215 -0
  246. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts +7 -0
  247. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  248. package/dist/cjs/src/transaction/fixedScript/replayProtection.js +78 -0
  249. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  250. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  251. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.js +152 -0
  252. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts +30 -0
  253. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  254. package/dist/cjs/src/transaction/fixedScript/signPsbt.js +174 -0
  255. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  256. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  257. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.js +129 -0
  258. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts +17 -0
  259. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  260. package/dist/cjs/src/transaction/fixedScript/signTransaction.js +50 -0
  261. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  262. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  263. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +199 -0
  264. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  265. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  266. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.js +53 -0
  267. package/dist/cjs/src/transaction/index.d.ts +8 -0
  268. package/dist/cjs/src/transaction/index.d.ts.map +1 -0
  269. package/dist/cjs/src/transaction/index.js +50 -0
  270. package/dist/cjs/src/transaction/outputDifference.d.ts +40 -0
  271. package/dist/cjs/src/transaction/outputDifference.d.ts.map +1 -0
  272. package/dist/cjs/src/transaction/outputDifference.js +47 -0
  273. package/dist/cjs/src/transaction/parseTransaction.d.ts +4 -0
  274. package/dist/cjs/src/transaction/parseTransaction.d.ts.map +1 -0
  275. package/dist/cjs/src/transaction/parseTransaction.js +48 -0
  276. package/dist/cjs/src/transaction/recipient.d.ts +29 -0
  277. package/dist/cjs/src/transaction/recipient.d.ts.map +1 -0
  278. package/dist/cjs/src/transaction/recipient.js +88 -0
  279. package/dist/cjs/src/transaction/signTransaction.d.ts +6 -0
  280. package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -0
  281. package/dist/cjs/src/transaction/signTransaction.js +105 -0
  282. package/dist/cjs/src/transaction/types.d.ts +49 -0
  283. package/dist/cjs/src/transaction/types.d.ts.map +1 -0
  284. package/dist/cjs/src/transaction/types.js +7 -0
  285. package/dist/cjs/src/transaction/verifyTransaction.d.ts +4 -0
  286. package/dist/cjs/src/transaction/verifyTransaction.d.ts.map +1 -0
  287. package/dist/cjs/src/transaction/verifyTransaction.js +50 -0
  288. package/dist/cjs/src/verifyKey.d.ts +29 -0
  289. package/dist/cjs/src/verifyKey.d.ts.map +1 -0
  290. package/dist/cjs/src/verifyKey.js +164 -0
  291. package/dist/cjs/src/wallet.d.ts +15 -0
  292. package/dist/cjs/src/wallet.d.ts.map +1 -0
  293. package/dist/cjs/src/wallet.js +8 -0
  294. package/dist/cjs/test/integration/impl/bch/bch.d.ts +2 -0
  295. package/dist/cjs/test/integration/impl/bch/bch.d.ts.map +1 -0
  296. package/dist/cjs/test/integration/impl/bch/bch.js +74 -0
  297. package/dist/cjs/test/unit/address.d.ts +2 -0
  298. package/dist/cjs/test/unit/address.d.ts.map +1 -0
  299. package/dist/cjs/test/unit/address.js +182 -0
  300. package/dist/cjs/test/unit/bip322.d.ts +2 -0
  301. package/dist/cjs/test/unit/bip322.d.ts.map +1 -0
  302. package/dist/cjs/test/unit/bip322.js +45 -0
  303. package/dist/cjs/test/unit/coins.d.ts +2 -0
  304. package/dist/cjs/test/unit/coins.d.ts.map +1 -0
  305. package/dist/cjs/test/unit/coins.js +97 -0
  306. package/dist/cjs/test/unit/customChangeWallet.d.ts +2 -0
  307. package/dist/cjs/test/unit/customChangeWallet.d.ts.map +1 -0
  308. package/dist/cjs/test/unit/customChangeWallet.js +154 -0
  309. package/dist/cjs/test/unit/customSigner.d.ts +3 -0
  310. package/dist/cjs/test/unit/customSigner.d.ts.map +1 -0
  311. package/dist/cjs/test/unit/customSigner.js +108 -0
  312. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts +2 -0
  313. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts.map +1 -0
  314. package/dist/cjs/test/unit/descriptor/NamedDescriptor.js +18 -0
  315. package/dist/cjs/test/unit/descriptor/builder.d.ts +2 -0
  316. package/dist/cjs/test/unit/descriptor/builder.d.ts.map +1 -0
  317. package/dist/cjs/test/unit/descriptor/builder.js +72 -0
  318. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts +2 -0
  319. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  320. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.js +20 -0
  321. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts +2 -0
  322. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts.map +1 -0
  323. package/dist/cjs/test/unit/descriptor/descriptorWallet.js +28 -0
  324. package/dist/cjs/test/unit/descriptorAddress.d.ts +3 -0
  325. package/dist/cjs/test/unit/descriptorAddress.d.ts.map +1 -0
  326. package/dist/cjs/test/unit/descriptorAddress.js +102 -0
  327. package/dist/cjs/test/unit/explainTransaction.d.ts +2 -0
  328. package/dist/cjs/test/unit/explainTransaction.d.ts.map +1 -0
  329. package/dist/cjs/test/unit/explainTransaction.js +74 -0
  330. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts +15 -0
  331. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts.map +1 -0
  332. package/dist/cjs/test/unit/fixtures/bip322/fixtures.js +51 -0
  333. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts +4 -0
  334. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts.map +1 -0
  335. package/dist/cjs/test/unit/fixtures/psbtHexProof.js +9 -0
  336. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts +2 -0
  337. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts.map +1 -0
  338. package/dist/cjs/test/unit/impl/bch/unit/bch.js +138 -0
  339. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts +2 -0
  340. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts.map +1 -0
  341. package/dist/cjs/test/unit/impl/bcha/unit/index.js +47 -0
  342. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts +2 -0
  343. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts.map +1 -0
  344. package/dist/cjs/test/unit/impl/bsv/unit/index.js +32 -0
  345. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts +2 -0
  346. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts.map +1 -0
  347. package/dist/cjs/test/unit/impl/btc/unit/btc.js +220 -0
  348. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts +4 -0
  349. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts.map +1 -0
  350. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.js +10 -0
  351. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts +2 -0
  352. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts.map +1 -0
  353. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.js +18 -0
  354. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts +2 -0
  355. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts.map +1 -0
  356. package/dist/cjs/test/unit/impl/btg/unit/index.js +29 -0
  357. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts +2 -0
  358. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts.map +1 -0
  359. package/dist/cjs/test/unit/impl/dash/unit/index.js +32 -0
  360. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts +2 -0
  361. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts.map +1 -0
  362. package/dist/cjs/test/unit/impl/doge/unit/index.js +32 -0
  363. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts +2 -0
  364. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts.map +1 -0
  365. package/dist/cjs/test/unit/impl/ltc/unit/index.js +39 -0
  366. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts +2 -0
  367. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts.map +1 -0
  368. package/dist/cjs/test/unit/impl/zec/unit/index.js +29 -0
  369. package/dist/cjs/test/unit/keySignatures.d.ts +2 -0
  370. package/dist/cjs/test/unit/keySignatures.d.ts.map +1 -0
  371. package/dist/cjs/test/unit/keySignatures.js +54 -0
  372. package/dist/cjs/test/unit/keychains.d.ts +2 -0
  373. package/dist/cjs/test/unit/keychains.d.ts.map +1 -0
  374. package/dist/cjs/test/unit/keychains.js +49 -0
  375. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts +2 -0
  376. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts.map +1 -0
  377. package/dist/cjs/test/unit/offlineVault/halfSigned.js +124 -0
  378. package/dist/cjs/test/unit/parseTransaction.d.ts +2 -0
  379. package/dist/cjs/test/unit/parseTransaction.d.ts.map +1 -0
  380. package/dist/cjs/test/unit/parseTransaction.js +125 -0
  381. package/dist/cjs/test/unit/prebuildAndSign.d.ts +6 -0
  382. package/dist/cjs/test/unit/prebuildAndSign.d.ts.map +1 -0
  383. package/dist/cjs/test/unit/prebuildAndSign.js +270 -0
  384. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts +2 -0
  385. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts.map +1 -0
  386. package/dist/cjs/test/unit/recovery/backupKeyRecovery.js +309 -0
  387. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts +2 -0
  388. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts.map +1 -0
  389. package/dist/cjs/test/unit/recovery/crossChainRecovery.js +295 -0
  390. package/dist/cjs/test/unit/recovery/mock.d.ts +30 -0
  391. package/dist/cjs/test/unit/recovery/mock.d.ts.map +1 -0
  392. package/dist/cjs/test/unit/recovery/mock.js +138 -0
  393. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts +2 -0
  394. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  395. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.js +30 -0
  396. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts +6 -0
  397. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts.map +1 -0
  398. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.js +17 -0
  399. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts +2 -0
  400. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts.map +1 -0
  401. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.js +76 -0
  402. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts +2 -0
  403. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts.map +1 -0
  404. package/dist/cjs/test/unit/transaction/descriptor/parse.js +135 -0
  405. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts +2 -0
  406. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts.map +1 -0
  407. package/dist/cjs/test/unit/transaction/descriptor/sign.js +32 -0
  408. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts +2 -0
  409. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts.map +1 -0
  410. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.js +48 -0
  411. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts +2 -0
  412. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts.map +1 -0
  413. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +132 -0
  414. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.d.ts +2 -0
  415. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.d.ts.map +1 -0
  416. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.js +288 -0
  417. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts +2 -0
  418. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  419. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.js +59 -0
  420. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts +2 -0
  421. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  422. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.js +157 -0
  423. package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts +3 -0
  424. package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts.map +1 -0
  425. package/dist/cjs/test/unit/transaction/fixedScript/util.js +41 -0
  426. package/dist/cjs/test/unit/transaction.d.ts +2 -0
  427. package/dist/cjs/test/unit/transaction.d.ts.map +1 -0
  428. package/dist/cjs/test/unit/transaction.js +528 -0
  429. package/dist/cjs/test/unit/txFormat.d.ts +30 -0
  430. package/dist/cjs/test/unit/txFormat.d.ts.map +1 -0
  431. package/dist/cjs/test/unit/txFormat.js +174 -0
  432. package/dist/cjs/test/unit/util/fixtures.d.ts +14 -0
  433. package/dist/cjs/test/unit/util/fixtures.d.ts.map +1 -0
  434. package/dist/cjs/test/unit/util/fixtures.js +102 -0
  435. package/dist/cjs/test/unit/util/index.d.ts +7 -0
  436. package/dist/cjs/test/unit/util/index.d.ts.map +1 -0
  437. package/dist/cjs/test/unit/util/index.js +23 -0
  438. package/dist/cjs/test/unit/util/keychains.d.ts +26 -0
  439. package/dist/cjs/test/unit/util/keychains.d.ts.map +1 -0
  440. package/dist/cjs/test/unit/util/keychains.js +72 -0
  441. package/dist/cjs/test/unit/util/nockBitGo.d.ts +3 -0
  442. package/dist/cjs/test/unit/util/nockBitGo.d.ts.map +1 -0
  443. package/dist/cjs/test/unit/util/nockBitGo.js +11 -0
  444. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts +8 -0
  445. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts.map +1 -0
  446. package/dist/cjs/test/unit/util/nockIndexerAPI.js +56 -0
  447. package/dist/cjs/test/unit/util/transaction.d.ts +24 -0
  448. package/dist/cjs/test/unit/util/transaction.d.ts.map +1 -0
  449. package/dist/cjs/test/unit/util/transaction.js +107 -0
  450. package/dist/cjs/test/unit/util/unspents.d.ts +13 -0
  451. package/dist/cjs/test/unit/util/unspents.d.ts.map +1 -0
  452. package/dist/cjs/test/unit/util/unspents.js +106 -0
  453. package/dist/cjs/test/unit/util/utxoCoins.d.ts +8 -0
  454. package/dist/cjs/test/unit/util/utxoCoins.d.ts.map +1 -0
  455. package/dist/cjs/test/unit/util/utxoCoins.js +95 -0
  456. package/dist/cjs/test/unit/util/wallet.d.ts +4 -0
  457. package/dist/cjs/test/unit/util/wallet.d.ts.map +1 -0
  458. package/dist/cjs/test/unit/util/wallet.js +9 -0
  459. package/dist/cjs/test/unit/verifyTransaction.d.ts +2 -0
  460. package/dist/cjs/test/unit/verifyTransaction.d.ts.map +1 -0
  461. package/dist/cjs/test/unit/verifyTransaction.js +327 -0
  462. package/dist/cjs/test/unit/wallet.d.ts +2 -0
  463. package/dist/cjs/test/unit/wallet.d.ts.map +1 -0
  464. package/dist/cjs/test/unit/wallet.js +248 -0
  465. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  466. package/dist/esm/abstractUtxoCoin.d.ts +435 -0
  467. package/dist/esm/abstractUtxoCoin.d.ts.map +1 -0
  468. package/dist/esm/abstractUtxoCoin.js +616 -0
  469. package/dist/esm/address/fixedScript.d.ts +49 -0
  470. package/dist/esm/address/fixedScript.d.ts.map +1 -0
  471. package/dist/esm/address/fixedScript.js +94 -0
  472. package/dist/esm/address/index.d.ts +2 -0
  473. package/dist/esm/address/index.d.ts.map +1 -0
  474. package/dist/esm/address/index.js +2 -0
  475. package/dist/esm/config.d.ts +9 -0
  476. package/dist/esm/config.js +11 -0
  477. package/dist/esm/descriptor/NamedDescriptor.d.ts +20 -0
  478. package/dist/esm/descriptor/NamedDescriptor.d.ts.map +1 -0
  479. package/dist/esm/descriptor/NamedDescriptor.js +39 -0
  480. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  481. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  482. package/dist/esm/descriptor/assertDescriptorWalletAddress.js +27 -0
  483. package/dist/esm/descriptor/builder/builder.d.ts +13 -0
  484. package/dist/esm/descriptor/builder/builder.d.ts.map +1 -0
  485. package/dist/esm/descriptor/builder/builder.js +34 -0
  486. package/dist/esm/descriptor/builder/index.d.ts +3 -0
  487. package/dist/esm/descriptor/builder/index.d.ts.map +1 -0
  488. package/dist/esm/descriptor/builder/index.js +3 -0
  489. package/dist/esm/descriptor/builder/parse.d.ts +5 -0
  490. package/dist/esm/descriptor/builder/parse.d.ts.map +1 -0
  491. package/dist/esm/descriptor/builder/parse.js +112 -0
  492. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  493. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  494. package/dist/esm/descriptor/createWallet/createDescriptorWallet.js +37 -0
  495. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts +12 -0
  496. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  497. package/dist/esm/descriptor/createWallet/createDescriptors.js +29 -0
  498. package/dist/esm/descriptor/createWallet/index.d.ts +3 -0
  499. package/dist/esm/descriptor/createWallet/index.d.ts.map +1 -0
  500. package/dist/esm/descriptor/createWallet/index.js +3 -0
  501. package/dist/esm/descriptor/descriptorWallet.d.ts +19 -0
  502. package/dist/esm/descriptor/descriptorWallet.d.ts.map +1 -0
  503. package/dist/esm/descriptor/descriptorWallet.js +16 -0
  504. package/dist/esm/descriptor/index.d.ts +8 -0
  505. package/dist/esm/descriptor/index.d.ts.map +1 -0
  506. package/dist/esm/descriptor/index.js +7 -0
  507. package/dist/esm/descriptor/validatePolicy.d.ts +22 -0
  508. package/dist/esm/descriptor/validatePolicy.d.ts.map +1 -0
  509. package/dist/esm/descriptor/validatePolicy.js +80 -0
  510. package/dist/esm/impl/bch/bch.d.ts +20 -0
  511. package/dist/esm/impl/bch/bch.d.ts.map +1 -0
  512. package/dist/esm/impl/bch/bch.js +37 -0
  513. package/dist/esm/impl/bch/index.d.ts +3 -0
  514. package/dist/esm/impl/bch/index.d.ts.map +1 -0
  515. package/dist/esm/impl/bch/index.js +3 -0
  516. package/dist/esm/impl/bch/tbch.d.ts +10 -0
  517. package/dist/esm/impl/bch/tbch.d.ts.map +1 -0
  518. package/dist/esm/impl/bch/tbch.js +11 -0
  519. package/dist/esm/impl/bcha/bcha.d.ts +8 -0
  520. package/dist/esm/impl/bcha/bcha.d.ts.map +1 -0
  521. package/dist/esm/impl/bcha/bcha.js +11 -0
  522. package/dist/esm/impl/bcha/index.d.ts +3 -0
  523. package/dist/esm/impl/bcha/index.d.ts.map +1 -0
  524. package/dist/esm/impl/bcha/index.js +3 -0
  525. package/dist/esm/impl/bcha/tbcha.d.ts +10 -0
  526. package/dist/esm/impl/bcha/tbcha.d.ts.map +1 -0
  527. package/dist/esm/impl/bcha/tbcha.js +11 -0
  528. package/dist/esm/impl/bsv/bsv.d.ts +8 -0
  529. package/dist/esm/impl/bsv/bsv.d.ts.map +1 -0
  530. package/dist/esm/impl/bsv/bsv.js +11 -0
  531. package/dist/esm/impl/bsv/index.d.ts +3 -0
  532. package/dist/esm/impl/bsv/index.d.ts.map +1 -0
  533. package/dist/esm/impl/bsv/index.js +3 -0
  534. package/dist/esm/impl/bsv/tbsv.d.ts +10 -0
  535. package/dist/esm/impl/bsv/tbsv.d.ts.map +1 -0
  536. package/dist/esm/impl/bsv/tbsv.js +11 -0
  537. package/dist/esm/impl/btc/btc.d.ts +13 -0
  538. package/dist/esm/impl/btc/btc.d.ts.map +1 -0
  539. package/dist/esm/impl/btc/btc.js +18 -0
  540. package/dist/esm/impl/btc/index.d.ts +7 -0
  541. package/dist/esm/impl/btc/index.d.ts.map +1 -0
  542. package/dist/esm/impl/btc/index.js +7 -0
  543. package/dist/esm/impl/btc/inscriptionBuilder.d.ts +51 -0
  544. package/dist/esm/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  545. package/dist/esm/impl/btc/inscriptionBuilder.js +143 -0
  546. package/dist/esm/impl/btc/tbtc.d.ts +10 -0
  547. package/dist/esm/impl/btc/tbtc.d.ts.map +1 -0
  548. package/dist/esm/impl/btc/tbtc.js +11 -0
  549. package/dist/esm/impl/btc/tbtc4.d.ts +10 -0
  550. package/dist/esm/impl/btc/tbtc4.d.ts.map +1 -0
  551. package/dist/esm/impl/btc/tbtc4.js +11 -0
  552. package/dist/esm/impl/btc/tbtcbgsig.d.ts +10 -0
  553. package/dist/esm/impl/btc/tbtcbgsig.d.ts.map +1 -0
  554. package/dist/esm/impl/btc/tbtcbgsig.js +11 -0
  555. package/dist/esm/impl/btc/tbtcsig.d.ts +10 -0
  556. package/dist/esm/impl/btc/tbtcsig.d.ts.map +1 -0
  557. package/dist/esm/impl/btc/tbtcsig.js +11 -0
  558. package/dist/esm/impl/btg/btg.d.ts +7 -0
  559. package/dist/esm/impl/btg/btg.d.ts.map +1 -0
  560. package/dist/esm/impl/btg/btg.js +11 -0
  561. package/dist/esm/impl/btg/index.d.ts +2 -0
  562. package/dist/esm/impl/btg/index.d.ts.map +1 -0
  563. package/dist/esm/impl/btg/index.js +2 -0
  564. package/dist/esm/impl/dash/dash.d.ts +7 -0
  565. package/dist/esm/impl/dash/dash.d.ts.map +1 -0
  566. package/dist/esm/impl/dash/dash.js +11 -0
  567. package/dist/esm/impl/dash/index.d.ts +3 -0
  568. package/dist/esm/impl/dash/index.d.ts.map +1 -0
  569. package/dist/esm/impl/dash/index.js +3 -0
  570. package/dist/esm/impl/dash/tdash.d.ts +10 -0
  571. package/dist/esm/impl/dash/tdash.d.ts.map +1 -0
  572. package/dist/esm/impl/dash/tdash.js +11 -0
  573. package/dist/esm/impl/doge/doge.d.ts +32 -0
  574. package/dist/esm/impl/doge/doge.d.ts.map +1 -0
  575. package/dist/esm/impl/doge/doge.js +75 -0
  576. package/dist/esm/impl/doge/index.d.ts +3 -0
  577. package/dist/esm/impl/doge/index.d.ts.map +1 -0
  578. package/dist/esm/impl/doge/index.js +3 -0
  579. package/dist/esm/impl/doge/tdoge.d.ts +10 -0
  580. package/dist/esm/impl/doge/tdoge.d.ts.map +1 -0
  581. package/dist/esm/impl/doge/tdoge.js +11 -0
  582. package/dist/esm/impl/index.d.ts +10 -0
  583. package/dist/esm/impl/index.d.ts.map +1 -0
  584. package/dist/esm/impl/index.js +10 -0
  585. package/dist/esm/impl/ltc/index.d.ts +3 -0
  586. package/dist/esm/impl/ltc/index.d.ts.map +1 -0
  587. package/dist/esm/impl/ltc/index.js +3 -0
  588. package/dist/esm/impl/ltc/ltc.d.ts +7 -0
  589. package/dist/esm/impl/ltc/ltc.d.ts.map +1 -0
  590. package/dist/esm/impl/ltc/ltc.js +15 -0
  591. package/dist/esm/impl/ltc/tltc.d.ts +7 -0
  592. package/dist/esm/impl/ltc/tltc.d.ts.map +1 -0
  593. package/dist/esm/impl/ltc/tltc.js +14 -0
  594. package/dist/esm/impl/zec/index.d.ts +3 -0
  595. package/dist/esm/impl/zec/index.d.ts.map +1 -0
  596. package/dist/esm/impl/zec/index.js +3 -0
  597. package/dist/esm/impl/zec/tzec.d.ts +7 -0
  598. package/dist/esm/impl/zec/tzec.d.ts.map +1 -0
  599. package/dist/esm/impl/zec/tzec.js +11 -0
  600. package/dist/esm/impl/zec/zec.d.ts +10 -0
  601. package/dist/esm/impl/zec/zec.d.ts.map +1 -0
  602. package/dist/esm/impl/zec/zec.js +11 -0
  603. package/dist/esm/index.d.ts +21 -0
  604. package/dist/esm/index.d.ts.map +1 -0
  605. package/dist/esm/index.js +21 -0
  606. package/dist/esm/keychains.d.ts +52 -0
  607. package/dist/esm/keychains.d.ts.map +1 -0
  608. package/dist/esm/keychains.js +92 -0
  609. package/dist/esm/names.d.ts +26 -0
  610. package/dist/esm/names.d.ts.map +1 -0
  611. package/dist/esm/names.js +171 -0
  612. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  613. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  614. package/dist/esm/offlineVault/OfflineVaultHalfSigned.js +23 -0
  615. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts +46 -0
  616. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  617. package/dist/esm/offlineVault/OfflineVaultSignable.js +18 -0
  618. package/dist/esm/offlineVault/TransactionExplanation.d.ts +15 -0
  619. package/dist/esm/offlineVault/TransactionExplanation.d.ts.map +1 -0
  620. package/dist/esm/offlineVault/TransactionExplanation.js +13 -0
  621. package/dist/esm/offlineVault/descriptor/index.d.ts +2 -0
  622. package/dist/esm/offlineVault/descriptor/index.d.ts.map +1 -0
  623. package/dist/esm/offlineVault/descriptor/index.js +2 -0
  624. package/dist/esm/offlineVault/descriptor/transaction.d.ts +38 -0
  625. package/dist/esm/offlineVault/descriptor/transaction.d.ts.map +1 -0
  626. package/dist/esm/offlineVault/descriptor/transaction.js +41 -0
  627. package/dist/esm/offlineVault/index.d.ts +6 -0
  628. package/dist/esm/offlineVault/index.d.ts.map +1 -0
  629. package/dist/esm/offlineVault/index.js +4 -0
  630. package/dist/esm/recovery/RecoveryProvider.d.ts +22 -0
  631. package/dist/{src → esm}/recovery/RecoveryProvider.d.ts.map +1 -1
  632. package/dist/esm/recovery/RecoveryProvider.js +19 -0
  633. package/dist/esm/recovery/backupKeyRecovery.d.ts +89 -0
  634. package/dist/esm/recovery/backupKeyRecovery.d.ts.map +1 -0
  635. package/dist/esm/recovery/backupKeyRecovery.js +319 -0
  636. package/dist/esm/recovery/baseApi.d.ts +24 -0
  637. package/dist/esm/recovery/baseApi.d.ts.map +1 -0
  638. package/dist/esm/recovery/baseApi.js +64 -0
  639. package/dist/esm/recovery/coingeckoApi.d.ts +6 -0
  640. package/dist/esm/recovery/coingeckoApi.d.ts.map +1 -0
  641. package/dist/esm/recovery/coingeckoApi.js +40 -0
  642. package/dist/esm/recovery/crossChainRecovery.d.ts +96 -0
  643. package/dist/esm/recovery/crossChainRecovery.d.ts.map +1 -0
  644. package/dist/esm/recovery/crossChainRecovery.js +351 -0
  645. package/dist/esm/recovery/index.d.ts +7 -0
  646. package/dist/{src → esm}/recovery/index.d.ts.map +1 -1
  647. package/dist/esm/recovery/index.js +7 -0
  648. package/dist/esm/recovery/mempoolApi.d.ts +7 -0
  649. package/dist/{src → esm}/recovery/mempoolApi.d.ts.map +1 -1
  650. package/dist/esm/recovery/mempoolApi.js +29 -0
  651. package/dist/esm/recovery/psbt.d.ts +84 -0
  652. package/dist/esm/recovery/psbt.d.ts.map +1 -0
  653. package/dist/esm/recovery/psbt.js +207 -0
  654. package/dist/esm/transaction/bip322.d.ts +27 -0
  655. package/dist/esm/transaction/bip322.d.ts.map +1 -0
  656. package/dist/esm/transaction/bip322.js +86 -0
  657. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts +1 -0
  658. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  659. package/dist/esm/transaction/common/verifyPayGoAmount.js +1 -0
  660. package/dist/esm/transaction/decode.d.ts +11 -0
  661. package/dist/esm/transaction/decode.d.ts.map +1 -0
  662. package/dist/esm/transaction/decode.js +43 -0
  663. package/dist/esm/transaction/descriptor/explainPsbt.d.ts +5 -0
  664. package/dist/esm/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  665. package/dist/esm/transaction/descriptor/explainPsbt.js +44 -0
  666. package/dist/esm/transaction/descriptor/index.d.ts +7 -0
  667. package/dist/esm/transaction/descriptor/index.d.ts.map +1 -0
  668. package/dist/esm/transaction/descriptor/index.js +6 -0
  669. package/dist/esm/transaction/descriptor/parse.d.ts +16 -0
  670. package/dist/esm/transaction/descriptor/parse.d.ts.map +1 -0
  671. package/dist/esm/transaction/descriptor/parse.js +79 -0
  672. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts +14 -0
  673. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  674. package/dist/esm/transaction/descriptor/parseToAmountType.js +55 -0
  675. package/dist/esm/transaction/descriptor/recipient.d.ts +5 -0
  676. package/dist/esm/transaction/descriptor/recipient.d.ts.map +1 -0
  677. package/dist/esm/transaction/descriptor/recipient.js +2 -0
  678. package/dist/esm/transaction/descriptor/signPsbt.d.ts +25 -0
  679. package/dist/esm/transaction/descriptor/signPsbt.d.ts.map +1 -0
  680. package/dist/esm/transaction/descriptor/signPsbt.js +38 -0
  681. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts +36 -0
  682. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  683. package/dist/esm/transaction/descriptor/verifyTransaction.js +66 -0
  684. package/dist/esm/transaction/explainTransaction.d.ts +18 -0
  685. package/dist/esm/transaction/explainTransaction.d.ts.map +1 -0
  686. package/dist/esm/transaction/explainTransaction.js +52 -0
  687. package/dist/esm/transaction/fetchInputs.d.ts +26 -0
  688. package/dist/esm/transaction/fetchInputs.d.ts.map +1 -0
  689. package/dist/esm/transaction/fetchInputs.js +72 -0
  690. package/dist/esm/transaction/fixedScript/SigningError.d.ts +24 -0
  691. package/dist/esm/transaction/fixedScript/SigningError.d.ts.map +1 -0
  692. package/dist/esm/transaction/fixedScript/SigningError.js +21 -0
  693. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +11 -0
  694. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  695. package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +64 -0
  696. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts +73 -0
  697. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  698. package/dist/esm/transaction/fixedScript/explainTransaction.js +307 -0
  699. package/dist/esm/transaction/fixedScript/index.d.ts +10 -0
  700. package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -0
  701. package/dist/esm/transaction/fixedScript/index.js +9 -0
  702. package/dist/esm/transaction/fixedScript/musig2.d.ts +4 -0
  703. package/dist/esm/transaction/fixedScript/musig2.d.ts.map +1 -0
  704. package/dist/esm/transaction/fixedScript/musig2.js +2 -0
  705. package/dist/esm/transaction/fixedScript/parseOutput.d.ts +28 -0
  706. package/dist/esm/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  707. package/dist/esm/transaction/fixedScript/parseOutput.js +213 -0
  708. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts +8 -0
  709. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  710. package/dist/esm/transaction/fixedScript/parseTransaction.js +176 -0
  711. package/dist/esm/transaction/fixedScript/replayProtection.d.ts +7 -0
  712. package/dist/esm/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  713. package/dist/esm/transaction/fixedScript/replayProtection.js +39 -0
  714. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  715. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  716. package/dist/esm/transaction/fixedScript/signLegacyTransaction.js +112 -0
  717. package/dist/esm/transaction/fixedScript/signPsbt.d.ts +30 -0
  718. package/dist/esm/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  719. package/dist/esm/transaction/fixedScript/signPsbt.js +134 -0
  720. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  721. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  722. package/dist/esm/transaction/fixedScript/signPsbtWasm.js +122 -0
  723. package/dist/esm/transaction/fixedScript/signTransaction.d.ts +17 -0
  724. package/dist/esm/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  725. package/dist/esm/transaction/fixedScript/signTransaction.js +44 -0
  726. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  727. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  728. package/dist/esm/transaction/fixedScript/verifyTransaction.js +160 -0
  729. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  730. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  731. package/dist/esm/transaction/getPayGoVerificationPubkey.js +17 -0
  732. package/dist/esm/transaction/index.d.ts +8 -0
  733. package/dist/esm/transaction/index.d.ts.map +1 -0
  734. package/dist/esm/transaction/index.js +8 -0
  735. package/dist/esm/transaction/outputDifference.d.ts +40 -0
  736. package/dist/esm/transaction/outputDifference.d.ts.map +1 -0
  737. package/dist/esm/transaction/outputDifference.js +42 -0
  738. package/dist/esm/transaction/parseTransaction.d.ts +4 -0
  739. package/dist/esm/transaction/parseTransaction.d.ts.map +1 -0
  740. package/dist/esm/transaction/parseTransaction.js +12 -0
  741. package/dist/esm/transaction/recipient.d.ts +29 -0
  742. package/dist/esm/transaction/recipient.d.ts.map +1 -0
  743. package/dist/esm/transaction/recipient.js +48 -0
  744. package/dist/esm/transaction/signTransaction.d.ts +6 -0
  745. package/dist/esm/transaction/signTransaction.d.ts.map +1 -0
  746. package/dist/esm/transaction/signTransaction.js +66 -0
  747. package/dist/esm/transaction/types.d.ts +49 -0
  748. package/dist/esm/transaction/types.d.ts.map +1 -0
  749. package/dist/esm/transaction/types.js +4 -0
  750. package/dist/esm/transaction/verifyTransaction.d.ts +4 -0
  751. package/dist/esm/transaction/verifyTransaction.d.ts.map +1 -0
  752. package/dist/esm/transaction/verifyTransaction.js +14 -0
  753. package/dist/esm/verifyKey.d.ts +29 -0
  754. package/dist/esm/verifyKey.d.ts.map +1 -0
  755. package/dist/esm/verifyKey.js +123 -0
  756. package/dist/esm/wallet.d.ts +15 -0
  757. package/dist/esm/wallet.d.ts.map +1 -0
  758. package/dist/esm/wallet.js +5 -0
  759. package/package.json +48 -18
  760. package/.eslintignore +0 -5
  761. package/CHANGELOG.md +0 -253
  762. package/dist/src/abstractUtxoCoin.d.ts +0 -392
  763. package/dist/src/abstractUtxoCoin.d.ts.map +0 -1
  764. package/dist/src/abstractUtxoCoin.js +0 -931
  765. package/dist/src/config.js +0 -14
  766. package/dist/src/index.d.ts +0 -6
  767. package/dist/src/index.d.ts.map +0 -1
  768. package/dist/src/index.js +0 -18
  769. package/dist/src/parseOutput.d.ts +0 -22
  770. package/dist/src/parseOutput.d.ts.map +0 -1
  771. package/dist/src/parseOutput.js +0 -181
  772. package/dist/src/recovery/RecoveryProvider.js +0 -24
  773. package/dist/src/recovery/backupKeyRecovery.d.ts +0 -62
  774. package/dist/src/recovery/backupKeyRecovery.d.ts.map +0 -1
  775. package/dist/src/recovery/backupKeyRecovery.js +0 -293
  776. package/dist/src/recovery/baseApi.d.ts.map +0 -1
  777. package/dist/src/recovery/baseApi.js +0 -73
  778. package/dist/src/recovery/coingeckoApi.d.ts.map +0 -1
  779. package/dist/src/recovery/coingeckoApi.js +0 -47
  780. package/dist/src/recovery/crossChainRecovery.d.ts.map +0 -1
  781. package/dist/src/recovery/crossChainRecovery.js +0 -294
  782. package/dist/src/recovery/mempoolApi.js +0 -33
  783. package/dist/src/recovery/smartbitApi.d.ts +0 -11
  784. package/dist/src/recovery/smartbitApi.d.ts.map +0 -1
  785. package/dist/src/recovery/smartbitApi.js +0 -36
  786. package/dist/src/replayProtection.d.ts +0 -4
  787. package/dist/src/replayProtection.d.ts.map +0 -1
  788. package/dist/src/replayProtection.js +0 -21
  789. package/dist/src/sign.d.ts +0 -31
  790. package/dist/src/sign.d.ts.map +0 -1
  791. package/dist/src/sign.js +0 -104
  792. package/dist/tsconfig.tsbuildinfo +0 -8179
  793. /package/dist/{src → cjs/src}/config.d.ts +0 -0
  794. /package/dist/{src → cjs/src}/recovery/mempoolApi.d.ts +0 -0
  795. /package/dist/{src → esm}/config.d.ts.map +0 -0
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.signAndVerifyPsbtWasm = signAndVerifyPsbtWasm;
7
+ exports.signPsbtWithMusig2ParticipantWasm = signPsbtWithMusig2ParticipantWasm;
8
+ const assert_1 = __importDefault(require("assert"));
9
+ const wasm_utxo_1 = require("@bitgo/wasm-utxo");
10
+ const SigningError_1 = require("./SigningError");
11
+ /**
12
+ * Key Value: Unsigned tx id => PSBT
13
+ * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
14
+ * Reason: MuSig2 signer secure nonce is cached in the BitGoPsbt object. It will be required during the signing step.
15
+ * For more info, check SignTransactionOptions.signingStep
16
+ */
17
+ const PSBT_CACHE_WASM = new Map();
18
+ function hasKeyPathSpendInput(tx, rootWalletKeys, replayProtection) {
19
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
20
+ return parsed.inputs.some((input) => input.scriptType === 'p2trMusig2KeyPath');
21
+ }
22
+ /**
23
+ * Sign all inputs of a PSBT and verify signatures after signing.
24
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them failed.
25
+ *
26
+ * If it is the last signature, finalize and extract the transaction from the psbt.
27
+ */
28
+ function signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, replayProtection, { isLastSignature }) {
29
+ const wasmSigner = toWasmBIP32(signerKeychain);
30
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
31
+ const signErrors = [];
32
+ const verifyErrors = [];
33
+ // Sign all inputs (skipping replay protection inputs)
34
+ parsed.inputs.forEach((input, inputIndex) => {
35
+ if (input.scriptType === 'p2shP2pk') {
36
+ // Skip replay protection inputs - they are platform signed only
37
+ return;
38
+ }
39
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
40
+ try {
41
+ tx.sign(inputIndex, wasmSigner);
42
+ }
43
+ catch (e) {
44
+ signErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
45
+ }
46
+ });
47
+ // Verify signatures for all signed inputs
48
+ parsed.inputs.forEach((input, inputIndex) => {
49
+ if (input.scriptType === 'p2shP2pk') {
50
+ return;
51
+ }
52
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
53
+ try {
54
+ if (!tx.verifySignature(inputIndex, wasmSigner)) {
55
+ verifyErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, new Error('invalid signature')));
56
+ }
57
+ }
58
+ catch (e) {
59
+ verifyErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
60
+ }
61
+ });
62
+ if (signErrors.length || verifyErrors.length) {
63
+ throw new SigningError_1.TransactionSigningError(signErrors, verifyErrors);
64
+ }
65
+ if (isLastSignature) {
66
+ tx.finalizeAllInputs();
67
+ return Buffer.from(tx.extractTransaction());
68
+ }
69
+ return tx;
70
+ }
71
+ function toWasmBIP32(key) {
72
+ // Convert using base58 string to ensure private key is properly transferred
73
+ return wasm_utxo_1.BIP32.fromBase58(key.toBase58());
74
+ }
75
+ async function signPsbtWithMusig2ParticipantWasm(coin, tx, signerKeychain, rootWalletKeys, params) {
76
+ const wasmSigner = signerKeychain ? toWasmBIP32(signerKeychain) : undefined;
77
+ if (hasKeyPathSpendInput(tx, rootWalletKeys, params.replayProtection)) {
78
+ // We can only be the first signature on a transaction with taproot key path spend inputs because
79
+ // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
80
+ // deserialized from a hex.
81
+ if (params.isLastSignature) {
82
+ throw new Error('Cannot be last signature on a transaction with key path spend inputs');
83
+ }
84
+ switch (params.signingStep) {
85
+ case 'signerNonce':
86
+ (0, assert_1.default)(wasmSigner);
87
+ tx.generateMusig2Nonces(wasmSigner);
88
+ PSBT_CACHE_WASM.set(tx.unsignedTxid(), tx);
89
+ return tx;
90
+ case 'cosignerNonce':
91
+ (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
92
+ return await coin.getMusig2Nonces(tx, params.walletId);
93
+ case 'signerSignature': {
94
+ const txId = tx.unsignedTxid();
95
+ const cachedPsbt = PSBT_CACHE_WASM.get(txId);
96
+ (0, assert_1.default)(cachedPsbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE_WASM.size}).
97
+ This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
98
+ PSBT_CACHE_WASM.delete(txId);
99
+ cachedPsbt.combineMusig2Nonces(tx);
100
+ tx = cachedPsbt;
101
+ break;
102
+ }
103
+ default:
104
+ // this instance is not an external signer
105
+ (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
106
+ (0, assert_1.default)(wasmSigner);
107
+ tx.generateMusig2Nonces(wasmSigner);
108
+ const response = await coin.getMusig2Nonces(tx, params.walletId);
109
+ tx.combineMusig2Nonces(response);
110
+ break;
111
+ }
112
+ }
113
+ else {
114
+ switch (params.signingStep) {
115
+ case 'signerNonce':
116
+ case 'cosignerNonce':
117
+ /**
118
+ * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
119
+ * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
120
+ */
121
+ return tx;
122
+ }
123
+ }
124
+ (0, assert_1.default)(signerKeychain);
125
+ return signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, params.replayProtection, {
126
+ isLastSignature: params.isLastSignature,
127
+ });
128
+ }
129
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblBzYnRXYXNtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25Qc2J0V2FzbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQW1DQSxzREF3REM7QUFPRCw4RUFxRUM7QUF2S0Qsb0RBQTRCO0FBRzVCLGdEQUFvRTtBQUVwRSxpREFBNEU7QUFPNUU7Ozs7O0dBS0c7QUFDSCxNQUFNLGVBQWUsR0FBRyxJQUFJLEdBQUcsRUFBdUMsQ0FBQztBQUV2RSxTQUFTLG9CQUFvQixDQUMzQixFQUErQixFQUMvQixjQUFnRCxFQUNoRCxnQkFBc0M7SUFFdEMsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDLDhCQUE4QixDQUFDLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ25GLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxVQUFVLEtBQUssbUJBQW1CLENBQUMsQ0FBQztBQUNqRixDQUFDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFnQixxQkFBcUIsQ0FDbkMsRUFBK0IsRUFDL0IsY0FBOEIsRUFDOUIsY0FBZ0QsRUFDaEQsZ0JBQXNDLEVBQ3RDLEVBQUUsZUFBZSxFQUFnQztJQUVqRCxNQUFNLFVBQVUsR0FBRyxXQUFXLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDL0MsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDLDhCQUE4QixDQUFDLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBRW5GLE1BQU0sVUFBVSxHQUFnQyxFQUFFLENBQUM7SUFDbkQsTUFBTSxZQUFZLEdBQWdDLEVBQUUsQ0FBQztJQUVyRCxzREFBc0Q7SUFDdEQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLEVBQUU7UUFDMUMsSUFBSSxLQUFLLENBQUMsVUFB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QUNwQyxNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDakUsRUFBRSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUNqQyxNQUFNO1FBQ1YsQ0FBQztJQUNILENBQUM7U0FBTSxDQUFDO1FBQ04sUUFBUSxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDM0IsS0FBSyxhQUFhLENBQUM7WUFDbkIsS0FBSyxlQUFlO2dCQUNsQjs7O21CQUdHO2dCQUNILE9BQU8sRUFBRSxDQUFDO1FBQ2QsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFBLGdCQUFNLEVBQUMsY0FBYyxDQUFDLENBQUM7SUFDdkIsT0FBTyxxQkFBcUIsQ0FBQyxFQUFFLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxNQUFNLENBQUMsZ0JBQWdCLEVBQUU7UUFDeEYsZUFBZSxFQUFFLE1BQU0sQ0FBQyxlQUFlO0tBQ3hDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCB7IEJJUDMySW50ZXJmYWNlIH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgQklQMzIsIEVDUGFpciwgZml4ZWRTY3JpcHRXYWxsZXQgfSBmcm9tICdAYml0Z28vd2FzbS11dHhvJztcblxuaW1wb3J0IHsgSW5wdXRTaWduaW5nRXJyb3IsIFRyYW5zYWN0aW9uU2lnbmluZ0Vycm9yIH0gZnJvbSAnLi9TaWduaW5nRXJyb3InO1xuaW1wb3J0IHsgTXVzaWcyUGFydGljaXBhbnQgfSBmcm9tICcuL211c2lnMic7XG5cbmV4cG9ydCB0eXBlIFJlcGxheVByb3RlY3Rpb25LZXlzID0ge1xuICBwdWJsaWNLZXlzOiAoVWludDhBcnJheSB8IEVDUGFpcilbXTtcbn07XG5cbi8qKlxuICogS2V5IFZhbHVlOiBVbnNpZ25lZCB0eCBpZCA9PiBQU0JUXG4gKiBJdCBpcyB1c2VkIHRvIGNhY2hlIFBTQlRzIHdpdGggdGFwcm9vdCBrZXkgcGF0aCAoTXVTaWcyKSBpbnB1dHMgZHVyaW5nIGV4dGVybmFsIGV4cHJlc3Mgc2lnbmVyIGlzIGFjdGl2YXRlZC5cbiAqIFJlYXNvbjogTXVTaWcyIHNpZ25lciBzZWN1cmUgbm9uY2UgaXMgY2FjaGVkIGluIHRoZSBCaXRHb1BzYnQgb2JqZWN0LiBJdCB3aWxsIGJlIHJlcXVpcmVkIGR1cmluZyB0aGUgc2lnbmluZyBzdGVwLlxuICogRm9yIG1vcmUgaW5mbywgY2hlY2sgU2lnblRyYW5zYWN0aW9uT3B0aW9ucy5zaWduaW5nU3RlcFxuICovXG5jb25zdCBQU0JUX0NBQ0hFX1dBU00gPSBuZXcgTWFwPHN0cmluZywgZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PigpO1xuXG5mdW5jdGlvbiBoYXNLZXlQYXRoU3BlbmRJbnB1dChcbiAgdHg6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCxcbiAgcm9vdFdhbGxldEtleXM6IGZpeGVkU2NyaXB0V2FsbGV0LlJvb3RXYWxsZXRLZXlzLFxuICByZXBsYXlQcm90ZWN0aW9uOiBSZXBsYXlQcm90ZWN0aW9uS2V5c1xuKTogYm9vbGVhbiB7XG4gIGNvbnN0IHBhcnNlZCA9IHR4LnBhcnNlVHJhbnNhY3Rpb25XaXRoV2FsbGV0S2V5cyhyb290V2FsbGV0S2V5cywgcmVwbGF5UHJvdGVjdGlvbik7XG4gIHJldHVybiBwYXJzZWQuaW5wdXRzLnNvbWUoKGlucHV0KSA9PiBpbnB1dC5zY3JpcHRUeXBlID09PSAncDJ0ck11c2lnMktleVBhdGgnKTtcbn1cblxuLyoqXG4gKiBTaWduIGFsbCBpbnB1dHMgb2YgYSBQU0JUIGFuZCB2ZXJpZnkgc2lnbmF0dXJlcyBhZnRlciBzaWduaW5nLlxuICogQ29sbGVjdHMgYW5kIGxvZ3Mgc2lnbmluZyBlcnJvcnMgYW5kIHZlcmlmaWNhdGlvbiBlcnJvcnMsIHRocm93cyBlcnJvciBpbiB0aGUgZW5kIGlmIGFueSBvZiB0aGVtIGZhaWxlZC5cbiAqXG4gKiBJZiBpdCBpcyB0aGUgbGFzdCBzaWduYXR1cmUsIGZpbmFsaXplIGFuZCBleHRyYWN0IHRoZSB0cmFuc2FjdGlvbiBmcm9tIHRoZSBwc2J0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gc2lnbkFuZFZlcmlmeVBzYnRXYXNtKFxuICB0eDogZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0LFxuICBzaWduZXJLZXljaGFpbjogQklQMzJJbnRlcmZhY2UsXG4gIHJvb3RXYWxsZXRLZXlzOiBmaXhlZFNjcmlwdFdhbGxldC5Sb290V2FsbGV0S2V5cyxcbiAgcmVwbGF5UHJvdGVjdGlvbjogUmVwbGF5UHJvdGVjdGlvbktleXMsXG4gIHsgaXNMYXN0U2lnbmF0dXJlIH06IHsgaXNMYXN0U2lnbmF0dXJlOiBib29sZWFuIH1cbik6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCB8IEJ1ZmZlciB7XG4gIGNvbnN0IHdhc21TaWduZXIgPSB0b1dhc21CSVAzMihzaWduZXJLZXljaGFpbik7XG4gIGNvbnN0IHBhcnNlZCA9IHR4LnBhcnNlVHJhbnNhY3Rpb25XaXRoV2FsbGV0S2V5cyhyb290V2FsbGV0S2V5cywgcmVwbGF5UHJvdGVjdGlvbik7XG5cbiAgY29uc3Qgc2lnbkVycm9yczogSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PltdID0gW107XG4gIGNvbnN0IHZlcmlmeUVycm9yczogSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PltdID0gW107XG5cbiAgLy8gU2lnbiBhbGwgaW5wdXRzIChza2lwcGluZyByZXBsYXkgcHJvdGVjdGlvbiBpbnB1dHMpXG4gIHBhcnNlZC5pbnB1dHMuZm9yRWFjaCgoaW5wdXQsIGlucHV0SW5kZXgpID0+IHtcbiAgICBpZiAoaW5wdXQuc2NyaXB0VHlwZSA9PT0gJ3Ayc2hQMnBrJykge1xuICAgICAgLy8gU2tpcCByZXBsYXkgcHJvdGVjdGlvbiBpbnB1dHMgLSB0aGV5IGFyZSBwbGF0Zm9ybSBzaWduZWQgb25seVxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IG91dHB1dElkID0gYCR7aW5wdXQucHJldmlvdXNPdXRwdXQudHhpZH06JHtpbnB1dC5wcmV2aW91c091dHB1dC52b3V0fWA7XG4gICAgdHJ5IHtcbiAgICAgIHR4LnNpZ24oaW5wdXRJbmRleCwgd2FzbVNpZ25lcik7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgc2lnbkVycm9ycy5wdXNoKG5ldyBJbnB1dFNpZ25pbmdFcnJvcjxiaWdpbnQ+KGlucHV0SW5kZXgsIGlucHV0LnNjcmlwdFR5cGUsIHsgaWQ6IG91dHB1dElkIH0sIGUpKTtcbiAgICB9XG4gIH0pO1xuXG4gIC8vIFZlcmlmeSBzaWduYXR1cmVzIGZvciBhbGwgc2lnbmVkIGlucHV0c1xuICBwYXJzZWQuaW5wdXRzLmZvckVhY2goKGlucHV0LCBpbnB1dEluZGV4KSA9PiB7XG4gICAgaWYgKGlucHV0LnNjcmlwdFR5cGUgPT09ICdwMnNoUDJwaycpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBvdXRwdXRJZCA9IGAke2lucHV0LnByZXZpb3VzT3V0cHV0LnR4aWR9OiR7aW5wdXQucHJldmlvdXNPdXRwdXQudm91dH1gO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXR4LnZlcmlmeVNpZ25hdHVyZShpbnB1dEluZGV4LCB3YXNtU2lnbmVyKSkge1xuICAgICAgICB2ZXJpZnlFcnJvcnMucHVzaChcbiAgICAgICAgICBuZXcgSW5wdXRTaWduaW5nRXJyb3IoaW5wdXRJbmRleCwgaW5wdXQuc2NyaXB0VHlwZSwgeyBpZDogb3V0cHV0SWQgfSwgbmV3IEVycm9yKCdpbnZhbGlkIHNpZ25hdHVyZScpKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHZlcmlmeUVycm9ycy5wdXNoKG5ldyBJbnB1dFNpZ25pbmdFcnJvcjxiaWdpbnQ+KGlucHV0SW5kZXgsIGlucHV0LnNjcmlwdFR5cGUsIHsgaWQ6IG91dHB1dElkIH0sIGUpKTtcbiAgICB9XG4gIH0pO1xuXG4gIGlmIChzaWduRXJyb3JzLmxlbmd0aCB8fCB2ZXJpZnlFcnJvcnMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IFRyYW5zYWN0aW9uU2lnbmluZ0Vycm9yKHNpZ25FcnJvcnMsIHZlcmlmeUVycm9ycyk7XG4gIH1cblxuICBpZiAoaXNMYXN0U2lnbmF0dXJlKSB7XG4gICAgdHguZmluYWxpemVBbGxJbnB1dHMoKTtcbiAgICByZXR1cm4gQnVmZmVyLmZyb20odHguZXh0cmFjdFRyYW5zYWN0aW9uKCkpO1xuICB9XG5cbiAgcmV0dXJuIHR4O1xufVxuXG5mdW5jdGlvbiB0b1dhc21CSVAzMihrZXk6IEJJUDMySW50ZXJmYWNlKTogQklQMzIge1xuICAvLyBDb252ZXJ0IHVzaW5nIGJhc2U1OCBzdHJpbmcgdG8gZW5zdXJlIHByaXZhdGUga2V5IGlzIHByb3Blcmx5IHRyYW5zZmVycmVkXG4gIHJldHVybiBCSVAzMi5mcm9tQmFzZTU4KGtleS50b0Jhc2U1OCgpKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNpZ25Qc2J0V2l0aE11c2lnMlBhcnRpY2lwYW50V2FzbShcbiAgY29pbjogTXVzaWcyUGFydGljaXBhbnQ8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PixcbiAgdHg6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCxcbiAgc2lnbmVyS2V5Y2hhaW46IEJJUDMySW50ZXJmYWNlIHwgdW5kZWZpbmVkLFxuICByb290V2FsbGV0S2V5czogZml4ZWRTY3JpcHRXYWxsZXQuUm9vdFdhbGxldEtleXMsXG4gIHBhcmFtczoge1xuICAgIHJlcGxheVByb3RlY3Rpb246IFJlcGxheVByb3RlY3Rpb25LZXlzO1xuICAgIGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjtcbiAgICBzaWduaW5nU3RlcDogJ3NpZ25lck5vbmNlJyB8ICdjb3NpZ25lck5vbmNlJyB8ICdzaWduZXJTaWduYXR1cmUnIHwgdW5kZWZpbmVkO1xuICAgIHdhbGxldElkOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH1cbik6IFByb21pc2U8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0IHwgQnVmZmVyPiB7XG4gIGNvbnN0IHdhc21TaWduZXIgPSBzaWduZXJLZXljaGFpbiA/IHRvV2FzbUJJUDMyKHNpZ25lcktleWNoYWluKSA6IHVuZGVmaW5lZDtcblxuICBpZiAoaGFzS2V5UGF0aFNwZW5kSW5wdXQodHgsIHJvb3RXYWxsZXRLZXlzLCBwYXJhbXMucmVwbGF5UHJvdGVjdGlvbikpIHtcbiAgICAvLyBXZSBjYW4gb25seSBiZSB0aGUgZmlyc3Qgc2lnbmF0dXJlIG9uIGEgdHJhbnNhY3Rpb24gd2l0aCB0YXByb290IGtleSBwYXRoIHNwZW5kIGlucHV0cyBiZWNhdXNlXG4gICAgLy8gd2UgcmVxdWlyZSB0aGUgc2VjcmV0IG5vbmNlIGluIHRoZSBjYWNoZSBvZiB0aGUgZmlyc3Qgc2lnbmVyLCB3aGljaCBpcyBpbXBvc3NpYmxlIHRvIHJldHJpZXZlIGlmXG4gICAgLy8gZGVzZXJpYWxpemVkIGZyb20gYSBoZXguXG4gICAgaWYgKHBhcmFtcy5pc0xhc3RTaWduYXR1cmUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IGJlIGxhc3Qgc2lnbmF0dXJlIG9uIGEgdHJhbnNhY3Rpb24gd2l0aCBrZXkgcGF0aCBzcGVuZCBpbnB1dHMnKTtcbiAgICB9XG5cbiAgICBzd2l0Y2ggKHBhcmFtcy5zaWduaW5nU3RlcCkge1xuICAgICAgY2FzZSAnc2lnbmVyTm9uY2UnOlxuICAgICAgICBhc3NlcnQod2FzbVNpZ25lcik7XG4gICAgICAgIHR4LmdlbmVyYXRlTXVzaWcyTm9uY2VzKHdhc21TaWduZXIpO1xuICAgICAgICBQU0JUX0NBQ0hFX1dBU00uc2V0KHR4LnVuc2lnbmVkVHhpZCgpLCB0eCk7XG4gICAgICAgIHJldHVybiB0eDtcbiAgICAgIGNhc2UgJ2Nvc2lnbmVyTm9uY2UnOlxuICAgICAgICBhc3NlcnQocGFyYW1zLndhbGxldElkLCAnd2FsbGV0SWQgaXMgcmVxdWlyZWQgZm9yIE11U2lnMiBiaXRnbyBub25jZScpO1xuICAgICAgICByZXR1cm4gYXdhaXQgY29pbi5nZXRNdXNpZzJOb25jZXModHgsIHBhcmFtcy53YWxsZXRJZCk7XG4gICAgICBjYXNlICdzaWduZXJTaWduYXR1cmUnOiB7XG4gICAgICAgIGNvbnN0IHR4SWQgPSB0eC51bnNpZ25lZFR4aWQoKTtcbiAgICAgICAgY29uc3QgY2FjaGVkUHNidCA9IFBTQlRfQ0FDSEVfV0FTTS5nZXQodHhJZCk7XG4gICAgICAgIGFzc2VydChcbiAgICAgICAgICBjYWNoZWRQc2J0LFxuICAgICAgICAgIGBQc2J0IGlzIG1pc3NpbmcgZnJvbSB0eENhY2hlIChjYWNoZSBzaXplICR7UFNCVF9DQUNIRV9XQVNNLnNpemV9KS5cbiAgICAgICAgICAgIFRoaXMgbWF5IGJlIGR1ZSB0byB0aGUgcmVxdWVzdCBiZWluZyByb3V0ZWQgdG8gYSBkaWZmZXJlbnQgQml0R28tRXhwcmVzcyBpbnN0YW5jZSB0aGF0IGZvciBzaWduaW5nIHN0ZXAgJ3NpZ25lck5vbmNlJy5gXG4gICAgICAgICk7XG4gICAgICAgIFBTQlRfQ0FDSEVfV0FTTS5kZWxldGUodHhJZCk7XG4gICAgICAgIGNhY2hlZFBzYnQuY29tYmluZU11c2lnMk5vbmNlcyh0eCk7XG4gICAgICAgIHR4ID0gY2FjaGVkUHNidDtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyB0aGlzIGluc3RhbmNlIGlzIG5vdCBhbiBleHRlcm5hbCBzaWduZXJcbiAgICAgICAgYXNzZXJ0KHBhcmFtcy53YWxsZXRJZCwgJ3dhbGxldElkIGlzIHJlcXVpcmVkIGZvciBNdVNpZzIgYml0Z28gbm9uY2UnKTtcbiAgICAgICAgYXNzZXJ0KHdhc21TaWduZXIpO1xuICAgICAgICB0eC5nZW5lcmF0ZU11c2lnMk5vbmNlcyh3YXNtU2lnbmVyKTtcbiAgICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjb2luLmdldE11c2lnMk5vbmNlcyh0eCwgcGFyYW1zLndhbGxldElkKTtcbiAgICAgICAgdHguY29tYmluZU11c2lnMk5vbmNlcyhyZXNwb25zZSk7XG4gICAgICAgIGJyZWFrO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBzd2l0Y2ggKHBhcmFtcy5zaWduaW5nU3RlcCkge1xuICAgICAgY2FzZSAnc2lnbmVyTm9uY2UnOlxuICAgICAgY2FzZSAnY29zaWduZXJOb25jZSc6XG4gICAgICAgIC8qKlxuICAgICAgICAgKiBJbiBjZXJ0YWluIGNhc2VzLCB0aGUgY2FsbGVyIG9mIHRoaXMgbWV0aG9kIG1heSBub3Qga25vdyB3aGV0aGVyIHRoZSB0eEhleCBjb250YWlucyBhIHBzYnQgd2l0aCB0YXByb290IGtleSBwYXRoIHNwZW5kIGlucHV0KHMpLlxuICAgICAgICAgKiBJbnN0ZWFkIG9mIHRocm93aW5nIGVycm9yLCBuby1vcCBhbmQgcmV0dXJuIHRoZSB0eEhleC4gU28gdGhhdCB0aGUgY2FsbGVyIGNhbiBjYWxsIHRoaXMgbWV0aG9kIGluIHRoZSBzYW1lIHNlcXVlbmNlLlxuICAgICAgICAgKi9cbiAgICAgICAgcmV0dXJuIHR4O1xuICAgIH1cbiAgfVxuXG4gIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gIHJldHVybiBzaWduQW5kVmVyaWZ5UHNidFdhc20odHgsIHNpZ25lcktleWNoYWluLCByb290V2FsbGV0S2V5cywgcGFyYW1zLnJlcGxheVByb3RlY3Rpb24sIHtcbiAgICBpc0xhc3RTaWduYXR1cmU6IHBhcmFtcy5pc0xhc3RTaWduYXR1cmUsXG4gIH0pO1xufVxuIl19
@@ -0,0 +1,17 @@
1
+ import { BIP32Interface } from '@bitgo-beta/secp256k1';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ import { fixedScriptWallet } from '@bitgo/wasm-utxo';
4
+ import { Musig2Participant } from './musig2';
5
+ export declare function signTransaction<T extends utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt>(coin: Musig2Participant<utxolib.bitgo.UtxoPsbt> | Musig2Participant<fixedScriptWallet.BitGoPsbt>, tx: T, signerKeychain: BIP32Interface | undefined, network: utxolib.Network, params: {
6
+ walletId: string | undefined;
7
+ txInfo: {
8
+ unspents?: utxolib.bitgo.Unspent<bigint | number>[];
9
+ } | undefined;
10
+ isLastSignature: boolean;
11
+ signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
12
+ /** deprecated */
13
+ allowNonSegwitSigningWithoutPrevTx: boolean;
14
+ pubs: string[] | undefined;
15
+ cosignerPub: string | undefined;
16
+ }): Promise<utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt | Buffer>;
17
+ //# sourceMappingURL=signTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/signTransaction.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAM7C,wBAAsB,eAAe,CACnC,CAAC,SAAS,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,EAE/G,IAAI,EAAE,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAChG,EAAE,EAAE,CAAC,EACL,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE;IACN,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,MAAM,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;KAAE,GAAG,SAAS,CAAC;IAC5E,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,iBAAiB;IACjB,kCAAkC,EAAE,OAAO,CAAC;IAC5C,IAAI,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC3B,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,GACA,OAAO,CACR,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAC/G,CAwCA"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.signTransaction = signTransaction;
7
+ const assert_1 = __importDefault(require("assert"));
8
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
9
+ const lodash_1 = __importDefault(require("lodash"));
10
+ const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
11
+ const wasm_utxo_1 = require("@bitgo/wasm-utxo");
12
+ const signLegacyTransaction_1 = require("./signLegacyTransaction");
13
+ const signPsbt_1 = require("./signPsbt");
14
+ const signPsbtWasm_1 = require("./signPsbtWasm");
15
+ const replayProtection_1 = require("./replayProtection");
16
+ async function signTransaction(coin, tx, signerKeychain, network, params) {
17
+ let isLastSignature = false;
18
+ if (lodash_1.default.isBoolean(params.isLastSignature)) {
19
+ // if build is called instead of buildIncomplete, no signature placeholders are left in the sig script
20
+ isLastSignature = params.isLastSignature;
21
+ }
22
+ if (tx instanceof utxo_lib_1.bitgo.UtxoPsbt) {
23
+ return (0, signPsbt_1.signPsbtWithMusig2Participant)(coin, tx, signerKeychain, {
24
+ isLastSignature,
25
+ signingStep: params.signingStep,
26
+ walletId: params.walletId,
27
+ });
28
+ }
29
+ else if (tx instanceof wasm_utxo_1.fixedScriptWallet.BitGoPsbt) {
30
+ (0, assert_1.default)(params.pubs, 'pubs are required for fixed script signing');
31
+ (0, assert_1.default)((0, sdk_core_1.isTriple)(params.pubs), 'pubs must be a triple');
32
+ const rootWalletKeys = wasm_utxo_1.fixedScriptWallet.RootWalletKeys.fromXpubs(params.pubs);
33
+ return (0, signPsbtWasm_1.signPsbtWithMusig2ParticipantWasm)(coin, tx, signerKeychain, rootWalletKeys, {
34
+ replayProtection: {
35
+ publicKeys: (0, replayProtection_1.getReplayProtectionPubkeys)(network),
36
+ },
37
+ isLastSignature,
38
+ signingStep: params.signingStep,
39
+ walletId: params.walletId,
40
+ });
41
+ }
42
+ return (0, signLegacyTransaction_1.signLegacyTransaction)(tx, signerKeychain, {
43
+ isLastSignature,
44
+ signingStep: params.signingStep,
45
+ txInfo: params.txInfo,
46
+ pubs: params.pubs,
47
+ cosignerPub: params.cosignerPub,
48
+ });
49
+ }
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQWVBLDBDQTJEQztBQTFFRCxvREFBNEI7QUFFNUIsbURBQWdEO0FBQ2hELG9EQUF1QjtBQUV2QixtREFBNkM7QUFFN0MsZ0RBQXFEO0FBR3JELG1FQUFnRTtBQUNoRSx5Q0FBMkQ7QUFDM0QsaURBQW1FO0FBQ25FLHlEQUFnRTtBQUV6RCxLQUFLLFVBQVUsZUFBZSxDQUduQyxJQUFnRyxFQUNoRyxFQUFLLEVBQ0wsY0FBMEMsRUFDMUMsT0FBd0IsRUFDeEIsTUFTQztJQUlELElBQUksZUFBZSxHQUFHLEtBQUssQ0FBQztJQUM1QixJQUFJLGdCQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDO1FBQ3hDLHNHQUFzRztRQUN0RyxlQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQztJQUMzQyxDQUFDO0lBRUQsSUFBSSxFQUFFLFlBQVksZ0JBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQyxPQUFPLElBQUEsd0NBQTZCLEVBQUMsSUFBaUQsRUFBRSxFQUFFLEVBQUUsY0FBYyxFQUFFO1lBQzFHLGVBQWU7WUFDZixXQUFXLEVBQUUsTUFBTSxDQUFDLFdBQVc7WUFDL0IsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUM7U0FBTSxJQUFJLEVBQUUsWUFBWSw2QkFBaUIsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNyRCxJQUFBLGdCQUFNLEVBQUMsTUFBTSxDQUFDLElBQUksRUFBRSw0Q0FBNEMsQ0FBQyxDQUFDO1FBQ2xFLElBQUEsZ0JBQU0sRUFBQyxJQUFBLG1CQUFRLEVBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLHVCQUF1QixDQUFDLENBQUM7UUFDdkQsTUFBTSxjQUFjLEdBQUcsNkJBQWlCLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0UsT0FBTyxJQUFBLGdEQUFpQyxFQUN0QyxJQUFzRCxFQUN0RCxFQUFFLEVBQ0YsY0FBYyxFQUNkLGNBQWMsRUFDZDtZQUNFLGdCQUFnQixFQUFFO2dCQUNoQixVQUFVLEVBQUUsSUFBQSw2Q0FBMEIsRUFBQyxPQUFPLENBQUM7YUFDaEQ7WUFDRCxlQUFlO1lBQ2YsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXO1lBQy9CLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtTQUMxQixDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsT0FBTyxJQUFBLDZDQUFxQixFQUFDLEVBQUUsRUFBRSxjQUFjLEVBQUU7UUFDL0MsZUFBZTtRQUNmLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVztRQUMvQixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU07UUFDckIsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJO1FBQ2pCLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVztLQUNoQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgeyBpc1RyaXBsZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBCSVAzMkludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgeyBiaXRnbyB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgZml4ZWRTY3JpcHRXYWxsZXQgfSBmcm9tICdAYml0Z28vd2FzbS11dHhvJztcblxuaW1wb3J0IHsgTXVzaWcyUGFydGljaXBhbnQgfSBmcm9tICcuL211c2lnMic7XG5pbXBvcnQgeyBzaWduTGVnYWN5VHJhbnNhY3Rpb24gfSBmcm9tICcuL3NpZ25MZWdhY3lUcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBzaWduUHNidFdpdGhNdXNpZzJQYXJ0aWNpcGFudCB9IGZyb20gJy4vc2lnblBzYnQnO1xuaW1wb3J0IHsgc2lnblBzYnRXaXRoTXVzaWcyUGFydGljaXBhbnRXYXNtIH0gZnJvbSAnLi9zaWduUHNidFdhc20nO1xuaW1wb3J0IHsgZ2V0UmVwbGF5UHJvdGVjdGlvblB1YmtleXMgfSBmcm9tICcuL3JlcGxheVByb3RlY3Rpb24nO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc2lnblRyYW5zYWN0aW9uPFxuICBUIGV4dGVuZHMgdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludCB8IG51bWJlcj4gfCBmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnRcbj4oXG4gIGNvaW46IE11c2lnMlBhcnRpY2lwYW50PHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+IHwgTXVzaWcyUGFydGljaXBhbnQ8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PixcbiAgdHg6IFQsXG4gIHNpZ25lcktleWNoYWluOiBCSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCxcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrLFxuICBwYXJhbXM6IHtcbiAgICB3YWxsZXRJZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIHR4SW5mbzogeyB1bnNwZW50cz86IHV0eG9saWIuYml0Z28uVW5zcGVudDxiaWdpbnQgfCBudW1iZXI+W10gfSB8IHVuZGVmaW5lZDtcbiAgICBpc0xhc3RTaWduYXR1cmU6IGJvb2xlYW47XG4gICAgc2lnbmluZ1N0ZXA6ICdzaWduZXJOb25jZScgfCAnY29zaWduZXJOb25jZScgfCAnc2lnbmVyU2lnbmF0dXJlJyB8IHVuZGVmaW5lZDtcbiAgICAvKiogZGVwcmVjYXRlZCAqL1xuICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IGJvb2xlYW47XG4gICAgcHViczogc3RyaW5nW10gfCB1bmRlZmluZWQ7XG4gICAgY29zaWduZXJQdWI6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgfVxuKTogUHJvbWlzZTxcbiAgdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludCB8IG51bWJlcj4gfCBmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnQgfCBCdWZmZXJcbj4ge1xuICBsZXQgaXNMYXN0U2lnbmF0dXJlID0gZmFsc2U7XG4gIGlmIChfLmlzQm9vbGVhbihwYXJhbXMuaXNMYXN0U2lnbmF0dXJlKSkge1xuICAgIC8vIGlmIGJ1aWxkIGlzIGNhbGxlZCBpbnN0ZWFkIG9mIGJ1aWxkSW5jb21wbGV0ZSwgbm8gc2lnbmF0dXJlIHBsYWNlaG9sZGVycyBhcmUgbGVmdCBpbiB0aGUgc2lnIHNjcmlwdFxuICAgIGlzTGFzdFNpZ25hdHVyZSA9IHBhcmFtcy5pc0xhc3RTaWduYXR1cmU7XG4gIH1cblxuICBpZiAodHggaW5zdGFuY2VvZiBiaXRnby5VdHhvUHNidCkge1xuICAgIHJldHVybiBzaWduUHNidFdpdGhNdXNpZzJQYXJ0aWNpcGFudChjb2luIGFzIE11c2lnMlBhcnRpY2lwYW50PHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+LCB0eCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgIGlzTGFzdFNpZ25hdHVyZSxcbiAgICAgIHNpZ25pbmdTdGVwOiBwYXJhbXMuc2lnbmluZ1N0ZXAsXG4gICAgICB3YWxsZXRJZDogcGFyYW1zLndhbGxldElkLFxuICAgIH0pO1xuICB9IGVsc2UgaWYgKHR4IGluc3RhbmNlb2YgZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0KSB7XG4gICAgYXNzZXJ0KHBhcmFtcy5wdWJzLCAncHVicyBhcmUgcmVxdWlyZWQgZm9yIGZpeGVkIHNjcmlwdCBzaWduaW5nJyk7XG4gICAgYXNzZXJ0KGlzVHJpcGxlKHBhcmFtcy5wdWJzKSwgJ3B1YnMgbXVzdCBiZSBhIHRyaXBsZScpO1xuICAgIGNvbnN0IHJvb3RXYWxsZXRLZXlzID0gZml4ZWRTY3JpcHRXYWxsZXQuUm9vdFdhbGxldEtleXMuZnJvbVhwdWJzKHBhcmFtcy5wdWJzKTtcbiAgICByZXR1cm4gc2lnblBzYnRXaXRoTXVzaWcyUGFydGljaXBhbnRXYXNtKFxuICAgICAgY29pbiBhcyBNdXNpZzJQYXJ0aWNpcGFudDxmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnQ+LFxuICAgICAgdHgsXG4gICAgICBzaWduZXJLZXljaGFpbixcbiAgICAgIHJvb3RXYWxsZXRLZXlzLFxuICAgICAge1xuICAgICAgICByZXBsYXlQcm90ZWN0aW9uOiB7XG4gICAgICAgICAgcHVibGljS2V5czogZ2V0UmVwbGF5UHJvdGVjdGlvblB1YmtleXMobmV0d29yayksXG4gICAgICAgIH0sXG4gICAgICAgIGlzTGFzdFNpZ25hdHVyZSxcbiAgICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgICAgd2FsbGV0SWQ6IHBhcmFtcy53YWxsZXRJZCxcbiAgICAgIH1cbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIHNpZ25MZWdhY3lUcmFuc2FjdGlvbih0eCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICBpc0xhc3RTaWduYXR1cmUsXG4gICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICB0eEluZm86IHBhcmFtcy50eEluZm8sXG4gICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgY29zaWduZXJQdWI6IHBhcmFtcy5jb3NpZ25lclB1YixcbiAgfSk7XG59XG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { BitGoBase } from '@bitgo-beta/sdk-core';
2
+ import { AbstractUtxoCoin, VerifyTransactionOptions } from '../../abstractUtxoCoin';
3
+ /**
4
+ * Verify that a transaction prebuild complies with the original intention for fixed-script wallets
5
+ *
6
+ * This implementation handles transaction verification for traditional UTXO coins using fixed scripts
7
+ * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.
8
+ *
9
+ * @param coin - The UTXO coin instance
10
+ * @param bitgo - BitGo API instance for network calls
11
+ * @param params - Verification parameters
12
+ * @param params.txParams - Transaction parameters passed to send
13
+ * @param params.txPrebuild - Prebuild object returned by server
14
+ * @param params.wallet - Wallet object to obtain keys to verify against
15
+ * @param params.verification - Verification options (disableNetworking, keychains, addresses)
16
+ * @param params.reqId - Optional request ID for logging
17
+ * @returns {boolean} True if verification passes
18
+ * @throws {TxIntentMismatchError} if transaction validation fails
19
+ */
20
+ export declare function verifyTransaction<TNumber extends bigint | number>(coin: AbstractUtxoCoin, bitgo: BitGoBase, params: VerifyTransactionOptions<TNumber>): Promise<boolean>;
21
+ //# sourceMappingURL=verifyTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAoC,MAAM,sBAAsB,CAAC;AAGnF,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAsBpF;;;;;;;;;;;;;;;;GAgBG;AACH,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,CAmJlB"}
@@ -0,0 +1,199 @@
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.verifyTransaction = verifyTransaction;
40
+ const debug_1 = __importDefault(require("debug"));
41
+ const lodash_1 = __importDefault(require("lodash"));
42
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
43
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
44
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
45
+ const verifyKey_1 = require("../../verifyKey");
46
+ const fetchInputs_1 = require("../fetchInputs");
47
+ const debug = (0, debug_1.default)('bitgo:abstract-utxo:verifyTransaction');
48
+ /**
49
+ * Get the maximum percentage limit for pay-as-you-go outputs
50
+ *
51
+ * @protected
52
+ */
53
+ function getPayGoLimit(allowPaygoOutput) {
54
+ // allowing paygo outputs needs to be the default behavior, so only disallow paygo outputs if the
55
+ // relevant verification option is both set and false
56
+ if (!lodash_1.default.isNil(allowPaygoOutput) && !allowPaygoOutput) {
57
+ return 0;
58
+ }
59
+ // 150 basis points is the absolute permitted maximum if paygo outputs are allowed
60
+ return 0.015;
61
+ }
62
+ /**
63
+ * Verify that a transaction prebuild complies with the original intention for fixed-script wallets
64
+ *
65
+ * This implementation handles transaction verification for traditional UTXO coins using fixed scripts
66
+ * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.
67
+ *
68
+ * @param coin - The UTXO coin instance
69
+ * @param bitgo - BitGo API instance for network calls
70
+ * @param params - Verification parameters
71
+ * @param params.txParams - Transaction parameters passed to send
72
+ * @param params.txPrebuild - Prebuild object returned by server
73
+ * @param params.wallet - Wallet object to obtain keys to verify against
74
+ * @param params.verification - Verification options (disableNetworking, keychains, addresses)
75
+ * @param params.reqId - Optional request ID for logging
76
+ * @returns {boolean} True if verification passes
77
+ * @throws {TxIntentMismatchError} if transaction validation fails
78
+ */
79
+ async function verifyTransaction(coin, bitgo, params) {
80
+ const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;
81
+ const txExplanation = await sdk_core_1.TxIntentMismatchError.tryGetTxExplanation(coin, txPrebuild);
82
+ // Helper to throw TxIntentMismatchError with consistent context
83
+ const throwTxMismatch = (message) => {
84
+ throw new sdk_core_1.TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex, txExplanation);
85
+ };
86
+ if (!lodash_1.default.isUndefined(verification.disableNetworking) && !lodash_1.default.isBoolean(verification.disableNetworking)) {
87
+ throw new TypeError('verification.disableNetworking must be a boolean');
88
+ }
89
+ const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);
90
+ if (isPsbt && txPrebuild.txInfo?.unspents) {
91
+ throw new Error('should not have unspents in txInfo for psbt');
92
+ }
93
+ const disableNetworking = !!verification.disableNetworking;
94
+ const parsedTransaction = await coin.parseTransaction({
95
+ txParams,
96
+ txPrebuild,
97
+ wallet,
98
+ verification,
99
+ reqId,
100
+ });
101
+ const keychains = parsedTransaction.keychains;
102
+ // verify that the claimed user public key corresponds to the wallet's user private key
103
+ let userPublicKeyVerified = false;
104
+ try {
105
+ // verify the user public key matches the private key - this will throw if there is no match
106
+ userPublicKeyVerified = (0, verifyKey_1.verifyUserPublicKey)(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });
107
+ }
108
+ catch (e) {
109
+ debug('failed to verify user public key!', e);
110
+ }
111
+ // let's verify these keychains
112
+ const keySignatures = parsedTransaction.keySignatures;
113
+ if (!lodash_1.default.isEmpty(keySignatures)) {
114
+ const verify = (key, pub) => {
115
+ if (!keychains.user || !keychains.user.pub) {
116
+ throwTxMismatch('missing user keychain');
117
+ }
118
+ return (0, verifyKey_1.verifyKeySignature)({
119
+ userKeychain: keychains.user,
120
+ keychainToVerify: key,
121
+ keySignature: pub,
122
+ });
123
+ };
124
+ const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);
125
+ const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);
126
+ if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {
127
+ throw new Error('secondary public key signatures invalid');
128
+ }
129
+ debug('successfully verified backup and bitgo key signatures');
130
+ }
131
+ else if (!disableNetworking) {
132
+ // these keys were obtained online and their signatures were not verified
133
+ // this could be dangerous
134
+ console.log('unsigned keys obtained online are being used for address verification');
135
+ }
136
+ if (parsedTransaction.needsCustomChangeKeySignatureVerification) {
137
+ if (!keychains.user || !userPublicKeyVerified) {
138
+ throw new Error('transaction requires verification of user public key, but it was unable to be verified');
139
+ }
140
+ const customChangeKeySignaturesVerified = (0, verifyKey_1.verifyCustomChangeKeySignatures)(parsedTransaction, keychains.user);
141
+ if (!customChangeKeySignaturesVerified) {
142
+ throw new Error('transaction requires verification of custom change key signatures, but they were unable to be verified');
143
+ }
144
+ debug('successfully verified user public key and custom change key signatures');
145
+ }
146
+ const missingOutputs = parsedTransaction.missingOutputs;
147
+ if (missingOutputs.length !== 0) {
148
+ // there are some outputs in the recipients list that have not made it into the actual transaction
149
+ throwTxMismatch('expected outputs missing in transaction prebuild');
150
+ }
151
+ const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;
152
+ // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended
153
+ const payAsYouGoLimit = new bignumber_js_1.default(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(intendedExternalSpend.toString());
154
+ /*
155
+ Some explanation for why we're doing what we're doing:
156
+ Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for
157
+ it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a
158
+ threshold for the output's value above which we'll throw an error, because the paygo output should never be that
159
+ high.
160
+ */
161
+ // make sure that all the extra addresses are change addresses
162
+ // get all the additional external outputs the server added and calculate their values
163
+ const nonChangeAmount = new bignumber_js_1.default(parsedTransaction.implicitExternalSpendAmount.toString());
164
+ debug('Intended spend is %s, Non-change amount is %s, paygo limit is %s', intendedExternalSpend.toString(), nonChangeAmount.toString(), payAsYouGoLimit.toString());
165
+ // There are two instances where we will get into this point here
166
+ if (nonChangeAmount.gt(payAsYouGoLimit)) {
167
+ if (isPsbt && parsedTransaction.customChange) {
168
+ // In the case that we have a custom change address on a wallet and we are building the transaction
169
+ // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor
170
+ // can we fetch that information from the other wallet because we may not have the credentials. Therefore,
171
+ // we will not throw an error here, but we will log a warning.
172
+ debug(`cannot verify some of the addresses because it belongs to a separate wallet`);
173
+ }
174
+ else {
175
+ // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address
176
+ // there are some addresses that are outside the scope of intended recipients that are not change addresses
177
+ throwTxMismatch('prebuild attempts to spend to unintended external recipients');
178
+ }
179
+ }
180
+ const allOutputs = parsedTransaction.outputs;
181
+ if (!txPrebuild.txHex) {
182
+ throw new Error(`txPrebuild.txHex not set`);
183
+ }
184
+ const inputs = isPsbt
185
+ ? (0, fetchInputs_1.getPsbtTxInputs)(txPrebuild.txHex, coin.network).map((v) => ({
186
+ ...v,
187
+ value: utxolib.bitgo.toTNumber(v.value, coin.amountType),
188
+ }))
189
+ : await (0, fetchInputs_1.getTxInputs)({ txPrebuild, bitgo, coin, disableNetworking, reqId });
190
+ // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field
191
+ const inputAmount = inputs.reduce((sum, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value), BigInt(0));
192
+ const outputAmount = allOutputs.reduce((sum, o) => sum + BigInt(o.amount), BigInt(0));
193
+ const fee = inputAmount - outputAmount;
194
+ if (fee < 0) {
195
+ throw new Error(`attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`);
196
+ }
197
+ return true;
198
+ }
199
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5VHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZml4ZWRTY3JpcHQvdmVyaWZ5VHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUE2Q0EsOENBdUpDO0FBcE1ELGtEQUErQjtBQUMvQixvREFBdUI7QUFDdkIsZ0VBQXFDO0FBQ3JDLG1EQUFtRjtBQUNuRiw4REFBZ0Q7QUFJaEQsK0NBQTJHO0FBQzNHLGdEQUE4RDtBQUU5RCxNQUFNLEtBQUssR0FBRyxJQUFBLGVBQVUsRUFBQyx1Q0FBdUMsQ0FBQyxDQUFDO0FBRWxFOzs7O0dBSUc7QUFDSCxTQUFTLGFBQWEsQ0FBQyxnQkFBMEI7SUFDL0MsaUdBQWlHO0lBQ2pHLHFEQUFxRDtJQUNyRCxJQUFJLENBQUMsZ0JBQUMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDcEQsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBQ0Qsa0ZBQWtGO0lBQ2xGLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0ksS0FBSyxVQUFVLGlCQUFpQixDQUNyQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF5QztJQUV6QyxNQUFNLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsWUFBWSxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFMUUsTUFBTSxhQUFhLEdBQUcsTUFBTSxnQ0FBcUIsQ0FBQyxtQkFBbUIsQ0FBQyxJQUE0QixFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRWhILGdFQUFnRTtJQUNoRSxNQUFNLGVBQWUsR0FBRyxDQUFDLE9BQWUsRUFBUyxFQUFFO1FBQ2pELE1BQU0sSUFBSSxnQ0FBcUIs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QUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUN4RixNQUFNLENBQUMsQ0FBQyxDQUFDLENBQ1YsQ0FBQztJQUNGLE1BQU0sWUFBWSxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFXLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN0RyxNQUFNLEdBQUcsR0FBRyxXQUFXLEdBQUcsWUFBWSxDQUFDO0lBRXZDLElBQUksR0FBRyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ1osTUFBTSxJQUFJLEtBQUssQ0FDYix1QkFBdUIsWUFBWSw4Q0FBOEMsV0FBVyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsQ0FDcEgsQ0FBQztJQUNKLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYnVpbGREZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuaW1wb3J0IHsgQml0R29CYXNlLCBUeEludGVudE1pc21hdGNoRXJyb3IsIElCYXNlQ29pbiB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5pbXBvcnQgeyBBYnN0cmFjdFV0eG9Db2luLCBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnMgfSBmcm9tICcuLi8uLi9hYnN0cmFjdFV0eG9Db2luJztcbmltcG9ydCB7IE91dHB1dCwgUGFyc2VkVHJhbnNhY3Rpb24gfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyB2ZXJpZnlDdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVzLCB2ZXJpZnlLZXlTaWduYXR1cmUsIHZlcmlmeVVzZXJQdWJsaWNLZXkgfSBmcm9tICcuLi8uLi92ZXJpZnlLZXknO1xuaW1wb3J0IHsgZ2V0UHNidFR4SW5wdXRzLCBnZXRUeElucHV0cyB9IGZyb20gJy4uL2ZldGNoSW5wdXRzJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnZlcmlmeVRyYW5zYWN0aW9uJyk7XG5cbi8qKlxuICogR2V0IHRoZSBtYXhpbXVtIHBlcmNlbnRhZ2UgbGltaXQgZm9yIHBheS1hcy15b3UtZ28gb3V0cHV0c1xuICpcbiAqIEBwcm90ZWN0ZWRcbiAqL1xuZnVuY3Rpb24gZ2V0UGF5R29MaW1pdChhbGxvd1BheWdvT3V0cHV0PzogYm9vbGVhbik6IG51bWJlciB7XG4gIC8vIGFsbG93aW5nIHBheWdvIG91dHB1dHMgbmVlZHMgdG8gYmUgdGhlIGRlZmF1bHQgYmVoYXZpb3IsIHNvIG9ubHkgZGlzYWxsb3cgcGF5Z28gb3V0cHV0cyBpZiB0aGVcbiAgLy8gcmVsZXZhbnQgdmVyaWZpY2F0aW9uIG9wdGlvbiBpcyBib3RoIHNldCBhbmQgZmFsc2VcbiAgaWYgKCFfLmlzTmlsKGFsbG93UGF5Z29PdXRwdXQpICYmICFhbGxvd1BheWdvT3V0cHV0KSB7XG4gICAgcmV0dXJuIDA7XG4gIH1cbiAgLy8gMTUwIGJhc2lzIHBvaW50cyBpcyB0aGUgYWJzb2x1dGUgcGVybWl0dGVkIG1heGltdW0gaWYgcGF5Z28gb3V0cHV0cyBhcmUgYWxsb3dlZFxuICByZXR1cm4gMC4wMTU7XG59XG5cbi8qKlxuICogVmVyaWZ5IHRoYXQgYSB0cmFuc2FjdGlvbiBwcmVidWlsZCBjb21wbGllcyB3aXRoIHRoZSBvcmlnaW5hbCBpbnRlbnRpb24gZm9yIGZpeGVkLXNjcmlwdCB3YWxsZXRzXG4gKlxuICogVGhpcyBpbXBsZW1lbnRhdGlvbiBoYW5kbGVzIHRyYW5zYWN0aW9uIHZlcmlmaWNhdGlvbiBmb3IgdHJhZGl0aW9uYWwgVVRYTyBjb2lucyB1c2luZyBmaXhlZCBzY3JpcHRzXG4gKiAobm9uLWRlc2NyaXB0b3Igd2FsbGV0cykuIEl0IHZhbGlkYXRlcyBrZXljaGFpbnMsIHNpZ25hdHVyZXMsIG91dHB1dHMsIGFuZCBhbW91bnRzLlxuICpcbiAqIEBwYXJhbSBjb2luIC0gVGhlIFVUWE8gY29pbiBpbnN0YW5jZVxuICogQHBhcmFtIGJpdGdvIC0gQml0R28gQVBJIGluc3RhbmNlIGZvciBuZXR3b3JrIGNhbGxzXG4gKiBAcGFyYW0gcGFyYW1zIC0gVmVyaWZpY2F0aW9uIHBhcmFtZXRlcnNcbiAqIEBwYXJhbSBwYXJhbXMudHhQYXJhbXMgLSBUcmFuc2FjdGlvbiBwYXJhbWV0ZXJzIHBhc3NlZCB0byBzZW5kXG4gKiBAcGFyYW0gcGFyYW1zLnR4UHJlYnVpbGQgLSBQcmVidWlsZCBvYmplY3QgcmV0dXJuZWQgYnkgc2VydmVyXG4gKiBAcGFyYW0gcGFyYW1zLndhbGxldCAtIFdhbGxldCBvYmplY3QgdG8gb2J0YWluIGtleXMgdG8gdmVyaWZ5IGFnYWluc3RcbiAqIEBwYXJhbSBwYXJhbXMudmVyaWZpY2F0aW9uIC0gVmVyaWZpY2F0aW9uIG9wdGlvbnMgKGRpc2FibGVOZXR3b3JraW5nLCBrZXljaGFpbnMsIGFkZHJlc3NlcylcbiAqIEBwYXJhbSBwYXJhbXMucmVxSWQgLSBPcHRpb25hbCByZXF1ZXN0IElEIGZvciBsb2dnaW5nXG4gKiBAcmV0dXJucyB7Ym9vbGVhbn0gVHJ1ZSBpZiB2ZXJpZmljYXRpb24gcGFzc2VzXG4gKiBAdGhyb3dzIHtUeEludGVudE1pc21hdGNoRXJyb3J9IGlmIHRyYW5zYWN0aW9uIHZhbGlkYXRpb24gZmFpbHNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHZlcmlmeVRyYW5zYWN0aW9uPFROdW1iZXIgZXh0ZW5kcyBiaWdpbnQgfCBudW1iZXI+KFxuICBjb2luOiBBYnN0cmFjdFV0eG9Db2luLFxuICBiaXRnbzogQml0R29CYXNlLFxuICBwYXJhbXM6IFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTxib29sZWFuPiB7XG4gIGNvbnN0IHsgdHhQYXJhbXMsIHR4UHJlYnVpbGQsIHdhbGxldCwgdmVyaWZpY2F0aW9uID0ge30sIHJlcUlkIH0gPSBwYXJhbXM7XG5cbiAgY29uc3QgdHhFeHBsYW5hdGlvbiA9IGF3YWl0IFR4SW50ZW50TWlzbWF0Y2hFcnJvci50cnlHZXRUeEV4cGxhbmF0aW9uKGNvaW4gYXMgdW5rbm93biBhcyBJQmFzZUNvaW4sIHR4UHJlYnVpbGQpO1xuXG4gIC8vIEhlbHBlciB0byB0aHJvdyBUeEludGVudE1pc21hdGNoRXJyb3Igd2l0aCBjb25zaXN0ZW50IGNvbnRleHRcbiAgY29uc3QgdGhyb3dUeE1pc21hdGNoID0gKG1lc3NhZ2U6IHN0cmluZyk6IG5ldmVyID0+IHtcbiAgICB0aHJvdyBuZXcgVHhJbnRlbnRNaXNtYXRjaEVycm9yKG1lc3NhZ2UsIHJlcUlkLCBbdHhQYXJhbXNdLCB0eFByZWJ1aWxkLnR4SGV4LCB0eEV4cGxhbmF0aW9uKTtcbiAgfTtcblxuICBpZiAoIV8uaXNVbmRlZmluZWQodmVyaWZpY2F0aW9uLmRpc2FibGVOZXR3b3JraW5nKSAmJiAhXy5pc0Jvb2xlYW4odmVyaWZpY2F0aW9uLmRpc2FibGVOZXR3b3JraW5nKSkge1xuICAgIHRocm93IG5ldyBUeXBlRXJyb3IoJ3ZlcmlmaWNhdGlvbi5kaXNhYmxlTmV0d29ya2luZyBtdXN0IGJlIGEgYm9vbGVhbicpO1xuICB9XG4gIGNvbnN0IGlzUHNidCA9IHR4UHJlYnVpbGQudHhIZXggJiYgdXR4b2xpYi5iaXRnby5pc1BzYnQodHhQcmVidWlsZC50eEhleCk7XG4gIGlmIChpc1BzYnQgJiYgdHhQcmVidWlsZC50eEluZm8/LnVuc3BlbnRzKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdzaG91bGQgbm90IGhhdmUgdW5zcGVudHMgaW4gdHhJbmZvIGZvciBwc2J0Jyk7XG4gIH1cbiAgY29uc3QgZGlzYWJsZU5ldHdvcmtpbmcgPSAhIXZlcmlmaWNhdGlvbi5kaXNhYmxlTmV0d29ya2luZztcbiAgY29uc3QgcGFyc2VkVHJhbnNhY3Rpb246IFBhcnNlZFRyYW5zYWN0aW9uPFROdW1iZXI+ID0gYXdhaXQgY29pbi5wYXJzZVRyYW5zYWN0aW9uPFROdW1iZXI+KHtcbiAgICB0eFBhcmFtcyxcbiAgICB0eFByZWJ1aWxkLFxuICAgIHdhbGxldCxcbiAgICB2ZXJpZmljYXRpb24sXG4gICAgcmVxSWQsXG4gIH0pO1xuXG4gIGNvbnN0IGtleWNoYWlucyA9IHBhcnNlZFRyYW5zYWN0aW9uLmtleWNoYWlucztcblxuICAvLyB2ZXJpZnkgdGhhdCB0aGUgY2xhaW1lZCB1c2VyIHB1YmxpYyBrZXkgY29ycmVzcG9uZHMgdG8gdGhlIHdhbGxldCdzIHVzZXIgcHJpdmF0ZSBrZXlcbiAgbGV0IHVzZXJQdWJsaWNLZXlWZXJpZmllZCA9IGZhbHNlO1xuICB0cnkge1xuICAgIC8vIHZlcmlmeSB0aGUgdXNlciBwdWJsaWMga2V5IG1hdGNoZXMgdGhlIHByaXZhdGUga2V5IC0gdGhpcyB3aWxsIHRocm93IGlmIHRoZXJlIGlzIG5vIG1hdGNoXG4gICAgdXNlclB1YmxpY0tleVZlcmlmaWVkID0gdmVyaWZ5VXNlclB1YmxpY0tleShiaXRnbywgeyB1c2VyS2V5Y2hhaW46IGtleWNoYWlucy51c2VyLCBkaXNhYmxlTmV0d29ya2luZywgdHhQYXJhbXMgfSk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBkZWJ1ZygnZmFpbGVkIHRvIHZlcmlmeSB1c2VyIHB1YmxpYyBrZXkhJywgZSk7XG4gIH1cblxuICAvLyBsZXQncyB2ZXJpZnkgdGhlc2Uga2V5Y2hhaW5zXG4gIGNvbnN0IGtleVNpZ25hdHVyZXMgPSBwYXJzZWRUcmFuc2FjdGlvbi5rZXlTaWduYXR1cmVzO1xuICBpZiAoIV8uaXNFbXB0eShrZXlTaWduYXR1cmVzKSkge1xuICAgIGNvbnN0IHZlcmlmeSA9IChrZXksIHB1YikgPT4ge1xuICAgICAgaWYgKCFrZXljaGFpbnMudXNlciB8fCAha2V5Y2hhaW5zLnVzZXIucHViKSB7XG4gICAgICAgIHRocm93VHhNaXNtYXRjaCgnbWlzc2luZyB1c2VyIGtleWNoYWluJyk7XG4gICAgICB9XG4gICAgICByZXR1cm4gdmVyaWZ5S2V5U2lnbmF0dXJlKHtcbiAgICAgICAgdXNlcktleWNoYWluOiBrZXljaGFpbnMudXNlciBhcyB7IHB1Yjogc3RyaW5nIH0sXG4gICAgICAgIGtleWNoYWluVG9WZXJpZnk6IGtleSxcbiAgICAgICAga2V5U2lnbmF0dXJlOiBwdWIsXG4gICAgICB9KTtcbiAgICB9O1xuICAgIGNvbnN0IGlzQmFja3VwS2V5U2lnbmF0dXJlVmFsaWQgPSB2ZXJpZnkoa2V5Y2hhaW5zLmJhY2t1cCwga2V5U2lnbmF0dXJlcy5iYWNrdXBQdWIpO1xuICAgIGNvbnN0IGlzQml0Z29LZXlTaWduYXR1cmVWYWxpZCA9IHZlcmlmeShrZXljaGFpbnMuYml0Z28sIGtleVNpZ25hdHVyZXMuYml0Z29QdWIpO1xuICAgIGlmICghaXNCYWNrdXBLZXlTaWduYXR1cmVWYWxpZCB8fCAhaXNCaXRnb0tleVNpZ25hdHVyZVZhbGlkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3NlY29uZGFyeSBwdWJsaWMga2V5IHNpZ25hdHVyZXMgaW52YWxpZCcpO1xuICAgIH1cbiAgICBkZWJ1Zygnc3VjY2Vzc2Z1bGx5IHZlcmlmaWVkIGJhY2t1cCBhbmQgYml0Z28ga2V5IHNpZ25hdHVyZXMnKTtcbiAgfSBlbHNlIGlmICghZGlzYWJsZU5ldHdvcmtpbmcpIHtcbiAgICAvLyB0aGVzZSBrZXlzIHdlcmUgb2J0YWluZWQgb25saW5lIGFuZCB0aGVpciBzaWduYXR1cmVzIHdlcmUgbm90IHZlcmlmaWVkXG4gICAgLy8gdGhpcyBjb3VsZCBiZSBkYW5nZXJvdXNcbiAgICBjb25zb2xlLmxvZygndW5zaWduZWQga2V5cyBvYnRhaW5lZCBvbmxpbmUgYXJlIGJlaW5nIHVzZWQgZm9yIGFkZHJlc3MgdmVyaWZpY2F0aW9uJyk7XG4gIH1cblxuICBpZiAocGFyc2VkVHJhbnNhY3Rpb24ubmVlZHNDdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVWZXJpZmljYXRpb24pIHtcbiAgICBpZiAoIWtleWNoYWlucy51c2VyIHx8ICF1c2VyUHVibGljS2V5VmVyaWZpZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigndHJhbnNhY3Rpb24gcmVxdWlyZXMgdmVyaWZpY2F0aW9uIG9mIHVzZXIgcHVibGljIGtleSwgYnV0IGl0IHdhcyB1bmFibGUgdG8gYmUgdmVyaWZpZWQnKTtcbiAgICB9XG4gICAgY29uc3QgY3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlc1ZlcmlmaWVkID0gdmVyaWZ5Q3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlcyhwYXJzZWRUcmFuc2FjdGlvbiwga2V5Y2hhaW5zLnVzZXIpO1xuICAgIGlmICghY3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlc1ZlcmlmaWVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICd0cmFuc2FjdGlvbiByZXF1aXJlcyB2ZXJpZmljYXRpb24gb2YgY3VzdG9tIGNoYW5nZSBrZXkgc2lnbmF0dXJlcywgYnV0IHRoZXkgd2VyZSB1bmFibGUgdG8gYmUgdmVyaWZpZWQnXG4gICAgICApO1xuICAgIH1cbiAgICBkZWJ1Zygnc3VjY2Vzc2Z1bGx5IHZlcmlmaWVkIHVzZXIgcHVibGljIGtleSBhbmQgY3VzdG9tIGNoYW5nZSBrZXkgc2lnbmF0dXJlcycpO1xuICB9XG5cbiAgY29uc3QgbWlzc2luZ091dHB1dHMgPSBwYXJzZWRUcmFuc2FjdGlvbi5taXNzaW5nT3V0cHV0cztcbiAgaWYgKG1pc3NpbmdPdXRwdXRzLmxlbmd0aCAhPT0gMCkge1xuICAgIC8vIHRoZXJlIGFyZSBzb21lIG91dHB1dHMgaW4gdGhlIHJlY2lwaWVudHMgbGlzdCB0aGF0IGhhdmUgbm90IG1hZGUgaXQgaW50byB0aGUgYWN0dWFsIHRyYW5zYWN0aW9uXG4gICAgdGhyb3dUeE1pc21hdGNoKCdleHBlY3RlZCBvdXRwdXRzIG1pc3NpbmcgaW4gdHJhbnNhY3Rpb24gcHJlYnVpbGQnKTtcbiAgfVxuXG4gIGNvbnN0IGludGVuZGVkRXh0ZXJuYWxTcGVuZCA9IHBhcnNlZFRyYW5zYWN0aW9uLmV4cGxpY2l0RXh0ZXJuYWxTcGVuZEFtb3VudDtcblxuICAvLyB0aGlzIGlzIGEgbGltaXQgd2UgaW1wb3NlIGZvciB0aGUgdG90YWwgdmFsdWUgdGhhdCBpcyBhbWVuZGVkIHRvIHRoZSB0cmFuc2FjdGlvbiBiZXlvbmQgd2hhdCB3YXMgb3JpZ2luYWxseSBpbnRlbmRlZFxuICBjb25zdCBwYXlBc1lvdUdvTGltaXQgPSBuZXcgQmlnTnVtYmVyKGdldFBheUdvTGltaXQodmVyaWZpY2F0aW9uLmFsbG93UGF5Z29PdXRwdXQpKS5tdWx0aXBsaWVkQnkoXG4gICAgaW50ZW5kZWRFeHRlcm5hbFNwZW5kLnRvU3RyaW5nKClcbiAgKTtcblxuICAvKlxuICBTb21lIGV4cGxhbmF0aW9uIGZvciB3aHkgd2UncmUgZG9pbmcgd2hhdCB3ZSdyZSBkb2luZzpcbiAgU29tZSBjdXN0b21lcnMgd2lsbCBoYXZlIGFuIG91dHB1dCB0byBCaXRHbydzIFBBWUdvIHdhbGxldCBhZGRlZCB0byB0aGVpciB0cmFuc2FjdGlvbiwgYW5kIHdlIG5lZWQgdG8gYWNjb3VudCBmb3JcbiAgaXQgaGVyZS4gVG8gcHJvdGVjdCBzb21lb25lIHRhbXBlcmluZyB3aXRoIHRoZSBvdXRwdXQgdG8gbWFrZSBpdCBzZW5kIG1vcmUgdGhhbiBpdCBzaG91bGQgdG8gQml0R28sIHdlIGRlZmluZSBhXG4gIHRocmVzaG9sZCBmb3IgdGhlIG91dHB1dCdzIHZhbHVlIGFib3ZlIHdoaWNoIHdlJ2xsIHRocm93IGFuIGVycm9yLCBiZWNhdXNlIHRoZSBwYXlnbyBvdXRwdXQgc2hvdWxkIG5ldmVyIGJlIHRoYXRcbiAgaGlnaC5cbiAgICovXG5cbiAgLy8gbWFrZSBzdXJlIHRoYXQgYWxsIHRoZSBleHRyYSBhZGRyZXNzZXMgYXJlIGNoYW5nZSBhZGRyZXNzZXNcbiAgLy8gZ2V0IGFsbCB0aGUgYWRkaXRpb25hbCBleHRlcm5hbCBvdXRwdXRzIHRoZSBzZXJ2ZXIgYWRkZWQgYW5kIGNhbGN1bGF0ZSB0aGVpciB2YWx1ZXNcbiAgY29uc3Qgbm9uQ2hhbmdlQW1vdW50ID0gbmV3IEJpZ051bWJlcihwYXJzZWRUcmFuc2FjdGlvbi5pbXBsaWNpdEV4dGVybmFsU3BlbmRBbW91bnQudG9TdHJpbmcoKSk7XG5cbiAgZGVidWcoXG4gICAgJ0ludGVuZGVkIHNwZW5kIGlzICVzLCBOb24tY2hhbmdlIGFtb3VudCBpcyAlcywgcGF5Z28gbGltaXQgaXMgJXMnLFxuICAgIGludGVuZGVkRXh0ZXJuYWxTcGVuZC50b1N0cmluZygpLFxuICAgIG5vbkNoYW5nZUFtb3VudC50b1N0cmluZygpLFxuICAgIHBheUFzWW91R29MaW1pdC50b1N0cmluZygpXG4gICk7XG5cbiAgLy8gVGhlcmUgYXJlIHR3byBpbnN0YW5jZXMgd2hlcmUgd2Ugd2lsbCBnZXQgaW50byB0aGlzIHBvaW50IGhlcmVcbiAgaWYgKG5vbkNoYW5nZUFtb3VudC5ndChwYXlBc1lvdUdvTGltaXQpKSB7XG4gICAgaWYgKGlzUHNidCAmJiBwYXJzZWRUcmFuc2FjdGlvbi5jdXN0b21DaGFuZ2UpIHtcbiAgICAgIC8vIEluIHRoZSBjYXNlIHRoYXQgd2UgaGF2ZSBhIGN1c3RvbSBjaGFuZ2UgYWRkcmVzcyBvbiBhIHdhbGxldCBhbmQgd2UgYXJlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvblxuICAgICAgLy8gd2l0aCBhIFBTQlQsIHdlIGRvIG5vdCBoYXZlIHRoZSBtZXRhZGF0YSB0byB2ZXJpZnkgdGhlIGFkZHJlc3MgZnJvbSB0aGUgY3VzdG9tIGNoYW5nZSB3YWxsZXQsIG5vclxuICAgICAgLy8gY2FuIHdlIGZldGNoIHRoYXQgaW5mb3JtYXRpb24gZnJvbSB0aGUgb3RoZXIgd2FsbGV0IGJlY2F1c2Ugd2UgbWF5IG5vdCBoYXZlIHRoZSBjcmVkZW50aWFscy4gVGhlcmVmb3JlLFxuICAgICAgLy8gd2Ugd2lsbCBub3QgdGhyb3cgYW4gZXJyb3IgaGVyZSwgYnV0IHdlIHdpbGwgbG9nIGEgd2FybmluZy5cbiAgICAgIGRlYnVnKGBjYW5ub3QgdmVyaWZ5IHNvbWUgb2YgdGhlIGFkZHJlc3NlcyBiZWNhdXNlIGl0IGJlbG9uZ3MgdG8gYSBzZXBhcmF0ZSB3YWxsZXRgKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gdGhlIGFkZGl0aW9uYWwgZXh0ZXJuYWwgb3V0cHV0cyBjYW4gb25seSBiZSBCaXRHbydzIHBheS1hcy15b3UtZ28gZmVlLCBidXQgd2UgY2Fubm90IHZlcmlmeSB0aGUgd2FsbGV0IGFkZHJlc3NcbiAgICAgIC8vIHRoZXJlIGFyZSBzb21lIGFkZHJlc3NlcyB0aGF0IGFyZSBvdXRzaWRlIHRoZSBzY29wZSBvZiBpbnRlbmRlZCByZWNpcGllbnRzIHRoYXQgYXJlIG5vdCBjaGFuZ2UgYWRkcmVzc2VzXG4gICAgICB0aHJvd1R4TWlzbWF0Y2goJ3ByZWJ1aWxkIGF0dGVtcHRzIHRvIHNwZW5kIHRvIHVuaW50ZW5kZWQgZXh0ZXJuYWwgcmVjaXBpZW50cycpO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGFsbE91dHB1dHMgPSBwYXJzZWRUcmFuc2FjdGlvbi5vdXRwdXRzO1xuICBpZiAoIXR4UHJlYnVpbGQudHhIZXgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYHR4UHJlYnVpbGQudHhIZXggbm90IHNldGApO1xuICB9XG4gIGNvbnN0IGlucHV0cyA9IGlzUHNidFxuICAgID8gZ2V0UHNidFR4SW5wdXRzKHR4UHJlYnVpbGQudHhIZXgsIGNvaW4ubmV0d29yaykubWFwKCh2KSA9PiAoe1xuICAgICAgICAuLi52LFxuICAgICAgICB2YWx1ZTogdXR4b2xpYi5iaXRnby50b1ROdW1iZXIodi52YWx1ZSwgY29pbi5hbW91bnRUeXBlKSxcbiAgICAgIH0pKVxuICAgIDogYXdhaXQgZ2V0VHhJbnB1dHMoeyB0eFByZWJ1aWxkLCBiaXRnbywgY29pbiwgZGlzYWJsZU5ldHdvcmtpbmcsIHJlcUlkIH0pO1xuICAvLyBjb2lucyAoZG9nZSkgdGhhdCBjYW4gZXhjZWVkIG51bWJlciBsaW1pdHMgKGFuZCB0aHVzIHdpbGwgdXNlIGJpZ2ludCkgd2lsbCBoYXZlIHRoZSBgdmFsdWVTdHJpbmdgIGZpZWxkXG4gIGNvbnN0IGlucHV0QW1vdW50ID0gaW5wdXRzLnJlZHVjZShcbiAgICAoc3VtOiBiaWdpbnQsIGkpID0+IHN1bSArIEJpZ0ludChjb2luLmFtb3VudFR5cGUgPT09ICdiaWdpbnQnID8gaS52YWx1ZVN0cmluZyA6IGkudmFsdWUpLFxuICAgIEJpZ0ludCgwKVxuICApO1xuICBjb25zdCBvdXRwdXRBbW91bnQgPSBhbGxPdXRwdXRzLnJlZHVjZSgoc3VtOiBiaWdpbnQsIG86IE91dHB1dCkgPT4gc3VtICsgQmlnSW50KG8uYW1vdW50KSwgQmlnSW50KDApKTtcbiAgY29uc3QgZmVlID0gaW5wdXRBbW91bnQgLSBvdXRwdXRBbW91bnQ7XG5cbiAgaWYgKGZlZSA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgYXR0ZW1wdGluZyB0byBzcGVuZCAke291dHB1dEFtb3VudH0gc2F0b3NoaXMsIHdoaWNoIGV4Y2VlZHMgdGhlIGlucHV0IGFtb3VudCAoJHtpbnB1dEFtb3VudH0gc2F0b3NoaXMpIGJ5ICR7LWZlZX1gXG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuIl19
@@ -0,0 +1,9 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ /**
3
+ * We want to return the verification pubkey from our statics that has our
4
+ * verification pubkey.
5
+ * @param network
6
+ * @returns
7
+ */
8
+ export declare function getPayGoVerificationPubkey(network: utxolib.Network): string | undefined;
9
+ //# sourceMappingURL=getPayGoVerificationPubkey.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getPayGoVerificationPubkey.d.ts","sourceRoot":"","sources":["../../../../src/transaction/getPayGoVerificationPubkey.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAKhD;;;;;GAKG;AACH,wBAAgB,0BAA0B,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,GAAG,SAAS,CAMvF"}
@@ -0,0 +1,53 @@
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.getPayGoVerificationPubkey = getPayGoVerificationPubkey;
37
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
38
+ const BITGOPAYGOATTESTATIONPUBKEY = 'xpub6BKRgmCPX5oQiJgJ6Vq6BF8tDvZhwQki5dVVQohckK2ZJXtxj8K6M9pavLwt9piW33hZz17SWmG8QWsjJ1tHdde2Fs5UA3DFbApCtbdaGKn';
39
+ /**
40
+ * We want to return the verification pubkey from our statics that has our
41
+ * verification pubkey.
42
+ * @param network
43
+ * @returns
44
+ */
45
+ function getPayGoVerificationPubkey(network) {
46
+ if (utxolib.isTestnet(network)) {
47
+ return BITGOPAYGOATTESTATIONPUBKEY;
48
+ }
49
+ else if (utxolib.isMainnet(network)) {
50
+ return undefined;
51
+ }
52
+ }
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0UGF5R29WZXJpZmljYXRpb25QdWJrZXkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZ2V0UGF5R29WZXJpZmljYXRpb25QdWJrZXkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFXQSxnRUFNQztBQWpCRCw4REFBZ0Q7QUFFaEQsTUFBTSwyQkFBMkIsR0FDL0IsaUhBQWlILENBQUM7QUFFcEg7Ozs7O0dBS0c7QUFDSCxTQUFnQiwwQkFBMEIsQ0FBQyxPQUF3QjtJQUNqRSxJQUFJLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUMvQixPQUFPLDJCQUEyQixDQUFDO0lBQ3JDLENBQUM7U0FBTSxJQUFJLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUN0QyxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5jb25zdCBCSVRHT1BBWUdPQVRURVNUQVRJT05QVUJLRVkgPVxuICAneHB1YjZCS1JnbUNQWDVvUWlKZ0o2VnE2QkY4dER2Wmh3UWtpNWRWVlFvaGNrSzJaSlh0eGo4SzZNOXBhdkx3dDlwaVczM2haejE3U1dtRzhRV3NqSjF0SGRkZTJGczVVQTNERmJBcEN0YmRhR0tuJztcblxuLyoqXG4gKiBXZSB3YW50IHRvIHJldHVybiB0aGUgdmVyaWZpY2F0aW9uIHB1YmtleSBmcm9tIG91ciBzdGF0aWNzIHRoYXQgaGFzIG91clxuICogdmVyaWZpY2F0aW9uIHB1YmtleS5cbiAqIEBwYXJhbSBuZXR3b3JrXG4gKiBAcmV0dXJuc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0UGF5R29WZXJpZmljYXRpb25QdWJrZXkobmV0d29yazogdXR4b2xpYi5OZXR3b3JrKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgaWYgKHV0eG9saWIuaXNUZXN0bmV0KG5ldHdvcmspKSB7XG4gICAgcmV0dXJuIEJJVEdPUEFZR09BVFRFU1RBVElPTlBVQktFWTtcbiAgfSBlbHNlIGlmICh1dHhvbGliLmlzTWFpbm5ldChuZXR3b3JrKSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ export * from './types';
2
+ export * from './recipient';
3
+ export { explainTx } from './explainTransaction';
4
+ export { parseTransaction } from './parseTransaction';
5
+ export { verifyTransaction } from './verifyTransaction';
6
+ export * from './fetchInputs';
7
+ export * as bip322 from './bip322';
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/transaction/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,cAAc,eAAe,CAAC;AAC9B,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC"}