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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (761) hide show
  1. package/dist/{src → cjs/src}/abstractUtxoCoin.d.ts +12 -23
  2. package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -0
  3. package/dist/cjs/src/abstractUtxoCoin.js +639 -0
  4. package/dist/cjs/src/address/fixedScript.d.ts.map +1 -0
  5. package/dist/cjs/src/address/fixedScript.js +150 -0
  6. package/dist/cjs/src/address/index.d.ts.map +1 -0
  7. package/dist/{src → cjs/src}/address/index.js +1 -1
  8. package/dist/cjs/src/config.d.ts.map +1 -0
  9. package/dist/cjs/src/config.js +14 -0
  10. package/dist/cjs/src/descriptor/NamedDescriptor.d.ts.map +1 -0
  11. package/dist/cjs/src/descriptor/NamedDescriptor.js +79 -0
  12. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  13. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.js +66 -0
  14. package/dist/cjs/src/descriptor/builder/builder.d.ts.map +1 -0
  15. package/dist/cjs/src/descriptor/builder/builder.js +37 -0
  16. package/dist/cjs/src/descriptor/builder/index.d.ts.map +1 -0
  17. package/dist/{src → cjs/src}/descriptor/builder/index.js +1 -1
  18. package/dist/cjs/src/descriptor/builder/parse.d.ts.map +1 -0
  19. package/dist/cjs/src/descriptor/builder/parse.js +116 -0
  20. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  21. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.js +41 -0
  22. package/dist/cjs/src/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  23. package/dist/cjs/src/descriptor/createWallet/createDescriptors.js +33 -0
  24. package/dist/cjs/src/descriptor/createWallet/index.d.ts.map +1 -0
  25. package/dist/{src → cjs/src}/descriptor/createWallet/index.js +1 -1
  26. package/dist/cjs/src/descriptor/descriptorWallet.d.ts.map +1 -0
  27. package/dist/cjs/src/descriptor/descriptorWallet.js +54 -0
  28. package/dist/cjs/src/descriptor/index.d.ts.map +1 -0
  29. package/dist/{src → cjs/src}/descriptor/index.js +1 -1
  30. package/dist/cjs/src/descriptor/validatePolicy.d.ts.map +1 -0
  31. package/dist/cjs/src/descriptor/validatePolicy.js +92 -0
  32. package/dist/cjs/src/impl/bch/bch.d.ts.map +1 -0
  33. package/dist/cjs/src/impl/bch/bch.js +70 -0
  34. package/dist/cjs/src/impl/bch/index.d.ts.map +1 -0
  35. package/dist/{src → cjs/src}/impl/bch/index.js +1 -1
  36. package/dist/cjs/src/impl/bch/tbch.d.ts.map +1 -0
  37. package/dist/{src → cjs/src}/impl/bch/tbch.js +1 -1
  38. package/dist/cjs/src/impl/bcha/bcha.d.ts.map +1 -0
  39. package/dist/{src → cjs/src}/impl/bcha/bcha.js +1 -1
  40. package/dist/cjs/src/impl/bcha/index.d.ts.map +1 -0
  41. package/dist/{src → cjs/src}/impl/bcha/index.js +1 -1
  42. package/dist/cjs/src/impl/bcha/tbcha.d.ts.map +1 -0
  43. package/dist/{src → cjs/src}/impl/bcha/tbcha.js +1 -1
  44. package/dist/cjs/src/impl/bsv/bsv.d.ts.map +1 -0
  45. package/dist/{src → cjs/src}/impl/bsv/bsv.js +1 -1
  46. package/dist/cjs/src/impl/bsv/index.d.ts.map +1 -0
  47. package/dist/{src → cjs/src}/impl/bsv/index.js +1 -1
  48. package/dist/cjs/src/impl/bsv/tbsv.d.ts.map +1 -0
  49. package/dist/{src → cjs/src}/impl/bsv/tbsv.js +1 -1
  50. package/dist/cjs/src/impl/btc/btc.d.ts.map +1 -0
  51. package/dist/{src → cjs/src}/impl/btc/btc.js +1 -1
  52. package/dist/cjs/src/impl/btc/index.d.ts.map +1 -0
  53. package/dist/{src → cjs/src}/impl/btc/index.js +1 -1
  54. package/dist/cjs/src/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  55. package/dist/cjs/src/impl/btc/inscriptionBuilder.js +183 -0
  56. package/dist/cjs/src/impl/btc/tbtc.d.ts.map +1 -0
  57. package/dist/{src → cjs/src}/impl/btc/tbtc.js +1 -1
  58. package/dist/cjs/src/impl/btc/tbtc4.d.ts.map +1 -0
  59. package/dist/{src → cjs/src}/impl/btc/tbtc4.js +1 -1
  60. package/dist/cjs/src/impl/btc/tbtcbgsig.d.ts.map +1 -0
  61. package/dist/{src → cjs/src}/impl/btc/tbtcbgsig.js +1 -1
  62. package/dist/cjs/src/impl/btc/tbtcsig.d.ts.map +1 -0
  63. package/dist/{src → cjs/src}/impl/btc/tbtcsig.js +1 -1
  64. package/dist/cjs/src/impl/btg/btg.d.ts.map +1 -0
  65. package/dist/{src/impl/dash/dash.js → cjs/src/impl/btg/btg.js} +6 -6
  66. package/dist/cjs/src/impl/btg/index.d.ts.map +1 -0
  67. package/dist/{src → cjs/src}/impl/btg/index.js +1 -1
  68. package/dist/cjs/src/impl/dash/dash.d.ts.map +1 -0
  69. package/dist/cjs/src/impl/dash/dash.js +48 -0
  70. package/dist/cjs/src/impl/dash/index.d.ts.map +1 -0
  71. package/dist/{src → cjs/src}/impl/dash/index.js +1 -1
  72. package/dist/cjs/src/impl/dash/tdash.d.ts.map +1 -0
  73. package/dist/{src → cjs/src}/impl/dash/tdash.js +1 -1
  74. package/dist/{src → cjs/src}/impl/doge/doge.d.ts +3 -2
  75. package/dist/cjs/src/impl/doge/doge.d.ts.map +1 -0
  76. package/dist/cjs/src/impl/doge/doge.js +79 -0
  77. package/dist/cjs/src/impl/doge/index.d.ts.map +1 -0
  78. package/dist/{src → cjs/src}/impl/doge/index.js +1 -1
  79. package/dist/cjs/src/impl/doge/tdoge.d.ts.map +1 -0
  80. package/dist/{src → cjs/src}/impl/doge/tdoge.js +1 -1
  81. package/dist/cjs/src/impl/index.d.ts.map +1 -0
  82. package/dist/{src → cjs/src}/impl/index.js +1 -1
  83. package/dist/cjs/src/impl/ltc/index.d.ts.map +1 -0
  84. package/dist/{src → cjs/src}/impl/ltc/index.js +1 -1
  85. package/dist/cjs/src/impl/ltc/ltc.d.ts.map +1 -0
  86. package/dist/{src → cjs/src}/impl/ltc/ltc.js +1 -1
  87. package/dist/cjs/src/impl/ltc/tltc.d.ts.map +1 -0
  88. package/dist/{src → cjs/src}/impl/ltc/tltc.js +1 -1
  89. package/dist/cjs/src/impl/zec/index.d.ts.map +1 -0
  90. package/dist/{src → cjs/src}/impl/zec/index.js +1 -1
  91. package/dist/cjs/src/impl/zec/tzec.d.ts.map +1 -0
  92. package/dist/{src → cjs/src}/impl/zec/tzec.js +1 -1
  93. package/dist/cjs/src/impl/zec/zec.d.ts.map +1 -0
  94. package/dist/{src → cjs/src}/impl/zec/zec.js +1 -1
  95. package/dist/cjs/src/index.d.ts.map +1 -0
  96. package/dist/{src → cjs/src}/index.js +1 -1
  97. package/dist/cjs/src/keychains.d.ts.map +1 -0
  98. package/dist/cjs/src/keychains.js +104 -0
  99. package/dist/cjs/src/names.d.ts.map +1 -0
  100. package/dist/cjs/src/names.js +214 -0
  101. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  102. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.js +26 -0
  103. package/dist/cjs/src/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  104. package/dist/cjs/src/offlineVault/OfflineVaultSignable.js +55 -0
  105. package/dist/cjs/src/offlineVault/TransactionExplanation.d.ts.map +1 -0
  106. package/dist/cjs/src/offlineVault/TransactionExplanation.js +16 -0
  107. package/dist/cjs/src/offlineVault/descriptor/index.d.ts.map +1 -0
  108. package/dist/{src → cjs/src}/offlineVault/descriptor/index.js +1 -1
  109. package/dist/cjs/src/offlineVault/descriptor/transaction.d.ts.map +1 -0
  110. package/dist/cjs/src/offlineVault/descriptor/transaction.js +80 -0
  111. package/dist/cjs/src/offlineVault/index.d.ts.map +1 -0
  112. package/dist/{src → cjs/src}/offlineVault/index.js +1 -1
  113. package/dist/cjs/src/recovery/RecoveryProvider.d.ts.map +1 -0
  114. package/dist/cjs/src/recovery/RecoveryProvider.js +22 -0
  115. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts.map +1 -0
  116. package/dist/cjs/src/recovery/backupKeyRecovery.js +370 -0
  117. package/dist/cjs/src/recovery/baseApi.d.ts.map +1 -0
  118. package/dist/cjs/src/recovery/baseApi.js +73 -0
  119. package/dist/cjs/src/recovery/coingeckoApi.d.ts.map +1 -0
  120. package/dist/cjs/src/recovery/coingeckoApi.js +44 -0
  121. package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -0
  122. package/dist/cjs/src/recovery/crossChainRecovery.js +364 -0
  123. package/dist/cjs/src/recovery/index.d.ts.map +1 -0
  124. package/dist/{src → cjs/src}/recovery/index.js +1 -1
  125. package/dist/cjs/src/recovery/mempoolApi.d.ts.map +1 -0
  126. package/dist/cjs/src/recovery/mempoolApi.js +36 -0
  127. package/dist/{src → cjs/src}/replayProtection.d.ts +1 -0
  128. package/dist/cjs/src/replayProtection.d.ts.map +1 -0
  129. package/dist/cjs/src/replayProtection.js +58 -0
  130. package/dist/cjs/src/sign.d.ts.map +1 -0
  131. package/dist/cjs/src/sign.js +205 -0
  132. package/dist/cjs/src/transaction/bip322.d.ts.map +1 -0
  133. package/dist/cjs/src/transaction/bip322.js +125 -0
  134. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  135. package/dist/cjs/src/transaction/common/verifyPayGoAmount.js +3 -0
  136. package/dist/{src → cjs/src}/transaction/descriptor/explainPsbt.d.ts +2 -2
  137. package/dist/cjs/src/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  138. package/dist/cjs/src/transaction/descriptor/explainPsbt.js +80 -0
  139. package/dist/cjs/src/transaction/descriptor/index.d.ts.map +1 -0
  140. package/dist/{src → cjs/src}/transaction/descriptor/index.js +1 -1
  141. package/dist/cjs/src/transaction/descriptor/parse.d.ts.map +1 -0
  142. package/dist/cjs/src/transaction/descriptor/parse.js +116 -0
  143. package/dist/cjs/src/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  144. package/dist/cjs/src/transaction/descriptor/parseToAmountType.js +60 -0
  145. package/dist/cjs/src/transaction/descriptor/recipient.d.ts.map +1 -0
  146. package/dist/cjs/src/transaction/descriptor/recipient.js +3 -0
  147. package/dist/cjs/src/transaction/descriptor/signPsbt.d.ts.map +1 -0
  148. package/dist/cjs/src/transaction/descriptor/signPsbt.js +43 -0
  149. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  150. package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +108 -0
  151. package/dist/{src → cjs/src}/transaction/explainTransaction.d.ts +4 -3
  152. package/dist/cjs/src/transaction/explainTransaction.d.ts.map +1 -0
  153. package/dist/cjs/src/transaction/explainTransaction.js +88 -0
  154. package/dist/cjs/src/transaction/fetchInputs.d.ts.map +1 -0
  155. package/dist/cjs/src/transaction/fetchInputs.js +109 -0
  156. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +10 -0
  157. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  158. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +43 -0
  159. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts +63 -0
  160. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  161. package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +321 -0
  162. package/dist/{src → cjs/src}/transaction/fixedScript/index.d.ts +1 -0
  163. package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -0
  164. package/dist/{src → cjs/src}/transaction/fixedScript/index.js +4 -2
  165. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  166. package/dist/cjs/src/transaction/fixedScript/parseOutput.js +213 -0
  167. package/dist/{src → cjs/src}/transaction/fixedScript/parseTransaction.d.ts +1 -1
  168. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  169. package/dist/cjs/src/transaction/fixedScript/parseTransaction.js +203 -0
  170. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  171. package/dist/cjs/src/transaction/fixedScript/signTransaction.js +101 -0
  172. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  173. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +198 -0
  174. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  175. package/dist/{src → cjs/src}/transaction/getPayGoVerificationPubkey.js +1 -1
  176. package/dist/cjs/src/transaction/index.d.ts.map +1 -0
  177. package/dist/{src → cjs/src}/transaction/index.js +1 -1
  178. package/dist/cjs/src/transaction/outputDifference.d.ts.map +1 -0
  179. package/dist/cjs/src/transaction/outputDifference.js +47 -0
  180. package/dist/cjs/src/transaction/parseTransaction.d.ts.map +1 -0
  181. package/dist/{src → cjs/src}/transaction/parseTransaction.js +1 -1
  182. package/dist/cjs/src/transaction/recipient.d.ts.map +1 -0
  183. package/dist/cjs/src/transaction/recipient.js +88 -0
  184. package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -0
  185. package/dist/cjs/src/transaction/signTransaction.js +102 -0
  186. package/dist/cjs/src/transaction/verifyTransaction.d.ts.map +1 -0
  187. package/dist/{src → cjs/src}/transaction/verifyTransaction.js +1 -1
  188. package/dist/cjs/src/verifyKey.d.ts.map +1 -0
  189. package/dist/cjs/src/verifyKey.js +164 -0
  190. package/dist/cjs/src/wallet.d.ts.map +1 -0
  191. package/dist/cjs/src/wallet.js +8 -0
  192. package/dist/cjs/test/integration/impl/bch/bch.d.ts +2 -0
  193. package/dist/cjs/test/integration/impl/bch/bch.d.ts.map +1 -0
  194. package/dist/cjs/test/integration/impl/bch/bch.js +74 -0
  195. package/dist/cjs/test/unit/address.d.ts +2 -0
  196. package/dist/cjs/test/unit/address.d.ts.map +1 -0
  197. package/dist/cjs/test/unit/address.js +182 -0
  198. package/dist/cjs/test/unit/bip322.d.ts +2 -0
  199. package/dist/cjs/test/unit/bip322.d.ts.map +1 -0
  200. package/dist/cjs/test/unit/bip322.js +45 -0
  201. package/dist/cjs/test/unit/coins.d.ts +2 -0
  202. package/dist/cjs/test/unit/coins.d.ts.map +1 -0
  203. package/dist/cjs/test/unit/coins.js +97 -0
  204. package/dist/cjs/test/unit/customChangeWallet.d.ts +2 -0
  205. package/dist/cjs/test/unit/customChangeWallet.d.ts.map +1 -0
  206. package/dist/cjs/test/unit/customChangeWallet.js +154 -0
  207. package/dist/cjs/test/unit/customSigner.d.ts +3 -0
  208. package/dist/cjs/test/unit/customSigner.d.ts.map +1 -0
  209. package/dist/cjs/test/unit/customSigner.js +108 -0
  210. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts +2 -0
  211. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts.map +1 -0
  212. package/dist/cjs/test/unit/descriptor/NamedDescriptor.js +18 -0
  213. package/dist/cjs/test/unit/descriptor/builder.d.ts +2 -0
  214. package/dist/cjs/test/unit/descriptor/builder.d.ts.map +1 -0
  215. package/dist/cjs/test/unit/descriptor/builder.js +72 -0
  216. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts +2 -0
  217. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  218. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.js +20 -0
  219. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts +2 -0
  220. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts.map +1 -0
  221. package/dist/cjs/test/unit/descriptor/descriptorWallet.js +28 -0
  222. package/dist/cjs/test/unit/descriptorAddress.d.ts +3 -0
  223. package/dist/cjs/test/unit/descriptorAddress.d.ts.map +1 -0
  224. package/dist/cjs/test/unit/descriptorAddress.js +102 -0
  225. package/dist/cjs/test/unit/explainTransaction.d.ts +2 -0
  226. package/dist/cjs/test/unit/explainTransaction.d.ts.map +1 -0
  227. package/dist/cjs/test/unit/explainTransaction.js +74 -0
  228. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts +15 -0
  229. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts.map +1 -0
  230. package/dist/cjs/test/unit/fixtures/bip322/fixtures.js +51 -0
  231. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts +4 -0
  232. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts.map +1 -0
  233. package/dist/cjs/test/unit/fixtures/psbtHexProof.js +9 -0
  234. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts +2 -0
  235. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts.map +1 -0
  236. package/dist/cjs/test/unit/impl/bch/unit/bch.js +138 -0
  237. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts +2 -0
  238. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts.map +1 -0
  239. package/dist/cjs/test/unit/impl/bcha/unit/index.js +47 -0
  240. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts +2 -0
  241. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts.map +1 -0
  242. package/dist/cjs/test/unit/impl/bsv/unit/index.js +32 -0
  243. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts +2 -0
  244. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts.map +1 -0
  245. package/dist/cjs/test/unit/impl/btc/unit/btc.js +220 -0
  246. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts +4 -0
  247. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts.map +1 -0
  248. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.js +10 -0
  249. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts +2 -0
  250. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts.map +1 -0
  251. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.js +18 -0
  252. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts +2 -0
  253. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts.map +1 -0
  254. package/dist/cjs/test/unit/impl/btg/unit/index.js +29 -0
  255. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts +2 -0
  256. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts.map +1 -0
  257. package/dist/cjs/test/unit/impl/dash/unit/index.js +32 -0
  258. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts +2 -0
  259. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts.map +1 -0
  260. package/dist/cjs/test/unit/impl/doge/unit/index.js +32 -0
  261. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts +2 -0
  262. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts.map +1 -0
  263. package/dist/cjs/test/unit/impl/ltc/unit/index.js +39 -0
  264. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts +2 -0
  265. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts.map +1 -0
  266. package/dist/cjs/test/unit/impl/zec/unit/index.js +29 -0
  267. package/dist/cjs/test/unit/keySignatures.d.ts +2 -0
  268. package/dist/cjs/test/unit/keySignatures.d.ts.map +1 -0
  269. package/dist/cjs/test/unit/keySignatures.js +54 -0
  270. package/dist/cjs/test/unit/keychains.d.ts +2 -0
  271. package/dist/cjs/test/unit/keychains.d.ts.map +1 -0
  272. package/dist/cjs/test/unit/keychains.js +49 -0
  273. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts +2 -0
  274. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts.map +1 -0
  275. package/dist/cjs/test/unit/offlineVault/halfSigned.js +124 -0
  276. package/dist/cjs/test/unit/parseTransaction.d.ts +2 -0
  277. package/dist/cjs/test/unit/parseTransaction.d.ts.map +1 -0
  278. package/dist/cjs/test/unit/parseTransaction.js +125 -0
  279. package/dist/cjs/test/unit/prebuildAndSign.d.ts +6 -0
  280. package/dist/cjs/test/unit/prebuildAndSign.d.ts.map +1 -0
  281. package/dist/cjs/test/unit/prebuildAndSign.js +270 -0
  282. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts +2 -0
  283. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts.map +1 -0
  284. package/dist/cjs/test/unit/recovery/backupKeyRecovery.js +285 -0
  285. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts +2 -0
  286. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts.map +1 -0
  287. package/dist/cjs/test/unit/recovery/crossChainRecovery.js +283 -0
  288. package/dist/cjs/test/unit/recovery/mock.d.ts +30 -0
  289. package/dist/cjs/test/unit/recovery/mock.d.ts.map +1 -0
  290. package/dist/cjs/test/unit/recovery/mock.js +138 -0
  291. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts +2 -0
  292. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  293. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.js +30 -0
  294. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts +6 -0
  295. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts.map +1 -0
  296. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.js +17 -0
  297. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts +2 -0
  298. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts.map +1 -0
  299. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.js +76 -0
  300. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts +2 -0
  301. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts.map +1 -0
  302. package/dist/cjs/test/unit/transaction/descriptor/parse.js +135 -0
  303. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts +2 -0
  304. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts.map +1 -0
  305. package/dist/cjs/test/unit/transaction/descriptor/sign.js +32 -0
  306. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts +2 -0
  307. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts.map +1 -0
  308. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.js +48 -0
  309. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts +2 -0
  310. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts.map +1 -0
  311. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +108 -0
  312. package/dist/cjs/test/unit/transaction.d.ts +2 -0
  313. package/dist/cjs/test/unit/transaction.d.ts.map +1 -0
  314. package/dist/cjs/test/unit/transaction.js +501 -0
  315. package/dist/cjs/test/unit/txFormat.d.ts +30 -0
  316. package/dist/cjs/test/unit/txFormat.d.ts.map +1 -0
  317. package/dist/cjs/test/unit/txFormat.js +162 -0
  318. package/dist/cjs/test/unit/util/fixtures.d.ts +14 -0
  319. package/dist/cjs/test/unit/util/fixtures.d.ts.map +1 -0
  320. package/dist/cjs/test/unit/util/fixtures.js +102 -0
  321. package/dist/cjs/test/unit/util/index.d.ts +7 -0
  322. package/dist/cjs/test/unit/util/index.d.ts.map +1 -0
  323. package/dist/cjs/test/unit/util/index.js +23 -0
  324. package/dist/cjs/test/unit/util/keychains.d.ts +26 -0
  325. package/dist/cjs/test/unit/util/keychains.d.ts.map +1 -0
  326. package/dist/cjs/test/unit/util/keychains.js +72 -0
  327. package/dist/cjs/test/unit/util/nockBitGo.d.ts +3 -0
  328. package/dist/cjs/test/unit/util/nockBitGo.d.ts.map +1 -0
  329. package/dist/cjs/test/unit/util/nockBitGo.js +11 -0
  330. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts +8 -0
  331. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts.map +1 -0
  332. package/dist/cjs/test/unit/util/nockIndexerAPI.js +56 -0
  333. package/dist/cjs/test/unit/util/transaction.d.ts +24 -0
  334. package/dist/cjs/test/unit/util/transaction.d.ts.map +1 -0
  335. package/dist/cjs/test/unit/util/transaction.js +107 -0
  336. package/dist/cjs/test/unit/util/unspents.d.ts +13 -0
  337. package/dist/cjs/test/unit/util/unspents.d.ts.map +1 -0
  338. package/dist/cjs/test/unit/util/unspents.js +106 -0
  339. package/dist/cjs/test/unit/util/utxoCoins.d.ts +8 -0
  340. package/dist/cjs/test/unit/util/utxoCoins.d.ts.map +1 -0
  341. package/dist/cjs/test/unit/util/utxoCoins.js +95 -0
  342. package/dist/cjs/test/unit/util/wallet.d.ts +4 -0
  343. package/dist/cjs/test/unit/util/wallet.d.ts.map +1 -0
  344. package/dist/cjs/test/unit/util/wallet.js +9 -0
  345. package/dist/cjs/test/unit/verifyTransaction.d.ts +2 -0
  346. package/dist/cjs/test/unit/verifyTransaction.d.ts.map +1 -0
  347. package/dist/cjs/test/unit/verifyTransaction.js +327 -0
  348. package/dist/cjs/test/unit/wallet.d.ts +2 -0
  349. package/dist/cjs/test/unit/wallet.d.ts.map +1 -0
  350. package/dist/cjs/test/unit/wallet.js +248 -0
  351. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  352. package/dist/esm/abstractUtxoCoin.d.ts +464 -0
  353. package/dist/esm/abstractUtxoCoin.d.ts.map +1 -0
  354. package/dist/esm/abstractUtxoCoin.js +598 -0
  355. package/dist/esm/address/fixedScript.d.ts +51 -0
  356. package/dist/esm/address/fixedScript.js +109 -0
  357. package/dist/esm/address/index.d.ts +2 -0
  358. package/dist/esm/address/index.js +2 -0
  359. package/dist/esm/config.d.ts +9 -0
  360. package/dist/esm/config.js +11 -0
  361. package/dist/esm/descriptor/NamedDescriptor.d.ts +20 -0
  362. package/dist/esm/descriptor/NamedDescriptor.js +39 -0
  363. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  364. package/dist/esm/descriptor/assertDescriptorWalletAddress.js +27 -0
  365. package/dist/esm/descriptor/builder/builder.d.ts +13 -0
  366. package/dist/esm/descriptor/builder/builder.js +34 -0
  367. package/dist/esm/descriptor/builder/index.d.ts +3 -0
  368. package/dist/esm/descriptor/builder/index.js +3 -0
  369. package/dist/esm/descriptor/builder/parse.d.ts +5 -0
  370. package/dist/esm/descriptor/builder/parse.js +112 -0
  371. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  372. package/dist/esm/descriptor/createWallet/createDescriptorWallet.js +37 -0
  373. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts +12 -0
  374. package/dist/esm/descriptor/createWallet/createDescriptors.js +29 -0
  375. package/dist/esm/descriptor/createWallet/index.d.ts +3 -0
  376. package/dist/esm/descriptor/createWallet/index.js +3 -0
  377. package/dist/esm/descriptor/descriptorWallet.d.ts +19 -0
  378. package/dist/esm/descriptor/descriptorWallet.js +16 -0
  379. package/dist/esm/descriptor/index.d.ts +8 -0
  380. package/dist/esm/descriptor/index.js +7 -0
  381. package/dist/esm/descriptor/validatePolicy.d.ts +22 -0
  382. package/dist/esm/descriptor/validatePolicy.js +80 -0
  383. package/dist/esm/impl/bch/bch.d.ts +20 -0
  384. package/dist/esm/impl/bch/bch.js +33 -0
  385. package/dist/esm/impl/bch/index.d.ts +3 -0
  386. package/dist/esm/impl/bch/index.js +3 -0
  387. package/dist/esm/impl/bch/tbch.d.ts +10 -0
  388. package/dist/esm/impl/bch/tbch.js +11 -0
  389. package/dist/esm/impl/bcha/bcha.d.ts +9 -0
  390. package/dist/esm/impl/bcha/bcha.js +21 -0
  391. package/dist/esm/impl/bcha/index.d.ts +3 -0
  392. package/dist/esm/impl/bcha/index.js +3 -0
  393. package/dist/esm/impl/bcha/tbcha.d.ts +10 -0
  394. package/dist/esm/impl/bcha/tbcha.js +11 -0
  395. package/dist/esm/impl/bsv/bsv.d.ts +8 -0
  396. package/dist/esm/impl/bsv/bsv.js +11 -0
  397. package/dist/esm/impl/bsv/index.d.ts +3 -0
  398. package/dist/esm/impl/bsv/index.js +3 -0
  399. package/dist/esm/impl/bsv/tbsv.d.ts +10 -0
  400. package/dist/esm/impl/bsv/tbsv.js +11 -0
  401. package/dist/esm/impl/btc/btc.d.ts +13 -0
  402. package/dist/esm/impl/btc/btc.js +18 -0
  403. package/dist/esm/impl/btc/index.d.ts +7 -0
  404. package/dist/esm/impl/btc/index.js +7 -0
  405. package/dist/esm/impl/btc/inscriptionBuilder.d.ts +51 -0
  406. package/dist/esm/impl/btc/inscriptionBuilder.js +143 -0
  407. package/dist/esm/impl/btc/tbtc.d.ts +10 -0
  408. package/dist/esm/impl/btc/tbtc.js +11 -0
  409. package/dist/esm/impl/btc/tbtc4.d.ts +10 -0
  410. package/dist/esm/impl/btc/tbtc4.js +11 -0
  411. package/dist/esm/impl/btc/tbtcbgsig.d.ts +10 -0
  412. package/dist/esm/impl/btc/tbtcbgsig.js +11 -0
  413. package/dist/esm/impl/btc/tbtcsig.d.ts +10 -0
  414. package/dist/esm/impl/btc/tbtcsig.js +11 -0
  415. package/dist/esm/impl/btg/btg.d.ts +7 -0
  416. package/dist/esm/impl/btg/btg.js +11 -0
  417. package/dist/esm/impl/btg/index.d.ts +2 -0
  418. package/dist/esm/impl/btg/index.js +2 -0
  419. package/dist/esm/impl/dash/dash.d.ts +7 -0
  420. package/dist/esm/impl/dash/dash.js +11 -0
  421. package/dist/esm/impl/dash/index.d.ts +3 -0
  422. package/dist/esm/impl/dash/index.js +3 -0
  423. package/dist/esm/impl/dash/tdash.d.ts +10 -0
  424. package/dist/esm/impl/dash/tdash.js +11 -0
  425. package/dist/esm/impl/doge/doge.d.ts +31 -0
  426. package/dist/esm/impl/doge/doge.d.ts.map +1 -0
  427. package/dist/esm/impl/doge/doge.js +75 -0
  428. package/dist/esm/impl/doge/index.d.ts +3 -0
  429. package/dist/esm/impl/doge/index.js +3 -0
  430. package/dist/esm/impl/doge/tdoge.d.ts +10 -0
  431. package/dist/esm/impl/doge/tdoge.js +11 -0
  432. package/dist/esm/impl/index.d.ts +10 -0
  433. package/dist/esm/impl/index.js +10 -0
  434. package/dist/esm/impl/ltc/index.d.ts +3 -0
  435. package/dist/esm/impl/ltc/index.js +3 -0
  436. package/dist/esm/impl/ltc/ltc.d.ts +7 -0
  437. package/dist/esm/impl/ltc/ltc.js +15 -0
  438. package/dist/esm/impl/ltc/tltc.d.ts +7 -0
  439. package/dist/esm/impl/ltc/tltc.js +14 -0
  440. package/dist/esm/impl/zec/index.d.ts +3 -0
  441. package/dist/esm/impl/zec/index.js +3 -0
  442. package/dist/esm/impl/zec/tzec.d.ts +7 -0
  443. package/dist/esm/impl/zec/tzec.js +11 -0
  444. package/dist/esm/impl/zec/zec.d.ts +10 -0
  445. package/dist/esm/impl/zec/zec.js +11 -0
  446. package/dist/esm/index.d.ts +21 -0
  447. package/dist/esm/index.js +21 -0
  448. package/dist/esm/keychains.d.ts +48 -0
  449. package/dist/esm/keychains.js +61 -0
  450. package/dist/esm/names.d.ts +26 -0
  451. package/dist/esm/names.js +171 -0
  452. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  453. package/dist/esm/offlineVault/OfflineVaultHalfSigned.js +23 -0
  454. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts +46 -0
  455. package/dist/esm/offlineVault/OfflineVaultSignable.js +18 -0
  456. package/dist/esm/offlineVault/TransactionExplanation.d.ts +15 -0
  457. package/dist/esm/offlineVault/TransactionExplanation.js +13 -0
  458. package/dist/esm/offlineVault/descriptor/index.d.ts +2 -0
  459. package/dist/esm/offlineVault/descriptor/index.js +2 -0
  460. package/dist/esm/offlineVault/descriptor/transaction.d.ts +38 -0
  461. package/dist/esm/offlineVault/descriptor/transaction.js +41 -0
  462. package/dist/esm/offlineVault/index.d.ts +6 -0
  463. package/dist/esm/offlineVault/index.js +4 -0
  464. package/dist/esm/recovery/RecoveryProvider.d.ts +22 -0
  465. package/dist/{src → esm}/recovery/RecoveryProvider.js +6 -9
  466. package/dist/esm/recovery/backupKeyRecovery.d.ts +88 -0
  467. package/dist/esm/recovery/backupKeyRecovery.js +329 -0
  468. package/dist/esm/recovery/baseApi.d.ts +24 -0
  469. package/dist/esm/recovery/baseApi.js +64 -0
  470. package/dist/esm/recovery/coingeckoApi.d.ts +6 -0
  471. package/dist/esm/recovery/coingeckoApi.js +40 -0
  472. package/dist/esm/recovery/crossChainRecovery.d.ts +86 -0
  473. package/dist/esm/recovery/crossChainRecovery.js +325 -0
  474. package/dist/esm/recovery/index.d.ts +7 -0
  475. package/dist/esm/recovery/index.js +7 -0
  476. package/dist/esm/recovery/mempoolApi.d.ts +7 -0
  477. package/dist/esm/recovery/mempoolApi.js +29 -0
  478. package/dist/esm/replayProtection.d.ts +5 -0
  479. package/dist/esm/replayProtection.d.ts.map +1 -0
  480. package/dist/esm/replayProtection.js +20 -0
  481. package/dist/esm/sign.d.ts +54 -0
  482. package/dist/esm/sign.js +162 -0
  483. package/dist/esm/transaction/bip322.d.ts +27 -0
  484. package/dist/esm/transaction/bip322.js +86 -0
  485. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts +1 -0
  486. package/dist/{src → esm}/transaction/common/verifyPayGoAmount.js +0 -2
  487. package/dist/esm/transaction/descriptor/explainPsbt.d.ts +5 -0
  488. package/dist/esm/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  489. package/dist/esm/transaction/descriptor/explainPsbt.js +44 -0
  490. package/dist/esm/transaction/descriptor/index.d.ts +7 -0
  491. package/dist/esm/transaction/descriptor/index.js +6 -0
  492. package/dist/esm/transaction/descriptor/parse.d.ts +15 -0
  493. package/dist/esm/transaction/descriptor/parse.js +79 -0
  494. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts +13 -0
  495. package/dist/esm/transaction/descriptor/parseToAmountType.js +55 -0
  496. package/dist/esm/transaction/descriptor/recipient.d.ts +5 -0
  497. package/dist/{src → esm}/transaction/descriptor/recipient.js +1 -2
  498. package/dist/esm/transaction/descriptor/signPsbt.d.ts +25 -0
  499. package/dist/esm/transaction/descriptor/signPsbt.js +38 -0
  500. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts +35 -0
  501. package/dist/esm/transaction/descriptor/verifyTransaction.js +65 -0
  502. package/dist/esm/transaction/explainTransaction.d.ts +18 -0
  503. package/dist/esm/transaction/explainTransaction.d.ts.map +1 -0
  504. package/dist/esm/transaction/explainTransaction.js +52 -0
  505. package/dist/esm/transaction/fetchInputs.d.ts +26 -0
  506. package/dist/esm/transaction/fetchInputs.js +72 -0
  507. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +10 -0
  508. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  509. package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +40 -0
  510. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts +63 -0
  511. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  512. package/dist/esm/transaction/fixedScript/explainTransaction.js +284 -0
  513. package/dist/esm/transaction/fixedScript/index.d.ts +7 -0
  514. package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -0
  515. package/dist/esm/transaction/fixedScript/index.js +6 -0
  516. package/dist/esm/transaction/fixedScript/parseOutput.d.ts +26 -0
  517. package/dist/{src → esm}/transaction/fixedScript/parseOutput.js +22 -28
  518. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts +7 -0
  519. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  520. package/dist/esm/transaction/fixedScript/parseTransaction.js +164 -0
  521. package/dist/esm/transaction/fixedScript/signTransaction.d.ts +18 -0
  522. package/dist/esm/transaction/fixedScript/signTransaction.js +95 -0
  523. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  524. package/dist/esm/transaction/fixedScript/verifyTransaction.js +159 -0
  525. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  526. package/dist/esm/transaction/getPayGoVerificationPubkey.js +17 -0
  527. package/dist/esm/transaction/index.d.ts +7 -0
  528. package/dist/esm/transaction/index.js +7 -0
  529. package/dist/esm/transaction/outputDifference.d.ts +40 -0
  530. package/dist/esm/transaction/outputDifference.js +42 -0
  531. package/dist/esm/transaction/parseTransaction.d.ts +3 -0
  532. package/dist/esm/transaction/parseTransaction.js +12 -0
  533. package/dist/esm/transaction/recipient.d.ts +29 -0
  534. package/dist/esm/transaction/recipient.js +48 -0
  535. package/dist/esm/transaction/signTransaction.d.ts +6 -0
  536. package/dist/esm/transaction/signTransaction.js +63 -0
  537. package/dist/esm/transaction/verifyTransaction.d.ts +4 -0
  538. package/dist/esm/transaction/verifyTransaction.js +14 -0
  539. package/dist/esm/verifyKey.d.ts +28 -0
  540. package/dist/esm/verifyKey.js +123 -0
  541. package/dist/esm/wallet.d.ts +15 -0
  542. package/dist/esm/wallet.js +5 -0
  543. package/package.json +32 -15
  544. package/dist/src/abstractUtxoCoin.d.ts.map +0 -1
  545. package/dist/src/abstractUtxoCoin.js +0 -634
  546. package/dist/src/address/fixedScript.js +0 -150
  547. package/dist/src/config.js +0 -14
  548. package/dist/src/descriptor/NamedDescriptor.js +0 -79
  549. package/dist/src/descriptor/assertDescriptorWalletAddress.js +0 -66
  550. package/dist/src/descriptor/builder/builder.js +0 -37
  551. package/dist/src/descriptor/builder/parse.js +0 -116
  552. package/dist/src/descriptor/createWallet/createDescriptorWallet.js +0 -41
  553. package/dist/src/descriptor/createWallet/createDescriptors.js +0 -33
  554. package/dist/src/descriptor/descriptorWallet.js +0 -54
  555. package/dist/src/descriptor/validatePolicy.js +0 -92
  556. package/dist/src/impl/bch/bch.js +0 -70
  557. package/dist/src/impl/btc/inscriptionBuilder.js +0 -183
  558. package/dist/src/impl/btg/btg.js +0 -48
  559. package/dist/src/impl/doge/doge.d.ts.map +0 -1
  560. package/dist/src/impl/doge/doge.js +0 -79
  561. package/dist/src/keychains.js +0 -104
  562. package/dist/src/names.js +0 -214
  563. package/dist/src/offlineVault/OfflineVaultHalfSigned.js +0 -26
  564. package/dist/src/offlineVault/OfflineVaultSignable.js +0 -55
  565. package/dist/src/offlineVault/TransactionExplanation.js +0 -16
  566. package/dist/src/offlineVault/descriptor/transaction.js +0 -80
  567. package/dist/src/recovery/backupKeyRecovery.js +0 -370
  568. package/dist/src/recovery/baseApi.js +0 -73
  569. package/dist/src/recovery/coingeckoApi.js +0 -44
  570. package/dist/src/recovery/crossChainRecovery.js +0 -364
  571. package/dist/src/recovery/mempoolApi.js +0 -36
  572. package/dist/src/replayProtection.d.ts.map +0 -1
  573. package/dist/src/replayProtection.js +0 -53
  574. package/dist/src/sign.js +0 -205
  575. package/dist/src/transaction/bip322.js +0 -125
  576. package/dist/src/transaction/descriptor/explainPsbt.d.ts.map +0 -1
  577. package/dist/src/transaction/descriptor/explainPsbt.js +0 -80
  578. package/dist/src/transaction/descriptor/parse.js +0 -116
  579. package/dist/src/transaction/descriptor/parseToAmountType.js +0 -60
  580. package/dist/src/transaction/descriptor/signPsbt.js +0 -43
  581. package/dist/src/transaction/descriptor/verifyTransaction.js +0 -108
  582. package/dist/src/transaction/explainTransaction.d.ts.map +0 -1
  583. package/dist/src/transaction/explainTransaction.js +0 -67
  584. package/dist/src/transaction/fetchInputs.js +0 -109
  585. package/dist/src/transaction/fixedScript/explainTransaction.d.ts +0 -29
  586. package/dist/src/transaction/fixedScript/explainTransaction.d.ts.map +0 -1
  587. package/dist/src/transaction/fixedScript/explainTransaction.js +0 -321
  588. package/dist/src/transaction/fixedScript/index.d.ts.map +0 -1
  589. package/dist/src/transaction/fixedScript/parseTransaction.d.ts.map +0 -1
  590. package/dist/src/transaction/fixedScript/parseTransaction.js +0 -203
  591. package/dist/src/transaction/fixedScript/signTransaction.js +0 -101
  592. package/dist/src/transaction/fixedScript/verifyTransaction.js +0 -198
  593. package/dist/src/transaction/outputDifference.js +0 -47
  594. package/dist/src/transaction/recipient.js +0 -88
  595. package/dist/src/transaction/signTransaction.js +0 -102
  596. package/dist/src/verifyKey.js +0 -164
  597. package/dist/src/wallet.js +0 -8
  598. /package/dist/{src → cjs/src}/address/fixedScript.d.ts +0 -0
  599. /package/dist/{src → cjs/src}/address/index.d.ts +0 -0
  600. /package/dist/{src → cjs/src}/config.d.ts +0 -0
  601. /package/dist/{src → cjs/src}/descriptor/NamedDescriptor.d.ts +0 -0
  602. /package/dist/{src → cjs/src}/descriptor/assertDescriptorWalletAddress.d.ts +0 -0
  603. /package/dist/{src → cjs/src}/descriptor/builder/builder.d.ts +0 -0
  604. /package/dist/{src → cjs/src}/descriptor/builder/index.d.ts +0 -0
  605. /package/dist/{src → cjs/src}/descriptor/builder/parse.d.ts +0 -0
  606. /package/dist/{src → cjs/src}/descriptor/createWallet/createDescriptorWallet.d.ts +0 -0
  607. /package/dist/{src → cjs/src}/descriptor/createWallet/createDescriptors.d.ts +0 -0
  608. /package/dist/{src → cjs/src}/descriptor/createWallet/index.d.ts +0 -0
  609. /package/dist/{src → cjs/src}/descriptor/descriptorWallet.d.ts +0 -0
  610. /package/dist/{src → cjs/src}/descriptor/index.d.ts +0 -0
  611. /package/dist/{src → cjs/src}/descriptor/validatePolicy.d.ts +0 -0
  612. /package/dist/{src → cjs/src}/impl/bch/bch.d.ts +0 -0
  613. /package/dist/{src → cjs/src}/impl/bch/index.d.ts +0 -0
  614. /package/dist/{src → cjs/src}/impl/bch/tbch.d.ts +0 -0
  615. /package/dist/{src → cjs/src}/impl/bcha/bcha.d.ts +0 -0
  616. /package/dist/{src → cjs/src}/impl/bcha/index.d.ts +0 -0
  617. /package/dist/{src → cjs/src}/impl/bcha/tbcha.d.ts +0 -0
  618. /package/dist/{src → cjs/src}/impl/bsv/bsv.d.ts +0 -0
  619. /package/dist/{src → cjs/src}/impl/bsv/index.d.ts +0 -0
  620. /package/dist/{src → cjs/src}/impl/bsv/tbsv.d.ts +0 -0
  621. /package/dist/{src → cjs/src}/impl/btc/btc.d.ts +0 -0
  622. /package/dist/{src → cjs/src}/impl/btc/index.d.ts +0 -0
  623. /package/dist/{src → cjs/src}/impl/btc/inscriptionBuilder.d.ts +0 -0
  624. /package/dist/{src → cjs/src}/impl/btc/tbtc.d.ts +0 -0
  625. /package/dist/{src → cjs/src}/impl/btc/tbtc4.d.ts +0 -0
  626. /package/dist/{src → cjs/src}/impl/btc/tbtcbgsig.d.ts +0 -0
  627. /package/dist/{src → cjs/src}/impl/btc/tbtcsig.d.ts +0 -0
  628. /package/dist/{src → cjs/src}/impl/btg/btg.d.ts +0 -0
  629. /package/dist/{src → cjs/src}/impl/btg/index.d.ts +0 -0
  630. /package/dist/{src → cjs/src}/impl/dash/dash.d.ts +0 -0
  631. /package/dist/{src → cjs/src}/impl/dash/index.d.ts +0 -0
  632. /package/dist/{src → cjs/src}/impl/dash/tdash.d.ts +0 -0
  633. /package/dist/{src → cjs/src}/impl/doge/index.d.ts +0 -0
  634. /package/dist/{src → cjs/src}/impl/doge/tdoge.d.ts +0 -0
  635. /package/dist/{src → cjs/src}/impl/index.d.ts +0 -0
  636. /package/dist/{src → cjs/src}/impl/ltc/index.d.ts +0 -0
  637. /package/dist/{src → cjs/src}/impl/ltc/ltc.d.ts +0 -0
  638. /package/dist/{src → cjs/src}/impl/ltc/tltc.d.ts +0 -0
  639. /package/dist/{src → cjs/src}/impl/zec/index.d.ts +0 -0
  640. /package/dist/{src → cjs/src}/impl/zec/tzec.d.ts +0 -0
  641. /package/dist/{src → cjs/src}/impl/zec/zec.d.ts +0 -0
  642. /package/dist/{src → cjs/src}/index.d.ts +0 -0
  643. /package/dist/{src → cjs/src}/keychains.d.ts +0 -0
  644. /package/dist/{src → cjs/src}/names.d.ts +0 -0
  645. /package/dist/{src → cjs/src}/offlineVault/OfflineVaultHalfSigned.d.ts +0 -0
  646. /package/dist/{src → cjs/src}/offlineVault/OfflineVaultSignable.d.ts +0 -0
  647. /package/dist/{src → cjs/src}/offlineVault/TransactionExplanation.d.ts +0 -0
  648. /package/dist/{src → cjs/src}/offlineVault/descriptor/index.d.ts +0 -0
  649. /package/dist/{src → cjs/src}/offlineVault/descriptor/transaction.d.ts +0 -0
  650. /package/dist/{src → cjs/src}/offlineVault/index.d.ts +0 -0
  651. /package/dist/{src → cjs/src}/recovery/RecoveryProvider.d.ts +0 -0
  652. /package/dist/{src → cjs/src}/recovery/backupKeyRecovery.d.ts +0 -0
  653. /package/dist/{src → cjs/src}/recovery/baseApi.d.ts +0 -0
  654. /package/dist/{src → cjs/src}/recovery/coingeckoApi.d.ts +0 -0
  655. /package/dist/{src → cjs/src}/recovery/crossChainRecovery.d.ts +0 -0
  656. /package/dist/{src → cjs/src}/recovery/index.d.ts +0 -0
  657. /package/dist/{src → cjs/src}/recovery/mempoolApi.d.ts +0 -0
  658. /package/dist/{src → cjs/src}/sign.d.ts +0 -0
  659. /package/dist/{src → cjs/src}/transaction/bip322.d.ts +0 -0
  660. /package/dist/{src → cjs/src}/transaction/common/verifyPayGoAmount.d.ts +0 -0
  661. /package/dist/{src → cjs/src}/transaction/descriptor/index.d.ts +0 -0
  662. /package/dist/{src → cjs/src}/transaction/descriptor/parse.d.ts +0 -0
  663. /package/dist/{src → cjs/src}/transaction/descriptor/parseToAmountType.d.ts +0 -0
  664. /package/dist/{src → cjs/src}/transaction/descriptor/recipient.d.ts +0 -0
  665. /package/dist/{src → cjs/src}/transaction/descriptor/signPsbt.d.ts +0 -0
  666. /package/dist/{src → cjs/src}/transaction/descriptor/verifyTransaction.d.ts +0 -0
  667. /package/dist/{src → cjs/src}/transaction/fetchInputs.d.ts +0 -0
  668. /package/dist/{src → cjs/src}/transaction/fixedScript/parseOutput.d.ts +0 -0
  669. /package/dist/{src → cjs/src}/transaction/fixedScript/signTransaction.d.ts +0 -0
  670. /package/dist/{src → cjs/src}/transaction/fixedScript/verifyTransaction.d.ts +0 -0
  671. /package/dist/{src → cjs/src}/transaction/getPayGoVerificationPubkey.d.ts +0 -0
  672. /package/dist/{src → cjs/src}/transaction/index.d.ts +0 -0
  673. /package/dist/{src → cjs/src}/transaction/outputDifference.d.ts +0 -0
  674. /package/dist/{src → cjs/src}/transaction/parseTransaction.d.ts +0 -0
  675. /package/dist/{src → cjs/src}/transaction/recipient.d.ts +0 -0
  676. /package/dist/{src → cjs/src}/transaction/signTransaction.d.ts +0 -0
  677. /package/dist/{src → cjs/src}/transaction/verifyTransaction.d.ts +0 -0
  678. /package/dist/{src → cjs/src}/verifyKey.d.ts +0 -0
  679. /package/dist/{src → cjs/src}/wallet.d.ts +0 -0
  680. /package/dist/{src → esm}/address/fixedScript.d.ts.map +0 -0
  681. /package/dist/{src → esm}/address/index.d.ts.map +0 -0
  682. /package/dist/{src → esm}/config.d.ts.map +0 -0
  683. /package/dist/{src → esm}/descriptor/NamedDescriptor.d.ts.map +0 -0
  684. /package/dist/{src → esm}/descriptor/assertDescriptorWalletAddress.d.ts.map +0 -0
  685. /package/dist/{src → esm}/descriptor/builder/builder.d.ts.map +0 -0
  686. /package/dist/{src → esm}/descriptor/builder/index.d.ts.map +0 -0
  687. /package/dist/{src → esm}/descriptor/builder/parse.d.ts.map +0 -0
  688. /package/dist/{src → esm}/descriptor/createWallet/createDescriptorWallet.d.ts.map +0 -0
  689. /package/dist/{src → esm}/descriptor/createWallet/createDescriptors.d.ts.map +0 -0
  690. /package/dist/{src → esm}/descriptor/createWallet/index.d.ts.map +0 -0
  691. /package/dist/{src → esm}/descriptor/descriptorWallet.d.ts.map +0 -0
  692. /package/dist/{src → esm}/descriptor/index.d.ts.map +0 -0
  693. /package/dist/{src → esm}/descriptor/validatePolicy.d.ts.map +0 -0
  694. /package/dist/{src → esm}/impl/bch/bch.d.ts.map +0 -0
  695. /package/dist/{src → esm}/impl/bch/index.d.ts.map +0 -0
  696. /package/dist/{src → esm}/impl/bch/tbch.d.ts.map +0 -0
  697. /package/dist/{src → esm}/impl/bcha/bcha.d.ts.map +0 -0
  698. /package/dist/{src → esm}/impl/bcha/index.d.ts.map +0 -0
  699. /package/dist/{src → esm}/impl/bcha/tbcha.d.ts.map +0 -0
  700. /package/dist/{src → esm}/impl/bsv/bsv.d.ts.map +0 -0
  701. /package/dist/{src → esm}/impl/bsv/index.d.ts.map +0 -0
  702. /package/dist/{src → esm}/impl/bsv/tbsv.d.ts.map +0 -0
  703. /package/dist/{src → esm}/impl/btc/btc.d.ts.map +0 -0
  704. /package/dist/{src → esm}/impl/btc/index.d.ts.map +0 -0
  705. /package/dist/{src → esm}/impl/btc/inscriptionBuilder.d.ts.map +0 -0
  706. /package/dist/{src → esm}/impl/btc/tbtc.d.ts.map +0 -0
  707. /package/dist/{src → esm}/impl/btc/tbtc4.d.ts.map +0 -0
  708. /package/dist/{src → esm}/impl/btc/tbtcbgsig.d.ts.map +0 -0
  709. /package/dist/{src → esm}/impl/btc/tbtcsig.d.ts.map +0 -0
  710. /package/dist/{src → esm}/impl/btg/btg.d.ts.map +0 -0
  711. /package/dist/{src → esm}/impl/btg/index.d.ts.map +0 -0
  712. /package/dist/{src → esm}/impl/dash/dash.d.ts.map +0 -0
  713. /package/dist/{src → esm}/impl/dash/index.d.ts.map +0 -0
  714. /package/dist/{src → esm}/impl/dash/tdash.d.ts.map +0 -0
  715. /package/dist/{src → esm}/impl/doge/index.d.ts.map +0 -0
  716. /package/dist/{src → esm}/impl/doge/tdoge.d.ts.map +0 -0
  717. /package/dist/{src → esm}/impl/index.d.ts.map +0 -0
  718. /package/dist/{src → esm}/impl/ltc/index.d.ts.map +0 -0
  719. /package/dist/{src → esm}/impl/ltc/ltc.d.ts.map +0 -0
  720. /package/dist/{src → esm}/impl/ltc/tltc.d.ts.map +0 -0
  721. /package/dist/{src → esm}/impl/zec/index.d.ts.map +0 -0
  722. /package/dist/{src → esm}/impl/zec/tzec.d.ts.map +0 -0
  723. /package/dist/{src → esm}/impl/zec/zec.d.ts.map +0 -0
  724. /package/dist/{src → esm}/index.d.ts.map +0 -0
  725. /package/dist/{src → esm}/keychains.d.ts.map +0 -0
  726. /package/dist/{src → esm}/names.d.ts.map +0 -0
  727. /package/dist/{src → esm}/offlineVault/OfflineVaultHalfSigned.d.ts.map +0 -0
  728. /package/dist/{src → esm}/offlineVault/OfflineVaultSignable.d.ts.map +0 -0
  729. /package/dist/{src → esm}/offlineVault/TransactionExplanation.d.ts.map +0 -0
  730. /package/dist/{src → esm}/offlineVault/descriptor/index.d.ts.map +0 -0
  731. /package/dist/{src → esm}/offlineVault/descriptor/transaction.d.ts.map +0 -0
  732. /package/dist/{src → esm}/offlineVault/index.d.ts.map +0 -0
  733. /package/dist/{src → esm}/recovery/RecoveryProvider.d.ts.map +0 -0
  734. /package/dist/{src → esm}/recovery/backupKeyRecovery.d.ts.map +0 -0
  735. /package/dist/{src → esm}/recovery/baseApi.d.ts.map +0 -0
  736. /package/dist/{src → esm}/recovery/coingeckoApi.d.ts.map +0 -0
  737. /package/dist/{src → esm}/recovery/crossChainRecovery.d.ts.map +0 -0
  738. /package/dist/{src → esm}/recovery/index.d.ts.map +0 -0
  739. /package/dist/{src → esm}/recovery/mempoolApi.d.ts.map +0 -0
  740. /package/dist/{src → esm}/sign.d.ts.map +0 -0
  741. /package/dist/{src → esm}/transaction/bip322.d.ts.map +0 -0
  742. /package/dist/{src → esm}/transaction/common/verifyPayGoAmount.d.ts.map +0 -0
  743. /package/dist/{src → esm}/transaction/descriptor/index.d.ts.map +0 -0
  744. /package/dist/{src → esm}/transaction/descriptor/parse.d.ts.map +0 -0
  745. /package/dist/{src → esm}/transaction/descriptor/parseToAmountType.d.ts.map +0 -0
  746. /package/dist/{src → esm}/transaction/descriptor/recipient.d.ts.map +0 -0
  747. /package/dist/{src → esm}/transaction/descriptor/signPsbt.d.ts.map +0 -0
  748. /package/dist/{src → esm}/transaction/descriptor/verifyTransaction.d.ts.map +0 -0
  749. /package/dist/{src → esm}/transaction/fetchInputs.d.ts.map +0 -0
  750. /package/dist/{src → esm}/transaction/fixedScript/parseOutput.d.ts.map +0 -0
  751. /package/dist/{src → esm}/transaction/fixedScript/signTransaction.d.ts.map +0 -0
  752. /package/dist/{src → esm}/transaction/fixedScript/verifyTransaction.d.ts.map +0 -0
  753. /package/dist/{src → esm}/transaction/getPayGoVerificationPubkey.d.ts.map +0 -0
  754. /package/dist/{src → esm}/transaction/index.d.ts.map +0 -0
  755. /package/dist/{src → esm}/transaction/outputDifference.d.ts.map +0 -0
  756. /package/dist/{src → esm}/transaction/parseTransaction.d.ts.map +0 -0
  757. /package/dist/{src → esm}/transaction/recipient.d.ts.map +0 -0
  758. /package/dist/{src → esm}/transaction/signTransaction.d.ts.map +0 -0
  759. /package/dist/{src → esm}/transaction/verifyTransaction.d.ts.map +0 -0
  760. /package/dist/{src → esm}/verifyKey.d.ts.map +0 -0
  761. /package/dist/{src → esm}/wallet.d.ts.map +0 -0
