@lifi/sdk 3.0.0-alpha.2 → 3.0.0-alpha.21

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 (446) hide show
  1. package/dist/_cjs/config.js +48 -0
  2. package/dist/_cjs/config.js.map +1 -0
  3. package/dist/{cjs → _cjs}/constants.js +2 -4
  4. package/dist/_cjs/constants.js.map +1 -0
  5. package/dist/_cjs/core/BaseStepExecutor.js +55 -0
  6. package/dist/_cjs/core/BaseStepExecutor.js.map +1 -0
  7. package/dist/_cjs/core/EVM/EVM.js +46 -0
  8. package/dist/_cjs/core/EVM/EVM.js.map +1 -0
  9. package/dist/_cjs/core/EVM/EVMStepExecutor.js +276 -0
  10. package/dist/_cjs/core/EVM/EVMStepExecutor.js.map +1 -0
  11. package/dist/{cjs/types → _cjs/core/EVM}/abi.js +1 -0
  12. package/dist/_cjs/core/EVM/abi.js.map +1 -0
  13. package/dist/{cjs/execution → _cjs/core/EVM}/checkAllowance.js +12 -12
  14. package/dist/_cjs/core/EVM/checkAllowance.js.map +1 -0
  15. package/dist/{cjs/allowance → _cjs/core/EVM}/getAllowance.js +15 -17
  16. package/dist/_cjs/core/EVM/getAllowance.js.map +1 -0
  17. package/dist/{cjs/balance/getBalance.js → _cjs/core/EVM/getEVMBalance.js} +22 -22
  18. package/dist/_cjs/core/EVM/getEVMBalance.js.map +1 -0
  19. package/dist/{cjs/execution → _cjs/core/EVM}/multisig.js +7 -11
  20. package/dist/_cjs/core/EVM/multisig.js.map +1 -0
  21. package/dist/_cjs/core/EVM/publicClient.js +35 -0
  22. package/dist/_cjs/core/EVM/publicClient.js.map +1 -0
  23. package/dist/_cjs/core/EVM/setAllowance.js +71 -0
  24. package/dist/_cjs/core/EVM/setAllowance.js.map +1 -0
  25. package/dist/_cjs/core/EVM/switchChain.js +37 -0
  26. package/dist/_cjs/core/EVM/switchChain.js.map +1 -0
  27. package/dist/_cjs/core/EVM/types.js +9 -0
  28. package/dist/_cjs/core/EVM/types.js.map +1 -0
  29. package/dist/{cjs/utils/getMaxPriorityFeePerGas.js → _cjs/core/EVM/utils.js} +11 -3
  30. package/dist/_cjs/core/EVM/utils.js.map +1 -0
  31. package/dist/_cjs/core/Solana/Solana.js +44 -0
  32. package/dist/_cjs/core/Solana/Solana.js.map +1 -0
  33. package/dist/_cjs/core/Solana/SolanaStepExecutor.js +157 -0
  34. package/dist/_cjs/core/Solana/SolanaStepExecutor.js.map +1 -0
  35. package/dist/_cjs/core/Solana/connection.js +18 -0
  36. package/dist/_cjs/core/Solana/connection.js.map +1 -0
  37. package/dist/_cjs/core/Solana/getSolanaBalance.js +50 -0
  38. package/dist/_cjs/core/Solana/getSolanaBalance.js.map +1 -0
  39. package/dist/_cjs/core/Solana/types.js +10 -0
  40. package/dist/_cjs/core/Solana/types.js.map +1 -0
  41. package/dist/_cjs/core/StatusManager.js +167 -0
  42. package/dist/_cjs/core/StatusManager.js.map +1 -0
  43. package/dist/{cjs/execution → _cjs/core}/checkBalance.js +5 -5
  44. package/dist/_cjs/core/checkBalance.js.map +1 -0
  45. package/dist/_cjs/core/execution.js +134 -0
  46. package/dist/_cjs/core/execution.js.map +1 -0
  47. package/dist/_cjs/core/executionState.js +23 -0
  48. package/dist/_cjs/core/executionState.js.map +1 -0
  49. package/dist/_cjs/core/index.js +7 -0
  50. package/dist/_cjs/core/index.js.map +1 -0
  51. package/dist/_cjs/core/prepareRestart.js +23 -0
  52. package/dist/_cjs/core/prepareRestart.js.map +1 -0
  53. package/dist/_cjs/core/provider.js +15 -0
  54. package/dist/_cjs/core/provider.js.map +1 -0
  55. package/dist/_cjs/core/stepComparison.js +25 -0
  56. package/dist/_cjs/core/stepComparison.js.map +1 -0
  57. package/dist/{cjs/allowance → _cjs/core}/types.js +1 -0
  58. package/dist/_cjs/core/types.js.map +1 -0
  59. package/dist/{cjs/execution → _cjs/core}/utils.js +16 -10
  60. package/dist/_cjs/core/utils.js.map +1 -0
  61. package/dist/{cjs/execution → _cjs/core}/waitForReceivingTransaction.js +10 -12
  62. package/dist/_cjs/core/waitForReceivingTransaction.js.map +1 -0
  63. package/dist/_cjs/createConfig.js +48 -0
  64. package/dist/_cjs/createConfig.js.map +1 -0
  65. package/dist/{cjs → _cjs}/helpers.js +11 -25
  66. package/dist/_cjs/helpers.js.map +1 -0
  67. package/dist/_cjs/index.js +20 -0
  68. package/dist/_cjs/index.js.map +1 -0
  69. package/dist/_cjs/package.json +1 -0
  70. package/dist/{cjs → _cjs}/request.js +22 -16
  71. package/dist/_cjs/request.js.map +1 -0
  72. package/dist/_cjs/services/api.js +284 -0
  73. package/dist/_cjs/services/api.js.map +1 -0
  74. package/dist/_cjs/services/balance.js +49 -0
  75. package/dist/_cjs/services/balance.js.map +1 -0
  76. package/dist/{cjs → _cjs}/typeguards.js +1 -0
  77. package/dist/_cjs/typeguards.js.map +1 -0
  78. package/dist/_cjs/types/index.js +5 -0
  79. package/dist/_cjs/types/index.js.map +1 -0
  80. package/dist/{cjs/types/internal.types.js → _cjs/types/internal.js} +1 -0
  81. package/dist/_cjs/types/internal.js.map +1 -0
  82. package/dist/{cjs → _cjs}/utils/errors.js +25 -3
  83. package/dist/_cjs/utils/errors.js.map +1 -0
  84. package/dist/_cjs/utils/getTransactionMessage.js +31 -0
  85. package/dist/_cjs/utils/getTransactionMessage.js.map +1 -0
  86. package/dist/_cjs/utils/index.js +9 -0
  87. package/dist/_cjs/utils/index.js.map +1 -0
  88. package/dist/{cjs → _cjs}/utils/median.js +1 -0
  89. package/dist/_cjs/utils/median.js.map +1 -0
  90. package/dist/_cjs/utils/parseBackendError.js +27 -0
  91. package/dist/_cjs/utils/parseBackendError.js.map +1 -0
  92. package/dist/_cjs/utils/parseError.js +67 -0
  93. package/dist/_cjs/utils/parseError.js.map +1 -0
  94. package/dist/{cjs → _cjs}/utils/utils.js +5 -11
  95. package/dist/_cjs/utils/utils.js.map +1 -0
  96. package/dist/{cjs → _cjs}/version.js +2 -1
  97. package/dist/_cjs/version.js.map +1 -0
  98. package/dist/_esm/config.js +45 -0
  99. package/dist/_esm/config.js.map +1 -0
  100. package/dist/{constants.js → _esm/constants.js} +1 -0
  101. package/dist/_esm/constants.js.map +1 -0
  102. package/dist/_esm/core/BaseStepExecutor.js +52 -0
  103. package/dist/_esm/core/BaseStepExecutor.js.map +1 -0
  104. package/dist/_esm/core/EVM/EVM.js +42 -0
  105. package/dist/_esm/core/EVM/EVM.js.map +1 -0
  106. package/dist/_esm/core/EVM/EVMStepExecutor.js +304 -0
  107. package/dist/_esm/core/EVM/EVMStepExecutor.js.map +1 -0
  108. package/dist/{types → _esm/core/EVM}/abi.js +1 -0
  109. package/dist/_esm/core/EVM/abi.js.map +1 -0
  110. package/dist/{execution → _esm/core/EVM}/checkAllowance.js +8 -6
  111. package/dist/_esm/core/EVM/checkAllowance.js.map +1 -0
  112. package/dist/{allowance → _esm/core/EVM}/getAllowance.js +20 -5
  113. package/dist/_esm/core/EVM/getAllowance.js.map +1 -0
  114. package/dist/{balance/getBalance.js → _esm/core/EVM/getEVMBalance.js} +11 -11
  115. package/dist/_esm/core/EVM/getEVMBalance.js.map +1 -0
  116. package/dist/{execution → _esm/core/EVM}/multisig.js +5 -6
  117. package/dist/_esm/core/EVM/multisig.js.map +1 -0
  118. package/dist/_esm/core/EVM/publicClient.js +37 -0
  119. package/dist/_esm/core/EVM/publicClient.js.map +1 -0
  120. package/dist/{allowance → _esm/core/EVM}/setAllowance.js +46 -11
  121. package/dist/_esm/core/EVM/setAllowance.js.map +1 -0
  122. package/dist/{execution → _esm/core/EVM}/switchChain.js +5 -3
  123. package/dist/_esm/core/EVM/switchChain.js.map +1 -0
  124. package/dist/_esm/core/EVM/types.js +6 -0
  125. package/dist/_esm/core/EVM/types.js.map +1 -0
  126. package/dist/{utils/getMaxPriorityFeePerGas.js → _esm/core/EVM/utils.js} +9 -1
  127. package/dist/_esm/core/EVM/utils.js.map +1 -0
  128. package/dist/_esm/core/Solana/Solana.js +40 -0
  129. package/dist/_esm/core/Solana/Solana.js.map +1 -0
  130. package/dist/_esm/core/Solana/SolanaStepExecutor.js +158 -0
  131. package/dist/_esm/core/Solana/SolanaStepExecutor.js.map +1 -0
  132. package/dist/_esm/core/Solana/connection.js +19 -0
  133. package/dist/_esm/core/Solana/connection.js.map +1 -0
  134. package/dist/_esm/core/Solana/getSolanaBalance.js +46 -0
  135. package/dist/_esm/core/Solana/getSolanaBalance.js.map +1 -0
  136. package/dist/_esm/core/Solana/types.js +7 -0
  137. package/dist/_esm/core/Solana/types.js.map +1 -0
  138. package/dist/_esm/core/StatusManager.js +203 -0
  139. package/dist/_esm/core/StatusManager.js.map +1 -0
  140. package/dist/{execution → _esm/core}/checkBalance.js +3 -2
  141. package/dist/_esm/core/checkBalance.js.map +1 -0
  142. package/dist/_esm/core/execution.js +173 -0
  143. package/dist/_esm/core/execution.js.map +1 -0
  144. package/dist/_esm/core/executionState.js +20 -0
  145. package/dist/_esm/core/executionState.js.map +1 -0
  146. package/dist/_esm/core/index.js +4 -0
  147. package/dist/_esm/core/index.js.map +1 -0
  148. package/dist/_esm/core/prepareRestart.js +64 -0
  149. package/dist/_esm/core/prepareRestart.js.map +1 -0
  150. package/dist/_esm/core/provider.js +11 -0
  151. package/dist/_esm/core/provider.js.map +1 -0
  152. package/dist/{execution → _esm/core}/stepComparison.js +7 -5
  153. package/dist/_esm/core/stepComparison.js.map +1 -0
  154. package/dist/_esm/core/types.js +2 -0
  155. package/dist/_esm/core/types.js.map +1 -0
  156. package/dist/{execution → _esm/core}/utils.js +14 -0
  157. package/dist/_esm/core/utils.js.map +1 -0
  158. package/dist/{execution → _esm/core}/waitForReceivingTransaction.js +8 -7
  159. package/dist/_esm/core/waitForReceivingTransaction.js.map +1 -0
  160. package/dist/_esm/createConfig.js +45 -0
  161. package/dist/_esm/createConfig.js.map +1 -0
  162. package/dist/{helpers.js → _esm/helpers.js} +4 -3
  163. package/dist/_esm/helpers.js.map +1 -0
  164. package/dist/_esm/index.js +12 -0
  165. package/dist/_esm/index.js.map +1 -0
  166. package/dist/_esm/package.json +1 -0
  167. package/dist/{request.js → _esm/request.js} +19 -9
  168. package/dist/_esm/request.js.map +1 -0
  169. package/dist/_esm/services/api.js +353 -0
  170. package/dist/_esm/services/api.js.map +1 -0
  171. package/dist/_esm/services/balance.js +65 -0
  172. package/dist/_esm/services/balance.js.map +1 -0
  173. package/dist/{typeguards.js → _esm/typeguards.js} +1 -0
  174. package/dist/_esm/typeguards.js.map +1 -0
  175. package/dist/_esm/types/index.js +2 -0
  176. package/dist/_esm/types/index.js.map +1 -0
  177. package/dist/_esm/types/internal.js +2 -0
  178. package/dist/_esm/types/internal.js.map +1 -0
  179. package/dist/{utils → _esm/utils}/errors.js +25 -0
  180. package/dist/_esm/utils/errors.js.map +1 -0
  181. package/dist/_esm/utils/getTransactionMessage.js +28 -0
  182. package/dist/_esm/utils/getTransactionMessage.js.map +1 -0
  183. package/dist/_esm/utils/index.js +6 -0
  184. package/dist/_esm/utils/index.js.map +1 -0
  185. package/dist/{utils → _esm/utils}/median.js +1 -0
  186. package/dist/_esm/utils/median.js.map +1 -0
  187. package/dist/_esm/utils/parseBackendError.js +24 -0
  188. package/dist/_esm/utils/parseBackendError.js.map +1 -0
  189. package/dist/{utils → _esm/utils}/parseError.js +4 -53
  190. package/dist/_esm/utils/parseError.js.map +1 -0
  191. package/dist/{utils → _esm/utils}/utils.js +2 -1
  192. package/dist/_esm/utils/utils.js.map +1 -0
  193. package/dist/_esm/version.js +3 -0
  194. package/dist/_esm/version.js.map +1 -0
  195. package/dist/_types/config.d.ts +11 -0
  196. package/dist/_types/config.d.ts.map +1 -0
  197. package/dist/{cjs → _types}/constants.d.ts +1 -0
  198. package/dist/_types/constants.d.ts.map +1 -0
  199. package/dist/_types/core/BaseStepExecutor.d.ts +13 -0
  200. package/dist/_types/core/BaseStepExecutor.d.ts.map +1 -0
  201. package/dist/_types/core/EVM/EVM.d.ts +3 -0
  202. package/dist/_types/core/EVM/EVM.d.ts.map +1 -0
  203. package/dist/_types/core/EVM/EVMStepExecutor.d.ts +17 -0
  204. package/dist/_types/core/EVM/EVMStepExecutor.d.ts.map +1 -0
  205. package/dist/{cjs/types → _types/core/EVM}/abi.d.ts +1 -0
  206. package/dist/_types/core/EVM/abi.d.ts.map +1 -0
  207. package/dist/_types/core/EVM/checkAllowance.d.ts +6 -0
  208. package/dist/_types/core/EVM/checkAllowance.d.ts.map +1 -0
  209. package/dist/{cjs/allowance → _types/core/EVM}/getAllowance.d.ts +15 -1
  210. package/dist/_types/core/EVM/getAllowance.d.ts.map +1 -0
  211. package/dist/_types/core/EVM/getEVMBalance.d.ts +3 -0
  212. package/dist/_types/core/EVM/getEVMBalance.d.ts.map +1 -0
  213. package/dist/_types/core/EVM/multisig.d.ts +6 -0
  214. package/dist/_types/core/EVM/multisig.d.ts.map +1 -0
  215. package/dist/_types/core/EVM/publicClient.d.ts +8 -0
  216. package/dist/_types/core/EVM/publicClient.d.ts.map +1 -0
  217. package/dist/_types/core/EVM/setAllowance.d.ts +25 -0
  218. package/dist/_types/core/EVM/setAllowance.d.ts.map +1 -0
  219. package/dist/{execution → _types/core/EVM}/switchChain.d.ts +6 -4
  220. package/dist/_types/core/EVM/switchChain.d.ts.map +1 -0
  221. package/dist/_types/core/EVM/types.d.ts +57 -0
  222. package/dist/_types/core/EVM/types.d.ts.map +1 -0
  223. package/dist/_types/core/EVM/utils.d.ts +5 -0
  224. package/dist/_types/core/EVM/utils.d.ts.map +1 -0
  225. package/dist/_types/core/Solana/Solana.d.ts +3 -0
  226. package/dist/_types/core/Solana/Solana.d.ts.map +1 -0
  227. package/dist/_types/core/Solana/SolanaStepExecutor.d.ts +13 -0
  228. package/dist/_types/core/Solana/SolanaStepExecutor.d.ts.map +1 -0
  229. package/dist/_types/core/Solana/connection.d.ts +8 -0
  230. package/dist/_types/core/Solana/connection.d.ts.map +1 -0
  231. package/dist/_types/core/Solana/getSolanaBalance.d.ts +3 -0
  232. package/dist/_types/core/Solana/getSolanaBalance.d.ts.map +1 -0
  233. package/dist/_types/core/Solana/types.d.ts +13 -0
  234. package/dist/_types/core/Solana/types.d.ts.map +1 -0
  235. package/dist/{cjs/execution → _types/core}/StatusManager.d.ts +12 -16
  236. package/dist/_types/core/StatusManager.d.ts.map +1 -0
  237. package/dist/_types/core/checkBalance.d.ts +3 -0
  238. package/dist/_types/core/checkBalance.d.ts.map +1 -0
  239. package/dist/_types/core/execution.d.ts +42 -0
  240. package/dist/_types/core/execution.d.ts.map +1 -0
  241. package/dist/_types/core/executionState.d.ts +16 -0
  242. package/dist/_types/core/executionState.d.ts.map +1 -0
  243. package/dist/_types/core/index.d.ts +4 -0
  244. package/dist/_types/core/index.d.ts.map +1 -0
  245. package/dist/_types/core/prepareRestart.d.ts +3 -0
  246. package/dist/_types/core/prepareRestart.d.ts.map +1 -0
  247. package/dist/_types/core/provider.d.ts +3 -0
  248. package/dist/_types/core/provider.d.ts.map +1 -0
  249. package/dist/{execution → _types/core}/stepComparison.d.ts +7 -4
  250. package/dist/_types/core/stepComparison.d.ts.map +1 -0
  251. package/dist/_types/core/types.d.ts +71 -0
  252. package/dist/_types/core/types.d.ts.map +1 -0
  253. package/dist/{execution → _types/core}/utils.d.ts +5 -2
  254. package/dist/_types/core/utils.d.ts.map +1 -0
  255. package/dist/_types/core/waitForReceivingTransaction.d.ts +4 -0
  256. package/dist/_types/core/waitForReceivingTransaction.d.ts.map +1 -0
  257. package/dist/_types/createConfig.d.ts +7 -0
  258. package/dist/_types/createConfig.d.ts.map +1 -0
  259. package/dist/{helpers.d.ts → _types/helpers.d.ts} +4 -3
  260. package/dist/_types/helpers.d.ts.map +1 -0
  261. package/dist/_types/index.d.ts +12 -0
  262. package/dist/_types/index.d.ts.map +1 -0
  263. package/dist/{request.d.ts → _types/request.d.ts} +1 -0
  264. package/dist/_types/request.d.ts.map +1 -0
  265. package/dist/_types/services/api.d.ts +87 -0
  266. package/dist/_types/services/api.d.ts.map +1 -0
  267. package/dist/_types/services/balance.d.ts +30 -0
  268. package/dist/_types/services/balance.d.ts.map +1 -0
  269. package/dist/{cjs → _types}/typeguards.d.ts +3 -2
  270. package/dist/_types/typeguards.d.ts.map +1 -0
  271. package/dist/_types/types/index.d.ts +2 -0
  272. package/dist/_types/types/index.d.ts.map +1 -0
  273. package/dist/_types/types/internal.d.ts +56 -0
  274. package/dist/_types/types/internal.d.ts.map +1 -0
  275. package/dist/{utils → _types/utils}/errors.d.ts +1 -0
  276. package/dist/_types/utils/errors.d.ts.map +1 -0
  277. package/dist/_types/utils/getTransactionMessage.d.ts +4 -0
  278. package/dist/_types/utils/getTransactionMessage.d.ts.map +1 -0
  279. package/dist/_types/utils/index.d.ts +6 -0
  280. package/dist/_types/utils/index.d.ts.map +1 -0
  281. package/dist/{cjs → _types}/utils/median.d.ts +1 -0
  282. package/dist/_types/utils/median.d.ts.map +1 -0
  283. package/dist/_types/utils/parseBackendError.d.ts +3 -0
  284. package/dist/_types/utils/parseBackendError.d.ts.map +1 -0
  285. package/dist/{utils → _types/utils}/parseError.d.ts +4 -6
  286. package/dist/_types/utils/parseError.d.ts.map +1 -0
  287. package/dist/{utils → _types/utils}/utils.d.ts +1 -0
  288. package/dist/_types/utils/utils.d.ts.map +1 -0
  289. package/dist/_types/version.d.ts +3 -0
  290. package/dist/_types/version.d.ts.map +1 -0
  291. package/dist/config.ts +47 -0
  292. package/dist/constants.ts +7 -0
  293. package/dist/core/BaseStepExecutor.ts +40 -0
  294. package/dist/core/EVM/EVM.ts +50 -0
  295. package/dist/core/EVM/EVMStepExecutor.ts +472 -0
  296. package/dist/core/EVM/abi.ts +47 -0
  297. package/dist/core/EVM/checkAllowance.ts +152 -0
  298. package/dist/core/EVM/getAllowance.ts +146 -0
  299. package/dist/core/EVM/getEVMBalance.ts +120 -0
  300. package/dist/core/EVM/multisig.ts +53 -0
  301. package/dist/core/EVM/publicClient.ts +46 -0
  302. package/dist/core/EVM/setAllowance.ts +144 -0
  303. package/dist/core/EVM/switchChain.ts +77 -0
  304. package/dist/core/EVM/types.ts +75 -0
  305. package/dist/core/EVM/utils.ts +43 -0
  306. package/dist/core/Solana/Solana.ts +46 -0
  307. package/dist/core/Solana/SolanaStepExecutor.ts +253 -0
  308. package/dist/core/Solana/connection.ts +19 -0
  309. package/dist/core/Solana/getSolanaBalance.ts +62 -0
  310. package/dist/core/Solana/types.ts +18 -0
  311. package/dist/core/StatusManager.ts +238 -0
  312. package/dist/core/checkBalance.ts +48 -0
  313. package/dist/core/execution.ts +218 -0
  314. package/dist/core/executionState.ts +40 -0
  315. package/dist/core/index.ts +3 -0
  316. package/dist/core/prepareRestart.ts +81 -0
  317. package/dist/core/provider.ts +12 -0
  318. package/dist/core/stepComparison.ts +51 -0
  319. package/dist/core/types.ts +103 -0
  320. package/dist/core/utils.ts +122 -0
  321. package/dist/core/waitForReceivingTransaction.ts +73 -0
  322. package/dist/createConfig.ts +54 -0
  323. package/dist/helpers.ts +97 -0
  324. package/dist/index.ts +11 -0
  325. package/dist/request.ts +79 -0
  326. package/dist/services/api.ts +472 -0
  327. package/dist/services/balance.ts +93 -0
  328. package/dist/typeguards.ts +89 -0
  329. package/dist/types/index.ts +1 -0
  330. package/dist/types/internal.ts +58 -0
  331. package/dist/utils/errors.ts +231 -0
  332. package/dist/utils/getTransactionMessage.ts +46 -0
  333. package/dist/utils/index.ts +5 -0
  334. package/dist/utils/median.ts +11 -0
  335. package/dist/utils/parseBackendError.ts +50 -0
  336. package/dist/utils/parseError.ts +204 -0
  337. package/dist/utils/utils.ts +48 -0
  338. package/dist/version.ts +2 -0
  339. package/package.json +27 -86
  340. package/dist/LiFi.d.ts +0 -171
  341. package/dist/LiFi.js +0 -246
  342. package/dist/allowance/getAllowance.d.ts +0 -6
  343. package/dist/allowance/index.d.ts +0 -3
  344. package/dist/allowance/index.js +0 -3
  345. package/dist/allowance/setAllowance.d.ts +0 -5
  346. package/dist/allowance/types.d.ts +0 -27
  347. package/dist/allowance/types.js +0 -1
  348. package/dist/balance/getBalance.d.ts +0 -2
  349. package/dist/balance/getTokenBalance.d.ts +0 -8
  350. package/dist/balance/getTokenBalance.js +0 -27
  351. package/dist/balance/index.d.ts +0 -2
  352. package/dist/balance/index.js +0 -2
  353. package/dist/cjs/LiFi.d.ts +0 -171
  354. package/dist/cjs/LiFi.js +0 -276
  355. package/dist/cjs/allowance/index.d.ts +0 -3
  356. package/dist/cjs/allowance/index.js +0 -19
  357. package/dist/cjs/allowance/setAllowance.d.ts +0 -5
  358. package/dist/cjs/allowance/setAllowance.js +0 -56
  359. package/dist/cjs/allowance/types.d.ts +0 -27
  360. package/dist/cjs/balance/getBalance.d.ts +0 -2
  361. package/dist/cjs/balance/getTokenBalance.d.ts +0 -8
  362. package/dist/cjs/balance/getTokenBalance.js +0 -33
  363. package/dist/cjs/balance/index.d.ts +0 -2
  364. package/dist/cjs/balance/index.js +0 -18
  365. package/dist/cjs/connectors.d.ts +0 -8
  366. package/dist/cjs/connectors.js +0 -75
  367. package/dist/cjs/execution/RouteExecutionManager.d.ts +0 -59
  368. package/dist/cjs/execution/RouteExecutionManager.js +0 -202
  369. package/dist/cjs/execution/StatusManager.js +0 -171
  370. package/dist/cjs/execution/StepExecutionManager.d.ts +0 -7
  371. package/dist/cjs/execution/StepExecutionManager.js +0 -267
  372. package/dist/cjs/execution/StepExecutor.d.ts +0 -15
  373. package/dist/cjs/execution/StepExecutor.js +0 -62
  374. package/dist/cjs/execution/checkAllowance.d.ts +0 -4
  375. package/dist/cjs/execution/checkBalance.d.ts +0 -2
  376. package/dist/cjs/execution/index.d.ts +0 -1
  377. package/dist/cjs/execution/index.js +0 -17
  378. package/dist/cjs/execution/multisig.d.ts +0 -4
  379. package/dist/cjs/execution/prepareRestart.d.ts +0 -3
  380. package/dist/cjs/execution/prepareRestart.js +0 -65
  381. package/dist/cjs/execution/stepComparison.d.ts +0 -14
  382. package/dist/cjs/execution/stepComparison.js +0 -37
  383. package/dist/cjs/execution/switchChain.d.ts +0 -21
  384. package/dist/cjs/execution/switchChain.js +0 -54
  385. package/dist/cjs/execution/utils.d.ts +0 -12
  386. package/dist/cjs/execution/waitForReceivingTransaction.d.ts +0 -3
  387. package/dist/cjs/helpers.d.ts +0 -18
  388. package/dist/cjs/index.d.ts +0 -5
  389. package/dist/cjs/index.js +0 -24
  390. package/dist/cjs/request.d.ts +0 -9
  391. package/dist/cjs/services/ApiService.d.ts +0 -17
  392. package/dist/cjs/services/ApiService.js +0 -326
  393. package/dist/cjs/services/ChainsService.d.ts +0 -11
  394. package/dist/cjs/services/ChainsService.js +0 -39
  395. package/dist/cjs/services/ConfigService.d.ts +0 -23
  396. package/dist/cjs/services/ConfigService.js +0 -101
  397. package/dist/cjs/types/index.d.ts +0 -4
  398. package/dist/cjs/types/index.js +0 -22
  399. package/dist/cjs/types/internal.types.d.ts +0 -142
  400. package/dist/cjs/utils/errors.d.ts +0 -107
  401. package/dist/cjs/utils/getMaxPriorityFeePerGas.d.ts +0 -2
  402. package/dist/cjs/utils/index.d.ts +0 -5
  403. package/dist/cjs/utils/index.js +0 -21
  404. package/dist/cjs/utils/parseError.d.ts +0 -37
  405. package/dist/cjs/utils/parseError.js +0 -157
  406. package/dist/cjs/utils/utils.d.ts +0 -10
  407. package/dist/cjs/version.d.ts +0 -2
  408. package/dist/connectors.d.ts +0 -8
  409. package/dist/connectors.js +0 -41
  410. package/dist/constants.d.ts +0 -6
  411. package/dist/execution/RouteExecutionManager.d.ts +0 -59
  412. package/dist/execution/RouteExecutionManager.js +0 -195
  413. package/dist/execution/StatusManager.d.ts +0 -67
  414. package/dist/execution/StatusManager.js +0 -167
  415. package/dist/execution/StepExecutionManager.d.ts +0 -7
  416. package/dist/execution/StepExecutionManager.js +0 -260
  417. package/dist/execution/StepExecutor.d.ts +0 -15
  418. package/dist/execution/StepExecutor.js +0 -58
  419. package/dist/execution/checkAllowance.d.ts +0 -4
  420. package/dist/execution/checkBalance.d.ts +0 -2
  421. package/dist/execution/index.d.ts +0 -1
  422. package/dist/execution/index.js +0 -1
  423. package/dist/execution/multisig.d.ts +0 -4
  424. package/dist/execution/prepareRestart.d.ts +0 -3
  425. package/dist/execution/prepareRestart.js +0 -61
  426. package/dist/execution/waitForReceivingTransaction.d.ts +0 -3
  427. package/dist/index.d.ts +0 -5
  428. package/dist/index.js +0 -6
  429. package/dist/services/ApiService.d.ts +0 -17
  430. package/dist/services/ApiService.js +0 -321
  431. package/dist/services/ChainsService.d.ts +0 -11
  432. package/dist/services/ChainsService.js +0 -33
  433. package/dist/services/ConfigService.d.ts +0 -23
  434. package/dist/services/ConfigService.js +0 -99
  435. package/dist/typeguards.d.ts +0 -4
  436. package/dist/types/abi.d.ts +0 -5
  437. package/dist/types/index.d.ts +0 -4
  438. package/dist/types/index.js +0 -4
  439. package/dist/types/internal.types.d.ts +0 -142
  440. package/dist/types/internal.types.js +0 -1
  441. package/dist/utils/getMaxPriorityFeePerGas.d.ts +0 -2
  442. package/dist/utils/index.d.ts +0 -5
  443. package/dist/utils/index.js +0 -5
  444. package/dist/utils/median.d.ts +0 -1
  445. package/dist/version.d.ts +0 -2
  446. package/dist/version.js +0 -2
