@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
@@ -1,267 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.StepExecutionManager = void 0;
7
- const viem_1 = require("viem");
8
- const ApiService_1 = __importDefault(require("../services/ApiService"));
9
- const ChainsService_1 = __importDefault(require("../services/ChainsService"));
10
- const ConfigService_1 = __importDefault(require("../services/ConfigService"));
11
- const utils_1 = require("../utils");
12
- const errors_1 = require("../utils/errors");
13
- const parseError_1 = require("../utils/parseError");
14
- const utils_2 = require("../utils/utils");
15
- const checkAllowance_1 = require("./checkAllowance");
16
- const checkBalance_1 = require("./checkBalance");
17
- const multisig_1 = require("./multisig");
18
- const stepComparison_1 = require("./stepComparison");
19
- const switchChain_1 = require("./switchChain");
20
- const utils_3 = require("./utils");
21
- const waitForReceivingTransaction_1 = require("./waitForReceivingTransaction");
22
- class StepExecutionManager {
23
- constructor() {
24
- this.allowUserInteraction = true;
25
- this.allowInteraction = (value) => {
26
- this.allowUserInteraction = value;
27
- };
28
- this.execute = async ({ walletClient, step, statusManager, settings, }) => {
29
- const client = walletClient.extend(viem_1.publicActions);
30
- const config = ConfigService_1.default.getInstance().getConfig();
31
- const isMultisigWalletClient = !!config.multisig?.isMultisigWalletClient;
32
- const multisigBatchTransactions = [];
33
- const shouldBatchTransactions = config.multisig?.shouldBatchTransactions &&
34
- !!config.multisig.sendBatchTransaction;
35
- step.execution = statusManager.initExecutionObject(step);
36
- const chainsService = ChainsService_1.default.getInstance();
37
- const fromChain = await chainsService.getChainById(step.action.fromChainId);
38
- const toChain = await chainsService.getChainById(step.action.toChainId);
39
- const isBridgeExecution = fromChain.id !== toChain.id;
40
- const currentProcessType = isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP';
41
- // STEP 1: Check allowance
42
- const existingProcess = step.execution.process.find((p) => p.type === currentProcessType);
43
- // Check token approval only if fromToken is not the native token => no approval needed in that case
44
- const checkForAllowance = !existingProcess?.txHash &&
45
- !(0, utils_2.isZeroAddress)(step.action.fromToken.address) &&
46
- (shouldBatchTransactions || !isMultisigWalletClient);
47
- if (checkForAllowance) {
48
- const data = await (0, checkAllowance_1.checkAllowance)(client, step, statusManager, settings, fromChain, this.allowUserInteraction, shouldBatchTransactions);
49
- if (data) {
50
- // allowance doesn't need value
51
- const baseTransaction = {
52
- to: step.action.fromToken.address,
53
- data,
54
- };
55
- multisigBatchTransactions.push(baseTransaction);
56
- }
57
- }
58
- // STEP 2: Get transaction
59
- let process = statusManager.findOrCreateProcess(step, currentProcessType);
60
- if (process.status !== 'DONE') {
61
- const multisigProcess = step.execution.process.find((p) => !!p.multisigTxHash);
62
- try {
63
- if (isMultisigWalletClient && multisigProcess) {
64
- const multisigTxHash = multisigProcess.multisigTxHash;
65
- if (!multisigTxHash) {
66
- throw new errors_1.ValidationError('Multisig internal transaction hash is undefined.');
67
- }
68
- await (0, multisig_1.updateMultisigRouteProcess)(multisigTxHash, step, statusManager, process.type, fromChain);
69
- }
70
- let txHash;
71
- if (process.txHash) {
72
- // Make sure that the chain is still correct
73
- const updatedWalletClient = await (0, switchChain_1.switchChain)(walletClient, statusManager, step, settings.switchChainHook, this.allowUserInteraction);
74
- if (!updatedWalletClient) {
75
- // Chain switch was not successful, stop execution here
76
- return step.execution;
77
- }
78
- walletClient = updatedWalletClient;
79
- // Load exiting transaction
80
- txHash = process.txHash;
81
- }
82
- else {
83
- process = statusManager.updateProcess(step, process.type, 'STARTED');
84
- // Check balance
85
- await (0, checkBalance_1.checkBalance)(client.account.address, step);
86
- // Create new transaction
87
- if (!step.transactionRequest) {
88
- const updatedStep = await ApiService_1.default.getStepTransaction(step);
89
- const comparedStep = await (0, stepComparison_1.stepComparison)(statusManager, step, updatedStep, settings, this.allowUserInteraction);
90
- step = {
91
- ...comparedStep,
92
- execution: step.execution,
93
- };
94
- }
95
- let transactionRequest = {
96
- to: step.transactionRequest?.to,
97
- from: step.transactionRequest?.from,
98
- data: step.transactionRequest?.data,
99
- value: step.transactionRequest?.value
100
- ? BigInt(step.transactionRequest.value)
101
- : undefined,
102
- maxPriorityFeePerGas: walletClient.account?.type === 'local'
103
- ? await (0, utils_1.getMaxPriorityFeePerGas)(client)
104
- : undefined,
105
- // gas: step.transactionRequest?.gasLimit
106
- // ? BigInt(step.transactionRequest.gasLimit as string)
107
- // : undefined,
108
- // gasPrice: step.transactionRequest?.gasPrice
109
- // ? BigInt(step.transactionRequest.gasPrice as string)
110
- // : undefined,
111
- // maxFeePerGas: step.transactionRequest?.maxFeePerGas
112
- // ? BigInt(step.transactionRequest.maxFeePerGas as string)
113
- // : undefined,
114
- // maxPriorityFeePerGas: step.transactionRequest?.maxPriorityFeePerGas
115
- // ? BigInt(step.transactionRequest.maxPriorityFeePerGas as string)
116
- // : undefined,
117
- };
118
- if (!transactionRequest) {
119
- throw new errors_1.TransactionError(errors_1.LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
120
- }
121
- // STEP 3: Send the transaction
122
- // Make sure that the chain is still correct
123
- const updatedWalletClient = await (0, switchChain_1.switchChain)(walletClient, statusManager, step, settings.switchChainHook, this.allowUserInteraction);
124
- if (!updatedWalletClient) {
125
- // Chain switch was not successful, stop execution here
126
- return step.execution;
127
- }
128
- walletClient = updatedWalletClient;
129
- process = statusManager.updateProcess(step, process.type, 'ACTION_REQUIRED');
130
- if (!this.allowUserInteraction) {
131
- return step.execution;
132
- }
133
- if (settings.updateTransactionRequestHook) {
134
- const customizedTransactionRequest = await settings.updateTransactionRequestHook(transactionRequest);
135
- transactionRequest = {
136
- ...transactionRequest,
137
- ...customizedTransactionRequest,
138
- };
139
- }
140
- if (shouldBatchTransactions &&
141
- config.multisig?.sendBatchTransaction) {
142
- if (transactionRequest.to && transactionRequest.data) {
143
- const populatedTransaction = {
144
- value: transactionRequest.value,
145
- to: transactionRequest.to,
146
- data: transactionRequest.data,
147
- };
148
- multisigBatchTransactions.push(populatedTransaction);
149
- txHash = await config.multisig?.sendBatchTransaction(multisigBatchTransactions);
150
- }
151
- else {
152
- throw new errors_1.TransactionError(errors_1.LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
153
- }
154
- }
155
- else {
156
- txHash = await walletClient.sendTransaction({
157
- to: transactionRequest.to,
158
- account: walletClient.account,
159
- data: transactionRequest.data,
160
- maxPriorityFeePerGas: transactionRequest.maxPriorityFeePerGas,
161
- chain: null,
162
- });
163
- }
164
- // STEP 4: Wait for the transaction
165
- if (isMultisigWalletClient) {
166
- process = statusManager.updateProcess(step, process.type, 'ACTION_REQUIRED', {
167
- multisigTxHash: txHash,
168
- });
169
- }
170
- else {
171
- process = statusManager.updateProcess(step, process.type, 'PENDING', {
172
- txHash: txHash,
173
- txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${txHash}`,
174
- });
175
- }
176
- }
177
- let replacementReason;
178
- const transactionReceipt = await client.waitForTransactionReceipt({
179
- hash: txHash,
180
- onReplaced(response) {
181
- replacementReason = response.reason;
182
- statusManager.updateProcess(step, process.type, 'PENDING', {
183
- txHash: response.transaction.hash,
184
- txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${response.transaction.hash}`,
185
- });
186
- },
187
- });
188
- if (replacementReason === 'cancelled') {
189
- throw new errors_1.TransactionError(errors_1.LiFiErrorCode.TransactionCanceled, 'User canceled transaction.');
190
- }
191
- // if it's multisig wallet client and the process is in ACTION_REQUIRED
192
- // then signatures are still needed
193
- if (isMultisigWalletClient && process.status === 'ACTION_REQUIRED') {
194
- await (0, multisig_1.updateMultisigRouteProcess)(transactionReceipt.transactionHash, step, statusManager, process.type, fromChain);
195
- }
196
- if (!isMultisigWalletClient) {
197
- process = statusManager.updateProcess(step, process.type, 'PENDING', {
198
- txHash: transactionReceipt.transactionHash,
199
- txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${transactionReceipt.transactionHash}`,
200
- });
201
- }
202
- if (isBridgeExecution) {
203
- process = statusManager.updateProcess(step, process.type, 'DONE');
204
- }
205
- }
206
- catch (e) {
207
- const error = await (0, parseError_1.parseError)(e, step, process);
208
- process = statusManager.updateProcess(step, process.type, 'FAILED', {
209
- error: {
210
- message: error.message,
211
- htmlMessage: error.htmlMessage,
212
- code: error.code,
213
- },
214
- });
215
- statusManager.updateExecution(step, 'FAILED');
216
- throw error;
217
- }
218
- }
219
- // STEP 5: Wait for the receiving chain
220
- const processTxHash = process.txHash;
221
- if (isBridgeExecution) {
222
- process = statusManager.findOrCreateProcess(step, 'RECEIVING_CHAIN', 'PENDING');
223
- }
224
- let statusResponse;
225
- try {
226
- if (!processTxHash) {
227
- throw new Error('Transaction hash is undefined.');
228
- }
229
- statusResponse = (await (0, waitForReceivingTransaction_1.waitForReceivingTransaction)(processTxHash, statusManager, process.type, step));
230
- const statusReceiving = statusResponse.receiving;
231
- process = statusManager.updateProcess(step, process.type, 'DONE', {
232
- substatus: statusResponse.substatus,
233
- substatusMessage: statusResponse.substatusMessage ||
234
- (0, utils_3.getSubstatusMessage)(statusResponse.status, statusResponse.substatus),
235
- txHash: statusReceiving?.txHash,
236
- txLink: `${toChain.metamask.blockExplorerUrls[0]}tx/${statusReceiving?.txHash}`,
237
- });
238
- statusManager.updateExecution(step, 'DONE', {
239
- fromAmount: statusResponse.sending.amount,
240
- toAmount: statusReceiving?.amount,
241
- toToken: statusReceiving?.token,
242
- gasAmount: statusResponse.sending.gasAmount,
243
- gasAmountUSD: statusResponse.sending.gasAmountUSD,
244
- gasPrice: statusResponse.sending.gasPrice,
245
- gasToken: statusResponse.sending.gasToken,
246
- gasUsed: statusResponse.sending.gasUsed,
247
- });
248
- }
249
- catch (e) {
250
- const htmlMessage = await (0, parseError_1.getTransactionFailedMessage)(step, process.txLink);
251
- process = statusManager.updateProcess(step, process.type, 'FAILED', {
252
- error: {
253
- code: errors_1.LiFiErrorCode.TransactionFailed,
254
- message: 'Failed while waiting for receiving chain.',
255
- htmlMessage,
256
- },
257
- });
258
- statusManager.updateExecution(step, 'FAILED');
259
- console.warn(e);
260
- throw e;
261
- }
262
- // DONE
263
- return step.execution;
264
- };
265
- }
266
- }
267
- exports.StepExecutionManager = StepExecutionManager;
@@ -1,15 +0,0 @@
1
- import type { WalletClient } from 'viem';
2
- import type { InteractionSettings, InternalExecutionSettings, LifiStep } from '../types';
3
- import type { StatusManager } from './StatusManager';
4
- import { StepExecutionManager } from './StepExecutionManager';
5
- export declare class StepExecutor {
6
- stepExecutionManager: StepExecutionManager;
7
- statusManager: StatusManager;
8
- settings: InternalExecutionSettings;
9
- allowUserInteraction: boolean;
10
- executionStopped: boolean;
11
- constructor(statusManager: StatusManager, settings: InternalExecutionSettings);
12
- setInteraction: (settings?: InteractionSettings) => void;
13
- checkChain: () => never;
14
- executeStep: (walletClient: WalletClient, step: LifiStep) => Promise<LifiStep>;
15
- }
@@ -1,62 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StepExecutor = void 0;
4
- const StepExecutionManager_1 = require("./StepExecutionManager");
5
- const switchChain_1 = require("./switchChain");
6
- // Please be careful when changing the defaults as it may break the behavior (e.g., background execution)
7
- const defaultInteractionSettings = {
8
- allowInteraction: true,
9
- allowUpdates: true,
10
- stopExecution: false,
11
- };
12
- class StepExecutor {
13
- constructor(statusManager, settings) {
14
- this.allowUserInteraction = true;
15
- this.executionStopped = false;
16
- this.setInteraction = (settings) => {
17
- const interactionSettings = {
18
- ...defaultInteractionSettings,
19
- ...settings,
20
- };
21
- this.allowUserInteraction = interactionSettings.allowInteraction;
22
- this.stepExecutionManager.allowInteraction(interactionSettings.allowInteraction);
23
- this.statusManager.allowUpdates(interactionSettings.allowUpdates);
24
- this.executionStopped = interactionSettings.stopExecution;
25
- };
26
- // TODO: add checkChain method and update wallet client inside executors
27
- // This can come in handy when we execute multiple routes simultaneously and
28
- // should be sure that we are on the right chain when waiting for transactions.
29
- this.checkChain = () => {
30
- throw new Error('checkChain is not implemented.');
31
- };
32
- this.executeStep = async (walletClient, step) => {
33
- // Make sure that the chain is still correct
34
- // Find if it's bridging and the step is waiting for a transaction on the receiving chain
35
- const recievingChainProcess = step.execution?.process.find((process) => process.type === 'RECEIVING_CHAIN');
36
- // If the step is waiting for a transaction on the receiving chain, we do not switch the chain
37
- // All changes are already done from the source chain
38
- // Return the step
39
- if (recievingChainProcess?.substatus !== 'WAIT_DESTINATION_TRANSACTION' ||
40
- !recievingChainProcess) {
41
- const updatedWalletClient = await (0, switchChain_1.switchChain)(walletClient, this.statusManager, step, this.settings.switchChainHook, this.allowUserInteraction);
42
- if (!updatedWalletClient) {
43
- // Chain switch was not successful, stop execution here
44
- return step;
45
- }
46
- walletClient = updatedWalletClient;
47
- }
48
- const parameters = {
49
- walletClient,
50
- step,
51
- settings: this.settings,
52
- statusManager: this.statusManager,
53
- };
54
- await this.stepExecutionManager.execute(parameters);
55
- return step;
56
- };
57
- this.stepExecutionManager = new StepExecutionManager_1.StepExecutionManager();
58
- this.statusManager = statusManager;
59
- this.settings = settings;
60
- }
61
- }
62
- exports.StepExecutor = StepExecutor;
@@ -1,4 +0,0 @@
1
- import type { Hash, WalletClient } from 'viem';
2
- import type { StatusManager } from '../execution/StatusManager';
3
- import type { Chain, InternalExecutionSettings, LifiStep } from '../types';
4
- export declare const checkAllowance: (walletClient: WalletClient, step: LifiStep, statusManager: StatusManager, settings: InternalExecutionSettings, chain: Chain, allowUserInteraction?: boolean, shouldBatchTransactions?: boolean) => Promise<Hash | void>;
@@ -1,2 +0,0 @@
1
- import type { LifiStep } from '..';
2
- export declare const checkBalance: (walletAddress: string, step: LifiStep, depth?: number) => Promise<void>;
@@ -1 +0,0 @@
1
- export * from './StatusManager';
@@ -1,17 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./StatusManager"), exports);
@@ -1,4 +0,0 @@
1
- import type { ExtendedChain, LifiStep, ProcessType } from '@lifi/types';
2
- import type { Hash } from 'viem';
3
- import type { StatusManager } from './StatusManager';
4
- export declare const updateMultisigRouteProcess: (internalTxHash: Hash, step: LifiStep, statusManager: StatusManager, processType: ProcessType, fromChain: ExtendedChain) => Promise<void>;
@@ -1,3 +0,0 @@
1
- import { type WalletClient } from 'viem';
2
- import type { Route } from '../types';
3
- export declare const prepareRestart: (route: Route, walletClient: WalletClient) => Promise<void>;
@@ -1,65 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.prepareRestart = void 0;
4
- const viem_1 = require("viem");
5
- const errors_1 = require("../utils/errors");
6
- const prepareRestart = async (route, walletClient) => {
7
- for (let index = 0; index < route.steps.length; index++) {
8
- const step = route.steps[index];
9
- const stepHasFailed = step.execution?.status === 'FAILED';
10
- if (stepHasFailed) {
11
- await handleErrorType(walletClient, step);
12
- deleteFailedProcesses(step);
13
- deleteTransactionData(step);
14
- }
15
- }
16
- };
17
- exports.prepareRestart = prepareRestart;
18
- const handleErrorType = async (walletClient, step) => {
19
- const client = walletClient.extend(viem_1.publicActions);
20
- const isGasLimitError = step.execution?.process.some((p) => p.error?.code === errors_1.LiFiErrorCode.GasLimitError);
21
- const isGasPriceError = step.execution?.process.some((p) => p.error?.code === errors_1.LiFiErrorCode.TransactionUnderpriced);
22
- const { transactionRequest } = step;
23
- // if (isGasLimitError) {
24
- // if (transactionRequest) {
25
- // let gasLimit = transactionRequest.gasLimit
26
- // try {
27
- // gasLimit = await client.estimateGas(transactionRequest)
28
- // } catch (error) {}
29
- // if (gasLimit) {
30
- // transactionRequest.gasLimit = BigNumber.from(
31
- // `${(BigInt(gasLimit.toString()) * 125n) / 100n}`
32
- // )
33
- // }
34
- // }
35
- // step.estimate.gasCosts?.forEach(
36
- // (gasCost) =>
37
- // (gasCost.limit = `${Math.round(Number(gasCost.limit) * 1.25)}`)
38
- // )
39
- // }
40
- // if (isGasPriceError) {
41
- // if (transactionRequest) {
42
- // let gasPrice = transactionRequest.gasPrice
43
- // try {
44
- // gasPrice = await client.getGasPrice()
45
- // } catch (error) {}
46
- // if (gasPrice) {
47
- // transactionRequest.gasPrice = BigNumber.from(
48
- // `${(BigInt(gasPrice.toString()) * 125n) / 100n}`
49
- // )
50
- // }
51
- // }
52
- // step.estimate.gasCosts?.forEach(
53
- // (gasCost) =>
54
- // (gasCost.price = `${Math.round(Number(gasCost.price) * 1.25)}`)
55
- // )
56
- // }
57
- };
58
- const deleteFailedProcesses = (step) => {
59
- if (step.execution) {
60
- step.execution.process = step.execution.process.filter((process) => process.status === 'DONE');
61
- }
62
- };
63
- const deleteTransactionData = (step) => {
64
- step.transactionRequest = undefined;
65
- };
@@ -1,14 +0,0 @@
1
- import type { InternalExecutionSettings, LifiStep } from '../types';
2
- import type { StatusManager } from './StatusManager';
3
- /**
4
- * This method checks whether the new and updated Step meets the required exchange rate conditions.
5
- * If yes it returns the updated Step.
6
- * If no and if user interaction is allowed it triggers the acceptExchangeRateUpdateHook. If no user interaction is allowed it aborts.
7
- * @param statusManager
8
- * @param oldStep
9
- * @param newStep
10
- * @param settings
11
- * @param allowUserInteraction
12
- * @returns Return LifiStep
13
- */
14
- export declare const stepComparison: (statusManager: StatusManager, oldStep: LifiStep, newStep: LifiStep, settings: InternalExecutionSettings, allowUserInteraction: boolean) => Promise<LifiStep>;
@@ -1,37 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.stepComparison = void 0;
4
- const errors_1 = require("../utils/errors");
5
- const utils_1 = require("./utils");
6
- /**
7
- * This method checks whether the new and updated Step meets the required exchange rate conditions.
8
- * If yes it returns the updated Step.
9
- * If no and if user interaction is allowed it triggers the acceptExchangeRateUpdateHook. If no user interaction is allowed it aborts.
10
- * @param statusManager
11
- * @param oldStep
12
- * @param newStep
13
- * @param settings
14
- * @param allowUserInteraction
15
- * @returns Return LifiStep
16
- */
17
- const stepComparison = async (statusManager, oldStep, newStep, settings, allowUserInteraction) => {
18
- // Check if changed exchange rate is in the range of slippage threshold
19
- if ((0, utils_1.checkStepSlippageThreshold)(oldStep, newStep)) {
20
- return statusManager.updateStepInRoute(newStep);
21
- }
22
- let allowStepUpdate;
23
- if (allowUserInteraction) {
24
- allowStepUpdate = await settings.acceptExchangeRateUpdateHook({
25
- oldToAmount: oldStep.estimate.toAmount,
26
- newToAmount: newStep.estimate.toAmount,
27
- toToken: newStep.action.toToken,
28
- });
29
- }
30
- if (!allowStepUpdate) {
31
- // The user declined the new exchange rate, so we are not going to proceed
32
- throw new errors_1.TransactionError(errors_1.LiFiErrorCode.ExchangeRateUpdateCanceled, 'Exchange rate has changed!', `Transaction was not sent, your funds are still in your wallet.
33
- The exchange rate has changed and the previous estimation can not be fulfilled due to value loss.`);
34
- }
35
- return statusManager.updateStepInRoute(newStep);
36
- };
37
- exports.stepComparison = stepComparison;
@@ -1,21 +0,0 @@
1
- import type { LifiStep } from '@lifi/types';
2
- import type { WalletClient } from 'viem';
3
- import type { SwitchChainHook } from '../types';
4
- import type { StatusManager } from './StatusManager';
5
- /**
6
- * This method checks whether the wallet client is configured for the correct chain.
7
- * If yes it returns the wallet clien.
8
- * If no and if user interaction is allowed it triggers the switchChainHook. If no user interaction is allowed it aborts.
9
- *
10
- * Account Type: local -
11
- * We need to create and return a new WalletClient from the switchChainHook in order to continue execution on a new chain.
12
- *
13
- * Account Type: json-rpc -
14
- * We can switch chain and return existing WalletClient from the switchChainHook in order to continue execution on a new chain.
15
- * @param walletClient
16
- * @param statusManager
17
- * @param step
18
- * @param switchChainHook
19
- * @param allowUserInteraction
20
- */
21
- export declare const switchChain: (walletClient: WalletClient, statusManager: StatusManager, step: LifiStep, switchChainHook: SwitchChainHook, allowUserInteraction: boolean) => Promise<WalletClient | undefined>;
@@ -1,54 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.switchChain = void 0;
4
- const errors_1 = require("../utils/errors");
5
- /**
6
- * This method checks whether the wallet client is configured for the correct chain.
7
- * If yes it returns the wallet clien.
8
- * If no and if user interaction is allowed it triggers the switchChainHook. If no user interaction is allowed it aborts.
9
- *
10
- * Account Type: local -
11
- * We need to create and return a new WalletClient from the switchChainHook in order to continue execution on a new chain.
12
- *
13
- * Account Type: json-rpc -
14
- * We can switch chain and return existing WalletClient from the switchChainHook in order to continue execution on a new chain.
15
- * @param walletClient
16
- * @param statusManager
17
- * @param step
18
- * @param switchChainHook
19
- * @param allowUserInteraction
20
- */
21
- const switchChain = async (walletClient, statusManager, step, switchChainHook, allowUserInteraction) => {
22
- // if we are already on the correct chain we can proceed directly
23
- if ((await walletClient.getChainId()) === step.action.fromChainId) {
24
- return walletClient;
25
- }
26
- // -> set status message
27
- step.execution = statusManager.initExecutionObject(step);
28
- statusManager.updateExecution(step, 'ACTION_REQUIRED');
29
- let switchProcess = statusManager.findOrCreateProcess(step, 'SWITCH_CHAIN', 'ACTION_REQUIRED');
30
- if (!allowUserInteraction) {
31
- return;
32
- }
33
- try {
34
- const updatedWalletClient = await switchChainHook(step.action.fromChainId);
35
- const updatedChainId = await updatedWalletClient?.getChainId();
36
- if (updatedChainId !== step.action.fromChainId) {
37
- throw new errors_1.ProviderError(errors_1.LiFiErrorCode.ChainSwitchError, 'Chain switch required.');
38
- }
39
- switchProcess = statusManager.updateProcess(step, switchProcess.type, 'DONE');
40
- statusManager.updateExecution(step, 'PENDING');
41
- return updatedWalletClient;
42
- }
43
- catch (error) {
44
- statusManager.updateProcess(step, switchProcess.type, 'FAILED', {
45
- error: {
46
- message: error.message,
47
- code: errors_1.LiFiErrorCode.ChainSwitchError,
48
- },
49
- });
50
- statusManager.updateExecution(step, 'FAILED');
51
- throw error;
52
- }
53
- };
54
- exports.switchChain = switchChain;
@@ -1,12 +0,0 @@
1
- import type { LifiStep, ProcessType, Status, StatusMessage, Substatus } from '@lifi/types';
2
- export declare function getProcessMessage(type: ProcessType, status: Status): string | undefined;
3
- export declare function getSubstatusMessage(status: StatusMessage, substatus?: Substatus): string | undefined;
4
- /**
5
- * Used to check if changed exchange rate is in the range of slippage threshold.
6
- * We use a slippage value as a threshold to trigger the rate change hook.
7
- * This can result in almost doubled slippage for the user and need to be revisited.
8
- * @param oldStep
9
- * @param newStep
10
- * @returns Boolean
11
- */
12
- export declare function checkStepSlippageThreshold(oldStep: LifiStep, newStep: LifiStep): boolean;
@@ -1,3 +0,0 @@
1
- import type { LifiStep, ProcessType, StatusResponse } from '@lifi/types';
2
- import type { StatusManager } from '..';
3
- export declare function waitForReceivingTransaction(txHash: string, statusManager: StatusManager, processType: ProcessType, step: LifiStep): Promise<StatusResponse>;
@@ -1,18 +0,0 @@
1
- import type { LifiStep, Route } from '@lifi/types';
2
- import type { TenderlyResponse } from './types';
3
- /**
4
- * Returns a random number between min (inclusive) and max (inclusive)
5
- * @param min - minimum number.
6
- * @param max - maximum number.
7
- * @returns - random number.
8
- */
9
- export declare const getRandomNumber: (min: number, max: number) => number;
10
- export declare const checkPackageUpdates: (packageName?: string, packageVersion?: string, disableCheck?: boolean) => Promise<void>;
11
- /**
12
- * Converts a quote to Route
13
- * @param step - Step returned from the quote endpoint.
14
- * @returns - The route to be executed.
15
- * @throws {ValidationError} Throws a ValidationError if the step has missing values.
16
- */
17
- export declare const convertQuoteToRoute: (step: LifiStep) => Route;
18
- export declare const fetchTxErrorDetails: (txHash: string, chainId: number) => Promise<TenderlyResponse>;
@@ -1,5 +0,0 @@
1
- export * from './execution';
2
- export * from './helpers';
3
- export { LiFi } from './LiFi';
4
- export * from './types';
5
- export * from './utils/errors';