@yaswap/wallet-core 2.0.0

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 (563) hide show
  1. package/CHANGELOG.md +804 -0
  2. package/README.md +163 -0
  3. package/dist/package.json +76 -0
  4. package/dist/src/build.config.d.ts +46 -0
  5. package/dist/src/build.config.js +237 -0
  6. package/dist/src/build.config.js.map +1 -0
  7. package/dist/src/factory/client/clients.d.ts +11 -0
  8. package/dist/src/factory/client/clients.js +119 -0
  9. package/dist/src/factory/client/clients.js.map +1 -0
  10. package/dist/src/factory/client/evm.d.ts +6 -0
  11. package/dist/src/factory/client/evm.js +71 -0
  12. package/dist/src/factory/client/evm.js.map +1 -0
  13. package/dist/src/factory/client/index.d.ts +11 -0
  14. package/dist/src/factory/client/index.js +38 -0
  15. package/dist/src/factory/client/index.js.map +1 -0
  16. package/dist/src/factory/client/nft.d.ts +4 -0
  17. package/dist/src/factory/client/nft.js +26 -0
  18. package/dist/src/factory/client/nft.js.map +1 -0
  19. package/dist/src/factory/index.d.ts +3 -0
  20. package/dist/src/factory/index.js +7 -0
  21. package/dist/src/factory/index.js.map +1 -0
  22. package/dist/src/factory/settings.d.ts +4 -0
  23. package/dist/src/factory/settings.js +27 -0
  24. package/dist/src/factory/settings.js.map +1 -0
  25. package/dist/src/factory/swap/index.d.ts +4 -0
  26. package/dist/src/factory/swap/index.js +66 -0
  27. package/dist/src/factory/swap/index.js.map +1 -0
  28. package/dist/src/index.d.ts +1619 -0
  29. package/dist/src/index.js +38 -0
  30. package/dist/src/index.js.map +1 -0
  31. package/dist/src/index.test.d.ts +1 -0
  32. package/dist/src/index.test.js +187 -0
  33. package/dist/src/index.test.js.map +1 -0
  34. package/dist/src/nameResolvers/nameResolver.d.ts +7 -0
  35. package/dist/src/nameResolvers/nameResolver.js +3 -0
  36. package/dist/src/nameResolvers/nameResolver.js.map +1 -0
  37. package/dist/src/nameResolvers/uns.d.ts +12 -0
  38. package/dist/src/nameResolvers/uns.js +83 -0
  39. package/dist/src/nameResolvers/uns.js.map +1 -0
  40. package/dist/src/nameResolvers/uns.test.d.ts +1 -0
  41. package/dist/src/nameResolvers/uns.test.js +29 -0
  42. package/dist/src/nameResolvers/uns.test.js.map +1 -0
  43. package/dist/src/store/actions/acceptTermsAndConditions.d.ts +4 -0
  44. package/dist/src/store/actions/acceptTermsAndConditions.js +17 -0
  45. package/dist/src/store/actions/acceptTermsAndConditions.js.map +1 -0
  46. package/dist/src/store/actions/acceptTermsAndConditions.test.d.ts +1 -0
  47. package/dist/src/store/actions/acceptTermsAndConditions.test.js +22 -0
  48. package/dist/src/store/actions/acceptTermsAndConditions.test.js.map +1 -0
  49. package/dist/src/store/actions/accounts/createAccount.d.ts +7 -0
  50. package/dist/src/store/actions/accounts/createAccount.js +27 -0
  51. package/dist/src/store/actions/accounts/createAccount.js.map +1 -0
  52. package/dist/src/store/actions/accounts/createAccount.test.d.ts +1 -0
  53. package/dist/src/store/actions/accounts/createAccount.test.js +29 -0
  54. package/dist/src/store/actions/accounts/createAccount.test.js.map +1 -0
  55. package/dist/src/store/actions/accounts/index.d.ts +5 -0
  56. package/dist/src/store/actions/accounts/index.js +9 -0
  57. package/dist/src/store/actions/accounts/index.js.map +1 -0
  58. package/dist/src/store/actions/accounts/removeAccount.d.ts +7 -0
  59. package/dist/src/store/actions/accounts/removeAccount.js +12 -0
  60. package/dist/src/store/actions/accounts/removeAccount.js.map +1 -0
  61. package/dist/src/store/actions/accounts/removeAccount.test.d.ts +1 -0
  62. package/dist/src/store/actions/accounts/removeAccount.test.js +53 -0
  63. package/dist/src/store/actions/accounts/removeAccount.test.js.map +1 -0
  64. package/dist/src/store/actions/accounts/toggleAccount.d.ts +8 -0
  65. package/dist/src/store/actions/accounts/toggleAccount.js +19 -0
  66. package/dist/src/store/actions/accounts/toggleAccount.js.map +1 -0
  67. package/dist/src/store/actions/accounts/toggleAccount.test.d.ts +1 -0
  68. package/dist/src/store/actions/accounts/toggleAccount.test.js +44 -0
  69. package/dist/src/store/actions/accounts/toggleAccount.test.js.map +1 -0
  70. package/dist/src/store/actions/accounts/toggleBlockchain.d.ts +9 -0
  71. package/dist/src/store/actions/accounts/toggleBlockchain.js +14 -0
  72. package/dist/src/store/actions/accounts/toggleBlockchain.js.map +1 -0
  73. package/dist/src/store/actions/accounts/updateAccount.d.ts +26 -0
  74. package/dist/src/store/actions/accounts/updateAccount.js +14 -0
  75. package/dist/src/store/actions/accounts/updateAccount.js.map +1 -0
  76. package/dist/src/store/actions/addCustomToken.d.ts +12 -0
  77. package/dist/src/store/actions/addCustomToken.js +12 -0
  78. package/dist/src/store/actions/addCustomToken.js.map +1 -0
  79. package/dist/src/store/actions/addCustomToken.test.d.ts +1 -0
  80. package/dist/src/store/actions/addCustomToken.test.js +59 -0
  81. package/dist/src/store/actions/addCustomToken.test.js.map +1 -0
  82. package/dist/src/store/actions/addExternalConnection.d.ts +9 -0
  83. package/dist/src/store/actions/addExternalConnection.js +13 -0
  84. package/dist/src/store/actions/addExternalConnection.js.map +1 -0
  85. package/dist/src/store/actions/addExternalConnection.test.d.ts +1 -0
  86. package/dist/src/store/actions/addExternalConnection.test.js +100 -0
  87. package/dist/src/store/actions/addExternalConnection.test.js.map +1 -0
  88. package/dist/src/store/actions/analytics.d.ts +21 -0
  89. package/dist/src/store/actions/analytics.js +58 -0
  90. package/dist/src/store/actions/analytics.js.map +1 -0
  91. package/dist/src/store/actions/analytics.test.d.ts +1 -0
  92. package/dist/src/store/actions/analytics.test.js +33 -0
  93. package/dist/src/store/actions/analytics.test.js.map +1 -0
  94. package/dist/src/store/actions/changeActiveNetwork.d.ts +5 -0
  95. package/dist/src/store/actions/changeActiveNetwork.js +13 -0
  96. package/dist/src/store/actions/changeActiveNetwork.js.map +1 -0
  97. package/dist/src/store/actions/changeActiveWalletId.d.ts +5 -0
  98. package/dist/src/store/actions/changeActiveWalletId.js +11 -0
  99. package/dist/src/store/actions/changeActiveWalletId.js.map +1 -0
  100. package/dist/src/store/actions/changeActiveWalletId.test.d.ts +1 -0
  101. package/dist/src/store/actions/changeActiveWalletId.test.js +40 -0
  102. package/dist/src/store/actions/changeActiveWalletId.test.js.map +1 -0
  103. package/dist/src/store/actions/changePassword.d.ts +4 -0
  104. package/dist/src/store/actions/changePassword.js +13 -0
  105. package/dist/src/store/actions/changePassword.js.map +1 -0
  106. package/dist/src/store/actions/changePassword.test.d.ts +1 -0
  107. package/dist/src/store/actions/changePassword.test.js +22 -0
  108. package/dist/src/store/actions/changePassword.test.js.map +1 -0
  109. package/dist/src/store/actions/checkPendingActions.d.ts +5 -0
  110. package/dist/src/store/actions/checkPendingActions.js +25 -0
  111. package/dist/src/store/actions/checkPendingActions.js.map +1 -0
  112. package/dist/src/store/actions/clearErrorLog.d.ts +2 -0
  113. package/dist/src/store/actions/clearErrorLog.js +10 -0
  114. package/dist/src/store/actions/clearErrorLog.js.map +1 -0
  115. package/dist/src/store/actions/createWallet.d.ts +7 -0
  116. package/dist/src/store/actions/createWallet.js +90 -0
  117. package/dist/src/store/actions/createWallet.js.map +1 -0
  118. package/dist/src/store/actions/createWallet.test.d.ts +1 -0
  119. package/dist/src/store/actions/createWallet.test.js +41 -0
  120. package/dist/src/store/actions/createWallet.test.js.map +1 -0
  121. package/dist/src/store/actions/customChainSettings.d.ts +15 -0
  122. package/dist/src/store/actions/customChainSettings.js +37 -0
  123. package/dist/src/store/actions/customChainSettings.js.map +1 -0
  124. package/dist/src/store/actions/disableAssets.d.ts +7 -0
  125. package/dist/src/store/actions/disableAssets.js +28 -0
  126. package/dist/src/store/actions/disableAssets.js.map +1 -0
  127. package/dist/src/store/actions/disableEthereumInjection.d.ts +2 -0
  128. package/dist/src/store/actions/disableEthereumInjection.js +11 -0
  129. package/dist/src/store/actions/disableEthereumInjection.js.map +1 -0
  130. package/dist/src/store/actions/disableEthereumInjection.test.d.ts +1 -0
  131. package/dist/src/store/actions/disableEthereumInjection.test.js +24 -0
  132. package/dist/src/store/actions/disableEthereumInjection.test.js.map +1 -0
  133. package/dist/src/store/actions/enableAssets.d.ts +7 -0
  134. package/dist/src/store/actions/enableAssets.js +65 -0
  135. package/dist/src/store/actions/enableAssets.js.map +1 -0
  136. package/dist/src/store/actions/enableAssets.test.d.ts +1 -0
  137. package/dist/src/store/actions/enableAssets.test.js +37 -0
  138. package/dist/src/store/actions/enableAssets.test.js.map +1 -0
  139. package/dist/src/store/actions/enableDisableAssets.test.d.ts +1 -0
  140. package/dist/src/store/actions/enableDisableAssets.test.js +79 -0
  141. package/dist/src/store/actions/enableDisableAssets.test.js.map +1 -0
  142. package/dist/src/store/actions/enableEthereumInjection.d.ts +2 -0
  143. package/dist/src/store/actions/enableEthereumInjection.js +11 -0
  144. package/dist/src/store/actions/enableEthereumInjection.js.map +1 -0
  145. package/dist/src/store/actions/exportPrivateKey.d.ts +9 -0
  146. package/dist/src/store/actions/exportPrivateKey.js +12 -0
  147. package/dist/src/store/actions/exportPrivateKey.js.map +1 -0
  148. package/dist/src/store/actions/exportPrivateKey.test.d.ts +1 -0
  149. package/dist/src/store/actions/exportPrivateKey.test.js +36 -0
  150. package/dist/src/store/actions/exportPrivateKey.test.js.map +1 -0
  151. package/dist/src/store/actions/fetchTokenDetails.d.ts +11 -0
  152. package/dist/src/store/actions/fetchTokenDetails.js +22 -0
  153. package/dist/src/store/actions/fetchTokenDetails.js.map +1 -0
  154. package/dist/src/store/actions/forgetDappConnections.d.ts +2 -0
  155. package/dist/src/store/actions/forgetDappConnections.js +11 -0
  156. package/dist/src/store/actions/forgetDappConnections.js.map +1 -0
  157. package/dist/src/store/actions/getLockForAsset.d.ts +8 -0
  158. package/dist/src/store/actions/getLockForAsset.js +34 -0
  159. package/dist/src/store/actions/getLockForAsset.js.map +1 -0
  160. package/dist/src/store/actions/getQuotes.d.ts +13 -0
  161. package/dist/src/store/actions/getQuotes.js +70 -0
  162. package/dist/src/store/actions/getQuotes.js.map +1 -0
  163. package/dist/src/store/actions/getQuotes.test.d.ts +1 -0
  164. package/dist/src/store/actions/getQuotes.test.js +30 -0
  165. package/dist/src/store/actions/getQuotes.test.js.map +1 -0
  166. package/dist/src/store/actions/getUnusedAddresses.d.ts +8 -0
  167. package/dist/src/store/actions/getUnusedAddresses.js +51 -0
  168. package/dist/src/store/actions/getUnusedAddresses.js.map +1 -0
  169. package/dist/src/store/actions/hardware-wallet/getLedgerAccounts.d.ts +16 -0
  170. package/dist/src/store/actions/hardware-wallet/getLedgerAccounts.js +57 -0
  171. package/dist/src/store/actions/hardware-wallet/getLedgerAccounts.js.map +1 -0
  172. package/dist/src/store/actions/hardware-wallet/index.d.ts +1 -0
  173. package/dist/src/store/actions/hardware-wallet/index.js +5 -0
  174. package/dist/src/store/actions/hardware-wallet/index.js.map +1 -0
  175. package/dist/src/store/actions/index.d.ts +47 -0
  176. package/dist/src/store/actions/index.js +51 -0
  177. package/dist/src/store/actions/index.js.map +1 -0
  178. package/dist/src/store/actions/initializeAddresses.d.ts +6 -0
  179. package/dist/src/store/actions/initializeAddresses.js +26 -0
  180. package/dist/src/store/actions/initializeAddresses.js.map +1 -0
  181. package/dist/src/store/actions/initializeAddresses.test.d.ts +1 -0
  182. package/dist/src/store/actions/initializeAddresses.test.js +58 -0
  183. package/dist/src/store/actions/initializeAddresses.test.js.map +1 -0
  184. package/dist/src/store/actions/lockWallet.d.ts +2 -0
  185. package/dist/src/store/actions/lockWallet.js +11 -0
  186. package/dist/src/store/actions/lockWallet.js.map +1 -0
  187. package/dist/src/store/actions/lockWallet.test.d.ts +1 -0
  188. package/dist/src/store/actions/lockWallet.test.js +24 -0
  189. package/dist/src/store/actions/lockWallet.test.js.map +1 -0
  190. package/dist/src/store/actions/logError.d.ts +3 -0
  191. package/dist/src/store/actions/logError.js +10 -0
  192. package/dist/src/store/actions/logError.js.map +1 -0
  193. package/dist/src/store/actions/logError.test.d.ts +1 -0
  194. package/dist/src/store/actions/logError.test.js +27 -0
  195. package/dist/src/store/actions/logError.test.js.map +1 -0
  196. package/dist/src/store/actions/newSwap.d.ts +12 -0
  197. package/dist/src/store/actions/newSwap.js +34 -0
  198. package/dist/src/store/actions/newSwap.js.map +1 -0
  199. package/dist/src/store/actions/performNextAction/index.d.ts +7 -0
  200. package/dist/src/store/actions/performNextAction/index.js +65 -0
  201. package/dist/src/store/actions/performNextAction/index.js.map +1 -0
  202. package/dist/src/store/actions/performNextAction/send.d.ts +7 -0
  203. package/dist/src/store/actions/performNextAction/send.js +54 -0
  204. package/dist/src/store/actions/performNextAction/send.js.map +1 -0
  205. package/dist/src/store/actions/performNextAction/sendNFT.d.ts +7 -0
  206. package/dist/src/store/actions/performNextAction/sendNFT.js +50 -0
  207. package/dist/src/store/actions/performNextAction/sendNFT.js.map +1 -0
  208. package/dist/src/store/actions/performNextAction/utils.d.ts +11 -0
  209. package/dist/src/store/actions/performNextAction/utils.js +42 -0
  210. package/dist/src/store/actions/performNextAction/utils.js.map +1 -0
  211. package/dist/src/store/actions/proxyMutation.d.ts +5 -0
  212. package/dist/src/store/actions/proxyMutation.js +9 -0
  213. package/dist/src/store/actions/proxyMutation.js.map +1 -0
  214. package/dist/src/store/actions/removeCustomToken.d.ts +7 -0
  215. package/dist/src/store/actions/removeCustomToken.js +11 -0
  216. package/dist/src/store/actions/removeCustomToken.js.map +1 -0
  217. package/dist/src/store/actions/retrySwap.d.ts +5 -0
  218. package/dist/src/store/actions/retrySwap.js +23 -0
  219. package/dist/src/store/actions/retrySwap.js.map +1 -0
  220. package/dist/src/store/actions/sendNFTTransaction.d.ts +4 -0
  221. package/dist/src/store/actions/sendNFTTransaction.js +47 -0
  222. package/dist/src/store/actions/sendNFTTransaction.js.map +1 -0
  223. package/dist/src/store/actions/sendTransaction.d.ts +17 -0
  224. package/dist/src/store/actions/sendTransaction.js +51 -0
  225. package/dist/src/store/actions/sendTransaction.js.map +1 -0
  226. package/dist/src/store/actions/sendTransaction.test.d.ts +1 -0
  227. package/dist/src/store/actions/sendTransaction.test.js +80 -0
  228. package/dist/src/store/actions/sendTransaction.test.js.map +1 -0
  229. package/dist/src/store/actions/setEthereumInjectionChain.d.ts +5 -0
  230. package/dist/src/store/actions/setEthereumInjectionChain.js +11 -0
  231. package/dist/src/store/actions/setEthereumInjectionChain.js.map +1 -0
  232. package/dist/src/store/actions/setEthereumInjectionChain.test.d.ts +1 -0
  233. package/dist/src/store/actions/setEthereumInjectionChain.test.js +20 -0
  234. package/dist/src/store/actions/setEthereumInjectionChain.test.js.map +1 -0
  235. package/dist/src/store/actions/setWhatsNewModalVersion.d.ts +4 -0
  236. package/dist/src/store/actions/setWhatsNewModalVersion.js +10 -0
  237. package/dist/src/store/actions/setWhatsNewModalVersion.js.map +1 -0
  238. package/dist/src/store/actions/setWhatsNewModalVersion.test.d.ts +1 -0
  239. package/dist/src/store/actions/setWhatsNewModalVersion.test.js +24 -0
  240. package/dist/src/store/actions/setWhatsNewModalVersion.test.js.map +1 -0
  241. package/dist/src/store/actions/showNotification.d.ts +2 -0
  242. package/dist/src/store/actions/showNotification.js +10 -0
  243. package/dist/src/store/actions/showNotification.js.map +1 -0
  244. package/dist/src/store/actions/toggleExperiment.d.ts +5 -0
  245. package/dist/src/store/actions/toggleExperiment.js +10 -0
  246. package/dist/src/store/actions/toggleExperiment.js.map +1 -0
  247. package/dist/src/store/actions/toggleExperiment.test.d.ts +1 -0
  248. package/dist/src/store/actions/toggleExperiment.test.js +34 -0
  249. package/dist/src/store/actions/toggleExperiment.test.js.map +1 -0
  250. package/dist/src/store/actions/toggleNFTStarred.d.ts +8 -0
  251. package/dist/src/store/actions/toggleNFTStarred.js +10 -0
  252. package/dist/src/store/actions/toggleNFTStarred.js.map +1 -0
  253. package/dist/src/store/actions/unlockWallet.d.ts +4 -0
  254. package/dist/src/store/actions/unlockWallet.js +22 -0
  255. package/dist/src/store/actions/unlockWallet.js.map +1 -0
  256. package/dist/src/store/actions/updateAccountBalance.d.ts +7 -0
  257. package/dist/src/store/actions/updateAccountBalance.js +29 -0
  258. package/dist/src/store/actions/updateAccountBalance.js.map +1 -0
  259. package/dist/src/store/actions/updateBalances.d.ts +9 -0
  260. package/dist/src/store/actions/updateBalances.js +169 -0
  261. package/dist/src/store/actions/updateBalances.js.map +1 -0
  262. package/dist/src/store/actions/updateBalances.test.d.ts +1 -0
  263. package/dist/src/store/actions/updateBalances.test.js +43 -0
  264. package/dist/src/store/actions/updateBalances.test.js.map +1 -0
  265. package/dist/src/store/actions/updateCurrenciesInfo.d.ts +5 -0
  266. package/dist/src/store/actions/updateCurrenciesInfo.js +14 -0
  267. package/dist/src/store/actions/updateCurrenciesInfo.js.map +1 -0
  268. package/dist/src/store/actions/updateFees.d.ts +6 -0
  269. package/dist/src/store/actions/updateFees.js +16 -0
  270. package/dist/src/store/actions/updateFees.js.map +1 -0
  271. package/dist/src/store/actions/updateFees.test.d.ts +1 -0
  272. package/dist/src/store/actions/updateFees.test.js +86 -0
  273. package/dist/src/store/actions/updateFees.test.js.map +1 -0
  274. package/dist/src/store/actions/updateFiatRates.d.ts +5 -0
  275. package/dist/src/store/actions/updateFiatRates.js +15 -0
  276. package/dist/src/store/actions/updateFiatRates.js.map +1 -0
  277. package/dist/src/store/actions/updateFiatRates.test.d.ts +1 -0
  278. package/dist/src/store/actions/updateFiatRates.test.js +43 -0
  279. package/dist/src/store/actions/updateFiatRates.test.js.map +1 -0
  280. package/dist/src/store/actions/updateMarketData.d.ts +8 -0
  281. package/dist/src/store/actions/updateMarketData.js +28 -0
  282. package/dist/src/store/actions/updateMarketData.js.map +1 -0
  283. package/dist/src/store/actions/updateMarketData.test.d.ts +1 -0
  284. package/dist/src/store/actions/updateMarketData.test.js +49 -0
  285. package/dist/src/store/actions/updateMarketData.test.js.map +1 -0
  286. package/dist/src/store/actions/updateNFTs.d.ts +7 -0
  287. package/dist/src/store/actions/updateNFTs.js +39 -0
  288. package/dist/src/store/actions/updateNFTs.js.map +1 -0
  289. package/dist/src/store/actions/updateNFTs.test.d.ts +1 -0
  290. package/dist/src/store/actions/updateNFTs.test.js +32 -0
  291. package/dist/src/store/actions/updateNFTs.test.js.map +1 -0
  292. package/dist/src/store/actions/updateTransactionFee.d.ts +11 -0
  293. package/dist/src/store/actions/updateTransactionFee.js +81 -0
  294. package/dist/src/store/actions/updateTransactionFee.js.map +1 -0
  295. package/dist/src/store/broker/notification.d.ts +4 -0
  296. package/dist/src/store/broker/notification.js +84 -0
  297. package/dist/src/store/broker/notification.js.map +1 -0
  298. package/dist/src/store/getters.d.ts +59 -0
  299. package/dist/src/store/getters.js +350 -0
  300. package/dist/src/store/getters.js.map +1 -0
  301. package/dist/src/store/index.d.ts +3524 -0
  302. package/dist/src/store/index.js +24 -0
  303. package/dist/src/store/index.js.map +1 -0
  304. package/dist/src/store/migrations/10_analytics_settings.d.ts +4 -0
  305. package/dist/src/store/migrations/10_analytics_settings.js +19 -0
  306. package/dist/src/store/migrations/10_analytics_settings.js.map +1 -0
  307. package/dist/src/store/migrations/11_12_rsk_legacy_derivation_path.d.ts +8 -0
  308. package/dist/src/store/migrations/11_12_rsk_legacy_derivation_path.js +22 -0
  309. package/dist/src/store/migrations/11_12_rsk_legacy_derivation_path.js.map +1 -0
  310. package/dist/src/store/migrations/13_rsk_fish_token.d.ts +4 -0
  311. package/dist/src/store/migrations/13_rsk_fish_token.js +19 -0
  312. package/dist/src/store/migrations/13_rsk_fish_token.js.map +1 -0
  313. package/dist/src/store/migrations/14_account_set_derivation_path.d.ts +4 -0
  314. package/dist/src/store/migrations/14_account_set_derivation_path.js +56 -0
  315. package/dist/src/store/migrations/14_account_set_derivation_path.js.map +1 -0
  316. package/dist/src/store/migrations/15_accounts_chains_set_enabled.d.ts +4 -0
  317. package/dist/src/store/migrations/15_accounts_chains_set_enabled.js +25 -0
  318. package/dist/src/store/migrations/15_accounts_chains_set_enabled.js.map +1 -0
  319. package/dist/src/store/migrations/16_enable_terra_chain.d.ts +4 -0
  320. package/dist/src/store/migrations/16_enable_terra_chain.js +10 -0
  321. package/dist/src/store/migrations/16_enable_terra_chain.js.map +1 -0
  322. package/dist/src/store/migrations/17_remove_injection_enabled.d.ts +4 -0
  323. package/dist/src/store/migrations/17_remove_injection_enabled.js +12 -0
  324. package/dist/src/store/migrations/17_remove_injection_enabled.js.map +1 -0
  325. package/dist/src/store/migrations/18_enable_avalanche_chain.d.ts +4 -0
  326. package/dist/src/store/migrations/18_enable_avalanche_chain.js +10 -0
  327. package/dist/src/store/migrations/18_enable_avalanche_chain.js.map +1 -0
  328. package/dist/src/store/migrations/19_remove_existing_ledger_accounts.d.ts +4 -0
  329. package/dist/src/store/migrations/19_remove_existing_ledger_accounts.js +25 -0
  330. package/dist/src/store/migrations/19_remove_existing_ledger_accounts.js.map +1 -0
  331. package/dist/src/store/migrations/19_remove_existing_ledger_accounts.state.pre.json +1944 -0
  332. package/dist/src/store/migrations/19_remove_existing_ledger_accounts_test.d.ts +1 -0
  333. package/dist/src/store/migrations/19_remove_existing_ledger_accounts_test.js +7 -0
  334. package/dist/src/store/migrations/19_remove_existing_ledger_accounts_test.js.map +1 -0
  335. package/dist/src/store/migrations/1_first_migration.d.ts +4 -0
  336. package/dist/src/store/migrations/1_first_migration.js +11 -0
  337. package/dist/src/store/migrations/1_first_migration.js.map +1 -0
  338. package/dist/src/store/migrations/20_fix_accounts.d.ts +4 -0
  339. package/dist/src/store/migrations/20_fix_accounts.js +68 -0
  340. package/dist/src/store/migrations/20_fix_accounts.js.map +1 -0
  341. package/dist/src/store/migrations/21_enable_solana_chain.d.ts +4 -0
  342. package/dist/src/store/migrations/21_enable_solana_chain.js +10 -0
  343. package/dist/src/store/migrations/21_enable_solana_chain.js.map +1 -0
  344. package/dist/src/store/migrations/22_enable_optimism_chain.d.ts +4 -0
  345. package/dist/src/store/migrations/22_enable_optimism_chain.js +10 -0
  346. package/dist/src/store/migrations/22_enable_optimism_chain.js.map +1 -0
  347. package/dist/src/store/migrations/2_set_default_assets.d.ts +4 -0
  348. package/dist/src/store/migrations/2_set_default_assets.js +20 -0
  349. package/dist/src/store/migrations/2_set_default_assets.js.map +1 -0
  350. package/dist/src/store/migrations/3_add_network_custom_tokens.d.ts +4 -0
  351. package/dist/src/store/migrations/3_add_network_custom_tokens.js +21 -0
  352. package/dist/src/store/migrations/3_add_network_custom_tokens.js.map +1 -0
  353. package/dist/src/store/migrations/4_fix_rsk_token_injected_asset.d.ts +4 -0
  354. package/dist/src/store/migrations/4_fix_rsk_token_injected_asset.js +15 -0
  355. package/dist/src/store/migrations/4_fix_rsk_token_injected_asset.js.map +1 -0
  356. package/dist/src/store/migrations/5_multiple_account_support.d.ts +4 -0
  357. package/dist/src/store/migrations/5_multiple_account_support.js +96 -0
  358. package/dist/src/store/migrations/5_multiple_account_support.js.map +1 -0
  359. package/dist/src/store/migrations/6_use_ledger_live_default.d.ts +4 -0
  360. package/dist/src/store/migrations/6_use_ledger_live_default.js +11 -0
  361. package/dist/src/store/migrations/6_use_ledger_live_default.js.map +1 -0
  362. package/dist/src/store/migrations/7_multi_provider_swaps.d.ts +4 -0
  363. package/dist/src/store/migrations/7_multi_provider_swaps.js +27 -0
  364. package/dist/src/store/migrations/7_multi_provider_swaps.js.map +1 -0
  365. package/dist/src/store/migrations/8_remove_use_ledger_live.d.ts +4 -0
  366. package/dist/src/store/migrations/8_remove_use_ledger_live.js +12 -0
  367. package/dist/src/store/migrations/8_remove_use_ledger_live.js.map +1 -0
  368. package/dist/src/store/migrations/9_inject_ethereum_asset_chain.d.ts +4 -0
  369. package/dist/src/store/migrations/9_inject_ethereum_asset_chain.js +14 -0
  370. package/dist/src/store/migrations/9_inject_ethereum_asset_chain.js.map +1 -0
  371. package/dist/src/store/migrations/before_after_migration_script.test.d.ts +1 -0
  372. package/dist/src/store/migrations/before_after_migration_script.test.js +92 -0
  373. package/dist/src/store/migrations/before_after_migration_script.test.js.map +1 -0
  374. package/dist/src/store/migrations/enable_chain.d.ts +3 -0
  375. package/dist/src/store/migrations/enable_chain.js +71 -0
  376. package/dist/src/store/migrations/enable_chain.js.map +1 -0
  377. package/dist/src/store/migrations/index.d.ts +5 -0
  378. package/dist/src/store/migrations/index.js +78 -0
  379. package/dist/src/store/migrations/index.js.map +1 -0
  380. package/dist/src/store/migrations/migration_script.test.d.ts +1 -0
  381. package/dist/src/store/migrations/migration_script.test.js +59 -0
  382. package/dist/src/store/migrations/migration_script.test.js.map +1 -0
  383. package/dist/src/store/mutations.d.ts +209 -0
  384. package/dist/src/store/mutations.js +348 -0
  385. package/dist/src/store/mutations.js.map +1 -0
  386. package/dist/src/store/state.d.ts +3 -0
  387. package/dist/src/store/state.js +46 -0
  388. package/dist/src/store/state.js.map +1 -0
  389. package/dist/src/store/types.d.ts +249 -0
  390. package/dist/src/store/types.js +64 -0
  391. package/dist/src/store/types.js.map +1 -0
  392. package/dist/src/store/utils.d.ts +38 -0
  393. package/dist/src/store/utils.js +194 -0
  394. package/dist/src/store/utils.js.map +1 -0
  395. package/dist/src/swaps/EvmSwapProvider.d.ts +32 -0
  396. package/dist/src/swaps/EvmSwapProvider.js +118 -0
  397. package/dist/src/swaps/EvmSwapProvider.js.map +1 -0
  398. package/dist/src/swaps/SwapProvider.d.ts +35 -0
  399. package/dist/src/swaps/SwapProvider.js +89 -0
  400. package/dist/src/swaps/SwapProvider.js.map +1 -0
  401. package/dist/src/swaps/astroport/AstroportSwapProvider.d.ts +67 -0
  402. package/dist/src/swaps/astroport/AstroportSwapProvider.js +251 -0
  403. package/dist/src/swaps/astroport/AstroportSwapProvider.js.map +1 -0
  404. package/dist/src/swaps/astroport/info.json +7 -0
  405. package/dist/src/swaps/astroport/queries.d.ts +108 -0
  406. package/dist/src/swaps/astroport/queries.js +227 -0
  407. package/dist/src/swaps/astroport/queries.js.map +1 -0
  408. package/dist/src/swaps/debridge/DeBridgeSwapProvider.d.ts +98 -0
  409. package/dist/src/swaps/debridge/DeBridgeSwapProvider.js +553 -0
  410. package/dist/src/swaps/debridge/DeBridgeSwapProvider.js.map +1 -0
  411. package/dist/src/swaps/debridge/abi/DeBridgeGate.json +1958 -0
  412. package/dist/src/swaps/debridge/abi/SignatureVerifier.json +925 -0
  413. package/dist/src/swaps/debridge/info.json +13 -0
  414. package/dist/src/swaps/fastbtc/FastBTCDepositSwapProvider.d.ts +103 -0
  415. package/dist/src/swaps/fastbtc/FastBTCDepositSwapProvider.js +292 -0
  416. package/dist/src/swaps/fastbtc/FastBTCDepositSwapProvider.js.map +1 -0
  417. package/dist/src/swaps/fastbtc/FastBTCWithdrawSwapProvider.d.ts +108 -0
  418. package/dist/src/swaps/fastbtc/FastBTCWithdrawSwapProvider.js +306 -0
  419. package/dist/src/swaps/fastbtc/FastBTCWithdrawSwapProvider.js.map +1 -0
  420. package/dist/src/swaps/fastbtc/fastBtcBridgeContract.d.ts +19 -0
  421. package/dist/src/swaps/fastbtc/fastBtcBridgeContract.js +24 -0
  422. package/dist/src/swaps/fastbtc/fastBtcBridgeContract.js.map +1 -0
  423. package/dist/src/swaps/fastbtc/info.json +7 -0
  424. package/dist/src/swaps/hop/HopSwapProvider.d.ts +124 -0
  425. package/dist/src/swaps/hop/HopSwapProvider.js +479 -0
  426. package/dist/src/swaps/hop/HopSwapProvider.js.map +1 -0
  427. package/dist/src/swaps/hop/info.json +12 -0
  428. package/dist/src/swaps/hop/queries.d.ts +2 -0
  429. package/dist/src/swaps/hop/queries.js +61 -0
  430. package/dist/src/swaps/hop/queries.js.map +1 -0
  431. package/dist/src/swaps/jupiter/JupiterSwapProvider.d.ts +46 -0
  432. package/dist/src/swaps/jupiter/JupiterSwapProvider.js +189 -0
  433. package/dist/src/swaps/jupiter/JupiterSwapProvider.js.map +1 -0
  434. package/dist/src/swaps/jupiter/info.json +7 -0
  435. package/dist/src/swaps/lifi/LifiSwapProvider.d.ts +76 -0
  436. package/dist/src/swaps/lifi/LifiSwapProvider.js +313 -0
  437. package/dist/src/swaps/lifi/LifiSwapProvider.js.map +1 -0
  438. package/dist/src/swaps/lifi/info.json +7 -0
  439. package/dist/src/swaps/liquality/LiqualitySwapProvider.d.ts +104 -0
  440. package/dist/src/swaps/liquality/LiqualitySwapProvider.js +704 -0
  441. package/dist/src/swaps/liquality/LiqualitySwapProvider.js.map +1 -0
  442. package/dist/src/swaps/liquality/info.json +7 -0
  443. package/dist/src/swaps/liqualityboost/liqualityBoostERC20toNative/LiqualityBoostERC20toNative.d.ts +124 -0
  444. package/dist/src/swaps/liqualityboost/liqualityBoostERC20toNative/LiqualityBoostERC20toNative.js +239 -0
  445. package/dist/src/swaps/liqualityboost/liqualityBoostERC20toNative/LiqualityBoostERC20toNative.js.map +1 -0
  446. package/dist/src/swaps/liqualityboost/liqualityBoostERC20toNative/info.json +7 -0
  447. package/dist/src/swaps/liqualityboost/liqualityBoostNativeToERC20/LiqualityBoostNativeToERC20.d.ts +52 -0
  448. package/dist/src/swaps/liqualityboost/liqualityBoostNativeToERC20/LiqualityBoostNativeToERC20.js +213 -0
  449. package/dist/src/swaps/liqualityboost/liqualityBoostNativeToERC20/LiqualityBoostNativeToERC20.js.map +1 -0
  450. package/dist/src/swaps/liqualityboost/liqualityBoostNativeToERC20/info.json +7 -0
  451. package/dist/src/swaps/liqualityboost/types.d.ts +17 -0
  452. package/dist/src/swaps/liqualityboost/types.js +3 -0
  453. package/dist/src/swaps/liqualityboost/types.js.map +1 -0
  454. package/dist/src/swaps/oneinch/OneinchSwapProvider.d.ts +86 -0
  455. package/dist/src/swaps/oneinch/OneinchSwapProvider.js +369 -0
  456. package/dist/src/swaps/oneinch/OneinchSwapProvider.js.map +1 -0
  457. package/dist/src/swaps/oneinch/info.json +13 -0
  458. package/dist/src/swaps/sovryn/SovrynSwapProvider.d.ts +110 -0
  459. package/dist/src/swaps/sovryn/SovrynSwapProvider.js +369 -0
  460. package/dist/src/swaps/sovryn/SovrynSwapProvider.js.map +1 -0
  461. package/dist/src/swaps/sovryn/info.json +7 -0
  462. package/dist/src/swaps/teleswap/TeleSwapSwapProvider.d.ts +167 -0
  463. package/dist/src/swaps/teleswap/TeleSwapSwapProvider.js +874 -0
  464. package/dist/src/swaps/teleswap/TeleSwapSwapProvider.js.map +1 -0
  465. package/dist/src/swaps/teleswap/info.json +7 -0
  466. package/dist/src/swaps/thorchain/ThorchainSwapProvider.d.ts +194 -0
  467. package/dist/src/swaps/thorchain/ThorchainSwapProvider.js +534 -0
  468. package/dist/src/swaps/thorchain/ThorchainSwapProvider.js.map +1 -0
  469. package/dist/src/swaps/thorchain/info.json +7 -0
  470. package/dist/src/swaps/types.d.ts +87 -0
  471. package/dist/src/swaps/types.js +9 -0
  472. package/dist/src/swaps/types.js.map +1 -0
  473. package/dist/src/swaps/uniswap/UniswapSwapProvider.d.ts +117 -0
  474. package/dist/src/swaps/uniswap/UniswapSwapProvider.js +438 -0
  475. package/dist/src/swaps/uniswap/UniswapSwapProvider.js.map +1 -0
  476. package/dist/src/swaps/uniswap/info.json +7 -0
  477. package/dist/src/swaps/utils.d.ts +92 -0
  478. package/dist/src/swaps/utils.js +57 -0
  479. package/dist/src/swaps/utils.js.map +1 -0
  480. package/dist/src/tsconfig.json +30 -0
  481. package/dist/src/types.d.ts +29 -0
  482. package/dist/src/types.js +3 -0
  483. package/dist/src/types.js.map +1 -0
  484. package/dist/src/utils/accounts.d.ts +16 -0
  485. package/dist/src/utils/accounts.js +89 -0
  486. package/dist/src/utils/accounts.js.map +1 -0
  487. package/dist/src/utils/address.d.ts +8 -0
  488. package/dist/src/utils/address.js +17 -0
  489. package/dist/src/utils/address.js.map +1 -0
  490. package/dist/src/utils/address.test.d.ts +1 -0
  491. package/dist/src/utils/address.test.js +12 -0
  492. package/dist/src/utils/address.test.js.map +1 -0
  493. package/dist/src/utils/asset.d.ts +22 -0
  494. package/dist/src/utils/asset.js +198 -0
  495. package/dist/src/utils/asset.js.map +1 -0
  496. package/dist/src/utils/asset.test.d.ts +1 -0
  497. package/dist/src/utils/asset.test.js +42 -0
  498. package/dist/src/utils/asset.test.js.map +1 -0
  499. package/dist/src/utils/chainify.d.ts +3 -0
  500. package/dist/src/utils/chainify.js +41 -0
  501. package/dist/src/utils/chainify.js.map +1 -0
  502. package/dist/src/utils/coinFormatter.d.ts +13 -0
  503. package/dist/src/utils/coinFormatter.js +58 -0
  504. package/dist/src/utils/coinFormatter.js.map +1 -0
  505. package/dist/src/utils/crypto.d.ts +6 -0
  506. package/dist/src/utils/crypto.js +70 -0
  507. package/dist/src/utils/crypto.js.map +1 -0
  508. package/dist/src/utils/cryptoassets.d.ts +5 -0
  509. package/dist/src/utils/cryptoassets.js +26 -0
  510. package/dist/src/utils/cryptoassets.js.map +1 -0
  511. package/dist/src/utils/derivationPath.d.ts +6 -0
  512. package/dist/src/utils/derivationPath.js +75 -0
  513. package/dist/src/utils/derivationPath.js.map +1 -0
  514. package/dist/src/utils/derivationPath.spec.d.ts +1 -0
  515. package/dist/src/utils/derivationPath.spec.js +37 -0
  516. package/dist/src/utils/derivationPath.spec.js.map +1 -0
  517. package/dist/src/utils/export.d.ts +5 -0
  518. package/dist/src/utils/export.js +24 -0
  519. package/dist/src/utils/export.js.map +1 -0
  520. package/dist/src/utils/fees.d.ts +43 -0
  521. package/dist/src/utils/fees.js +222 -0
  522. package/dist/src/utils/fees.js.map +1 -0
  523. package/dist/src/utils/fees.test.d.ts +1 -0
  524. package/dist/src/utils/fees.test.js +40 -0
  525. package/dist/src/utils/fees.test.js.map +1 -0
  526. package/dist/src/utils/fetchTokenDetails.d.ts +1 -0
  527. package/dist/src/utils/fetchTokenDetails.js +19 -0
  528. package/dist/src/utils/fetchTokenDetails.js.map +1 -0
  529. package/dist/src/utils/history.d.ts +66 -0
  530. package/dist/src/utils/history.js +135 -0
  531. package/dist/src/utils/history.js.map +1 -0
  532. package/dist/src/utils/isTransactionNotFoundError.d.ts +1 -0
  533. package/dist/src/utils/isTransactionNotFoundError.js +16 -0
  534. package/dist/src/utils/isTransactionNotFoundError.js.map +1 -0
  535. package/dist/src/utils/ledger.d.ts +12 -0
  536. package/dist/src/utils/ledger.js +38 -0
  537. package/dist/src/utils/ledger.js.map +1 -0
  538. package/dist/src/utils/moment.d.ts +2 -0
  539. package/dist/src/utils/moment.js +8 -0
  540. package/dist/src/utils/moment.js.map +1 -0
  541. package/dist/src/utils/networks.d.ts +10 -0
  542. package/dist/src/utils/networks.js +43 -0
  543. package/dist/src/utils/networks.js.map +1 -0
  544. package/dist/src/utils/parseTokenTx.d.ts +2 -0
  545. package/dist/src/utils/parseTokenTx.js +10 -0
  546. package/dist/src/utils/parseTokenTx.js.map +1 -0
  547. package/dist/src/utils/quotes.d.ts +5 -0
  548. package/dist/src/utils/quotes.js +20 -0
  549. package/dist/src/utils/quotes.js.map +1 -0
  550. package/dist/src/utils/quotes.test.d.ts +1 -0
  551. package/dist/src/utils/quotes.test.js +85 -0
  552. package/dist/src/utils/quotes.test.js.map +1 -0
  553. package/dist/src/utils/timeline.d.ts +71 -0
  554. package/dist/src/utils/timeline.js +176 -0
  555. package/dist/src/utils/timeline.js.map +1 -0
  556. package/dist/src/walletOptions/defaultOptions.d.ts +3 -0
  557. package/dist/src/walletOptions/defaultOptions.js +36 -0
  558. package/dist/src/walletOptions/defaultOptions.js.map +1 -0
  559. package/dist/src/walletOptions/index.d.ts +7 -0
  560. package/dist/src/walletOptions/index.js +11 -0
  561. package/dist/src/walletOptions/index.js.map +1 -0
  562. package/dist/tsconfig.tsbuildinfo +1 -0
  563. package/package.json +76 -0