@@ -0,0 +1,238 @@
1
+ import type {
2
+ Execution,
3
+ LiFiStep,
4
+ Process,
5
+ ProcessType,
6
+ Status,
7
+ Token,
8
+ } from '@lifi/types'
9
+ import { emptyExecution } from '@lifi/types'
10
+ import { executionState } from './executionState.js'
11
+ import { getProcessMessage } from './utils.js'
12
+
13
+ interface Receipt {
14
+ fromAmount?: string
15
+ toAmount?: string
16
+ toToken?: Token
17
+ gasPrice?: string
18
+ gasUsed?: string
19
+ gasToken?: Token
20
+ gasAmount?: string
21
+ gasAmountUSD?: string
22
+ }
23
+
24
+ type OptionalParameters = Partial<
25
+ Pick<
26
+ Process,
27
+ | 'doneAt'
28
+ | 'failedAt'
29
+ | 'txHash'
30
+ | 'txLink'
31
+ | 'error'
32
+ | 'substatus'
33
+ | 'substatusMessage'
34
+ | 'multisigTxHash'
35
+ >
36
+ >
37
+
38
+ /**
39
+ * Manages status updates of a route and provides various functions for tracking processes
40
+ * @param {string} routeId The route dd this StatusManger belongs to.
41
+ * @returns {StatusManager} An instance of StatusManager.
42
+ */
43
+ export class StatusManager {
44
+ private readonly routeId: string
45
+ private shouldUpdate = true
46
+
47
+ constructor(routeId: string) {
48
+ this.routeId = routeId
49
+ }
50
+
51
+ /**
52
+ * Initializes the execution object of a Step.
53
+ * @param step The current step in execution
54
+ * @returns The initialized execution object for this step and a function to update this step
55
+ */
56
+ initExecutionObject = (step: LiFiStep): Execution => {
57
+ if (!step.execution) {
58
+ step.execution = structuredClone<Execution>(emptyExecution)
59
+ step.execution.status = 'PENDING'
60
+ this.updateStepInRoute(step)
61
+ }
62
+
63
+ // Change status to PENDING after resuming from FAILED
64
+ if (step.execution.status === 'FAILED') {
65
+ step.execution.status = 'PENDING'
66
+ this.updateStepInRoute(step)
67
+ }
68
+
69
+ return step.execution
70
+ }
71
+
72
+ /**
73
+ * Updates the execution object of a Step.
74
+ * @param step The current step in execution
75
+ * @param status The status for the execution
76
+ * @param receipt Optional. Information about received tokens
77
+ * @returns The step with the updated execution object
78
+ */
79
+ updateExecution(step: LiFiStep, status: Status, receipt?: Receipt): LiFiStep {
80
+ if (!step.execution) {
81
+ throw Error("Can't update empty execution.")
82
+ }
83
+ step.execution.status = status
84
+ if (receipt) {
85
+ step.execution = {
86
+ ...step.execution,
87
+ ...receipt,
88
+ }
89
+ }
90
+ this.updateStepInRoute(step)
91
+ return step
92
+ }
93
+
94
+ /**
95
+ * Create and push a new process into the execution.
96
+ * @param step The step that should contain the new process.
97
+ * @param type Type of the process. Used to identify already existing processes.
98
+ * @param status By default created procces is set to the STARTED status. We can override new process with the needed status.
99
+ * @returns Returns process.
100
+ */
101
+ findOrCreateProcess = (
102
+ step: LiFiStep,
103
+ type: ProcessType,
104
+ status?: Status
105
+ ): Process => {
106
+ if (!step.execution?.process) {
107
+ throw new Error("Execution hasn't been initialized.")
108
+ }
109
+
110
+ const process = step.execution.process.find((p) => p.type === type)
111
+
112
+ if (process) {
113
+ if (status && process.status !== status) {
114
+ process.status = status
115
+ this.updateStepInRoute(step)
116
+ }
117
+ return process
118
+ }
119
+
120
+ const newProcess: Process = {
121
+ type: type,
122
+ startedAt: Date.now(),
123
+ message: getProcessMessage(type, status ?? 'STARTED'),
124
+ status: status ?? 'STARTED',
125
+ }
126
+
127
+ step.execution.process.push(newProcess)
128
+ this.updateStepInRoute(step)
129
+ return newProcess
130
+ }
131
+
132
+ /**
133
+ * Update a process object.
134
+ * @param step The step where the process should be updated
135
+ * @param type The process type to update
136
+ * @param status The status the process gets.
137
+ * @param [params] Additional parameters to append to the process.
138
+ * @returns The update process
139
+ */
140
+ updateProcess = (
141
+ step: LiFiStep,
142
+ type: ProcessType,
143
+ status: Status,
144
+ params?: OptionalParameters
145
+ ): Process => {
146
+ if (!step.execution) {
147
+ throw new Error("Can't update an empty step execution.")
148
+ }
149
+ const currentProcess = step?.execution?.process.find((p) => p.type === type)
150
+
151
+ if (!currentProcess) {
152
+ throw new Error("Can't find a process for the given type.")
153
+ }
154
+
155
+ switch (status) {
156
+ case 'CANCELLED':
157
+ currentProcess.doneAt = Date.now()
158
+ break
159
+ case 'FAILED':
160
+ currentProcess.doneAt = Date.now()
161
+ step.execution.status = 'FAILED'
162
+ break
163
+ case 'DONE':
164
+ currentProcess.doneAt = Date.now()
165
+ break
166
+ case 'PENDING':
167
+ step.execution.status = 'PENDING'
168
+ break
169
+ case 'ACTION_REQUIRED':
170
+ step.execution.status = 'ACTION_REQUIRED'
171
+ break
172
+ default:
173
+ break
174
+ }
175
+
176
+ currentProcess.status = status
177
+ currentProcess.message = getProcessMessage(type, status)
178
+ // set extra parameters or overwritte the standard params set in the switch statement
179
+ if (params) {
180
+ for (const [key, value] of Object.entries(params)) {
181
+ currentProcess[key] = value
182
+ }
183
+ }
184
+ // Sort processes, the ones with DONE status go first
185
+ step.execution.process = [
186
+ ...step?.execution?.process.filter(
187
+ (process) => process.status === 'DONE'
188
+ ),
189
+ ...step?.execution?.process.filter(
190
+ (process) => process.status !== 'DONE'
191
+ ),
192
+ ]
193
+ this.updateStepInRoute(step) // updates the step in the route
194
+ return currentProcess
195
+ }
196
+
197
+ /**
198
+ * Remove a process from the execution
199
+ * @param step The step where the process should be removed from
200
+ * @param type The process type to remove
201
+ */
202
+ removeProcess = (step: LiFiStep, type: ProcessType): void => {
203
+ if (!step.execution) {
204
+ throw new Error("Execution hasn't been initialized.")
205
+ }
206
+ const index = step.execution.process.findIndex((p) => p.type === type)
207
+ step.execution.process.splice(index, 1)
208
+ this.updateStepInRoute(step)
209
+ }
210
+
211
+ updateStepInRoute = (step: LiFiStep): LiFiStep => {
212
+ if (!this.shouldUpdate) {
213
+ return step
214
+ }
215
+ const data = executionState.get(this.routeId)
216
+
217
+ if (!data) {
218
+ throw new Error('Execution data not found.')
219
+ }
220
+
221
+ const stepIndex = data.route.steps.findIndex(
222
+ (routeStep) => routeStep.id === step.id
223
+ )
224
+
225
+ if (stepIndex === -1) {
226
+ throw new Error("Couldn't find a step to update.")
227
+ }
228
+
229
+ data.route.steps[stepIndex] = { ...data.route.steps[stepIndex], ...step }
230
+
231
+ data.executionOptions?.updateRouteHook?.(data.route)
232
+ return data.route.steps[stepIndex]
233
+ }
234
+
235
+ allowUpdates(value: boolean): void {
236
+ this.shouldUpdate = value
237
+ }
238
+ }
@@ -0,0 +1,48 @@
1
+ import type { LiFiStep } from '@lifi/types'
2
+ import { formatUnits } from 'viem'
3
+ import { getTokenBalance } from '../services/balance.js'
4
+ import { BalanceError } from '../utils/errors.js'
5
+
6
+ export const checkBalance = async (
7
+ walletAddress: string,
8
+ step: LiFiStep,
9
+ depth = 0
10
+ ): Promise<void> => {
11
+ const token = await getTokenBalance(walletAddress, step.action.fromToken)
12
+ if (token) {
13
+ const currentBalance = token.amount ?? 0n
14
+ const neededBalance = BigInt(step.action.fromAmount)
15
+
16
+ if (currentBalance < neededBalance) {
17
+ if (depth <= 3) {
18
+ await new Promise((resolve) => {
19
+ setTimeout(resolve, 200)
20
+ })
21
+ await checkBalance(walletAddress, step, depth + 1)
22
+ } else if (
23
+ (neededBalance * BigInt((1 - step.action.slippage) * 1_000_000_000)) /
24
+ 1_000_000_000n <=
25
+ currentBalance
26
+ ) {
27
+ // adjust amount in slippage limits
28
+ step.action.fromAmount = currentBalance.toString()
29
+ } else {
30
+ const neeeded = formatUnits(neededBalance, token.decimals)
31
+ const current = formatUnits(currentBalance, token.decimals)
32
+ let errorMessage =
33
+ `Your ${token.symbol} balance is too low, ` +
34
+ `you try to transfer ${neeeded} ${token.symbol}, ` +
35
+ `but your wallet only holds ${current} ${token.symbol}. ` +
36
+ `No funds have been sent.`
37
+
38
+ if (currentBalance !== 0n) {
39
+ errorMessage +=
40
+ `If the problem consists, please delete this transfer and ` +
41
+ `start a new one with a maximum of ${current} ${token.symbol}.`
42
+ }
43
+
44
+ throw new BalanceError('The balance is too low.', errorMessage)
45
+ }
46
+ }
47
+ }
48
+ }
@@ -0,0 +1,218 @@
1
+ /* eslint-disable @typescript-eslint/no-empty-function */
2
+ import type { Route } from '@lifi/types'
3
+ import { config } from '../config.js'
4
+ import { executionState } from './executionState.js'
5
+ import { prepareRestart } from './prepareRestart.js'
6
+ import type { ExecutionOptions } from './types.js'
7
+
8
+ /**
9
+ * Execute a route.
10
+ * @param route - The route that should be executed. Cannot be an active route.
11
+ * @param executionOptions - An object containing settings and callbacks.
12
+ * @returns The executed route.
13
+ * @throws {LiFiError} Throws a LiFiError if the execution fails.
14
+ */
15
+ export const executeRoute = async (
16
+ route: Route,
17
+ executionOptions?: ExecutionOptions
18
+ ): Promise<Route> => {
19
+ // Deep clone to prevent side effects
20
+ const clonedRoute = structuredClone<Route>(route)
21
+
22
+ let executionPromise = executionState.get(clonedRoute.id)?.promise
23
+ // Check if route is already running
24
+ if (executionPromise) {
25
+ return executionPromise
26
+ }
27
+
28
+ executionPromise = executeSteps(clonedRoute, executionOptions)
29
+
30
+ executionState.create(route, executionOptions, executionPromise)
31
+
32
+ return executionPromise
33
+ }
34
+
35
+ /**
36
+ * Resume the execution of a route that has been stopped or had an error while executing.
37
+ * @param route - The route that is to be executed. Cannot be an active route.
38
+ * @param executionOptions - An object containing settings and callbacks.
39
+ * @returns The executed route.
40
+ * @throws {LiFiError} Throws a LiFiError if the execution fails.
41
+ */
42
+ export const resumeRoute = async (
43
+ route: Route,
44
+ executionOptions?: ExecutionOptions
45
+ ): Promise<Route> => {
46
+ // Deep clone to prevent side effects
47
+ const clonedRoute = structuredClone<Route>(route)
48
+
49
+ const execution = executionState.get(clonedRoute.id)
50
+
51
+ if (execution) {
52
+ const executionHalted = execution.executors.some(
53
+ (executor) => !executor.allowExecution
54
+ )
55
+ if (!executionHalted) {
56
+ // Check if we want to resume route execution in the background
57
+ updateRouteExecution(route, {
58
+ executeInBackground: executionOptions?.executeInBackground,
59
+ })
60
+ if (!execution.promise) {
61
+ // We should never reach this point if we do clean-up properly
62
+ throw new Error('Route execution promise not found.')
63
+ }
64
+ return execution.promise
65
+ }
66
+ }
67
+
68
+ await prepareRestart(clonedRoute)
69
+
70
+ const executionPromise = executeSteps(clonedRoute, executionOptions)
71
+ executionState.create(route, executionOptions, executionPromise)
72
+
73
+ return executionPromise
74
+ }
75
+
76
+ const executeSteps = async (
77
+ route: Route,
78
+ executionOptions?: ExecutionOptions
79
+ ): Promise<Route> => {
80
+ executionState.create(route, executionOptions)
81
+
82
+ // Loop over steps and execute them
83
+ for (let index = 0; index < route.steps.length; index++) {
84
+ const execution = executionState.get(route.id)
85
+ // Check if execution has stopped in the meantime
86
+ if (!execution) {
87
+ break
88
+ }
89
+
90
+ const step = route.steps[index]
91
+ const previousStep = route.steps[index - 1]
92
+ // Check if the step is already done
93
+ //
94
+ if (step.execution?.status === 'DONE') {
95
+ continue
96
+ }
97
+
98
+ // Update amount using output of previous execution. In the future this should be handled by calling `updateRoute`
99
+ if (previousStep?.execution?.toAmount) {
100
+ step.action.fromAmount = previousStep.execution.toAmount
101
+ }
102
+
103
+ try {
104
+ const fromAddress = step.action.fromAddress
105
+ if (!fromAddress) {
106
+ throw new Error('Action fromAddress is not specified.')
107
+ }
108
+
109
+ const provider = config
110
+ .get()
111
+ .providers?.find((provider) => provider.isAddress(fromAddress))
112
+
113
+ if (!provider) {
114
+ throw new Error('SDK Execution Provider not found.')
115
+ }
116
+
117
+ const stepExecutor = await provider.getStepExecutor({
118
+ routeId: route.id,
119
+ executionOptions: execution.executionOptions,
120
+ })
121
+ execution.executors.push(stepExecutor)
122
+
123
+ // Check if we want to execute this step in the background
124
+ if (execution.executionOptions) {
125
+ updateRouteExecution(route, execution.executionOptions)
126
+ }
127
+
128
+ const executedStep = await stepExecutor.executeStep(step)
129
+
130
+ // We may reach this point if user interaction isn't allowed. We want to stop execution until we resume it
131
+ if (executedStep.execution?.status !== 'DONE') {
132
+ stopRouteExecution(route)
133
+ }
134
+
135
+ // Execution stopped during the current step, we don't want to continue to the next step so we return already
136
+ if (stepExecutor.allowExecution) {
137
+ return route
138
+ }
139
+ } catch (e) {
140
+ stopRouteExecution(route)
141
+ throw e
142
+ }
143
+ }
144
+
145
+ // Clean up after the execution
146
+ executionState.delete(route.id)
147
+ return route
148
+ }
149
+
150
+ /**
151
+ * Updates route execution to background or foreground state.
152
+ * @param route - A route that is currently in execution.
153
+ * @param options - An object with execution settings.
154
+ */
155
+ export const updateRouteExecution = (
156
+ route: Route,
157
+ options: ExecutionOptions
158
+ ): void => {
159
+ const execution = executionState.get(route.id)
160
+ if (!execution) {
161
+ return
162
+ }
163
+
164
+ if ('executeInBackground' in options) {
165
+ for (const executor of execution.executors) {
166
+ executor.setInteraction({
167
+ allowInteraction: !options?.executeInBackground,
168
+ allowUpdates: true,
169
+ })
170
+ }
171
+ }
172
+ // Update active route settings so we know what the current state of execution is
173
+ execution.executionOptions = {
174
+ ...execution.executionOptions,
175
+ ...options,
176
+ }
177
+ }
178
+
179
+ /**
180
+ * Stops the execution of an active route.
181
+ * @param route - A route that is currently in execution.
182
+ * @returns The stopped route.
183
+ */
184
+ export const stopRouteExecution = (route: Route): Route => {
185
+ const execution = executionState.get(route.id)
186
+ if (!execution) {
187
+ return route
188
+ }
189
+
190
+ for (const executor of execution.executors) {
191
+ executor.setInteraction({
192
+ allowInteraction: false,
193
+ allowUpdates: false,
194
+ allowExecution: false,
195
+ })
196
+ }
197
+ executionState.delete(route.id)
198
+ return route
199
+ }
200
+
201
+ /**
202
+ * Get the list of active routes.
203
+ * @returns A list of routes.
204
+ */
205
+ export const getActiveRoutes = (): Route[] => {
206
+ return Object.values(executionState.state)
207
+ .map((dict) => dict?.route)
208
+ .filter(Boolean) as Route[]
209
+ }
210
+
211
+ /**
212
+ * Return the current route information for given route. The route has to be active.
213
+ * @param routeId - A route id.
214
+ * @returns The updated route.
215
+ */
216
+ export const getActiveRoute = (routeId: string): Route | undefined => {
217
+ return executionState.get(routeId)?.route
218
+ }
@@ -0,0 +1,40 @@
1
+ import type { Route } from '@lifi/types'
2
+ import type { ExecutionOptions, StepExecutor } from './types.js'
3
+
4
+ export interface ExecutionData {
5
+ route: Route
6
+ executors: StepExecutor[]
7
+ executionOptions?: ExecutionOptions
8
+ promise?: Promise<Route>
9
+ }
10
+
11
+ export interface ExecutionState {
12
+ state: Partial<Record<string, ExecutionData>>
13
+ get(routeId: string): ExecutionData | undefined
14
+ create(
15
+ route: Route,
16
+ executionOptions?: ExecutionOptions,
17
+ promise?: Promise<Route>
18
+ ): ExecutionData
19
+ delete(routeId: string): void
20
+ }
21
+
22
+ export const executionState: ExecutionState = {
23
+ state: {},
24
+ get(routeId: string) {
25
+ return this.state[routeId]
26
+ },
27
+ create(route, executionOptions, promise) {
28
+ this.state[route.id] = {
29
+ ...this.state[route.id],
30
+ route,
31
+ executionOptions,
32
+ promise,
33
+ executors: [],
34
+ }
35
+ return this.state[route.id]!
36
+ },
37
+ delete(routeId) {
38
+ delete this.state[routeId]
39
+ },
40
+ }
@@ -0,0 +1,3 @@
1
+ export * from './StatusManager.js'
2
+ export * from './execution.js'
3
+ export * from './types.js'
@@ -0,0 +1,81 @@
1
+ import type { LiFiStep, Route } from '@lifi/types'
2
+
3
+ export const prepareRestart = async (route: Route) => {
4
+ for (let index = 0; index < route.steps.length; index++) {
5
+ const step = route.steps[index]
6
+ const stepHasFailed = step.execution?.status === 'FAILED'
7
+
8
+ if (stepHasFailed) {
9
+ // await handleErrorType(walletClient, step)
10
+ deleteFailedProcesses(step)
11
+ deleteTransactionData(step)
12
+ }
13
+ }
14
+ }
15
+
16
+ // const handleErrorType = async (walletClient: WalletClient, step: LiFiStep) => {
17
+ // const client = walletClient.extend(publicActions)
18
+
19
+ // const isGasLimitError = step.execution?.process.some(
20
+ // (p) => p.error?.code === LiFiErrorCode.GasLimitError
21
+ // )
22
+ // const isGasPriceError = step.execution?.process.some(
23
+ // (p) => p.error?.code === LiFiErrorCode.TransactionUnderpriced
24
+ // )
25
+
26
+ // const { transactionRequest } = step
27
+
28
+ // if (isGasLimitError) {
29
+ // if (transactionRequest) {
30
+ // let gasLimit = transactionRequest.gasLimit
31
+
32
+ // try {
33
+ // gasLimit = await client.estimateGas(transactionRequest)
34
+ // } catch (error) {}
35
+
36
+ // if (gasLimit) {
37
+ // transactionRequest.gasLimit = BigNumber.from(
38
+ // `${(BigInt(gasLimit.toString()) * 125n) / 100n}`
39
+ // )
40
+ // }
41
+ // }
42
+
43
+ // step.estimate.gasCosts?.forEach(
44
+ // (gasCost) =>
45
+ // (gasCost.limit = `${Math.round(Number(gasCost.limit) * 1.25)}`)
46
+ // )
47
+ // }
48
+
49
+ // if (isGasPriceError) {
50
+ // if (transactionRequest) {
51
+ // let gasPrice = transactionRequest.gasPrice
52
+
53
+ // try {
54
+ // gasPrice = await client.getGasPrice()
55
+ // } catch (error) {}
56
+
57
+ // if (gasPrice) {
58
+ // transactionRequest.gasPrice = BigNumber.from(
59
+ // `${(BigInt(gasPrice.toString()) * 125n) / 100n}`
60
+ // )
61
+ // }
62
+ // }
63
+
64
+ // step.estimate.gasCosts?.forEach(
65
+ // (gasCost) =>
66
+ // (gasCost.price = `${Math.round(Number(gasCost.price) * 1.25)}`)
67
+ // )
68
+ // }
69
+ // }
70
+
71
+ const deleteFailedProcesses = (step: LiFiStep) => {
72
+ if (step.execution) {
73
+ step.execution.process = step.execution.process.filter(
74
+ (process) => process.status === 'DONE'
75
+ )
76
+ }
77
+ }
78
+
79
+ const deleteTransactionData = (step: LiFiStep) => {
80
+ step.transactionRequest = undefined
81
+ }
@@ -0,0 +1,12 @@
1
+ import type { ChainType } from '@lifi/types'
2
+ import { config } from '../config.js'
3
+
4
+ export const getProvider = <T>(type: ChainType): T => {
5
+ const provider = config
6
+ .get()
7
+ .providers?.find((provider) => provider.type === type) as T
8
+ if (!provider) {
9
+ throw new Error(`${type} provider not found.`)
10
+ }
11
+ return provider
12
+ }
@@ -0,0 +1,51 @@
1
+ import type { LiFiStep } from '@lifi/types'
2
+ import { LiFiErrorCode, TransactionError } from '../utils/errors.js'
3
+ import type { StatusManager } from './StatusManager.js'
4
+ import type { ExecutionOptions } from './types.js'
5
+ import { checkStepSlippageThreshold } from './utils.js'
6
+
7
+ /**
8
+ * This method checks whether the new and updated Step meets the required exchange rate conditions.
9
+ * If yes it returns the updated Step.
10
+ * If no and if user interaction is allowed it triggers the acceptExchangeRateUpdateHook. If no user interaction is allowed it aborts.
11
+ * @param statusManager
12
+ * @param oldStep
13
+ * @param newStep
14
+ * @param settings
15
+ * @param allowUserInteraction
16
+ * @param executionOptions
17
+ * @returns Return LiFiStep
18
+ */
19
+ export const stepComparison = async (
20
+ statusManager: StatusManager,
21
+ oldStep: LiFiStep,
22
+ newStep: LiFiStep,
23
+ allowUserInteraction: boolean,
24
+ executionOptions?: ExecutionOptions
25
+ ): Promise<LiFiStep> => {
26
+ // Check if changed exchange rate is in the range of slippage threshold
27
+ if (checkStepSlippageThreshold(oldStep, newStep)) {
28
+ return statusManager.updateStepInRoute(newStep)
29
+ }
30
+
31
+ let allowStepUpdate: boolean | undefined
32
+ if (allowUserInteraction) {
33
+ allowStepUpdate = await executionOptions?.acceptExchangeRateUpdateHook?.({
34
+ oldToAmount: oldStep.estimate.toAmount,
35
+ newToAmount: newStep.estimate.toAmount,
36
+ toToken: newStep.action.toToken,
37
+ })
38
+ }
39
+
40
+ if (!allowStepUpdate) {
41
+ // The user declined the new exchange rate, so we are not going to proceed
42
+ throw new TransactionError(
43
+ LiFiErrorCode.ExchangeRateUpdateCanceled,
44
+ 'Exchange rate has changed!',
45
+ `Transaction was not sent, your funds are still in your wallet.
46
+ The exchange rate has changed and the previous estimation can not be fulfilled due to value loss.`
47
+ )
48
+ }
49
+
50
+ return statusManager.updateStepInRoute(newStep)
51
+ }