@@ -1,101 +0,0 @@
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 lodash_1 = __importDefault(require("lodash"));
9
- const secp256k1_1 = require("@bitgo-beta/secp256k1");
10
- const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
11
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
12
- const sign_1 = require("../../sign");
13
- /**
14
- * Key Value: Unsigned tx id => PSBT
15
- * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
16
- * Reason: MuSig2 signer secure nonce is cached in the UtxoPsbt object. It will be required during the signing step.
17
- * For more info, check SignTransactionOptions.signingStep
18
- *
19
- * TODO BTC-276: This cache may need to be done with LRU like memory safe caching if memory issues comes up.
20
- */
21
- const PSBT_CACHE = new Map();
22
- async function signTransaction(coin, tx, signerKeychain, params) {
23
- const isTxWithKeyPathSpendInput = tx instanceof utxo_lib_1.bitgo.UtxoPsbt && utxo_lib_1.bitgo.isTransactionWithKeyPathSpendInput(tx);
24
- let isLastSignature = false;
25
- if (lodash_1.default.isBoolean(params.isLastSignature)) {
26
- // We can only be the first signature on a transaction with taproot key path spend inputs because
27
- // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
28
- // deserialized from a hex.
29
- if (params.isLastSignature && isTxWithKeyPathSpendInput) {
30
- throw new Error('Cannot be last signature on a transaction with key path spend inputs');
31
- }
32
- // if build is called instead of buildIncomplete, no signature placeholders are left in the sig script
33
- isLastSignature = params.isLastSignature;
34
- }
35
- if (tx instanceof utxo_lib_1.bitgo.UtxoPsbt && isTxWithKeyPathSpendInput) {
36
- switch (params.signingStep) {
37
- case 'signerNonce':
38
- (0, assert_1.default)(signerKeychain);
39
- tx.setAllInputsMusig2NonceHD(signerKeychain);
40
- PSBT_CACHE.set(tx.getUnsignedTx().getId(), tx);
41
- return { txHex: tx.toHex() };
42
- case 'cosignerNonce':
43
- (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
44
- return { txHex: (await coin.signPsbt(tx.toHex(), params.walletId)).psbt };
45
- case 'signerSignature':
46
- const txId = tx.getUnsignedTx().getId();
47
- const psbt = PSBT_CACHE.get(txId);
48
- (0, assert_1.default)(psbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE.size}).
49
- This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
50
- PSBT_CACHE.delete(txId);
51
- tx = psbt.combine(tx);
52
- break;
53
- default:
54
- // this instance is not an external signer
55
- (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
56
- (0, assert_1.default)(signerKeychain);
57
- tx.setAllInputsMusig2NonceHD(signerKeychain);
58
- const response = await coin.signPsbt(tx.toHex(), params.walletId);
59
- tx.combine(utxo_lib_1.bitgo.createPsbtFromHex(response.psbt, coin.network));
60
- break;
61
- }
62
- }
63
- else {
64
- switch (params.signingStep) {
65
- case 'signerNonce':
66
- case 'cosignerNonce':
67
- /**
68
- * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
69
- * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
70
- */
71
- return { txHex: tx.toHex() };
72
- }
73
- }
74
- let signedTransaction;
75
- if (tx instanceof utxo_lib_1.bitgo.UtxoPsbt) {
76
- (0, assert_1.default)(signerKeychain);
77
- signedTransaction = (0, sign_1.signAndVerifyPsbt)(tx, signerKeychain, {
78
- isLastSignature,
79
- });
80
- }
81
- else {
82
- if (tx.ins.length !== params.txInfo?.unspents?.length) {
83
- throw new Error('length of unspents array should equal to the number of transaction inputs');
84
- }
85
- if (!params.pubs || !(0, sdk_core_1.isTriple)(params.pubs)) {
86
- throw new Error(`must provide xpub array`);
87
- }
88
- const keychains = params.pubs.map((pub) => secp256k1_1.bip32.fromBase58(pub));
89
- const cosignerPub = params.cosignerPub ?? params.pubs[2];
90
- const cosignerKeychain = secp256k1_1.bip32.fromBase58(cosignerPub);
91
- (0, assert_1.default)(signerKeychain);
92
- const walletSigner = new utxo_lib_1.bitgo.WalletUnspentSigner(keychains, signerKeychain, cosignerKeychain);
93
- signedTransaction = (0, sign_1.signAndVerifyWalletTransaction)(tx, params.txInfo.unspents, walletSigner, {
94
- isLastSignature,
95
- });
96
- }
97
- return {
98
- txHex: signedTransaction.toBuffer().toString('hex'),
99
- };
100
- }
101
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQXFCQSwwQ0FxR0M7QUExSEQsb0RBQTRCO0FBRTVCLG9EQUF1QjtBQUN2QixxREFBOEQ7QUFDOUQsbURBQTZDO0FBRTdDLG1EQUF3RDtBQUV4RCxxQ0FBK0U7QUFHL0U7Ozs7Ozs7R0FPRztBQUNILE1BQU0sVUFBVSxHQUFHLElBQUksR0FBRyxFQUFrQyxDQUFDO0FBRXRELEtBQUssVUFBVSxlQUFlLENBQ25DLElBQXNCLEVBQ3RCLEVBQStCLEVBQy9CLGNBQTBDLEVBQzFDLE1BU0M7SUFFRCxNQUFNLHlCQUF5QixHQUFHLEVBQUUsWUFBWSxnQkFBSyxDQUFDLFFBQVEsSUFBSSxnQkFBSyxDQUFDLGtDQUFrQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBRS9HLElBQUksZUFBZSxHQUFHLEtBQUssQ0FBQztJQUM1QixJQUFJLGdCQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDO1FBQ3hDLGlHQUFpRztRQUNqRyxtR0FBbUc7UUFDbkcsMkJBQTJCO1FBQzNCLElBQUksTUFBTSxDQUFDLGVBQWUsSUFBSSx5QkFBeUIsRUFBRSxDQUFDO1lBQ3hELE1BQU0sSUFBSSxLQUFLLENBQUMsc0VBQXNFLENBQUMsQ0FBQztRQUMxRixDQUFDO1FBRUQsc0dBQXNHO1FBQ3RHLGVBQWUsR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDO0lBQzNDLENBQUM7SUFFRCxJQUFJLEVBQUUsWUFBWSxnQkFBSyxDQUFDLFFBQVEsSUFBSSx5QkFBeUIsRUFBRSxDQUFDO1FBQzlELFFBQVEsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzNCLEtBQUssYUFBYTtnQkFDaEIsSUFBQSxnQkFBTSxFQUFDLGNBQWMsQ0FB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QUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsaUJBQUssQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQTJCLENBQUM7UUFDNUYsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFdBQVcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3pELE1BQU0sZ0JBQWdCLEdBQUcsaUJBQUssQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFdkQsSUFBQSxnQkFBTSxFQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3ZCLE1BQU0sWUFBWSxHQUFHLElBQUksZ0JBQUssQ0FBQyxtQkFBbUIsQ0FBaUIsU0FBUyxFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ2hILGlCQUFpQixHQUFHLElBQUEscUNBQThCLEVBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLFlBQVksRUFBRTtZQUMzRixlQUFlO1NBQ2hCLENBQWtDLENBQUM7SUFDdEMsQ0FBQztJQUVELE9BQU87UUFDTCxLQUFLLEVBQUUsaUJBQWlCLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQztLQUNwRCxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IEJJUDMySW50ZXJmYWNlLCBiaXAzMiB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgeyBiaXRnbyB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgaXNUcmlwbGUsIFRyaXBsZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcblxuaW1wb3J0IHsgc2lnbkFuZFZlcmlmeVBzYnQsIHNpZ25BbmRWZXJpZnlXYWxsZXRUcmFuc2FjdGlvbiB9IGZyb20gJy4uLy4uL3NpZ24nO1xuaW1wb3J0IHsgQWJzdHJhY3RVdHhvQ29pbiwgRGVjb2RlZFRyYW5zYWN0aW9uLCBSb290V2FsbGV0S2V5cyB9IGZyb20gJy4uLy4uL2Fic3RyYWN0VXR4b0NvaW4nO1xuXG4vKipcbiAqIEtleSBWYWx1ZTogVW5zaWduZWQgdHggaWQgPT4gUFNCVFxuICogSXQgaXMgdXNlZCB0byBjYWNoZSBQU0JUcyB3aXRoIHRhcHJvb3Qga2V5IHBhdGggKE11U2lnMikgaW5wdXRzIGR1cmluZyBleHRlcm5hbCBleHByZXNzIHNpZ25lciBpcyBhY3RpdmF0ZWQuXG4gKiBSZWFzb246IE11U2lnMiBzaWduZXIgc2VjdXJlIG5vbmNlIGlzIGNhY2hlZCBpbiB0aGUgVXR4b1BzYnQgb2JqZWN0LiBJdCB3aWxsIGJlIHJlcXVpcmVkIGR1cmluZyB0aGUgc2lnbmluZyBzdGVwLlxuICogRm9yIG1vcmUgaW5mbywgY2hlY2sgU2lnblRyYW5zYWN0aW9uT3B0aW9ucy5zaWduaW5nU3RlcFxuICpcbiAqIFRPRE8gQlRDLTI3NjogVGhpcyBjYWNoZSBtYXkgbmVlZCB0byBiZSBkb25lIHdpdGggTFJVIGxpa2UgbWVtb3J5IHNhZmUgY2FjaGluZyBpZiBtZW1vcnkgaXNzdWVzIGNvbWVzIHVwLlxuICovXG5jb25zdCBQU0JUX0NBQ0hFID0gbmV3IE1hcDxzdHJpbmcsIHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+KCk7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIHR4OiBEZWNvZGVkVHJhbnNhY3Rpb248VE51bWJlcj4sXG4gIHNpZ25lcktleWNoYWluOiBCSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCxcbiAgcGFyYW1zOiB7XG4gICAgd2FsbGV0SWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICB0eEluZm86IHsgdW5zcGVudHM/OiB1dHhvbGliLmJpdGdvLlVuc3BlbnQ8VE51bWJlcj5bXSB9IHwgdW5kZWZpbmVkO1xuICAgIGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjtcbiAgICBzaWduaW5nU3RlcDogJ3NpZ25lck5vbmNlJyB8ICdjb3NpZ25lck5vbmNlJyB8ICdzaWduZXJTaWduYXR1cmUnIHwgdW5kZWZpbmVkO1xuICAgIC8qKiBkZXByZWNhdGVkICovXG4gICAgYWxsb3dOb25TZWd3aXRTaWduaW5nV2l0aG91dFByZXZUeDogYm9vbGVhbjtcbiAgICBwdWJzOiBzdHJpbmdbXSB8IHVuZGVmaW5lZDtcbiAgICBjb3NpZ25lclB1Yjogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICB9XG4pOiBQcm9taXNlPHsgdHhIZXg6IHN0cmluZyB9PiB7XG4gIGNvbnN0IGlzVHhXaXRoS2V5UGF0aFNwZW5kSW5wdXQgPSB0eCBpbnN0YW5jZW9mIGJpdGdvLlV0eG9Qc2J0ICYmIGJpdGdvLmlzVHJhbnNhY3Rpb25XaXRoS2V5UGF0aFNwZW5kSW5wdXQodHgpO1xuXG4gIGxldCBpc0xhc3RTaWduYXR1cmUgPSBmYWxzZTtcbiAgaWYgKF8uaXNCb29sZWFuKHBhcmFtcy5pc0xhc3RTaWduYXR1cmUpKSB7XG4gICAgLy8gV2UgY2FuIG9ubHkgYmUgdGhlIGZpcnN0IHNpZ25hdHVyZSBvbiBhIHRyYW5zYWN0aW9uIHdpdGggdGFwcm9vdCBrZXkgcGF0aCBzcGVuZCBpbnB1dHMgYmVjYXVzZVxuICAgIC8vIHdlIHJlcXVpcmUgdGhlIHNlY3JldCBub25jZSBpbiB0aGUgY2FjaGUgb2YgdGhlIGZpcnN0IHNpZ25lciwgd2hpY2ggaXMgaW1wb3NzaWJsZSB0byByZXRyaWV2ZSBpZlxuICAgIC8vIGRlc2VyaWFsaXplZCBmcm9tIGEgaGV4LlxuICAgIGlmIChwYXJhbXMuaXNMYXN0U2lnbmF0dXJlICYmIGlzVHhXaXRoS2V5UGF0aFNwZW5kSW5wdXQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IGJlIGxhc3Qgc2lnbmF0dXJlIG9uIGEgdHJhbnNhY3Rpb24gd2l0aCBrZXkgcGF0aCBzcGVuZCBpbnB1dHMnKTtcbiAgICB9XG5cbiAgICAvLyBpZiBidWlsZCBpcyBjYWxsZWQgaW5zdGVhZCBvZiBidWlsZEluY29tcGxldGUsIG5vIHNpZ25hdHVyZSBwbGFjZWhvbGRlcnMgYXJlIGxlZnQgaW4gdGhlIHNpZyBzY3JpcHRcbiAgICBpc0xhc3RTaWduYXR1cmUgPSBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlO1xuICB9XG5cbiAgaWYgKHR4IGluc3RhbmNlb2YgYml0Z28uVXR4b1BzYnQgJiYgaXNUeFdpdGhLZXlQYXRoU3BlbmRJbnB1dCkge1xuICAgIHN3aXRjaCAocGFyYW1zLnNpZ25pbmdTdGVwKSB7XG4gICAgICBjYXNlICdzaWduZXJOb25jZSc6XG4gICAgICAgIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gICAgICAgIHR4LnNldEFsbElucHV0c011c2lnMk5vbmNlSEQoc2lnbmVyS2V5Y2hhaW4pO1xuICAgICAgICBQU0JUX0NBQ0hFLnNldCh0eC5nZXRVbnNpZ25lZFR4KCkuZ2V0SWQoKSwgdHgpO1xuICAgICAgICByZXR1cm4geyB0eEhleDogdHgudG9IZXgoKSB9O1xuICAgICAgY2FzZSAnY29zaWduZXJOb25jZSc6XG4gICAgICAgIGFzc2VydChwYXJhbXMud2FsbGV0SWQsICd3YWxsZXRJZCBpcyByZXF1aXJlZCBmb3IgTXVTaWcyIGJpdGdvIG5vbmNlJyk7XG4gICAgICAgIHJldHVybiB7IHR4SGV4OiAoYXdhaXQgY29pbi5zaWduUHNidCh0eC50b0hleCgpLCBwYXJhbXMud2FsbGV0SWQpKS5wc2J0IH07XG4gICAgICBjYXNlICdzaWduZXJTaWduYXR1cmUnOlxuICAgICAgICBjb25zdCB0eElkID0gdHguZ2V0VW5zaWduZWRUeCgpLmdldElkKCk7XG4gICAgICAgIGNvbnN0IHBzYnQgPSBQU0JUX0NBQ0hFLmdldCh0eElkKTtcbiAgICAgICAgYXNzZXJ0KFxuICAgICAgICAgIHBzYnQsXG4gICAgICAgICAgYFBzYnQgaXMgbWlzc2luZyBmcm9tIHR4Q2FjaGUgKGNhY2hlIHNpemUgJHtQU0JUX0NBQ0hFLnNpemV9KS5cbiAgICAgICAgICAgIFRoaXMgbWF5IGJlIGR1ZSB0byB0aGUgcmVxdWVzdCBiZWluZyByb3V0ZWQgdG8gYSBkaWZmZXJlbnQgQml0R28tRXhwcmVzcyBpbnN0YW5jZSB0aGF0IGZvciBzaWduaW5nIHN0ZXAgJ3NpZ25lck5vbmNlJy5gXG4gICAgICAgICk7XG4gICAgICAgIFBTQlRfQ0FDSEUuZGVsZXRlKHR4SWQpO1xuICAgICAgICB0eCA9IHBzYnQuY29tYmluZSh0eCk7XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgLy8gdGhpcyBpbnN0YW5jZSBpcyBub3QgYW4gZXh0ZXJuYWwgc2lnbmVyXG4gICAgICAgIGFzc2VydChwYXJhbXMud2FsbGV0SWQsICd3YWxsZXRJZCBpcyByZXF1aXJlZCBmb3IgTXVTaWcyIGJpdGdvIG5vbmNlJyk7XG4gICAgICAgIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gICAgICAgIHR4LnNldEFsbElucHV0c011c2lnMk5vbmNlSEQoc2lnbmVyS2V5Y2hhaW4pO1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNvaW4uc2lnblBzYnQodHgudG9IZXgoKSwgcGFyYW1zLndhbGxldElkKTtcbiAgICAgICAgdHguY29tYmluZShiaXRnby5jcmVhdGVQc2J0RnJvbUhleChyZXNwb25zZS5wc2J0LCBjb2luLm5ldHdvcmspKTtcbiAgICAgICAgYnJlYWs7XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIHN3aXRjaCAocGFyYW1zLnNpZ25pbmdTdGVwKSB7XG4gICAgICBjYXNlICdzaWduZXJOb25jZSc6XG4gICAgICBjYXNlICdjb3NpZ25lck5vbmNlJzpcbiAgICAgICAgLyoqXG4gICAgICAgICAqIEluIGNlcnRhaW4gY2FzZXMsIHRoZSBjYWxsZXIgb2YgdGhpcyBtZXRob2QgbWF5IG5vdCBrbm93IHdoZXRoZXIgdGhlIHR4SGV4IGNvbnRhaW5zIGEgcHNidCB3aXRoIHRhcHJvb3Qga2V5IHBhdGggc3BlbmQgaW5wdXQocykuXG4gICAgICAgICAqIEluc3RlYWQgb2YgdGhyb3dpbmcgZXJyb3IsIG5vLW9wIGFuZCByZXR1cm4gdGhlIHR4SGV4LiBTbyB0aGF0IHRoZSBjYWxsZXIgY2FuIGNhbGwgdGhpcyBtZXRob2QgaW4gdGhlIHNhbWUgc2VxdWVuY2UuXG4gICAgICAgICAqL1xuICAgICAgICByZXR1cm4geyB0eEhleDogdHgudG9IZXgoKSB9O1xuICAgIH1cbiAgfVxuXG4gIGxldCBzaWduZWRUcmFuc2FjdGlvbjogYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludD4gfCBiaXRnby5VdHhvUHNidDtcbiAgaWYgKHR4IGluc3RhbmNlb2YgYml0Z28uVXR4b1BzYnQpIHtcbiAgICBhc3NlcnQoc2lnbmVyS2V5Y2hhaW4pO1xuICAgIHNpZ25lZFRyYW5zYWN0aW9uID0gc2lnbkFuZFZlcmlmeVBzYnQodHgsIHNpZ25lcktleWNoYWluLCB7XG4gICAgICBpc0xhc3RTaWduYXR1cmUsXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgaWYgKHR4Lmlucy5sZW5ndGggIT09IHBhcmFtcy50eEluZm8/LnVuc3BlbnRzPy5sZW5ndGgpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignbGVuZ3RoIG9mIHVuc3BlbnRzIGFycmF5IHNob3VsZCBlcXVhbCB0byB0aGUgbnVtYmVyIG9mIHRyYW5zYWN0aW9uIGlucHV0cycpO1xuICAgIH1cblxuICAgIGlmICghcGFyYW1zLnB1YnMgfHwgIWlzVHJpcGxlKHBhcmFtcy5wdWJzKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBtdXN0IHByb3ZpZGUgeHB1YiBhcnJheWApO1xuICAgIH1cblxuICAgIGNvbnN0IGtleWNoYWlucyA9IHBhcmFtcy5wdWJzLm1hcCgocHViKSA9PiBiaXAzMi5mcm9tQmFzZTU4KHB1YikpIGFzIFRyaXBsZTxCSVAzMkludGVyZmFjZT47XG4gICAgY29uc3QgY29zaWduZXJQdWIgPSBwYXJhbXMuY29zaWduZXJQdWIgPz8gcGFyYW1zLnB1YnNbMl07XG4gICAgY29uc3QgY29zaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgoY29zaWduZXJQdWIpO1xuXG4gICAgYXNzZXJ0KHNpZ25lcktleWNoYWluKTtcbiAgICBjb25zdCB3YWxsZXRTaWduZXIgPSBuZXcgYml0Z28uV2FsbGV0VW5zcGVudFNpZ25lcjxSb290V2FsbGV0S2V5cz4oa2V5Y2hhaW5zLCBzaWduZXJLZXljaGFpbiwgY29zaWduZXJLZXljaGFpbik7XG4gICAgc2lnbmVkVHJhbnNhY3Rpb24gPSBzaWduQW5kVmVyaWZ5V2FsbGV0VHJhbnNhY3Rpb24odHgsIHBhcmFtcy50eEluZm8udW5zcGVudHMsIHdhbGxldFNpZ25lciwge1xuICAgICAgaXNMYXN0U2lnbmF0dXJlLFxuICAgIH0pIGFzIGJpdGdvLlV0eG9UcmFuc2FjdGlvbjxiaWdpbnQ+O1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eEhleDogc2lnbmVkVHJhbnNhY3Rpb24udG9CdWZmZXIoKS50b1N0cmluZygnaGV4JyksXG4gIH07XG59XG4iXX0=
@@ -1,198 +0,0 @@
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
- // Helper to throw TxIntentMismatchError with consistent context
82
- const throwTxMismatch = (message) => {
83
- throw new sdk_core_1.TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex);
84
- };
85
- if (!lodash_1.default.isUndefined(verification.disableNetworking) && !lodash_1.default.isBoolean(verification.disableNetworking)) {
86
- throw new TypeError('verification.disableNetworking must be a boolean');
87
- }
88
- const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);
89
- if (isPsbt && txPrebuild.txInfo?.unspents) {
90
- throw new Error('should not have unspents in txInfo for psbt');
91
- }
92
- const disableNetworking = !!verification.disableNetworking;
93
- const parsedTransaction = await coin.parseTransaction({
94
- txParams,
95
- txPrebuild,
96
- wallet,
97
- verification,
98
- reqId,
99
- });
100
- const keychains = parsedTransaction.keychains;
101
- // verify that the claimed user public key corresponds to the wallet's user private key
102
- let userPublicKeyVerified = false;
103
- try {
104
- // verify the user public key matches the private key - this will throw if there is no match
105
- userPublicKeyVerified = (0, verifyKey_1.verifyUserPublicKey)(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });
106
- }
107
- catch (e) {
108
- debug('failed to verify user public key!', e);
109
- }
110
- // let's verify these keychains
111
- const keySignatures = parsedTransaction.keySignatures;
112
- if (!lodash_1.default.isEmpty(keySignatures)) {
113
- const verify = (key, pub) => {
114
- if (!keychains.user || !keychains.user.pub) {
115
- throwTxMismatch('missing user keychain');
116
- }
117
- return (0, verifyKey_1.verifyKeySignature)({
118
- userKeychain: keychains.user,
119
- keychainToVerify: key,
120
- keySignature: pub,
121
- });
122
- };
123
- const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);
124
- const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);
125
- if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {
126
- throw new Error('secondary public key signatures invalid');
127
- }
128
- debug('successfully verified backup and bitgo key signatures');
129
- }
130
- else if (!disableNetworking) {
131
- // these keys were obtained online and their signatures were not verified
132
- // this could be dangerous
133
- console.log('unsigned keys obtained online are being used for address verification');
134
- }
135
- if (parsedTransaction.needsCustomChangeKeySignatureVerification) {
136
- if (!keychains.user || !userPublicKeyVerified) {
137
- throw new Error('transaction requires verification of user public key, but it was unable to be verified');
138
- }
139
- const customChangeKeySignaturesVerified = (0, verifyKey_1.verifyCustomChangeKeySignatures)(parsedTransaction, keychains.user);
140
- if (!customChangeKeySignaturesVerified) {
141
- throw new Error('transaction requires verification of custom change key signatures, but they were unable to be verified');
142
- }
143
- debug('successfully verified user public key and custom change key signatures');
144
- }
145
- const missingOutputs = parsedTransaction.missingOutputs;
146
- if (missingOutputs.length !== 0) {
147
- // there are some outputs in the recipients list that have not made it into the actual transaction
148
- throwTxMismatch('expected outputs missing in transaction prebuild');
149
- }
150
- const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;
151
- // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended
152
- const payAsYouGoLimit = new bignumber_js_1.default(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(intendedExternalSpend.toString());
153
- /*
154
- Some explanation for why we're doing what we're doing:
155
- Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for
156
- it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a
157
- threshold for the output's value above which we'll throw an error, because the paygo output should never be that
158
- high.
159
- */
160
- // make sure that all the extra addresses are change addresses
161
- // get all the additional external outputs the server added and calculate their values
162
- const nonChangeAmount = new bignumber_js_1.default(parsedTransaction.implicitExternalSpendAmount.toString());
163
- debug('Intended spend is %s, Non-change amount is %s, paygo limit is %s', intendedExternalSpend.toString(), nonChangeAmount.toString(), payAsYouGoLimit.toString());
164
- // There are two instances where we will get into this point here
165
- if (nonChangeAmount.gt(payAsYouGoLimit)) {
166
- if (isPsbt && parsedTransaction.customChange) {
167
- // In the case that we have a custom change address on a wallet and we are building the transaction
168
- // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor
169
- // can we fetch that information from the other wallet because we may not have the credentials. Therefore,
170
- // we will not throw an error here, but we will log a warning.
171
- debug(`cannot verify some of the addresses because it belongs to a separate wallet`);
172
- }
173
- else {
174
- // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address
175
- // there are some addresses that are outside the scope of intended recipients that are not change addresses
176
- throwTxMismatch('prebuild attempts to spend to unintended external recipients');
177
- }
178
- }
179
- const allOutputs = parsedTransaction.outputs;
180
- if (!txPrebuild.txHex) {
181
- throw new Error(`txPrebuild.txHex not set`);
182
- }
183
- const inputs = isPsbt
184
- ? (0, fetchInputs_1.getPsbtTxInputs)(txPrebuild.txHex, coin.network).map((v) => ({
185
- ...v,
186
- value: utxolib.bitgo.toTNumber(v.value, coin.amountType),
187
- }))
188
- : await (0, fetchInputs_1.getTxInputs)({ txPrebuild, bitgo, coin, disableNetworking, reqId });
189
- // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field
190
- const inputAmount = inputs.reduce((sum, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value), BigInt(0));
191
- const outputAmount = allOutputs.reduce((sum, o) => sum + BigInt(o.amount), BigInt(0));
192
- const fee = inputAmount - outputAmount;
193
- if (fee < 0) {
194
- throw new Error(`attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`);
195
- }
196
- return true;
197
- }
198
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5VHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZml4ZWRTY3JpcHQvdmVyaWZ5VHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUE0Q0EsOENBcUpDO0FBak1ELGtEQUErQjtBQUMvQixvREFBdUI7QUFDdkIsZ0VBQXFDO0FBQ3JDLG1EQUF3RTtBQUN4RSw4REFBZ0Q7QUFHaEQsK0NBQTJHO0FBQzNHLGdEQUE4RDtBQUU5RCxNQUFNLEtBQUssR0FBRyxJQUFBLGVBQVUsRUFBQyx1Q0FBdUMsQ0FBQyxDQUFDO0FBRWxFOzs7O0dBSUc7QUFDSCxTQUFTLGFBQWEsQ0FBQyxnQkFBMEI7SUFDL0MsaUdBQWlHO0lBQ2pHLHFEQUFxRDtJQUNyRCxJQUFJLENBQUMsZ0JBQUMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDcEQsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBQ0Qsa0ZBQWtGO0lBQ2xGLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0ksS0FBSyxVQUFVLGlCQUFpQixDQUNyQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF5QztJQUV6QyxNQUFNLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsWUFBWSxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFMUUsZ0VBQWdFO0lBQ2hFLE1BQU0sZUFBZSxHQUFHLENBQUMsT0FBZSxFQUFTLEVBQUU7UUFDakQsTUFBTSxJQUFJLGdDQUFxQixDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEYsQ0FB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QUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFDeEYsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUNWLENBQUM7SUFDRixNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBVyxFQUFFLENBQVMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEcsTUFBTSxHQUFHLEdBQUcsV0FBVyxHQUFHLFlBQVksQ0FBQztJQUV2QyxJQUFJLEdBQUcsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNaLE1BQU0sSUFBSSxLQUFLLENBQ2IsdUJBQXVCLFlBQVksOENBQThDLFdBQVcsaUJBQWlCLENBQUMsR0FBRyxFQUFFLENBQ3BILENBQUM7SUFDSixDQUFDO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGJ1aWxkRGVidWcgZnJvbSAnZGVidWcnO1xuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCBCaWdOdW1iZXIgZnJvbSAnYmlnbnVtYmVyLmpzJztcbmltcG9ydCB7IEJpdEdvQmFzZSwgVHhJbnRlbnRNaXNtYXRjaEVycm9yIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbmltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIE91dHB1dCwgUGFyc2VkVHJhbnNhY3Rpb24sIFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyB9IGZyb20gJy4uLy4uL2Fic3RyYWN0VXR4b0NvaW4nO1xuaW1wb3J0IHsgdmVyaWZ5Q3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlcywgdmVyaWZ5S2V5U2lnbmF0dXJlLCB2ZXJpZnlVc2VyUHVibGljS2V5IH0gZnJvbSAnLi4vLi4vdmVyaWZ5S2V5JztcbmltcG9ydCB7IGdldFBzYnRUeElucHV0cywgZ2V0VHhJbnB1dHMgfSBmcm9tICcuLi9mZXRjaElucHV0cyc7XG5cbmNvbnN0IGRlYnVnID0gYnVpbGREZWJ1ZygnYml0Z286YWJzdHJhY3QtdXR4bzp2ZXJpZnlUcmFuc2FjdGlvbicpO1xuXG4vKipcbiAqIEdldCB0aGUgbWF4aW11bSBwZXJjZW50YWdlIGxpbWl0IGZvciBwYXktYXMteW91LWdvIG91dHB1dHNcbiAqXG4gKiBAcHJvdGVjdGVkXG4gKi9cbmZ1bmN0aW9uIGdldFBheUdvTGltaXQoYWxsb3dQYXlnb091dHB1dD86IGJvb2xlYW4pOiBudW1iZXIge1xuICAvLyBhbGxvd2luZyBwYXlnbyBvdXRwdXRzIG5lZWRzIHRvIGJlIHRoZSBkZWZhdWx0IGJlaGF2aW9yLCBzbyBvbmx5IGRpc2FsbG93IHBheWdvIG91dHB1dHMgaWYgdGhlXG4gIC8vIHJlbGV2YW50IHZlcmlmaWNhdGlvbiBvcHRpb24gaXMgYm90aCBzZXQgYW5kIGZhbHNlXG4gIGlmICghXy5pc05pbChhbGxvd1BheWdvT3V0cHV0KSAmJiAhYWxsb3dQYXlnb091dHB1dCkge1xuICAgIHJldHVybiAwO1xuICB9XG4gIC8vIDE1MCBiYXNpcyBwb2ludHMgaXMgdGhlIGFic29sdXRlIHBlcm1pdHRlZCBtYXhpbXVtIGlmIHBheWdvIG91dHB1dHMgYXJlIGFsbG93ZWRcbiAgcmV0dXJuIDAuMDE1O1xufVxuXG4vKipcbiAqIFZlcmlmeSB0aGF0IGEgdHJhbnNhY3Rpb24gcHJlYnVpbGQgY29tcGxpZXMgd2l0aCB0aGUgb3JpZ2luYWwgaW50ZW50aW9uIGZvciBmaXhlZC1zY3JpcHQgd2FsbGV0c1xuICpcbiAqIFRoaXMgaW1wbGVtZW50YXRpb24gaGFuZGxlcyB0cmFuc2FjdGlvbiB2ZXJpZmljYXRpb24gZm9yIHRyYWRpdGlvbmFsIFVUWE8gY29pbnMgdXNpbmcgZml4ZWQgc2NyaXB0c1xuICogKG5vbi1kZXNjcmlwdG9yIHdhbGxldHMpLiBJdCB2YWxpZGF0ZXMga2V5Y2hhaW5zLCBzaWduYXR1cmVzLCBvdXRwdXRzLCBhbmQgYW1vdW50cy5cbiAqXG4gKiBAcGFyYW0gY29pbiAtIFRoZSBVVFhPIGNvaW4gaW5zdGFuY2VcbiAqIEBwYXJhbSBiaXRnbyAtIEJpdEdvIEFQSSBpbnN0YW5jZSBmb3IgbmV0d29yayBjYWxsc1xuICogQHBhcmFtIHBhcmFtcyAtIFZlcmlmaWNhdGlvbiBwYXJhbWV0ZXJzXG4gKiBAcGFyYW0gcGFyYW1zLnR4UGFyYW1zIC0gVHJhbnNhY3Rpb24gcGFyYW1ldGVycyBwYXNzZWQgdG8gc2VuZFxuICogQHBhcmFtIHBhcmFtcy50eFByZWJ1aWxkIC0gUHJlYnVpbGQgb2JqZWN0IHJldHVybmVkIGJ5IHNlcnZlclxuICogQHBhcmFtIHBhcmFtcy53YWxsZXQgLSBXYWxsZXQgb2JqZWN0IHRvIG9idGFpbiBrZXlzIHRvIHZlcmlmeSBhZ2FpbnN0XG4gKiBAcGFyYW0gcGFyYW1zLnZlcmlmaWNhdGlvbiAtIFZlcmlmaWNhdGlvbiBvcHRpb25zIChkaXNhYmxlTmV0d29ya2luZywga2V5Y2hhaW5zLCBhZGRyZXNzZXMpXG4gKiBAcGFyYW0gcGFyYW1zLnJlcUlkIC0gT3B0aW9uYWwgcmVxdWVzdCBJRCBmb3IgbG9nZ2luZ1xuICogQHJldHVybnMge2Jvb2xlYW59IFRydWUgaWYgdmVyaWZpY2F0aW9uIHBhc3Nlc1xuICogQHRocm93cyB7VHhJbnRlbnRNaXNtYXRjaEVycm9yfSBpZiB0cmFuc2FjdGlvbiB2YWxpZGF0aW9uIGZhaWxzXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB2ZXJpZnlUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgYmlnaW50IHwgbnVtYmVyPihcbiAgY29pbjogQWJzdHJhY3RVdHhvQ29pbixcbiAgYml0Z286IEJpdEdvQmFzZSxcbiAgcGFyYW1zOiBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnM8VE51bWJlcj5cbik6IFByb21pc2U8Ym9vbGVhbj4ge1xuICBjb25zdCB7IHR4UGFyYW1zLCB0eFByZWJ1aWxkLCB3YWxsZXQsIHZlcmlmaWNhdGlvbiA9IHt9LCByZXFJZCB9ID0gcGFyYW1zO1xuXG4gIC8vIEhlbHBlciB0byB0aHJvdyBUeEludGVudE1pc21hdGNoRXJyb3Igd2l0aCBjb25zaXN0ZW50IGNvbnRleHRcbiAgY29uc3QgdGhyb3dUeE1pc21hdGNoID0gKG1lc3NhZ2U6IHN0cmluZyk6IG5ldmVyID0+IHtcbiAgICB0aHJvdyBuZXcgVHhJbnRlbnRNaXNtYXRjaEVycm9yKG1lc3NhZ2UsIHJlcUlkLCBbdHhQYXJhbXNdLCB0eFByZWJ1aWxkLnR4SGV4KTtcbiAgfTtcblxuICBpZiAoIV8uaXNVbmRlZmluZWQodmVyaWZpY2F0aW9uLmRpc2FibGVOZXR3b3JraW5nKSAmJiAhXy5pc0Jvb2xlYW4odmVyaWZpY2F0aW9uLmRpc2FibGVOZXR3b3JraW5nKSkge1xuICAgIHRocm93IG5ldyBUeXBlRXJyb3IoJ3ZlcmlmaWNhdGlvbi5kaXNhYmxlTmV0d29ya2luZyBtdXN0IGJlIGEgYm9vbGVhbicpO1xuICB9XG4gIGNvbnN0IGlzUHNidCA9IHR4UHJlYnVpbGQudHhIZXggJiYgdXR4b2xpYi5iaXRnby5pc1BzYnQodHhQcmVidWlsZC50eEhleCk7XG4gIGlmIChpc1BzYnQgJiYgdHhQcmVidWlsZC50eEluZm8/LnVuc3BlbnRzKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdzaG91bGQgbm90IGhhdmUgdW5zcGVudHMgaW4gdHhJbmZvIGZvciBwc2J0Jyk7XG4gIH1cbiAgY29uc3QgZGlzYWJsZU5ldHdvcmtpbmcgPSAhIXZlcmlmaWNhdGlvbi5kaXNhYmxlTmV0d29ya2luZztcbiAgY29uc3QgcGFyc2VkVHJhbnNhY3Rpb246IFBhcnNlZFRyYW5zYWN0aW9uPFROdW1iZXI+ID0gYXdhaXQgY29pbi5wYXJzZVRyYW5zYWN0aW9uPFROdW1iZXI+KHtcbiAgICB0eFBhcmFtcyxcbiAgICB0eFByZWJ1aWxkLFxuICAgIHdhbGxldCxcbiAgICB2ZXJpZmljYXRpb24sXG4gICAgcmVxSWQsXG4gIH0pO1xuXG4gIGNvbnN0IGtleWNoYWlucyA9IHBhcnNlZFRyYW5zYWN0aW9uLmtleWNoYWlucztcblxuICAvLyB2ZXJpZnkgdGhhdCB0aGUgY2xhaW1lZCB1c2VyIHB1YmxpYyBrZXkgY29ycmVzcG9uZHMgdG8gdGhlIHdhbGxldCdzIHVzZXIgcHJpdmF0ZSBrZXlcbiAgbGV0IHVzZXJQdWJsaWNLZXlWZXJpZmllZCA9IGZhbHNlO1xuICB0cnkge1xuICAgIC8vIHZlcmlmeSB0aGUgdXNlciBwdWJsaWMga2V5IG1hdGNoZXMgdGhlIHByaXZhdGUga2V5IC0gdGhpcyB3aWxsIHRocm93IGlmIHRoZXJlIGlzIG5vIG1hdGNoXG4gICAgdXNlclB1YmxpY0tleVZlcmlmaWVkID0gdmVyaWZ5VXNlclB1YmxpY0tleShiaXRnbywgeyB1c2VyS2V5Y2hhaW46IGtleWNoYWlucy51c2VyLCBkaXNhYmxlTmV0d29ya2luZywgdHhQYXJhbXMgfSk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBkZWJ1ZygnZmFpbGVkIHRvIHZlcmlmeSB1c2VyIHB1YmxpYyBrZXkhJywgZSk7XG4gIH1cblxuICAvLyBsZXQncyB2ZXJpZnkgdGhlc2Uga2V5Y2hhaW5zXG4gIGNvbnN0IGtleVNpZ25hdHVyZXMgPSBwYXJzZWRUcmFuc2FjdGlvbi5rZXlTaWduYXR1cmVzO1xuICBpZiAoIV8uaXNFbXB0eShrZXlTaWduYXR1cmVzKSkge1xuICAgIGNvbnN0IHZlcmlmeSA9IChrZXksIHB1YikgPT4ge1xuICAgICAgaWYgKCFrZXljaGFpbnMudXNlciB8fCAha2V5Y2hhaW5zLnVzZXIucHViKSB7XG4gICAgICAgIHRocm93VHhNaXNtYXRjaCgnbWlzc2luZyB1c2VyIGtleWNoYWluJyk7XG4gICAgICB9XG4gICAgICByZXR1cm4gdmVyaWZ5S2V5U2lnbmF0dXJlKHtcbiAgICAgICAgdXNlcktleWNoYWluOiBrZXljaGFpbnMudXNlciBhcyB7IHB1Yjogc3RyaW5nIH0sXG4gICAgICAgIGtleWNoYWluVG9WZXJpZnk6IGtleSxcbiAgICAgICAga2V5U2lnbmF0dXJlOiBwdWIsXG4gICAgICB9KTtcbiAgICB9O1xuICAgIGNvbnN0IGlzQmFja3VwS2V5U2lnbmF0dXJlVmFsaWQgPSB2ZXJpZnkoa2V5Y2hhaW5zLmJhY2t1cCwga2V5U2lnbmF0dXJlcy5iYWNrdXBQdWIpO1xuICAgIGNvbnN0IGlzQml0Z29LZXlTaWduYXR1cmVWYWxpZCA9IHZlcmlmeShrZXljaGFpbnMuYml0Z28sIGtleVNpZ25hdHVyZXMuYml0Z29QdWIpO1xuICAgIGlmICghaXNCYWNrdXBLZXlTaWduYXR1cmVWYWxpZCB8fCAhaXNCaXRnb0tleVNpZ25hdHVyZVZhbGlkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3NlY29uZGFyeSBwdWJsaWMga2V5IHNpZ25hdHVyZXMgaW52YWxpZCcpO1xuICAgIH1cbiAgICBkZWJ1Zygnc3VjY2Vzc2Z1bGx5IHZlcmlmaWVkIGJhY2t1cCBhbmQgYml0Z28ga2V5IHNpZ25hdHVyZXMnKTtcbiAgfSBlbHNlIGlmICghZGlzYWJsZU5ldHdvcmtpbmcpIHtcbiAgICAvLyB0aGVzZSBrZXlzIHdlcmUgb2J0YWluZWQgb25saW5lIGFuZCB0aGVpciBzaWduYXR1cmVzIHdlcmUgbm90IHZlcmlmaWVkXG4gICAgLy8gdGhpcyBjb3VsZCBiZSBkYW5nZXJvdXNcbiAgICBjb25zb2xlLmxvZygndW5zaWduZWQga2V5cyBvYnRhaW5lZCBvbmxpbmUgYXJlIGJlaW5nIHVzZWQgZm9yIGFkZHJlc3MgdmVyaWZpY2F0aW9uJyk7XG4gIH1cblxuICBpZiAocGFyc2VkVHJhbnNhY3Rpb24ubmVlZHNDdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVWZXJpZmljYXRpb24pIHtcbiAgICBpZiAoIWtleWNoYWlucy51c2VyIHx8ICF1c2VyUHVibGljS2V5VmVyaWZpZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigndHJhbnNhY3Rpb24gcmVxdWlyZXMgdmVyaWZpY2F0aW9uIG9mIHVzZXIgcHVibGljIGtleSwgYnV0IGl0IHdhcyB1bmFibGUgdG8gYmUgdmVyaWZpZWQnKTtcbiAgICB9XG4gICAgY29uc3QgY3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlc1ZlcmlmaWVkID0gdmVyaWZ5Q3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlcyhwYXJzZWRUcmFuc2FjdGlvbiwga2V5Y2hhaW5zLnVzZXIpO1xuICAgIGlmICghY3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlc1ZlcmlmaWVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICd0cmFuc2FjdGlvbiByZXF1aXJlcyB2ZXJpZmljYXRpb24gb2YgY3VzdG9tIGNoYW5nZSBrZXkgc2lnbmF0dXJlcywgYnV0IHRoZXkgd2VyZSB1bmFibGUgdG8gYmUgdmVyaWZpZWQnXG4gICAgICApO1xuICAgIH1cbiAgICBkZWJ1Zygnc3VjY2Vzc2Z1bGx5IHZlcmlmaWVkIHVzZXIgcHVibGljIGtleSBhbmQgY3VzdG9tIGNoYW5nZSBrZXkgc2lnbmF0dXJlcycpO1xuICB9XG5cbiAgY29uc3QgbWlzc2luZ091dHB1dHMgPSBwYXJzZWRUcmFuc2FjdGlvbi5taXNzaW5nT3V0cHV0cztcbiAgaWYgKG1pc3NpbmdPdXRwdXRzLmxlbmd0aCAhPT0gMCkge1xuICAgIC8vIHRoZXJlIGFyZSBzb21lIG91dHB1dHMgaW4gdGhlIHJlY2lwaWVudHMgbGlzdCB0aGF0IGhhdmUgbm90IG1hZGUgaXQgaW50byB0aGUgYWN0dWFsIHRyYW5zYWN0aW9uXG4gICAgdGhyb3dUeE1pc21hdGNoKCdleHBlY3RlZCBvdXRwdXRzIG1pc3NpbmcgaW4gdHJhbnNhY3Rpb24gcHJlYnVpbGQnKTtcbiAgfVxuXG4gIGNvbnN0IGludGVuZGVkRXh0ZXJuYWxTcGVuZCA9IHBhcnNlZFRyYW5zYWN0aW9uLmV4cGxpY2l0RXh0ZXJuYWxTcGVuZEFtb3VudDtcblxuICAvLyB0aGlzIGlzIGEgbGltaXQgd2UgaW1wb3NlIGZvciB0aGUgdG90YWwgdmFsdWUgdGhhdCBpcyBhbWVuZGVkIHRvIHRoZSB0cmFuc2FjdGlvbiBiZXlvbmQgd2hhdCB3YXMgb3JpZ2luYWxseSBpbnRlbmRlZFxuICBjb25zdCBwYXlBc1lvdUdvTGltaXQgPSBuZXcgQmlnTnVtYmVyKGdldFBheUdvTGltaXQodmVyaWZpY2F0aW9uLmFsbG93UGF5Z29PdXRwdXQpKS5tdWx0aXBsaWVkQnkoXG4gICAgaW50ZW5kZWRFeHRlcm5hbFNwZW5kLnRvU3RyaW5nKClcbiAgKTtcblxuICAvKlxuICBTb21lIGV4cGxhbmF0aW9uIGZvciB3aHkgd2UncmUgZG9pbmcgd2hhdCB3ZSdyZSBkb2luZzpcbiAgU29tZSBjdXN0b21lcnMgd2lsbCBoYXZlIGFuIG91dHB1dCB0byBCaXRHbydzIFBBWUdvIHdhbGxldCBhZGRlZCB0byB0aGVpciB0cmFuc2FjdGlvbiwgYW5kIHdlIG5lZWQgdG8gYWNjb3VudCBmb3JcbiAgaXQgaGVyZS4gVG8gcHJvdGVjdCBzb21lb25lIHRhbXBlcmluZyB3aXRoIHRoZSBvdXRwdXQgdG8gbWFrZSBpdCBzZW5kIG1vcmUgdGhhbiBpdCBzaG91bGQgdG8gQml0R28sIHdlIGRlZmluZSBhXG4gIHRocmVzaG9sZCBmb3IgdGhlIG91dHB1dCdzIHZhbHVlIGFib3ZlIHdoaWNoIHdlJ2xsIHRocm93IGFuIGVycm9yLCBiZWNhdXNlIHRoZSBwYXlnbyBvdXRwdXQgc2hvdWxkIG5ldmVyIGJlIHRoYXRcbiAgaGlnaC5cbiAgICovXG5cbiAgLy8gbWFrZSBzdXJlIHRoYXQgYWxsIHRoZSBleHRyYSBhZGRyZXNzZXMgYXJlIGNoYW5nZSBhZGRyZXNzZXNcbiAgLy8gZ2V0IGFsbCB0aGUgYWRkaXRpb25hbCBleHRlcm5hbCBvdXRwdXRzIHRoZSBzZXJ2ZXIgYWRkZWQgYW5kIGNhbGN1bGF0ZSB0aGVpciB2YWx1ZXNcbiAgY29uc3Qgbm9uQ2hhbmdlQW1vdW50ID0gbmV3IEJpZ051bWJlcihwYXJzZWRUcmFuc2FjdGlvbi5pbXBsaWNpdEV4dGVybmFsU3BlbmRBbW91bnQudG9TdHJpbmcoKSk7XG5cbiAgZGVidWcoXG4gICAgJ0ludGVuZGVkIHNwZW5kIGlzICVzLCBOb24tY2hhbmdlIGFtb3VudCBpcyAlcywgcGF5Z28gbGltaXQgaXMgJXMnLFxuICAgIGludGVuZGVkRXh0ZXJuYWxTcGVuZC50b1N0cmluZygpLFxuICAgIG5vbkNoYW5nZUFtb3VudC50b1N0cmluZygpLFxuICAgIHBheUFzWW91R29MaW1pdC50b1N0cmluZygpXG4gICk7XG5cbiAgLy8gVGhlcmUgYXJlIHR3byBpbnN0YW5jZXMgd2hlcmUgd2Ugd2lsbCBnZXQgaW50byB0aGlzIHBvaW50IGhlcmVcbiAgaWYgKG5vbkNoYW5nZUFtb3VudC5ndChwYXlBc1lvdUdvTGltaXQpKSB7XG4gICAgaWYgKGlzUHNidCAmJiBwYXJzZWRUcmFuc2FjdGlvbi5jdXN0b21DaGFuZ2UpIHtcbiAgICAgIC8vIEluIHRoZSBjYXNlIHRoYXQgd2UgaGF2ZSBhIGN1c3RvbSBjaGFuZ2UgYWRkcmVzcyBvbiBhIHdhbGxldCBhbmQgd2UgYXJlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvblxuICAgICAgLy8gd2l0aCBhIFBTQlQsIHdlIGRvIG5vdCBoYXZlIHRoZSBtZXRhZGF0YSB0byB2ZXJpZnkgdGhlIGFkZHJlc3MgZnJvbSB0aGUgY3VzdG9tIGNoYW5nZSB3YWxsZXQsIG5vclxuICAgICAgLy8gY2FuIHdlIGZldGNoIHRoYXQgaW5mb3JtYXRpb24gZnJvbSB0aGUgb3RoZXIgd2FsbGV0IGJlY2F1c2Ugd2UgbWF5IG5vdCBoYXZlIHRoZSBjcmVkZW50aWFscy4gVGhlcmVmb3JlLFxuICAgICAgLy8gd2Ugd2lsbCBub3QgdGhyb3cgYW4gZXJyb3IgaGVyZSwgYnV0IHdlIHdpbGwgbG9nIGEgd2FybmluZy5cbiAgICAgIGRlYnVnKGBjYW5ub3QgdmVyaWZ5IHNvbWUgb2YgdGhlIGFkZHJlc3NlcyBiZWNhdXNlIGl0IGJlbG9uZ3MgdG8gYSBzZXBhcmF0ZSB3YWxsZXRgKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gdGhlIGFkZGl0aW9uYWwgZXh0ZXJuYWwgb3V0cHV0cyBjYW4gb25seSBiZSBCaXRHbydzIHBheS1hcy15b3UtZ28gZmVlLCBidXQgd2UgY2Fubm90IHZlcmlmeSB0aGUgd2FsbGV0IGFkZHJlc3NcbiAgICAgIC8vIHRoZXJlIGFyZSBzb21lIGFkZHJlc3NlcyB0aGF0IGFyZSBvdXRzaWRlIHRoZSBzY29wZSBvZiBpbnRlbmRlZCByZWNpcGllbnRzIHRoYXQgYXJlIG5vdCBjaGFuZ2UgYWRkcmVzc2VzXG4gICAgICB0aHJvd1R4TWlzbWF0Y2goJ3ByZWJ1aWxkIGF0dGVtcHRzIHRvIHNwZW5kIHRvIHVuaW50ZW5kZWQgZXh0ZXJuYWwgcmVjaXBpZW50cycpO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGFsbE91dHB1dHMgPSBwYXJzZWRUcmFuc2FjdGlvbi5vdXRwdXRzO1xuICBpZiAoIXR4UHJlYnVpbGQudHhIZXgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYHR4UHJlYnVpbGQudHhIZXggbm90IHNldGApO1xuICB9XG4gIGNvbnN0IGlucHV0cyA9IGlzUHNidFxuICAgID8gZ2V0UHNidFR4SW5wdXRzKHR4UHJlYnVpbGQudHhIZXgsIGNvaW4ubmV0d29yaykubWFwKCh2KSA9PiAoe1xuICAgICAgICAuLi52LFxuICAgICAgICB2YWx1ZTogdXR4b2xpYi5iaXRnby50b1ROdW1iZXIodi52YWx1ZSwgY29pbi5hbW91bnRUeXBlKSxcbiAgICAgIH0pKVxuICAgIDogYXdhaXQgZ2V0VHhJbnB1dHMoeyB0eFByZWJ1aWxkLCBiaXRnbywgY29pbiwgZGlzYWJsZU5ldHdvcmtpbmcsIHJlcUlkIH0pO1xuICAvLyBjb2lucyAoZG9nZSkgdGhhdCBjYW4gZXhjZWVkIG51bWJlciBsaW1pdHMgKGFuZCB0aHVzIHdpbGwgdXNlIGJpZ2ludCkgd2lsbCBoYXZlIHRoZSBgdmFsdWVTdHJpbmdgIGZpZWxkXG4gIGNvbnN0IGlucHV0QW1vdW50ID0gaW5wdXRzLnJlZHVjZShcbiAgICAoc3VtOiBiaWdpbnQsIGkpID0+IHN1bSArIEJpZ0ludChjb2luLmFtb3VudFR5cGUgPT09ICdiaWdpbnQnID8gaS52YWx1ZVN0cmluZyA6IGkudmFsdWUpLFxuICAgIEJpZ0ludCgwKVxuICApO1xuICBjb25zdCBvdXRwdXRBbW91bnQgPSBhbGxPdXRwdXRzLnJlZHVjZSgoc3VtOiBiaWdpbnQsIG86IE91dHB1dCkgPT4gc3VtICsgQmlnSW50KG8uYW1vdW50KSwgQmlnSW50KDApKTtcbiAgY29uc3QgZmVlID0gaW5wdXRBbW91bnQgLSBvdXRwdXRBbW91bnQ7XG5cbiAgaWYgKGZlZSA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgYXR0ZW1wdGluZyB0byBzcGVuZCAke291dHB1dEFtb3VudH0gc2F0b3NoaXMsIHdoaWNoIGV4Y2VlZHMgdGhlIGlucHV0IGFtb3VudCAoJHtpbnB1dEFtb3VudH0gc2F0b3NoaXMpIGJ5ICR7LWZlZX1gXG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuIl19
@@ -1,47 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.matchingOutput = matchingOutput;
4
- exports.outputDifference = outputDifference;
5
- exports.outputDifferencesWithExpected = outputDifferencesWithExpected;
6
- /**
7
- * @param a
8
- * @param b
9
- * @returns whether the two outputs are equal. Outputs with value `max` are considered equal to any other output with the same script.
10
- */
11
- function matchingOutput(a, b) {
12
- if (a.value === 'max' || b.value === 'max') {
13
- return a.script.equals(b.script);
14
- }
15
- return a.script.equals(b.script) && a.value === b.value;
16
- }
17
- /**
18
- * @returns all outputs in the first array that are not in the second array.
19
- * Outputs can occur more than once in each array.
20
- * An output with value `max` is considered equal to any other output with the same script.
21
- */
22
- function outputDifference(first, second) {
23
- first = first.slice();
24
- for (const output of second) {
25
- const index = first.findIndex((o) => matchingOutput(o, output));
26
- if (index !== -1) {
27
- first.splice(index, 1);
28
- }
29
- }
30
- return first;
31
- }
32
- /**
33
- * @param actualOutputs - external outputs in the transaction
34
- * @param expectedOutputs - external outputs that were expected to be in the transaction
35
- * @returns the difference between the actual and expected external outputs
36
- */
37
- function outputDifferencesWithExpected(actualOutputs, expectedOutputs) {
38
- const implicitOutputs = outputDifference(actualOutputs, expectedOutputs);
39
- const explicitOutputs = outputDifference(actualOutputs, implicitOutputs);
40
- const missingOutputs = outputDifference(expectedOutputs, actualOutputs);
41
- return {
42
- explicitOutputs,
43
- implicitOutputs,
44
- missingOutputs,
45
- };
46
- }
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0cHV0RGlmZmVyZW5jZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2FjdGlvbi9vdXRwdXREaWZmZXJlbmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBZ0JBLHdDQUtDO0FBT0QsNENBWUM7QUFxQkQsc0VBWUM7QUE5REQ7Ozs7R0FJRztBQUNILFNBQWdCLGNBQWMsQ0FBUyxDQUEyQixFQUFFLENBQTJCO0lBQzdGLElBQUksQ0FBQyxDQUFDLEtBQUssS0FBSyxLQUFLLElBQUksQ0FBQyxDQUFDLEtBQUssS0FBSyxLQUFLLEVBQUUsQ0FBQztRQUMzQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBQ0QsT0FBTyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssS0FBSyxDQUFDLENBQUMsS0FBSyxDQUFDO0FBQzFELENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQzlCLEtBQVUsRUFDVixNQUFXO0lBRVgsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN0QixLQUFLLE1BQU0sTUFBTSxJQUFJLE1BQU0sRUFBRSxDQUFDO1FBQzVCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNoRSxJQUFJLEtBQUssS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQ2pCLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3pCLENBQUM7SUFDSCxDQUFDO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDO0FBZ0JEOzs7O0dBSUc7QUFDSCxTQUFnQiw2QkFBNkIsQ0FDM0MsYUFBd0IsRUFDeEIsZUFBNEI7SUFFNUIsTUFBTSxlQUFlLEdBQUcsZ0JBQWdCLENBQUMsYUFBYSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3pFLE1BQU0sZUFBZSxHQUFHLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUN6RSxNQUFNLGNBQWMsR0FBRyxnQkFBZ0IsQ0FBQyxlQUFlLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDeEUsT0FBTztRQUNMLGVBQWU7UUFDZixlQUFlO1FBQ2YsY0FBYztLQUNmLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQ29tcGFyYWJsZU91dHB1dDxUVmFsdWU+ID0ge1xuICBzY3JpcHQ6IEJ1ZmZlcjtcbiAgdmFsdWU6IFRWYWx1ZTtcbn07XG5cbi8qKiBBY3R1YWwgb3V0cHV0cyBoYXZlIGZpeGVkIHZhbHVlcy4gKi9cbmV4cG9ydCB0eXBlIEFjdHVhbE91dHB1dCA9IENvbXBhcmFibGVPdXRwdXQ8YmlnaW50PjtcblxuLyoqIEV4cGVjdGVkIG91dHB1dHMgY2FuIGhhdmUgYSBmaXhlZCB2YWx1ZSBvciAnbWF4Jy4gKi9cbmV4cG9ydCB0eXBlIEV4cGVjdGVkT3V0cHV0ID0gQ29tcGFyYWJsZU91dHB1dDxiaWdpbnQgfCAnbWF4Jz47XG5cbi8qKlxuICogQHBhcmFtIGFcbiAqIEBwYXJhbSBiXG4gKiBAcmV0dXJucyB3aGV0aGVyIHRoZSB0d28gb3V0cHV0cyBhcmUgZXF1YWwuIE91dHB1dHMgd2l0aCB2YWx1ZSBgbWF4YCBhcmUgY29uc2lkZXJlZCBlcXVhbCB0byBhbnkgb3RoZXIgb3V0cHV0IHdpdGggdGhlIHNhbWUgc2NyaXB0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gbWF0Y2hpbmdPdXRwdXQ8VFZhbHVlPihhOiBDb21wYXJhYmxlT3V0cHV0PFRWYWx1ZT4sIGI6IENvbXBhcmFibGVPdXRwdXQ8VFZhbHVlPik6IGJvb2xlYW4ge1xuICBpZiAoYS52YWx1ZSA9PT0gJ21heCcgfHwgYi52YWx1ZSA9PT0gJ21heCcpIHtcbiAgICByZXR1cm4gYS5zY3JpcHQuZXF1YWxzKGIuc2NyaXB0KTtcbiAgfVxuICByZXR1cm4gYS5zY3JpcHQuZXF1YWxzKGIuc2NyaXB0KSAmJiBhLnZhbHVlID09PSBiLnZhbHVlO1xufVxuXG4vKipcbiAqIEByZXR1cm5zIGFsbCBvdXRwdXRzIGluIHRoZSBmaXJzdCBhcnJheSB0aGF0IGFyZSBub3QgaW4gdGhlIHNlY29uZCBhcnJheS5cbiAqIE91dHB1dHMgY2FuIG9jY3VyIG1vcmUgdGhhbiBvbmNlIGluIGVhY2ggYXJyYXkuXG4gKiBBbiBvdXRwdXQgd2l0aCB2YWx1ZSBgbWF4YCBpcyBjb25zaWRlcmVkIGVxdWFsIHRvIGFueSBvdGhlciBvdXRwdXQgd2l0aCB0aGUgc2FtZSBzY3JpcHQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBvdXRwdXREaWZmZXJlbmNlPEEgZXh0ZW5kcyBBY3R1YWxPdXRwdXQgfCBFeHBlY3RlZE91dHB1dCwgQiBleHRlbmRzIEFjdHVhbE91dHB1dCB8IEV4cGVjdGVkT3V0cHV0PihcbiAgZmlyc3Q6IEFbXSxcbiAgc2Vjb25kOiBCW11cbik6IEFbXSB7XG4gIGZpcnN0ID0gZmlyc3Quc2xpY2UoKTtcbiAgZm9yIChjb25zdCBvdXRwdXQgb2Ygc2Vjb25kKSB7XG4gICAgY29uc3QgaW5kZXggPSBmaXJzdC5maW5kSW5kZXgoKG8pID0+IG1hdGNoaW5nT3V0cHV0KG8sIG91dHB1dCkpO1xuICAgIGlmIChpbmRleCAhPT0gLTEpIHtcbiAgICAgIGZpcnN0LnNwbGljZShpbmRleCwgMSk7XG4gICAgfVxuICB9XG4gIHJldHVybiBmaXJzdDtcbn1cblxuZXhwb3J0IHR5cGUgT3V0cHV0RGlmZmVyZW5jZVdpdGhFeHBlY3RlZDxUQWN0dWFsIGV4dGVuZHMgQWN0dWFsT3V0cHV0LCBURXhwZWN0ZWQgZXh0ZW5kcyBFeHBlY3RlZE91dHB1dD4gPSB7XG4gIC8qKiBUaGVzZSBhcmUgdGhlIGV4dGVybmFsIG91dHB1dHMgdGhhdCB3ZXJlIGV4cGVjdGVkIGFuZCBmb3VuZCBpbiB0aGUgdHJhbnNhY3Rpb24uICovXG4gIGV4cGxpY2l0T3V0cHV0czogVEFjdHVhbFtdO1xuICAvKipcbiAgICogVGhlc2UgYXJlIHRoZSBzdXJwcmlzZSBleHRlcm5hbCBvdXRwdXRzIHRoYXQgd2VyZSBub3QgZXhwbGljaXRseSBzcGVjaWZpZWQgaW4gdGhlIHRyYW5zYWN0aW9uLlxuICAgKiBUaGV5IGNhbiBiZSBQYXlHbyBmZWVzLlxuICAgKi9cbiAgaW1wbGljaXRPdXRwdXRzOiBUQWN0dWFsW107XG4gIC8qKlxuICAgKiBUaGVzZSBhcmUgdGhlIG91dHB1dHMgdGhhdCB3ZXJlIGV4cGVjdGVkIHRvIGJlIGluIHRoZSB0cmFuc2FjdGlvbiBidXQgd2VyZSBub3QgZm91bmQuXG4gICAqL1xuICBtaXNzaW5nT3V0cHV0czogVEV4cGVjdGVkW107XG59O1xuXG4vKipcbiAqIEBwYXJhbSBhY3R1YWxPdXRwdXRzIC0gZXh0ZXJuYWwgb3V0cHV0cyBpbiB0aGUgdHJhbnNhY3Rpb25cbiAqIEBwYXJhbSBleHBlY3RlZE91dHB1dHMgLSBleHRlcm5hbCBvdXRwdXRzIHRoYXQgd2VyZSBleHBlY3RlZCB0byBiZSBpbiB0aGUgdHJhbnNhY3Rpb25cbiAqIEByZXR1cm5zIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdGhlIGFjdHVhbCBhbmQgZXhwZWN0ZWQgZXh0ZXJuYWwgb3V0cHV0c1xuICovXG5leHBvcnQgZnVuY3Rpb24gb3V0cHV0RGlmZmVyZW5jZXNXaXRoRXhwZWN0ZWQ8VEFjdHVhbCBleHRlbmRzIEFjdHVhbE91dHB1dCwgVEV4cGVjdGVkIGV4dGVuZHMgRXhwZWN0ZWRPdXRwdXQ+KFxuICBhY3R1YWxPdXRwdXRzOiBUQWN0dWFsW10sXG4gIGV4cGVjdGVkT3V0cHV0czogVEV4cGVjdGVkW11cbik6IE91dHB1dERpZmZlcmVuY2VXaXRoRXhwZWN0ZWQ8VEFjdHVhbCwgVEV4cGVjdGVkPiB7XG4gIGNvbnN0IGltcGxpY2l0T3V0cHV0cyA9IG91dHB1dERpZmZlcmVuY2UoYWN0dWFsT3V0cHV0cywgZXhwZWN0ZWRPdXRwdXRzKTtcbiAgY29uc3QgZXhwbGljaXRPdXRwdXRzID0gb3V0cHV0RGlmZmVyZW5jZShhY3R1YWxPdXRwdXRzLCBpbXBsaWNpdE91dHB1dHMpO1xuICBjb25zdCBtaXNzaW5nT3V0cHV0cyA9IG91dHB1dERpZmZlcmVuY2UoZXhwZWN0ZWRPdXRwdXRzLCBhY3R1YWxPdXRwdXRzKTtcbiAgcmV0dXJuIHtcbiAgICBleHBsaWNpdE91dHB1dHMsXG4gICAgaW1wbGljaXRPdXRwdXRzLFxuICAgIG1pc3NpbmdPdXRwdXRzLFxuICB9O1xufVxuIl19
@@ -1,88 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.isScriptRecipient = isScriptRecipient;
37
- exports.fromExtendedAddressFormat = fromExtendedAddressFormat;
38
- exports.fromExtendedAddressFormatToScript = fromExtendedAddressFormatToScript;
39
- exports.toExtendedAddressFormat = toExtendedAddressFormat;
40
- exports.assertValidTransactionRecipient = assertValidTransactionRecipient;
41
- const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
42
- const ScriptRecipientPrefix = 'scriptPubKey:';
43
- /**
44
- * Check if the address is a script recipient (starts with `scriptPubKey:`).
45
- * @param address
46
- */
47
- function isScriptRecipient(address) {
48
- return address.toLowerCase().startsWith(ScriptRecipientPrefix.toLowerCase());
49
- }
50
- /**
51
- * An extended address is one that encodes either a regular address or a hex encoded script with the prefix `scriptPubKey:`.
52
- * This function converts the extended address format to either a script or an address.
53
- * @param extendedAddress
54
- */
55
- function fromExtendedAddressFormat(extendedAddress) {
56
- if (isScriptRecipient(extendedAddress)) {
57
- return { script: extendedAddress.slice(ScriptRecipientPrefix.length) };
58
- }
59
- return { address: extendedAddress };
60
- }
61
- function fromExtendedAddressFormatToScript(extendedAddress, network) {
62
- const result = fromExtendedAddressFormat(extendedAddress);
63
- if ('script' in result) {
64
- return Buffer.from(result.script, 'hex');
65
- }
66
- return utxolib.addressFormat.toOutputScriptTryFormats(result.address, network);
67
- }
68
- /**
69
- * Convert a script or address to the extended address format.
70
- * @param script
71
- * @param network
72
- * @returns if the script is an OP_RETURN script, then it will be prefixed with `scriptPubKey:`, otherwise it will be converted to an address.
73
- */
74
- function toExtendedAddressFormat(script, network) {
75
- return script[0] === utxolib.opcodes.OP_RETURN
76
- ? `${ScriptRecipientPrefix}${script.toString('hex')}`
77
- : utxolib.address.fromOutputScript(script, network);
78
- }
79
- function assertValidTransactionRecipient(output) {
80
- // In the case that this is an OP_RETURN output or another non-encodable scriptPubkey, we dont have an address.
81
- // We will verify that the amount is zero, and if it isnt then we will throw an error.
82
- if (!output.address || isScriptRecipient(output.address)) {
83
- if (output.amount.toString() !== '0') {
84
- throw new Error(`Only zero amounts allowed for non-encodeable scriptPubkeys: ${JSON.stringify(output)}`);
85
- }
86
- }
87
- }
88
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjaXBpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3JlY2lwaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFBLDhDQUVDO0FBT0QsOERBS0M7QUFFRCw4RUFNQztBQVFELDBEQUlDO0FBRUQsMEVBUUM7QUFwREQsOERBQWdEO0FBRWhELE1BQU0scUJBQXFCLEdBQUcsZUFBZSxDQUFDO0FBRTlDOzs7R0FHRztBQUNILFNBQWdCLGlCQUFpQixDQUFDLE9BQWU7SUFDL0MsT0FBTyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUMsVUFBVSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7QUFDL0UsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQix5QkFBeUIsQ0FBQyxlQUF1QjtJQUMvRCxJQUFJLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUM7UUFDdkMsT0FBTyxFQUFFLE1BQU0sRUFBRSxlQUFlLENBQUMsS0FBSyxDQUFDLHFCQUFxQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7SUFDekUsQ0FBQztJQUNELE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLENBQUM7QUFDdEMsQ0FBQztBQUVELFNBQWdCLGlDQUFpQyxDQUFDLGVBQXVCLEVBQUUsT0FBd0I7SUFDakcsTUFBTSxNQUFNLEdBQUcseUJBQXlCLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDMUQsSUFBSSxRQUFRLElBQUksTUFBTSxFQUFFLENBQUM7UUFDdkIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUNELE9BQU8sT0FBTyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ2pGLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLHVCQUF1QixDQUFDLE1BQWMsRUFBRSxPQUF3QjtJQUM5RSxPQUFPLE1BQU0sQ0FBQyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsT0FBTyxDQUFDLFNBQVM7UUFDNUMsQ0FBQyxDQUFDLEdBQUcscUJBQXFCLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNyRCxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDeEQsQ0FBQztBQUVELFNBQWdCLCtCQUErQixDQUFDLE1BQThEO0lBQzVHLCtHQUErRztJQUMvRyxzRkFBc0Y7SUFDdEYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLElBQUksaUJBQWlCLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDekQsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxLQUFLLEdBQUcsRUFBRSxDQUFDO1lBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsK0RBQStELElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzNHLENBQUM7SUFDSCxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5jb25zdCBTY3JpcHRSZWNpcGllbnRQcmVmaXggPSAnc2NyaXB0UHViS2V5Oic7XG5cbi8qKlxuICogQ2hlY2sgaWYgdGhlIGFkZHJlc3MgaXMgYSBzY3JpcHQgcmVjaXBpZW50IChzdGFydHMgd2l0aCBgc2NyaXB0UHViS2V5OmApLlxuICogQHBhcmFtIGFkZHJlc3NcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzU2NyaXB0UmVjaXBpZW50KGFkZHJlc3M6IHN0cmluZyk6IGJvb2xlYW4ge1xuICByZXR1cm4gYWRkcmVzcy50b0xvd2VyQ2FzZSgpLnN0YXJ0c1dpdGgoU2NyaXB0UmVjaXBpZW50UHJlZml4LnRvTG93ZXJDYXNlKCkpO1xufVxuXG4vKipcbiAqIEFuIGV4dGVuZGVkIGFkZHJlc3MgaXMgb25lIHRoYXQgZW5jb2RlcyBlaXRoZXIgYSByZWd1bGFyIGFkZHJlc3Mgb3IgYSBoZXggZW5jb2RlZCBzY3JpcHQgd2l0aCB0aGUgcHJlZml4IGBzY3JpcHRQdWJLZXk6YC5cbiAqIFRoaXMgZnVuY3Rpb24gY29udmVydHMgdGhlIGV4dGVuZGVkIGFkZHJlc3MgZm9ybWF0IHRvIGVpdGhlciBhIHNjcmlwdCBvciBhbiBhZGRyZXNzLlxuICogQHBhcmFtIGV4dGVuZGVkQWRkcmVzc1xuICovXG5leHBvcnQgZnVuY3Rpb24gZnJvbUV4dGVuZGVkQWRkcmVzc0Zvcm1hdChleHRlbmRlZEFkZHJlc3M6IHN0cmluZyk6IHsgYWRkcmVzczogc3RyaW5nIH0gfCB7IHNjcmlwdDogc3RyaW5nIH0ge1xuICBpZiAoaXNTY3JpcHRSZWNpcGllbnQoZXh0ZW5kZWRBZGRyZXNzKSkge1xuICAgIHJldHVybiB7IHNjcmlwdDogZXh0ZW5kZWRBZGRyZXNzLnNsaWNlKFNjcmlwdFJlY2lwaWVudFByZWZpeC5sZW5ndGgpIH07XG4gIH1cbiAgcmV0dXJuIHsgYWRkcmVzczogZXh0ZW5kZWRBZGRyZXNzIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmcm9tRXh0ZW5kZWRBZGRyZXNzRm9ybWF0VG9TY3JpcHQoZXh0ZW5kZWRBZGRyZXNzOiBzdHJpbmcsIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IEJ1ZmZlciB7XG4gIGNvbnN0IHJlc3VsdCA9IGZyb21FeHRlbmRlZEFkZHJlc3NGb3JtYXQoZXh0ZW5kZWRBZGRyZXNzKTtcbiAgaWYgKCdzY3JpcHQnIGluIHJlc3VsdCkge1xuICAgIHJldHVybiBCdWZmZXIuZnJvbShyZXN1bHQuc2NyaXB0LCAnaGV4Jyk7XG4gIH1cbiAgcmV0dXJuIHV0eG9saWIuYWRkcmVzc0Zvcm1hdC50b091dHB1dFNjcmlwdFRyeUZvcm1hdHMocmVzdWx0LmFkZHJlc3MsIG5ldHdvcmspO1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzY3JpcHQgb3IgYWRkcmVzcyB0byB0aGUgZXh0ZW5kZWQgYWRkcmVzcyBmb3JtYXQuXG4gKiBAcGFyYW0gc2NyaXB0XG4gKiBAcGFyYW0gbmV0d29ya1xuICogQHJldHVybnMgaWYgdGhlIHNjcmlwdCBpcyBhbiBPUF9SRVRVUk4gc2NyaXB0LCB0aGVuIGl0IHdpbGwgYmUgcHJlZml4ZWQgd2l0aCBgc2NyaXB0UHViS2V5OmAsIG90aGVyd2lzZSBpdCB3aWxsIGJlIGNvbnZlcnRlZCB0byBhbiBhZGRyZXNzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9FeHRlbmRlZEFkZHJlc3NGb3JtYXQoc2NyaXB0OiBCdWZmZXIsIG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IHN0cmluZyB7XG4gIHJldHVybiBzY3JpcHRbMF0gPT09IHV0eG9saWIub3Bjb2Rlcy5PUF9SRVRVUk5cbiAgICA/IGAke1NjcmlwdFJlY2lwaWVudFByZWZpeH0ke3NjcmlwdC50b1N0cmluZygnaGV4Jyl9YFxuICAgIDogdXR4b2xpYi5hZGRyZXNzLmZyb21PdXRwdXRTY3JpcHQoc2NyaXB0LCBuZXR3b3JrKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkVHJhbnNhY3Rpb25SZWNpcGllbnQob3V0cHV0OiB7IGFtb3VudDogYmlnaW50IHwgbnVtYmVyIHwgc3RyaW5nOyBhZGRyZXNzPzogc3RyaW5nIH0pOiB2b2lkIHtcbiAgLy8gSW4gdGhlIGNhc2UgdGhhdCB0aGlzIGlzIGFuIE9QX1JFVFVSTiBvdXRwdXQgb3IgYW5vdGhlciBub24tZW5jb2RhYmxlIHNjcmlwdFB1YmtleSwgd2UgZG9udCBoYXZlIGFuIGFkZHJlc3MuXG4gIC8vIFdlIHdpbGwgdmVyaWZ5IHRoYXQgdGhlIGFtb3VudCBpcyB6ZXJvLCBhbmQgaWYgaXQgaXNudCB0aGVuIHdlIHdpbGwgdGhyb3cgYW4gZXJyb3IuXG4gIGlmICghb3V0cHV0LmFkZHJlc3MgfHwgaXNTY3JpcHRSZWNpcGllbnQob3V0cHV0LmFkZHJlc3MpKSB7XG4gICAgaWYgKG91dHB1dC5hbW91bnQudG9TdHJpbmcoKSAhPT0gJzAnKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE9ubHkgemVybyBhbW91bnRzIGFsbG93ZWQgZm9yIG5vbi1lbmNvZGVhYmxlIHNjcmlwdFB1YmtleXM6ICR7SlNPTi5zdHJpbmdpZnkob3V0cHV0KX1gKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -1,102 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.signTransaction = signTransaction;
40
- const lodash_1 = __importDefault(require("lodash"));
41
- const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
42
- const secp256k1_1 = require("@bitgo-beta/secp256k1");
43
- const debug_1 = __importDefault(require("debug"));
44
- const descriptor_1 = require("../descriptor");
45
- const keychains_1 = require("../keychains");
46
- const fixedScript = __importStar(require("./fixedScript"));
47
- const descriptor = __importStar(require("./descriptor"));
48
- const debug = (0, debug_1.default)('bitgo:abstract-utxo:transaction:signTransaction');
49
- function getSignerKeychain(userPrv) {
50
- if (userPrv === undefined) {
51
- return undefined;
52
- }
53
- if (typeof userPrv !== 'string') {
54
- throw new Error('expected user private key to be a string');
55
- }
56
- const signerKeychain = secp256k1_1.bip32.fromBase58(userPrv, utxolib.networks.bitcoin);
57
- if (signerKeychain.isNeutered()) {
58
- throw new Error('expected user private key but received public key');
59
- }
60
- debug(`Here is the public key of the xprv you used to sign: ${signerKeychain.neutered().toBase58()}`);
61
- return signerKeychain;
62
- }
63
- async function signTransaction(coin, bitgo, params) {
64
- const txPrebuild = params.txPrebuild;
65
- if (lodash_1.default.isUndefined(txPrebuild) || !lodash_1.default.isObject(txPrebuild)) {
66
- if (!lodash_1.default.isUndefined(txPrebuild) && !lodash_1.default.isObject(txPrebuild)) {
67
- throw new Error(`txPrebuild must be an object, got type ${typeof txPrebuild}`);
68
- }
69
- throw new Error('missing txPrebuild parameter');
70
- }
71
- const tx = coin.decodeTransactionFromPrebuild(params.txPrebuild);
72
- const signerKeychain = getSignerKeychain(params.prv);
73
- const { wallet } = params;
74
- if (wallet && (0, descriptor_1.isDescriptorWallet)(wallet)) {
75
- if (!signerKeychain) {
76
- throw new Error('missing signer');
77
- }
78
- const walletKeys = (0, keychains_1.toBip32Triple)(await (0, keychains_1.fetchKeychains)(coin, wallet));
79
- const descriptorMap = (0, descriptor_1.getDescriptorMapFromWallet)(wallet, walletKeys, (0, descriptor_1.getPolicyForEnv)(bitgo.env));
80
- if (tx instanceof utxolib.bitgo.UtxoPsbt) {
81
- descriptor.signPsbt(tx, descriptorMap, signerKeychain, {
82
- onUnknownInput: 'throw',
83
- });
84
- return { txHex: tx.toHex() };
85
- }
86
- else {
87
- throw new Error('expected a UtxoPsbt object');
88
- }
89
- }
90
- else {
91
- return fixedScript.signTransaction(coin, tx, getSignerKeychain(params.prv), {
92
- walletId: params.txPrebuild.walletId,
93
- txInfo: params.txPrebuild.txInfo,
94
- isLastSignature: params.isLastSignature ?? false,
95
- signingStep: params.signingStep,
96
- allowNonSegwitSigningWithoutPrevTx: params.allowNonSegwitSigningWithoutPrevTx ?? false,
97
- pubs: params.pubs,
98
- cosignerPub: params.cosignerPub,
99
- });
100
- }
101
- }
102
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQThCQSwwQ0E2Q0M7QUEzRUQsb0RBQXVCO0FBRXZCLDhEQUFnRDtBQUNoRCxxREFBOEM7QUFDOUMsa0RBQStCO0FBRy9CLDhDQUFnRztBQUNoRyw0Q0FBNkQ7QUFFN0QsMkRBQTZDO0FBQzdDLHlEQUEyQztBQUUzQyxNQUFNLEtBQUssR0FBRyxJQUFBLGVBQVUsRUFBQyxpREFBaUQsQ0FBQyxDQUFDO0FBRTVFLFNBQVMsaUJBQWlCLENBQUMsT0FBZ0I7SUFDekMsSUFBSSxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7UUFDMUIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUNELElBQUksT0FBTyxPQUFPLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDaEMsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFDRCxNQUFNLGNBQWMsR0FBRyxpQkFBSyxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzRSxJQUFJLGNBQWMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsS0FBSyxDQUFDLHdEQUF3RCxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RHLE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUM7QUFFTSxLQUFLLFVBQVUsZUFBZSxDQUNuQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF1QztJQUV2QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO0lBRXJDLElBQUksZ0JBQUMsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBQyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1FBQ3pELElBQUksQ0FBQyxnQkFBQyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGdCQUFDLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDMUQsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsT0FBTyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBQ2pGLENBQUM7UUFDRCxNQUFNLElBQUksS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFakUsTUFBTSxjQUFjLEdBQUcsaUJBQWlCLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXJELE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFMUIsSUFBSSxNQUFNLElBQUksSUFBQSwrQkFBa0IsRUFBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUNELE1BQU0sVUFBVSxHQUFHLElBQUEseUJBQWEsRUFBQyxNQUFNLElBQUEsMEJBQWMsRUFBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNyRSxNQUFNLGFBQWEsR0FBRyxJQUFBLHVDQUEwQixFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsSUFBQSw0QkFBZSxFQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pHLElBQUksRUFBRSxZQUFZLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDekMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRTtnQkFDckQsY0FBYyxFQUFFLE9BQU87YUFDeEIsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUMvQixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztRQUNoRCxDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDTixPQUFPLFdBQVcsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDMUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUMsUUFBUTtZQUNwQyxNQUFNLEVBQUUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNO1lBQ2hDLGVBQWUsRUFBRSxNQUFNLENBQUMsZUFBZSxJQUFJLEtBQUs7WUFDaEQsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXO1lBQy9CLGtDQUFrQyxFQUFFLE1BQU0sQ0FBQyxrQ0FBa0MsSUFBSSxLQUFLO1lBQ3RGLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSTtZQUNqQixXQUFXLEVBQUUsTUFBTSxDQUFDLFdBQVc7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBiaXAzMiB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgYnVpbGREZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5cbmltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMgfSBmcm9tICcuLi9hYnN0cmFjdFV0eG9Db2luJztcbmltcG9ydCB7IGdldERlc2NyaXB0b3JNYXBGcm9tV2FsbGV0LCBnZXRQb2xpY3lGb3JFbnYsIGlzRGVzY3JpcHRvcldhbGxldCB9IGZyb20gJy4uL2Rlc2NyaXB0b3InO1xuaW1wb3J0IHsgZmV0Y2hLZXljaGFpbnMsIHRvQmlwMzJUcmlwbGUgfSBmcm9tICcuLi9rZXljaGFpbnMnO1xuXG5pbXBvcnQgKiBhcyBmaXhlZFNjcmlwdCBmcm9tICcuL2ZpeGVkU2NyaXB0JztcbmltcG9ydCAqIGFzIGRlc2NyaXB0b3IgZnJvbSAnLi9kZXNjcmlwdG9yJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnRyYW5zYWN0aW9uOnNpZ25UcmFuc2FjdGlvbicpO1xuXG5mdW5jdGlvbiBnZXRTaWduZXJLZXljaGFpbih1c2VyUHJ2OiB1bmtub3duKTogdXR4b2xpYi5CSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCB7XG4gIGlmICh1c2VyUHJ2ID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG4gIGlmICh0eXBlb2YgdXNlclBydiAhPT0gJ3N0cmluZycpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2V4cGVjdGVkIHVzZXIgcHJpdmF0ZSBrZXkgdG8gYmUgYSBzdHJpbmcnKTtcbiAgfVxuICBjb25zdCBzaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgodXNlclBydiwgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luKTtcbiAgaWYgKHNpZ25lcktleWNoYWluLmlzTmV1dGVyZWQoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgdXNlciBwcml2YXRlIGtleSBidXQgcmVjZWl2ZWQgcHVibGljIGtleScpO1xuICB9XG4gIGRlYnVnKGBIZXJlIGlzIHRoZSBwdWJsaWMga2V5IG9mIHRoZSB4cHJ2IHlvdSB1c2VkIHRvIHNpZ246ICR7c2lnbmVyS2V5Y2hhaW4ubmV1dGVyZWQoKS50b0Jhc2U1OCgpfWApO1xuICByZXR1cm4gc2lnbmVyS2V5Y2hhaW47XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIGJpdGdvOiBCaXRHb0Jhc2UsXG4gIHBhcmFtczogU2lnblRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTx7IHR4SGV4OiBzdHJpbmcgfT4ge1xuICBjb25zdCB0eFByZWJ1aWxkID0gcGFyYW1zLnR4UHJlYnVpbGQ7XG5cbiAgaWYgKF8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgfHwgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICBpZiAoIV8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgJiYgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdHhQcmVidWlsZCBtdXN0IGJlIGFuIG9iamVjdCwgZ290IHR5cGUgJHt0eXBlb2YgdHhQcmVidWlsZH1gKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHR4UHJlYnVpbGQgcGFyYW1ldGVyJyk7XG4gIH1cblxuICBjb25zdCB0eCA9IGNvaW4uZGVjb2RlVHJhbnNhY3Rpb25Gcm9tUHJlYnVpbGQocGFyYW1zLnR4UHJlYnVpbGQpO1xuXG4gIGNvbnN0IHNpZ25lcktleWNoYWluID0gZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydik7XG5cbiAgY29uc3QgeyB3YWxsZXQgfSA9IHBhcmFtcztcblxuICBpZiAod2FsbGV0ICYmIGlzRGVzY3JpcHRvcldhbGxldCh3YWxsZXQpKSB7XG4gICAgaWYgKCFzaWduZXJLZXljaGFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHNpZ25lcicpO1xuICAgIH1cbiAgICBjb25zdCB3YWxsZXRLZXlzID0gdG9CaXAzMlRyaXBsZShhd2FpdCBmZXRjaEtleWNoYWlucyhjb2luLCB3YWxsZXQpKTtcbiAgICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvck1hcEZyb21XYWxsZXQod2FsbGV0LCB3YWxsZXRLZXlzLCBnZXRQb2xpY3lGb3JFbnYoYml0Z28uZW52KSk7XG4gICAgaWYgKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkge1xuICAgICAgZGVzY3JpcHRvci5zaWduUHNidCh0eCwgZGVzY3JpcHRvck1hcCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgICAgb25Vbmtub3duSW5wdXQ6ICd0aHJvdycsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7IHR4SGV4OiB0eC50b0hleCgpIH07XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgYSBVdHhvUHNidCBvYmplY3QnKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGZpeGVkU2NyaXB0LnNpZ25UcmFuc2FjdGlvbihjb2luLCB0eCwgZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydiksIHtcbiAgICAgIHdhbGxldElkOiBwYXJhbXMudHhQcmVidWlsZC53YWxsZXRJZCxcbiAgICAgIHR4SW5mbzogcGFyYW1zLnR4UHJlYnVpbGQudHhJbmZvLFxuICAgICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlID8/IGZhbHNlLFxuICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IHBhcmFtcy5hbGxvd05vblNlZ3dpdFNpZ25pbmdXaXRob3V0UHJldlR4ID8/IGZhbHNlLFxuICAgICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgICBjb3NpZ25lclB1YjogcGFyYW1zLmNvc2lnbmVyUHViLFxuICAgIH0pO1xuICB9XG59XG4iXX0=