@@ -0,0 +1,874 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TeleSwapSwapProvider = exports.TeleSwapTxTypes = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const cryptoassets_1 = require("@yaswap/cryptoassets");
6
+ const isTransactionNotFoundError_1 = require("../../utils/isTransactionNotFoundError");
7
+ const ERC20_json_1 = tslib_1.__importDefault(require("@uniswap/v2-core/build/ERC20.json"));
8
+ const UniswapV2Factory_json_1 = tslib_1.__importDefault(require("@uniswap/v2-core/build/UniswapV2Factory.json"));
9
+ const UniswapV2Router02_json_1 = tslib_1.__importDefault(require("@uniswap/v2-periphery/build/UniswapV2Router02.json"));
10
+ const bignumber_js_1 = tslib_1.__importDefault(require("bignumber.js"));
11
+ const ethers = tslib_1.__importStar(require("ethers"));
12
+ const lodash_1 = require("lodash");
13
+ const uuid_1 = require("uuid");
14
+ const build_config_1 = tslib_1.__importDefault(require("../../build.config"));
15
+ const utils_1 = require("../../store/actions/performNextAction/utils");
16
+ const types_1 = require("../../store/types");
17
+ const coinFormatter_1 = require("../../utils/coinFormatter");
18
+ const cryptoassets_2 = tslib_1.__importDefault(require("../../utils/cryptoassets"));
19
+ const SwapProvider_1 = require("../SwapProvider");
20
+ const scripts_1 = require("@teleportdao/scripts");
21
+ const configs_1 = require("@teleportdao/configs");
22
+ const bitcoin_1 = require("@teleportdao/bitcoin");
23
+ const error_parser_1 = require("@yaswap/error-parser");
24
+ const SUPPORTED_CHAINS = [
25
+ [cryptoassets_1.ChainId.Bitcoin, cryptoassets_1.ChainId.Polygon, 'testnet'],
26
+ [cryptoassets_1.ChainId.Polygon, cryptoassets_1.ChainId.Bitcoin, 'testnet'],
27
+ [cryptoassets_1.ChainId.Bitcoin, cryptoassets_1.ChainId.Polygon, 'mainnet'],
28
+ [cryptoassets_1.ChainId.Polygon, cryptoassets_1.ChainId.Bitcoin, 'mainnet'],
29
+ ];
30
+ const addressTypesNumber = { p2pk: 0, p2pkh: 1, p2sh: 2, p2wpkh: 3 };
31
+ const TRANSFER_APP_ID = 1;
32
+ const EXCHANGE_APP_ID = 10;
33
+ const SUGGESTED_DEADLINE = 7200;
34
+ const RELAY_FINALIZATION_PARAMETER = 5;
35
+ const ZERO_ADDRESS = '0x' + '0'.repeat(20 * 2);
36
+ const SLIPPAGE = 5;
37
+ const DUMMY_BYTES = '0x' + '0'.repeat(79 * 2);
38
+ var TeleSwapTxTypes;
39
+ (function (TeleSwapTxTypes) {
40
+ TeleSwapTxTypes["WRAP"] = "WRAP";
41
+ TeleSwapTxTypes["SWAP"] = "SWAP";
42
+ })(TeleSwapTxTypes = exports.TeleSwapTxTypes || (exports.TeleSwapTxTypes = {}));
43
+ class TeleSwapSwapProvider extends SwapProvider_1.SwapProvider {
44
+ constructor(config) {
45
+ super(config);
46
+ this.changeEndianness = (input) => {
47
+ const result = [];
48
+ let len = input.length - 2;
49
+ while (len >= 0) {
50
+ result.push(input.substr(len, 2));
51
+ len -= 2;
52
+ }
53
+ return result.join('');
54
+ };
55
+ }
56
+ getSupportedPairs() {
57
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
58
+ return [];
59
+ });
60
+ }
61
+ isSwapSupported(from, to, network) {
62
+ const fromChain = cryptoassets_2.default[from].chain;
63
+ const toChain = cryptoassets_2.default[to].chain;
64
+ const _SUPPORTED_CHAINS = SUPPORTED_CHAINS.map((item) => JSON.stringify(item));
65
+ return _SUPPORTED_CHAINS.includes(JSON.stringify([fromChain, toChain, network]));
66
+ }
67
+ getQuote({ network, from, to, amount }) {
68
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
69
+ let fees;
70
+ let amountAfterFee;
71
+ let amountAfterFeeInUnit;
72
+ const fromAmountInUnit = (0, cryptoassets_1.currencyToUnit)(cryptoassets_2.default[from], new bignumber_js_1.default(amount));
73
+ if (this.isSwapSupported(from, to, network) == false) {
74
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.Unsupported.Chain);
75
+ }
76
+ if (from == 'BTC') {
77
+ fees = yield this.getFees({ network, from, to, amount });
78
+ amountAfterFee = (0, bignumber_js_1.default)(amount).minus(fees.totalFeeInBTC);
79
+ amountAfterFeeInUnit = (0, cryptoassets_1.currencyToUnit)(cryptoassets_2.default[from], amountAfterFee);
80
+ let toAmountInUnit;
81
+ if (to != 'TELEBTC') {
82
+ toAmountInUnit = new bignumber_js_1.default((yield this.getOutputAmountAndPath(String((0, lodash_1.floor)(amountAfterFeeInUnit.toNumber())), from, to, network)).outputAmount.toString());
83
+ }
84
+ else {
85
+ toAmountInUnit = amountAfterFeeInUnit;
86
+ }
87
+ return {
88
+ fromAmount: fromAmountInUnit.toFixed(),
89
+ toAmount: toAmountInUnit.toFixed(),
90
+ };
91
+ }
92
+ else {
93
+ if (from != 'TELEBTC') {
94
+ const teleBTCAmount = (0, cryptoassets_1.unitToCurrency)(cryptoassets_2.default['TELEBTC'], (yield this.getOutputAmountAndPath((0, cryptoassets_1.currencyToUnit)(cryptoassets_2.default[from], amount).toString(), from, 'TELEBTC', network)).outputAmount.toString());
95
+ fees = yield this.getFees({ network, from, to, amount: teleBTCAmount });
96
+ amountAfterFee = teleBTCAmount.minus(fees.totalFeeInBTC);
97
+ amountAfterFeeInUnit = (0, cryptoassets_1.currencyToUnit)(cryptoassets_2.default['TELEBTC'], amountAfterFee);
98
+ return {
99
+ fromAmount: fromAmountInUnit.toFixed(),
100
+ toAmount: amountAfterFeeInUnit.toFixed(),
101
+ };
102
+ }
103
+ else {
104
+ fees = yield this.getFees({ network, from, to, amount });
105
+ amountAfterFee = (0, bignumber_js_1.default)(amount).minus(fees.totalFeeInBTC);
106
+ amountAfterFeeInUnit = (0, cryptoassets_1.currencyToUnit)(cryptoassets_2.default[from], amountAfterFee);
107
+ return {
108
+ fromAmount: fromAmountInUnit.toFixed(),
109
+ toAmount: amountAfterFeeInUnit.toFixed(),
110
+ };
111
+ }
112
+ }
113
+ });
114
+ }
115
+ sendBitcoinSwap({ quote, network, walletId, }) {
116
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
117
+ const to = (yield this._chooseLockerAddress(quote.from, quote.to, quote.fromAmount, network)).bitcoinAddress;
118
+ const value = new bignumber_js_1.default(quote.fromAmount);
119
+ const requestType = quote.to == 'TELEBTC' ? TeleSwapTxTypes.WRAP : TeleSwapTxTypes.SWAP;
120
+ const fromAddressRaw = yield this.getSwapAddress(network, walletId, quote.to, quote.toAccountId);
121
+ const opReturnData = yield this.getOpReturnData(quote, requestType, network, fromAddressRaw);
122
+ const client = this.getClient(network, walletId, quote.from, quote.fromAccountId);
123
+ let tx;
124
+ try {
125
+ tx = yield client.wallet.sendTransaction({
126
+ to: to,
127
+ value,
128
+ data: opReturnData,
129
+ fee: quote.fee,
130
+ });
131
+ }
132
+ catch (_a) {
133
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.FailedAssert.SendTransaction);
134
+ }
135
+ return {
136
+ status: 'WAITING_FOR_SEND_CONFIRMATIONS',
137
+ swapTxHash: tx === null || tx === void 0 ? void 0 : tx.hash,
138
+ swapTx: tx,
139
+ numberOfBitcoinConfirmations: 0,
140
+ };
141
+ });
142
+ }
143
+ sendBurn({ quote, network, walletId, }) {
144
+ var _a;
145
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
146
+ let value;
147
+ if (quote.from != 'TELEBTC') {
148
+ value = quote.exchangedTeleBTCAmount;
149
+ }
150
+ else {
151
+ value = new bignumber_js_1.default(quote.fromAmount);
152
+ }
153
+ const _lockerLockingScript = (yield this._chooseLockerAddress('TELEBTC', quote.to, value.toString(), network))
154
+ .lockerLockingScript;
155
+ const fromAddressRaw = yield this.getSwapAddress(network, walletId, quote.to, quote.toAccountId);
156
+ const client = this.getClient(network, walletId, quote.from, quote.fromAccountId);
157
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(quote.from, network), build_config_1.default.infuraApiKey);
158
+ const ccBurnRouterAddress = quote.network == types_1.Network.Mainnet
159
+ ? configs_1.teleswap.contractsInfo.polygon.mainnet.ccBurnAddress
160
+ : configs_1.teleswap.contractsInfo.polygon.testnet.ccBurnAddress;
161
+ const ccBurnRouter = new ethers.Contract(ccBurnRouterAddress, configs_1.teleswap.ABI.CCBurnRouterABI, api);
162
+ const inputAmountHex = '0x' + value.toNumber().toString(16);
163
+ const networkName = quote.network == types_1.Network.Mainnet ? 'bitcoin' : 'bitcoin_testnet';
164
+ const bitcoinNetwork = {
165
+ name: networkName,
166
+ connection: {
167
+ api: {
168
+ enabled: true,
169
+ provider: 'BlockStream',
170
+ token: null,
171
+ },
172
+ },
173
+ };
174
+ const bitcoinAddressObject = new bitcoin_1.BitcoinInterface(bitcoinNetwork.connection, bitcoinNetwork.name).convertAddressToObject(fromAddressRaw);
175
+ const _userScript = '0x' + ((_a = bitcoinAddressObject.addressObject.hash) === null || _a === void 0 ? void 0 : _a.toString('hex'));
176
+ const _scriptType = addressTypesNumber[bitcoinAddressObject.addressType];
177
+ const _encodedData = ccBurnRouter.interface.encodeFunctionData('ccBurn', [
178
+ inputAmountHex,
179
+ _userScript,
180
+ _scriptType,
181
+ _lockerLockingScript,
182
+ ]);
183
+ let tx;
184
+ try {
185
+ tx = yield client.wallet.sendTransaction({
186
+ to: ccBurnRouterAddress,
187
+ value: new bignumber_js_1.default(0),
188
+ data: _encodedData,
189
+ });
190
+ }
191
+ catch (_b) {
192
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.FailedAssert.SendTransaction);
193
+ }
194
+ return {
195
+ status: 'WAITING_FOR_BURN_CONFIRMATIONS',
196
+ swapTxHash: tx === null || tx === void 0 ? void 0 : tx.hash,
197
+ swapTx: tx,
198
+ userBitcoinAddress: fromAddressRaw,
199
+ };
200
+ });
201
+ }
202
+ sendExchange({ quote, network, walletId, }) {
203
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
204
+ const value = new bignumber_js_1.default(quote.fromAmount);
205
+ const fromAddressRaw = yield this.getSwapAddress(network, walletId, quote.from, quote.fromAccountId);
206
+ const client = this.getClient(network, walletId, quote.from, quote.fromAccountId);
207
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(quote.from, network), build_config_1.default.infuraApiKey);
208
+ const teleBTCAddress = cryptoassets_2.default['TELEBTC'].contractAddress;
209
+ const erc20 = new ethers.Contract(teleBTCAddress, ERC20_json_1.default.abi, api);
210
+ const currentBalance = (yield erc20.balanceOf(fromAddressRaw)).toString();
211
+ const exchangeRouter = new ethers.Contract(this.config.QuickSwapRouterAddress, UniswapV2Router02_json_1.default.abi, api);
212
+ const result = yield this.getOutputAmountAndPath(value.toString(), quote.from, 'TELEBTC', network);
213
+ const expectedOutput = (0, lodash_1.floor)((Number(result.outputAmount.toString()) * (100 - SLIPPAGE)) / 100);
214
+ const path = result.path;
215
+ const inputAmountHex = '0x' + value.toNumber().toString(16);
216
+ const outputAmountHex = '0x' + expectedOutput.toString(16);
217
+ const deadline = (yield api.getBlock('latest')).timestamp + 120;
218
+ let _encodedData;
219
+ let _value;
220
+ if (quote.from == 'MATIC') {
221
+ _value = value;
222
+ _encodedData = exchangeRouter.interface.encodeFunctionData('swapExactETHForTokens', [
223
+ outputAmountHex,
224
+ path,
225
+ fromAddressRaw,
226
+ deadline,
227
+ ]);
228
+ }
229
+ else {
230
+ _value = new bignumber_js_1.default(0);
231
+ _encodedData = exchangeRouter.interface.encodeFunctionData('swapExactTokensForTokens', [
232
+ inputAmountHex,
233
+ outputAmountHex,
234
+ path,
235
+ fromAddressRaw,
236
+ deadline,
237
+ ]);
238
+ }
239
+ let tx;
240
+ try {
241
+ tx = yield client.wallet.sendTransaction({
242
+ to: this.config.QuickSwapRouterAddress,
243
+ value: _value,
244
+ data: _encodedData,
245
+ });
246
+ }
247
+ catch (_a) {
248
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.FailedAssert.SendTransaction);
249
+ }
250
+ return {
251
+ status: 'WAITING_FOR_EXCHANGE_CONFIRMATIONS',
252
+ exchangeTxHash: tx === null || tx === void 0 ? void 0 : tx.hash,
253
+ exchangedTeleBTCAmount: new bignumber_js_1.default(currentBalance),
254
+ };
255
+ });
256
+ }
257
+ approveForExchange({ quote, network, walletId, }) {
258
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
259
+ const value = new bignumber_js_1.default(quote.fromAmount);
260
+ const client = this.getClient(network, walletId, quote.from, quote.fromAccountId);
261
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(quote.from, network), build_config_1.default.infuraApiKey);
262
+ const erc20 = new ethers.Contract(this.getTokenAddress(quote.from, network), ERC20_json_1.default.abi, api);
263
+ const inputAmountHex = '0x' + value.toNumber().toString(16);
264
+ const encodedData = erc20.interface.encodeFunctionData('approve', [
265
+ this.config.QuickSwapRouterAddress,
266
+ inputAmountHex,
267
+ ]);
268
+ let exchangeApproveTx;
269
+ try {
270
+ exchangeApproveTx = yield client.wallet.sendTransaction({
271
+ to: this.getTokenAddress(quote.from, network),
272
+ value: new bignumber_js_1.default(0),
273
+ data: encodedData,
274
+ });
275
+ }
276
+ catch (_a) {
277
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.FailedAssert.SendTransaction);
278
+ }
279
+ return {
280
+ status: 'WAITING_FOR_EXCHANGE_APPROVE_CONFIRMATIONS',
281
+ exchangeApproveTxHash: exchangeApproveTx === null || exchangeApproveTx === void 0 ? void 0 : exchangeApproveTx.hash,
282
+ };
283
+ });
284
+ }
285
+ approveForBurn({ quote, network, walletId, }) {
286
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
287
+ let value;
288
+ if (quote.from != 'TELEBTC') {
289
+ value = quote.exchangedTeleBTCAmount;
290
+ }
291
+ else {
292
+ value = new bignumber_js_1.default(quote.fromAmount);
293
+ }
294
+ const client = this.getClient(network, walletId, quote.from, quote.fromAccountId);
295
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(quote.from, network), build_config_1.default.infuraApiKey);
296
+ const teleBTCAddress = cryptoassets_2.default['TELEBTC'].contractAddress;
297
+ const erc20 = new ethers.Contract(teleBTCAddress, ERC20_json_1.default.abi, api);
298
+ const inputAmountHex = '0x' + value.toNumber().toString(16);
299
+ const ccBurnRouterAddress = quote.network == types_1.Network.Mainnet
300
+ ? configs_1.teleswap.contractsInfo.polygon.mainnet.ccBurnAddress
301
+ : configs_1.teleswap.contractsInfo.polygon.testnet.ccBurnAddress;
302
+ const encodedData = erc20.interface.encodeFunctionData('approve', [ccBurnRouterAddress, inputAmountHex]);
303
+ let approveTx;
304
+ try {
305
+ approveTx = yield client.wallet.sendTransaction({
306
+ to: teleBTCAddress,
307
+ value: new bignumber_js_1.default(0),
308
+ data: encodedData,
309
+ });
310
+ }
311
+ catch (_a) {
312
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.FailedAssert.SendTransaction);
313
+ }
314
+ return {
315
+ status: 'WAITING_FOR_APPROVE_CONFIRMATIONS',
316
+ approveTxHash: approveTx === null || approveTx === void 0 ? void 0 : approveTx.hash,
317
+ };
318
+ });
319
+ }
320
+ sendSwap({ network, walletId, swap }) {
321
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
322
+ if (swap.from == 'BTC') {
323
+ return yield this.sendBitcoinSwap({
324
+ quote: swap,
325
+ network,
326
+ walletId,
327
+ });
328
+ }
329
+ if (swap.from != 'TELEBTC' && swap.to == 'BTC') {
330
+ return yield this.approveForExchange({
331
+ quote: swap,
332
+ network,
333
+ walletId,
334
+ });
335
+ }
336
+ if (swap.from == 'TELEBTC' && swap.to == 'BTC') {
337
+ return yield this.approveForBurn({
338
+ quote: swap,
339
+ network,
340
+ walletId,
341
+ });
342
+ }
343
+ });
344
+ }
345
+ newSwap({ network, walletId, quote }) {
346
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
347
+ if (!this.isSwapSupported(quote.from, quote.to, network)) {
348
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.Unsupported.Chain);
349
+ }
350
+ const updates = yield this.sendSwap({ network, walletId, swap: quote });
351
+ return Object.assign({ id: (0, uuid_1.v4)(), fee: quote.fee }, updates);
352
+ });
353
+ }
354
+ estimateFees({ network, walletId, asset, txType, quote, feePrices, max }) {
355
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
356
+ if (txType === this._txTypes().SWAP && asset === 'BTC') {
357
+ const client = this.getClient(network, walletId, asset, quote.fromAccountId);
358
+ const value = max ? undefined : new bignumber_js_1.default(quote.fromAmount);
359
+ const txs = feePrices.map((fee) => ({ to: '', value, data: DUMMY_BYTES, fee }));
360
+ const totalFees = yield client.wallet.getTotalFees(txs, max);
361
+ return (0, lodash_1.mapValues)(totalFees, (f) => (0, cryptoassets_1.unitToCurrency)(cryptoassets_2.default[asset], f));
362
+ }
363
+ return null;
364
+ });
365
+ }
366
+ getMin(quote) {
367
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
368
+ return new bignumber_js_1.default((yield this.getFees({ network: quote.network, from: quote.from, to: quote.to, amount: new bignumber_js_1.default(0) })).teleporterFeeInBTC);
369
+ });
370
+ }
371
+ getTokenAddress(asset, network) {
372
+ switch (asset) {
373
+ case 'teleBTC':
374
+ case 'TELEBTC':
375
+ case 'BTC':
376
+ return cryptoassets_2.default['TELEBTC'].contractAddress;
377
+ case 'MATIC':
378
+ case 'WMATIC':
379
+ case 'PWMATIC':
380
+ return network == types_1.Network.Mainnet
381
+ ? cryptoassets_2.default['PWMATIC'].contractAddress
382
+ : configs_1.teleswap.tokenInfo.polygon.testnet.WrappedMATICAddress;
383
+ default:
384
+ return network == types_1.Network.Mainnet
385
+ ? cryptoassets_2.default[asset].contractAddress
386
+ : configs_1.teleswap.tokenInfo.polygon.testnet.chainlinkAddress;
387
+ }
388
+ }
389
+ waitForBitcoinConfirmations({ swap, network, walletId }) {
390
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
391
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
392
+ try {
393
+ const tx = yield client.chain.getTransactionByHash(swap.swapTxHash);
394
+ if (tx && tx.confirmations && tx.confirmations > 0) {
395
+ return {
396
+ endTime: Date.now(),
397
+ status: 'WAITING_FOR_RECEIVE',
398
+ numberOfBitcoinConfirmations: tx.confirmations,
399
+ };
400
+ }
401
+ }
402
+ catch (e) {
403
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
404
+ console.warn(e);
405
+ else
406
+ throw e;
407
+ }
408
+ });
409
+ }
410
+ waitForReceive({ swap, network, walletId }) {
411
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
412
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
413
+ try {
414
+ const bitcoinTxConfirmations = (yield client.chain.getTransactionByHash(swap.swapTxHash)).confirmations;
415
+ if (bitcoinTxConfirmations && bitcoinTxConfirmations >= RELAY_FINALIZATION_PARAMETER - 1) {
416
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(swap.to, network), build_config_1.default.infuraApiKey);
417
+ let ccRouterFactory;
418
+ let ccRouterFactoryAddress;
419
+ if (swap.to == 'TELEBTC') {
420
+ ccRouterFactoryAddress =
421
+ swap.network == types_1.Network.Mainnet
422
+ ? configs_1.teleswap.contractsInfo.polygon.mainnet.ccTransferAddress
423
+ : configs_1.teleswap.contractsInfo.polygon.testnet.ccTransferAddress;
424
+ ccRouterFactory = new ethers.Contract(ccRouterFactoryAddress, configs_1.teleswap.ABI.CCTransferRouterABI, api);
425
+ }
426
+ else {
427
+ ccRouterFactoryAddress =
428
+ swap.network == types_1.Network.Mainnet
429
+ ? configs_1.teleswap.contractsInfo.polygon.mainnet.ccExchangeAddress
430
+ : configs_1.teleswap.contractsInfo.polygon.testnet.ccExchangeAddress;
431
+ ccRouterFactory = new ethers.Contract(ccRouterFactoryAddress, configs_1.teleswap.ABI.CCExchangeRouterABI, api);
432
+ }
433
+ const result = yield ccRouterFactory.isRequestUsed('0x' + this.changeEndianness(swap.swapTxHash));
434
+ if (result) {
435
+ return {
436
+ endTime: Date.now(),
437
+ status: 'SUCCESS',
438
+ numberOfBitcoinConfirmations: bitcoinTxConfirmations,
439
+ };
440
+ }
441
+ else if (bitcoinTxConfirmations > (RELAY_FINALIZATION_PARAMETER + 1) * 2) {
442
+ return {
443
+ endTime: Date.now(),
444
+ status: 'FAILED',
445
+ numberOfBitcoinConfirmations: bitcoinTxConfirmations,
446
+ };
447
+ }
448
+ }
449
+ else if (bitcoinTxConfirmations && bitcoinTxConfirmations > swap.numberOfBitcoinConfirmations) {
450
+ return {
451
+ endTime: Date.now(),
452
+ status: 'WAITING_FOR_RECEIVE',
453
+ numberOfBitcoinConfirmations: bitcoinTxConfirmations,
454
+ };
455
+ }
456
+ }
457
+ catch (e) {
458
+ throw error_parser_1.CUSTOM_ERRORS.Unknown;
459
+ }
460
+ });
461
+ }
462
+ waitForApproveConfirmations({ swap, network, walletId }) {
463
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
464
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
465
+ try {
466
+ const tx = yield client.chain.getTransactionByHash(swap.approveTxHash);
467
+ if (tx && tx.confirmations && tx.confirmations > 0) {
468
+ return {
469
+ endTime: Date.now(),
470
+ status: 'APPROVE_CONFIRMED',
471
+ };
472
+ }
473
+ }
474
+ catch (e) {
475
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
476
+ console.warn(e);
477
+ else
478
+ throw e;
479
+ }
480
+ });
481
+ }
482
+ waitForExchangeApproveConfirmations({ swap, network, walletId, }) {
483
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
484
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
485
+ try {
486
+ const tx = yield client.chain.getTransactionByHash(swap.exchangeApproveTxHash);
487
+ if (tx && tx.confirmations && tx.confirmations > 0) {
488
+ return {
489
+ endTime: Date.now(),
490
+ status: 'EXCHANGE_APPROVE_CONFIRMED',
491
+ };
492
+ }
493
+ }
494
+ catch (e) {
495
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
496
+ console.warn(e);
497
+ else
498
+ throw e;
499
+ }
500
+ });
501
+ }
502
+ waitForExchangeConfirmations({ swap, network, walletId }) {
503
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
504
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
505
+ try {
506
+ const tx = yield client.chain.getTransactionByHash(swap.exchangeTxHash);
507
+ if (tx && tx.confirmations && tx.confirmations > 0) {
508
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(swap.from, network), build_config_1.default.infuraApiKey);
509
+ const fromAddressRaw = yield this.getSwapAddress(network, walletId, swap.from, swap.fromAccountId);
510
+ const teleBTCAddress = cryptoassets_2.default['TELEBTC'].contractAddress;
511
+ const erc20 = new ethers.Contract(teleBTCAddress, ERC20_json_1.default.abi, api);
512
+ const newBalance = new bignumber_js_1.default((yield erc20.balanceOf(fromAddressRaw)).toString());
513
+ return {
514
+ endTime: Date.now(),
515
+ status: 'EXCHANGE_CONFIRMED',
516
+ exchangedTeleBTCAmount: newBalance.minus(swap.exchangedTeleBTCAmount),
517
+ };
518
+ }
519
+ }
520
+ catch (e) {
521
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
522
+ console.warn(e);
523
+ else
524
+ throw e;
525
+ }
526
+ });
527
+ }
528
+ waitForBurnConfirmations({ swap, network, walletId }) {
529
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
530
+ const client = this.getClient(network, walletId, swap.from, swap.fromAccountId);
531
+ try {
532
+ const tx = yield client.chain.getTransactionByHash(swap.swapTxHash);
533
+ if (tx && tx.confirmations && tx.confirmations > 0) {
534
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(swap.from, network), build_config_1.default.infuraApiKey);
535
+ const ccBurnRouterAddress = network == types_1.Network.Mainnet
536
+ ? configs_1.teleswap.contractsInfo.polygon.mainnet.ccBurnAddress
537
+ : configs_1.teleswap.contractsInfo.polygon.testnet.ccBurnAddress;
538
+ const ccBurnRouter = new ethers.Contract(ccBurnRouterAddress, configs_1.teleswap.ABI.CCBurnRouterABI, api);
539
+ const fromAddressRaw = yield this.getSwapAddress(network, walletId, swap.from, swap.fromAccountId);
540
+ const filter = ccBurnRouter.filters.CCBurn(fromAddressRaw);
541
+ const receipt = yield api.getTransactionReceipt(swap.swapTxHash);
542
+ const logs = yield ccBurnRouter.queryFilter(filter, receipt.blockNumber, receipt.blockNumber);
543
+ const event = ccBurnRouter.interface.parseLog(logs[0]);
544
+ const burntAmount = event.args.burntAmount.toNumber();
545
+ return {
546
+ endTime: Date.now(),
547
+ status: 'WAITING_FOR_BURN_BITCOIN_CONFIRMATIONS',
548
+ toAmount: String(burntAmount),
549
+ };
550
+ }
551
+ }
552
+ catch (e) {
553
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
554
+ console.warn(e);
555
+ else
556
+ throw e;
557
+ }
558
+ });
559
+ }
560
+ waitForBurnBitcoinConfirmations({ swap, network }) {
561
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
562
+ try {
563
+ const isTestnet = network == types_1.Network.Testnet ? true : false;
564
+ const userBurnReqs = yield (0, scripts_1.getUserPendingBurns)({
565
+ userBurnRequests: [
566
+ {
567
+ address: swap.userBitcoinAddress,
568
+ amount: Number(swap.toAmount),
569
+ },
570
+ ],
571
+ targetNetworkConnectionInfo: this.getTargetNetworkConnectionInfo(swap.from, swap.network),
572
+ testnet: isTestnet,
573
+ mempool: true,
574
+ });
575
+ if (userBurnReqs.processedBurns.length > 0) {
576
+ return {
577
+ endTime: Date.now(),
578
+ status: 'SUCCESS',
579
+ };
580
+ }
581
+ }
582
+ catch (e) {
583
+ if ((0, isTransactionNotFoundError_1.isTransactionNotFoundError)(e))
584
+ console.warn(e);
585
+ else
586
+ throw e;
587
+ }
588
+ });
589
+ }
590
+ performNextSwapAction(store, { network, walletId, swap }) {
591
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
592
+ switch (swap.status) {
593
+ case 'WAITING_FOR_EXCHANGE_APPROVE_CONFIRMATIONS':
594
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForExchangeApproveConfirmations({ swap, network, walletId }); }));
595
+ case 'EXCHANGE_APPROVE_CONFIRMED':
596
+ return (0, utils_1.withLock)(store, { item: swap, network, walletId, asset: swap.from }, () => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.sendExchange({ quote: swap, network, walletId }); }));
597
+ case 'WAITING_FOR_EXCHANGE_CONFIRMATIONS':
598
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForExchangeConfirmations({ swap, network, walletId }); }));
599
+ case 'EXCHANGE_CONFIRMED':
600
+ return (0, utils_1.withLock)(store, { item: swap, network, walletId, asset: swap.from }, () => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.approveForBurn({ quote: swap, network, walletId }); }));
601
+ case 'WAITING_FOR_APPROVE_CONFIRMATIONS':
602
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForApproveConfirmations({ swap, network, walletId }); }));
603
+ case 'APPROVE_CONFIRMED':
604
+ return (0, utils_1.withLock)(store, { item: swap, network, walletId, asset: swap.from }, () => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.sendBurn({ quote: swap, network, walletId }); }));
605
+ case 'WAITING_FOR_BURN_CONFIRMATIONS':
606
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForBurnConfirmations({ swap, network, walletId }); }));
607
+ case 'WAITING_FOR_BURN_BITCOIN_CONFIRMATIONS':
608
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForBurnBitcoinConfirmations({ swap, network, walletId }); }));
609
+ case 'WAITING_FOR_SEND_CONFIRMATIONS':
610
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForBitcoinConfirmations({ swap, network, walletId }); }));
611
+ case 'WAITING_FOR_RECEIVE':
612
+ return (0, utils_1.withInterval)(() => tslib_1.__awaiter(this, void 0, void 0, function* () { return this.waitForReceive({ swap, network, walletId }); }));
613
+ }
614
+ });
615
+ }
616
+ _getStatuses() {
617
+ return {
618
+ WAITING_FOR_EXCHANGE_APPROVE_CONFIRMATIONS: {
619
+ step: 0,
620
+ label: 'Approve {from}',
621
+ filterStatus: 'PENDING',
622
+ notification() {
623
+ return {
624
+ message: 'Swap initiated',
625
+ };
626
+ },
627
+ },
628
+ EXCHANGE_APPROVE_CONFIRMED: {
629
+ step: 0,
630
+ label: 'Swapping {from}',
631
+ filterStatus: 'PENDING',
632
+ notification() {
633
+ return {
634
+ message: 'Exchange approve confirmed',
635
+ };
636
+ },
637
+ },
638
+ WAITING_FOR_EXCHANGE_CONFIRMATIONS: {
639
+ step: 1,
640
+ label: 'Swapping {from}',
641
+ filterStatus: 'PENDING',
642
+ },
643
+ EXCHANGE_CONFIRMED: {
644
+ step: 1,
645
+ label: 'Swapping {from}',
646
+ filterStatus: 'PENDING',
647
+ },
648
+ WAITING_FOR_APPROVE_CONFIRMATIONS: {
649
+ step: 0,
650
+ label: 'Approve {from}',
651
+ filterStatus: 'PENDING',
652
+ },
653
+ APPROVE_CONFIRMED: {
654
+ step: 0,
655
+ label: 'Swapping {from}',
656
+ filterStatus: 'PENDING',
657
+ notification() {
658
+ return {
659
+ message: 'Burn approve confirmed',
660
+ };
661
+ },
662
+ },
663
+ WAITING_FOR_BURN_CONFIRMATIONS: {
664
+ step: 1,
665
+ label: 'Swapping {from}',
666
+ filterStatus: 'PENDING',
667
+ },
668
+ WAITING_FOR_BURN_BITCOIN_CONFIRMATIONS: {
669
+ step: 1,
670
+ label: 'Swapping {from}',
671
+ filterStatus: 'PENDING',
672
+ notification() {
673
+ return {
674
+ message: 'Waiting for receiving BTC',
675
+ };
676
+ },
677
+ },
678
+ WAITING_FOR_SEND_CONFIRMATIONS: {
679
+ step: 0,
680
+ label: 'Swapping {from}',
681
+ filterStatus: 'PENDING',
682
+ },
683
+ WAITING_FOR_RECEIVE: {
684
+ step: 1,
685
+ label: 'Receiving {to}',
686
+ filterStatus: 'PENDING',
687
+ notification(swap) {
688
+ return {
689
+ message: `Waiting for confirmations: ${swap.numberOfBitcoinConfirmations} / ${RELAY_FINALIZATION_PARAMETER}`,
690
+ };
691
+ },
692
+ },
693
+ SUCCESS: {
694
+ step: 2,
695
+ label: 'Completed',
696
+ filterStatus: 'COMPLETED',
697
+ notification(swap) {
698
+ return {
699
+ message: `Swap completed, ${(0, coinFormatter_1.prettyBalance)(swap.toAmount, swap.to)} ${swap.to} ready to use`,
700
+ };
701
+ },
702
+ },
703
+ FAILED: {
704
+ step: 2,
705
+ label: 'Swap Failed',
706
+ filterStatus: 'FAILED',
707
+ notification(swap) {
708
+ return {
709
+ message: `Swap failed, please send ${swap === null || swap === void 0 ? void 0 : swap.swapTxHash} to the TeleportDAO discord`,
710
+ };
711
+ },
712
+ },
713
+ };
714
+ }
715
+ _txTypes() {
716
+ return TeleSwapTxTypes;
717
+ }
718
+ _fromTxType() {
719
+ return this._txTypes().SWAP;
720
+ }
721
+ _toTxType() {
722
+ return null;
723
+ }
724
+ _timelineDiagramSteps() {
725
+ return ['REQUEST', 'WAITING', 'RECEIVE'];
726
+ }
727
+ _totalSteps() {
728
+ return 3;
729
+ }
730
+ _chooseLockerAddress(from, to, value, network) {
731
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
732
+ const isTestnet = network === types_1.Network.Testnet ? true : false;
733
+ const type = from == 'BTC' ? 'transfer' : 'burn';
734
+ const targetNetworkConnectionInfo = from == 'BTC'
735
+ ? this.getTargetNetworkConnectionInfo(to, network)
736
+ : this.getTargetNetworkConnectionInfo(from, network);
737
+ const lockers = yield (0, scripts_1.getLockers)({
738
+ amount: (0, cryptoassets_1.unitToCurrency)(cryptoassets_2.default['BTC'], Number(value)),
739
+ type: type,
740
+ targetNetworkConnectionInfo: targetNetworkConnectionInfo,
741
+ testnet: isTestnet,
742
+ });
743
+ if (!lockers.preferredLocker) {
744
+ throw (0, error_parser_1.createInternalError)('Lockers capacity is low (decrease input amount)');
745
+ }
746
+ else {
747
+ return {
748
+ bitcoinAddress: lockers.preferredLocker.bitcoinAddress,
749
+ lockerLockingScript: lockers.preferredLocker.lockerInfo.lockerLockingScript,
750
+ };
751
+ }
752
+ });
753
+ }
754
+ getChainIdNumber(asset, network) {
755
+ const chainId = cryptoassets_2.default[asset].chain;
756
+ const chain = (0, cryptoassets_1.getChain)(network, chainId);
757
+ return Number(chain.network.chainId);
758
+ }
759
+ getFees(quote) {
760
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
761
+ const isTestnet = quote.network === types_1.Network.Testnet ? true : false;
762
+ let calculatedFee;
763
+ if (quote.from == 'BTC') {
764
+ calculatedFee = yield (0, scripts_1.calculateFee)({
765
+ amount: quote.amount,
766
+ type: 'transfer',
767
+ targetNetworkConnectionInfo: this.getTargetNetworkConnectionInfo(quote.to, quote.network),
768
+ testnet: isTestnet,
769
+ });
770
+ }
771
+ else {
772
+ calculatedFee = yield (0, scripts_1.calculateFee)({
773
+ amount: quote.amount,
774
+ type: 'burn',
775
+ targetNetworkConnectionInfo: this.getTargetNetworkConnectionInfo(quote.from, quote.network),
776
+ testnet: isTestnet,
777
+ });
778
+ }
779
+ return {
780
+ teleporterFeeInBTC: calculatedFee.teleporterFeeInBTC || 0,
781
+ teleporterPercentageFee: calculatedFee.teleporterPercentageFee || 0,
782
+ totalFeeInBTC: calculatedFee.totalFeeInBTC || 0,
783
+ };
784
+ });
785
+ }
786
+ getOutputAmountAndPath(amount, from, to, network) {
787
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
788
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(to, network), build_config_1.default.infuraApiKey);
789
+ const exchangeFactory = new ethers.Contract(this.config.QuickSwapFactoryAddress, UniswapV2Factory_json_1.default.abi, api);
790
+ const pair = yield exchangeFactory.getPair(this.getTokenAddress(from, network), this.getTokenAddress(to, network));
791
+ let isDirectPair = true;
792
+ if (pair == ZERO_ADDRESS) {
793
+ isDirectPair = false;
794
+ const _pair = yield exchangeFactory.getPair(this.getTokenAddress('WMATIC', network), this.getTokenAddress(to, network));
795
+ if (_pair == ZERO_ADDRESS) {
796
+ throw (0, error_parser_1.createInternalError)(error_parser_1.CUSTOM_ERRORS.NotFound.Default);
797
+ }
798
+ }
799
+ const exchangeRouter = new ethers.Contract(this.config.QuickSwapRouterAddress, UniswapV2Router02_json_1.default.abi, api);
800
+ let _path;
801
+ if (isDirectPair) {
802
+ _path = [this.getTokenAddress(from, network), this.getTokenAddress(to, network)];
803
+ }
804
+ else {
805
+ _path = [
806
+ this.getTokenAddress(from, network),
807
+ this.getTokenAddress('WMATIC', network),
808
+ this.getTokenAddress(to, network),
809
+ ];
810
+ }
811
+ const outputAmount = yield exchangeRouter.getAmountsOut(amount, _path);
812
+ return {
813
+ outputAmount: outputAmount[outputAmount.length - 1],
814
+ path: _path,
815
+ };
816
+ });
817
+ }
818
+ getTargetNetworkConnectionInfo(to, network) {
819
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(to, network), build_config_1.default.infuraApiKey);
820
+ const targetNetworkConnectionInfo = {
821
+ web3: {
822
+ url: api.connection.url,
823
+ },
824
+ };
825
+ return targetNetworkConnectionInfo;
826
+ }
827
+ getOpReturnData(quote, requestType, network, recipientAddress) {
828
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
829
+ const api = new ethers.providers.InfuraProvider(this.getChainIdNumber(quote.to, network), build_config_1.default.infuraApiKey);
830
+ let isExchange;
831
+ const chainId = this.getChainIdNumber(quote.to, types_1.Network.Mainnet);
832
+ let appId;
833
+ const speed = 0;
834
+ let exchangeTokenAddress;
835
+ let deadline;
836
+ let outputAmount;
837
+ const isFixedToken = true;
838
+ const percentageFee = (yield this.getFees({
839
+ network: network,
840
+ from: 'BTC',
841
+ to: quote.to,
842
+ amount: (0, cryptoassets_1.unitToCurrency)(cryptoassets_2.default['BTC'], Number(quote.fromAmount)),
843
+ })).teleporterPercentageFee;
844
+ if (requestType == TeleSwapTxTypes.SWAP) {
845
+ isExchange = true;
846
+ appId = EXCHANGE_APP_ID;
847
+ exchangeTokenAddress = this.getTokenAddress(quote.to, network);
848
+ deadline = (yield api.getBlock('latest')).timestamp + SUGGESTED_DEADLINE;
849
+ outputAmount = (0, lodash_1.floor)((Number(quote.toAmount) * (100 - SLIPPAGE)) / 100);
850
+ }
851
+ else {
852
+ isExchange = false;
853
+ appId = TRANSFER_APP_ID;
854
+ exchangeTokenAddress = ZERO_ADDRESS;
855
+ deadline = 0;
856
+ outputAmount = 0;
857
+ }
858
+ return bitcoin_1.TeleportDaoPayment.getTransferOpReturnData({
859
+ chainId,
860
+ appId,
861
+ recipientAddress,
862
+ percentageFee,
863
+ speed,
864
+ isExchange,
865
+ exchangeTokenAddress,
866
+ outputAmount,
867
+ deadline,
868
+ isFixedToken,
869
+ });
870
+ });
871
+ }
872
+ }
873
+ exports.TeleSwapSwapProvider = TeleSwapSwapProvider;
874
+ //# sourceMappingURL=TeleSwapSwapProvider.js.map