@lifi/sdk 3.0.0-alpha.4 → 3.0.0-alpha.41
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.
- package/package.json +31 -86
- package/src/_cjs/config.js +71 -0
- package/src/_cjs/config.js.map +1 -0
- package/{dist/cjs → src/_cjs}/constants.js +3 -5
- package/src/_cjs/constants.js.map +1 -0
- package/src/_cjs/core/BaseStepExecutor.js +55 -0
- package/src/_cjs/core/BaseStepExecutor.js.map +1 -0
- package/src/_cjs/core/EVM/EVM.js +43 -0
- package/src/_cjs/core/EVM/EVM.js.map +1 -0
- package/src/_cjs/core/EVM/EVMStepExecutor.js +284 -0
- package/src/_cjs/core/EVM/EVMStepExecutor.js.map +1 -0
- package/{dist/cjs/types → src/_cjs/core/EVM}/abi.js +1 -0
- package/src/_cjs/core/EVM/abi.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core/EVM}/checkAllowance.js +12 -12
- package/src/_cjs/core/EVM/checkAllowance.js.map +1 -0
- package/{dist/cjs/allowance → src/_cjs/core/EVM}/getAllowance.js +13 -17
- package/src/_cjs/core/EVM/getAllowance.js.map +1 -0
- package/{dist/cjs/balance/getBalance.js → src/_cjs/core/EVM/getEVMBalance.js} +20 -22
- package/src/_cjs/core/EVM/getEVMBalance.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core/EVM}/multisig.js +7 -11
- package/src/_cjs/core/EVM/multisig.js.map +1 -0
- package/src/_cjs/core/EVM/publicClient.js +35 -0
- package/src/_cjs/core/EVM/publicClient.js.map +1 -0
- package/src/_cjs/core/EVM/setAllowance.js +71 -0
- package/src/_cjs/core/EVM/setAllowance.js.map +1 -0
- package/src/_cjs/core/EVM/switchChain.js +38 -0
- package/src/_cjs/core/EVM/switchChain.js.map +1 -0
- package/src/_cjs/core/EVM/types.js +9 -0
- package/src/_cjs/core/EVM/types.js.map +1 -0
- package/{dist/cjs/utils/getMaxPriorityFeePerGas.js → src/_cjs/core/EVM/utils.js} +10 -3
- package/src/_cjs/core/EVM/utils.js.map +1 -0
- package/src/_cjs/core/Solana/Solana.js +44 -0
- package/src/_cjs/core/Solana/Solana.js.map +1 -0
- package/src/_cjs/core/Solana/SolanaStepExecutor.js +163 -0
- package/src/_cjs/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/src/_cjs/core/Solana/connection.js +18 -0
- package/src/_cjs/core/Solana/connection.js.map +1 -0
- package/src/_cjs/core/Solana/getSolanaBalance.js +60 -0
- package/src/_cjs/core/Solana/getSolanaBalance.js.map +1 -0
- package/src/_cjs/core/Solana/types.js +10 -0
- package/src/_cjs/core/Solana/types.js.map +1 -0
- package/src/_cjs/core/StatusManager.js +167 -0
- package/src/_cjs/core/StatusManager.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core}/checkBalance.js +5 -5
- package/src/_cjs/core/checkBalance.js.map +1 -0
- package/src/_cjs/core/execution.js +134 -0
- package/src/_cjs/core/execution.js.map +1 -0
- package/src/_cjs/core/executionState.js +23 -0
- package/src/_cjs/core/executionState.js.map +1 -0
- package/src/_cjs/core/index.js +7 -0
- package/src/_cjs/core/index.js.map +1 -0
- package/src/_cjs/core/prepareRestart.js +23 -0
- package/src/_cjs/core/prepareRestart.js.map +1 -0
- package/src/_cjs/core/provider.js +15 -0
- package/src/_cjs/core/provider.js.map +1 -0
- package/src/_cjs/core/stepComparison.js +25 -0
- package/src/_cjs/core/stepComparison.js.map +1 -0
- package/{dist/cjs/allowance → src/_cjs/core}/types.js +1 -0
- package/src/_cjs/core/types.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core}/utils.js +16 -10
- package/src/_cjs/core/utils.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core}/waitForReceivingTransaction.js +11 -12
- package/src/_cjs/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_cjs/createConfig.js +32 -0
- package/src/_cjs/createConfig.js.map +1 -0
- package/src/_cjs/helpers.js +57 -0
- package/src/_cjs/helpers.js.map +1 -0
- package/src/_cjs/index.js +22 -0
- package/src/_cjs/index.js.map +1 -0
- package/src/_cjs/package.json +1 -0
- package/src/_cjs/request.js +66 -0
- package/src/_cjs/request.js.map +1 -0
- package/src/_cjs/services/api.js +311 -0
- package/src/_cjs/services/api.js.map +1 -0
- package/src/_cjs/services/balance.js +49 -0
- package/src/_cjs/services/balance.js.map +1 -0
- package/{dist/cjs → src/_cjs}/typeguards.js +1 -0
- package/src/_cjs/typeguards.js.map +1 -0
- package/src/_cjs/types/index.js +5 -0
- package/src/_cjs/types/index.js.map +1 -0
- package/{dist/cjs/types/internal.types.js → src/_cjs/types/internal.js} +1 -0
- package/src/_cjs/types/internal.js.map +1 -0
- package/{dist/cjs → src/_cjs}/utils/errors.js +25 -3
- package/src/_cjs/utils/errors.js.map +1 -0
- package/src/_cjs/utils/getTransactionMessage.js +31 -0
- package/src/_cjs/utils/getTransactionMessage.js.map +1 -0
- package/src/_cjs/utils/index.js +9 -0
- package/src/_cjs/utils/index.js.map +1 -0
- package/{dist/cjs → src/_cjs}/utils/median.js +1 -0
- package/src/_cjs/utils/median.js.map +1 -0
- package/src/_cjs/utils/parseBackendError.js +27 -0
- package/src/_cjs/utils/parseBackendError.js.map +1 -0
- package/src/_cjs/utils/parseError.js +67 -0
- package/src/_cjs/utils/parseError.js.map +1 -0
- package/{dist/cjs → src/_cjs}/utils/utils.js +5 -11
- package/src/_cjs/utils/utils.js.map +1 -0
- package/{dist/cjs → src/_cjs}/version.js +2 -1
- package/src/_cjs/version.js.map +1 -0
- package/src/_esm/config.js +68 -0
- package/src/_esm/config.js.map +1 -0
- package/{dist → src/_esm}/constants.js +2 -4
- package/src/_esm/constants.js.map +1 -0
- package/src/_esm/core/BaseStepExecutor.js +52 -0
- package/src/_esm/core/BaseStepExecutor.js.map +1 -0
- package/src/_esm/core/EVM/EVM.js +39 -0
- package/src/_esm/core/EVM/EVM.js.map +1 -0
- package/src/_esm/core/EVM/EVMStepExecutor.js +309 -0
- package/src/_esm/core/EVM/EVMStepExecutor.js.map +1 -0
- package/{dist/types → src/_esm/core/EVM}/abi.js +1 -0
- package/src/_esm/core/EVM/abi.js.map +1 -0
- package/{dist/execution → src/_esm/core/EVM}/checkAllowance.js +8 -6
- package/src/_esm/core/EVM/checkAllowance.js.map +1 -0
- package/{dist/allowance → src/_esm/core/EVM}/getAllowance.js +19 -6
- package/src/_esm/core/EVM/getAllowance.js.map +1 -0
- package/{dist/balance/getBalance.js → src/_esm/core/EVM/getEVMBalance.js} +10 -12
- package/src/_esm/core/EVM/getEVMBalance.js.map +1 -0
- package/{dist/execution → src/_esm/core/EVM}/multisig.js +5 -6
- package/src/_esm/core/EVM/multisig.js.map +1 -0
- package/src/_esm/core/EVM/publicClient.js +37 -0
- package/src/_esm/core/EVM/publicClient.js.map +1 -0
- package/{dist/allowance → src/_esm/core/EVM}/setAllowance.js +46 -11
- package/src/_esm/core/EVM/setAllowance.js.map +1 -0
- package/{dist/execution → src/_esm/core/EVM}/switchChain.js +7 -4
- package/src/_esm/core/EVM/switchChain.js.map +1 -0
- package/src/_esm/core/EVM/types.js +6 -0
- package/src/_esm/core/EVM/types.js.map +1 -0
- package/{dist/utils/getMaxPriorityFeePerGas.js → src/_esm/core/EVM/utils.js} +9 -1
- package/src/_esm/core/EVM/utils.js.map +1 -0
- package/src/_esm/core/Solana/Solana.js +40 -0
- package/src/_esm/core/Solana/Solana.js.map +1 -0
- package/src/_esm/core/Solana/SolanaStepExecutor.js +164 -0
- package/src/_esm/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/src/_esm/core/Solana/connection.js +19 -0
- package/src/_esm/core/Solana/connection.js.map +1 -0
- package/src/_esm/core/Solana/getSolanaBalance.js +56 -0
- package/src/_esm/core/Solana/getSolanaBalance.js.map +1 -0
- package/src/_esm/core/Solana/types.js +7 -0
- package/src/_esm/core/Solana/types.js.map +1 -0
- package/src/_esm/core/StatusManager.js +203 -0
- package/src/_esm/core/StatusManager.js.map +1 -0
- package/{dist/execution → src/_esm/core}/checkBalance.js +3 -2
- package/src/_esm/core/checkBalance.js.map +1 -0
- package/src/_esm/core/execution.js +173 -0
- package/src/_esm/core/execution.js.map +1 -0
- package/src/_esm/core/executionState.js +20 -0
- package/src/_esm/core/executionState.js.map +1 -0
- package/src/_esm/core/index.js +4 -0
- package/src/_esm/core/index.js.map +1 -0
- package/src/_esm/core/prepareRestart.js +64 -0
- package/src/_esm/core/prepareRestart.js.map +1 -0
- package/src/_esm/core/provider.js +11 -0
- package/src/_esm/core/provider.js.map +1 -0
- package/{dist/execution → src/_esm/core}/stepComparison.js +7 -5
- package/src/_esm/core/stepComparison.js.map +1 -0
- package/src/_esm/core/types.js +2 -0
- package/src/_esm/core/types.js.map +1 -0
- package/{dist/execution → src/_esm/core}/utils.js +14 -0
- package/src/_esm/core/utils.js.map +1 -0
- package/{dist/execution → src/_esm/core}/waitForReceivingTransaction.js +9 -7
- package/src/_esm/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_esm/createConfig.js +28 -0
- package/src/_esm/createConfig.js.map +1 -0
- package/{dist → src/_esm}/helpers.js +5 -17
- package/src/_esm/helpers.js.map +1 -0
- package/src/_esm/index.js +13 -0
- package/src/_esm/index.js.map +1 -0
- package/src/_esm/package.json +1 -0
- package/{dist → src/_esm}/request.js +23 -13
- package/src/_esm/request.js.map +1 -0
- package/src/_esm/services/api.js +380 -0
- package/src/_esm/services/api.js.map +1 -0
- package/src/_esm/services/balance.js +65 -0
- package/src/_esm/services/balance.js.map +1 -0
- package/{dist → src/_esm}/typeguards.js +1 -0
- package/src/_esm/typeguards.js.map +1 -0
- package/src/_esm/types/index.js +2 -0
- package/src/_esm/types/index.js.map +1 -0
- package/src/_esm/types/internal.js +2 -0
- package/src/_esm/types/internal.js.map +1 -0
- package/{dist → src/_esm}/utils/errors.js +25 -0
- package/src/_esm/utils/errors.js.map +1 -0
- package/src/_esm/utils/getTransactionMessage.js +28 -0
- package/src/_esm/utils/getTransactionMessage.js.map +1 -0
- package/src/_esm/utils/index.js +6 -0
- package/src/_esm/utils/index.js.map +1 -0
- package/{dist → src/_esm}/utils/median.js +1 -0
- package/src/_esm/utils/median.js.map +1 -0
- package/src/_esm/utils/parseBackendError.js +24 -0
- package/src/_esm/utils/parseBackendError.js.map +1 -0
- package/{dist → src/_esm}/utils/parseError.js +4 -53
- package/src/_esm/utils/parseError.js.map +1 -0
- package/{dist → src/_esm}/utils/utils.js +2 -1
- package/src/_esm/utils/utils.js.map +1 -0
- package/src/_esm/version.js +3 -0
- package/src/_esm/version.js.map +1 -0
- package/src/_types/config.d.ts +15 -0
- package/src/_types/config.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/constants.d.ts +2 -4
- package/src/_types/constants.d.ts.map +1 -0
- package/src/_types/core/BaseStepExecutor.d.ts +13 -0
- package/src/_types/core/BaseStepExecutor.d.ts.map +1 -0
- package/src/_types/core/EVM/EVM.d.ts +3 -0
- package/src/_types/core/EVM/EVM.d.ts.map +1 -0
- package/src/_types/core/EVM/EVMStepExecutor.d.ts +16 -0
- package/src/_types/core/EVM/EVMStepExecutor.d.ts.map +1 -0
- package/{dist/cjs/types → src/_types/core/EVM}/abi.d.ts +1 -0
- package/src/_types/core/EVM/abi.d.ts.map +1 -0
- package/src/_types/core/EVM/checkAllowance.d.ts +6 -0
- package/src/_types/core/EVM/checkAllowance.d.ts.map +1 -0
- package/{dist/cjs/allowance → src/_types/core/EVM}/getAllowance.d.ts +15 -1
- package/src/_types/core/EVM/getAllowance.d.ts.map +1 -0
- package/src/_types/core/EVM/getEVMBalance.d.ts +3 -0
- package/src/_types/core/EVM/getEVMBalance.d.ts.map +1 -0
- package/src/_types/core/EVM/multisig.d.ts +6 -0
- package/src/_types/core/EVM/multisig.d.ts.map +1 -0
- package/src/_types/core/EVM/publicClient.d.ts +8 -0
- package/src/_types/core/EVM/publicClient.d.ts.map +1 -0
- package/src/_types/core/EVM/setAllowance.d.ts +25 -0
- package/src/_types/core/EVM/setAllowance.d.ts.map +1 -0
- package/{dist/cjs/execution → src/_types/core/EVM}/switchChain.d.ts +5 -4
- package/src/_types/core/EVM/switchChain.d.ts.map +1 -0
- package/src/_types/core/EVM/types.d.ts +55 -0
- package/src/_types/core/EVM/types.d.ts.map +1 -0
- package/src/_types/core/EVM/utils.d.ts +5 -0
- package/src/_types/core/EVM/utils.d.ts.map +1 -0
- package/src/_types/core/Solana/Solana.d.ts +3 -0
- package/src/_types/core/Solana/Solana.d.ts.map +1 -0
- package/src/_types/core/Solana/SolanaStepExecutor.d.ts +12 -0
- package/src/_types/core/Solana/SolanaStepExecutor.d.ts.map +1 -0
- package/src/_types/core/Solana/connection.d.ts +8 -0
- package/src/_types/core/Solana/connection.d.ts.map +1 -0
- package/src/_types/core/Solana/getSolanaBalance.d.ts +3 -0
- package/src/_types/core/Solana/getSolanaBalance.d.ts.map +1 -0
- package/src/_types/core/Solana/types.d.ts +13 -0
- package/src/_types/core/Solana/types.d.ts.map +1 -0
- package/{dist/cjs/execution → src/_types/core}/StatusManager.d.ts +15 -28
- package/src/_types/core/StatusManager.d.ts.map +1 -0
- package/src/_types/core/checkBalance.d.ts +3 -0
- package/src/_types/core/checkBalance.d.ts.map +1 -0
- package/src/_types/core/execution.d.ts +42 -0
- package/src/_types/core/execution.d.ts.map +1 -0
- package/src/_types/core/executionState.d.ts +15 -0
- package/src/_types/core/executionState.d.ts.map +1 -0
- package/src/_types/core/index.d.ts +4 -0
- package/src/_types/core/index.d.ts.map +1 -0
- package/src/_types/core/prepareRestart.d.ts +3 -0
- package/src/_types/core/prepareRestart.d.ts.map +1 -0
- package/src/_types/core/provider.d.ts +3 -0
- package/src/_types/core/provider.d.ts.map +1 -0
- package/{dist/execution → src/_types/core}/stepComparison.d.ts +7 -4
- package/src/_types/core/stepComparison.d.ts.map +1 -0
- package/src/_types/core/types.d.ts +80 -0
- package/src/_types/core/types.d.ts.map +1 -0
- package/{dist/execution → src/_types/core}/utils.d.ts +5 -2
- package/src/_types/core/utils.d.ts.map +1 -0
- package/src/_types/core/waitForReceivingTransaction.d.ts +4 -0
- package/src/_types/core/waitForReceivingTransaction.d.ts.map +1 -0
- package/src/_types/createConfig.d.ts +4 -0
- package/src/_types/createConfig.d.ts.map +1 -0
- package/{dist → src/_types}/helpers.d.ts +4 -3
- package/src/_types/helpers.d.ts.map +1 -0
- package/src/_types/index.d.ts +13 -0
- package/src/_types/index.d.ts.map +1 -0
- package/{dist → src/_types}/request.d.ts +1 -0
- package/src/_types/request.d.ts.map +1 -0
- package/src/_types/services/api.d.ts +89 -0
- package/src/_types/services/api.d.ts.map +1 -0
- package/src/_types/services/balance.d.ts +30 -0
- package/src/_types/services/balance.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/typeguards.d.ts +3 -2
- package/src/_types/typeguards.d.ts.map +1 -0
- package/src/_types/types/index.d.ts +2 -0
- package/src/_types/types/index.d.ts.map +1 -0
- package/src/_types/types/internal.d.ts +58 -0
- package/src/_types/types/internal.d.ts.map +1 -0
- package/{dist → src/_types}/utils/errors.d.ts +1 -0
- package/src/_types/utils/errors.d.ts.map +1 -0
- package/src/_types/utils/getTransactionMessage.d.ts +4 -0
- package/src/_types/utils/getTransactionMessage.d.ts.map +1 -0
- package/src/_types/utils/index.d.ts +6 -0
- package/src/_types/utils/index.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/utils/median.d.ts +1 -0
- package/src/_types/utils/median.d.ts.map +1 -0
- package/src/_types/utils/parseBackendError.d.ts +3 -0
- package/src/_types/utils/parseBackendError.d.ts.map +1 -0
- package/{dist → src/_types}/utils/parseError.d.ts +4 -6
- package/src/_types/utils/parseError.d.ts.map +1 -0
- package/{dist → src/_types}/utils/utils.d.ts +1 -0
- package/src/_types/utils/utils.d.ts.map +1 -0
- package/src/_types/version.d.ts +3 -0
- package/src/_types/version.d.ts.map +1 -0
- package/src/config.ts +71 -0
- package/src/constants.ts +4 -0
- package/src/core/BaseStepExecutor.ts +40 -0
- package/src/core/EVM/EVM.ts +47 -0
- package/src/core/EVM/EVMStepExecutor.ts +461 -0
- package/src/core/EVM/abi.ts +47 -0
- package/src/core/EVM/checkAllowance.ts +152 -0
- package/src/core/EVM/getAllowance.ts +144 -0
- package/src/core/EVM/getEVMBalance.ts +118 -0
- package/src/core/EVM/multisig.ts +53 -0
- package/src/core/EVM/publicClient.ts +46 -0
- package/src/core/EVM/setAllowance.ts +144 -0
- package/src/core/EVM/switchChain.ts +77 -0
- package/src/core/EVM/types.ts +73 -0
- package/src/core/EVM/utils.ts +42 -0
- package/src/core/Solana/Solana.ts +46 -0
- package/src/core/Solana/SolanaStepExecutor.ts +259 -0
- package/src/core/Solana/connection.ts +19 -0
- package/src/core/Solana/getSolanaBalance.ts +72 -0
- package/src/core/Solana/types.ts +18 -0
- package/src/core/StatusManager.ts +231 -0
- package/src/core/checkBalance.ts +48 -0
- package/src/core/execution.ts +218 -0
- package/src/core/executionState.ts +39 -0
- package/src/core/index.ts +3 -0
- package/src/core/prepareRestart.ts +82 -0
- package/src/core/provider.ts +12 -0
- package/src/core/stepComparison.ts +51 -0
- package/src/core/types.ts +117 -0
- package/src/core/utils.ts +122 -0
- package/src/core/waitForReceivingTransaction.ts +74 -0
- package/src/createConfig.ts +33 -0
- package/src/helpers.ts +83 -0
- package/src/index.ts +12 -0
- package/src/request.ts +79 -0
- package/src/services/api.ts +511 -0
- package/src/services/balance.ts +93 -0
- package/src/typeguards.ts +89 -0
- package/src/types/index.ts +1 -0
- package/src/types/internal.ts +60 -0
- package/src/utils/errors.ts +231 -0
- package/src/utils/getTransactionMessage.ts +46 -0
- package/src/utils/index.ts +5 -0
- package/src/utils/median.ts +11 -0
- package/src/utils/parseBackendError.ts +50 -0
- package/src/utils/parseError.ts +204 -0
- package/src/utils/utils.ts +48 -0
- package/src/version.ts +2 -0
- package/dist/LiFi.d.ts +0 -171
- package/dist/LiFi.js +0 -246
- package/dist/allowance/getAllowance.d.ts +0 -6
- package/dist/allowance/index.d.ts +0 -3
- package/dist/allowance/index.js +0 -3
- package/dist/allowance/setAllowance.d.ts +0 -5
- package/dist/allowance/types.d.ts +0 -27
- package/dist/allowance/types.js +0 -1
- package/dist/balance/getBalance.d.ts +0 -2
- package/dist/balance/getTokenBalance.d.ts +0 -8
- package/dist/balance/getTokenBalance.js +0 -27
- package/dist/balance/index.d.ts +0 -2
- package/dist/balance/index.js +0 -2
- package/dist/cjs/LiFi.d.ts +0 -171
- package/dist/cjs/LiFi.js +0 -276
- package/dist/cjs/allowance/index.d.ts +0 -3
- package/dist/cjs/allowance/index.js +0 -19
- package/dist/cjs/allowance/setAllowance.d.ts +0 -5
- package/dist/cjs/allowance/setAllowance.js +0 -56
- package/dist/cjs/allowance/types.d.ts +0 -27
- package/dist/cjs/balance/getBalance.d.ts +0 -2
- package/dist/cjs/balance/getTokenBalance.d.ts +0 -8
- package/dist/cjs/balance/getTokenBalance.js +0 -33
- package/dist/cjs/balance/index.d.ts +0 -2
- package/dist/cjs/balance/index.js +0 -18
- package/dist/cjs/connectors.d.ts +0 -8
- package/dist/cjs/connectors.js +0 -75
- package/dist/cjs/execution/RouteExecutionManager.d.ts +0 -59
- package/dist/cjs/execution/RouteExecutionManager.js +0 -202
- package/dist/cjs/execution/StatusManager.js +0 -171
- package/dist/cjs/execution/StepExecutionManager.d.ts +0 -7
- package/dist/cjs/execution/StepExecutionManager.js +0 -267
- package/dist/cjs/execution/StepExecutor.d.ts +0 -15
- package/dist/cjs/execution/StepExecutor.js +0 -62
- package/dist/cjs/execution/checkAllowance.d.ts +0 -4
- package/dist/cjs/execution/checkBalance.d.ts +0 -2
- package/dist/cjs/execution/index.d.ts +0 -1
- package/dist/cjs/execution/index.js +0 -17
- package/dist/cjs/execution/multisig.d.ts +0 -4
- package/dist/cjs/execution/prepareRestart.d.ts +0 -3
- package/dist/cjs/execution/prepareRestart.js +0 -65
- package/dist/cjs/execution/stepComparison.d.ts +0 -14
- package/dist/cjs/execution/stepComparison.js +0 -37
- package/dist/cjs/execution/switchChain.js +0 -54
- package/dist/cjs/execution/utils.d.ts +0 -12
- package/dist/cjs/execution/waitForReceivingTransaction.d.ts +0 -3
- package/dist/cjs/helpers.d.ts +0 -18
- package/dist/cjs/helpers.js +0 -84
- package/dist/cjs/index.d.ts +0 -5
- package/dist/cjs/index.js +0 -24
- package/dist/cjs/request.d.ts +0 -9
- package/dist/cjs/request.js +0 -60
- package/dist/cjs/services/ApiService.d.ts +0 -17
- package/dist/cjs/services/ApiService.js +0 -326
- package/dist/cjs/services/ChainsService.d.ts +0 -11
- package/dist/cjs/services/ChainsService.js +0 -39
- package/dist/cjs/services/ConfigService.d.ts +0 -23
- package/dist/cjs/services/ConfigService.js +0 -101
- package/dist/cjs/types/index.d.ts +0 -4
- package/dist/cjs/types/index.js +0 -22
- package/dist/cjs/types/internal.types.d.ts +0 -142
- package/dist/cjs/utils/errors.d.ts +0 -107
- package/dist/cjs/utils/getMaxPriorityFeePerGas.d.ts +0 -2
- package/dist/cjs/utils/index.d.ts +0 -5
- package/dist/cjs/utils/index.js +0 -21
- package/dist/cjs/utils/parseError.d.ts +0 -37
- package/dist/cjs/utils/parseError.js +0 -157
- package/dist/cjs/utils/utils.d.ts +0 -10
- package/dist/cjs/version.d.ts +0 -2
- package/dist/connectors.d.ts +0 -8
- package/dist/connectors.js +0 -41
- package/dist/constants.d.ts +0 -6
- package/dist/execution/RouteExecutionManager.d.ts +0 -59
- package/dist/execution/RouteExecutionManager.js +0 -195
- package/dist/execution/StatusManager.d.ts +0 -67
- package/dist/execution/StatusManager.js +0 -167
- package/dist/execution/StepExecutionManager.d.ts +0 -7
- package/dist/execution/StepExecutionManager.js +0 -260
- package/dist/execution/StepExecutor.d.ts +0 -15
- package/dist/execution/StepExecutor.js +0 -58
- package/dist/execution/checkAllowance.d.ts +0 -4
- package/dist/execution/checkBalance.d.ts +0 -2
- package/dist/execution/index.d.ts +0 -1
- package/dist/execution/index.js +0 -1
- package/dist/execution/multisig.d.ts +0 -4
- package/dist/execution/prepareRestart.d.ts +0 -3
- package/dist/execution/prepareRestart.js +0 -61
- package/dist/execution/switchChain.d.ts +0 -21
- package/dist/execution/waitForReceivingTransaction.d.ts +0 -3
- package/dist/index.d.ts +0 -5
- package/dist/index.js +0 -6
- package/dist/services/ApiService.d.ts +0 -17
- package/dist/services/ApiService.js +0 -321
- package/dist/services/ChainsService.d.ts +0 -11
- package/dist/services/ChainsService.js +0 -33
- package/dist/services/ConfigService.d.ts +0 -23
- package/dist/services/ConfigService.js +0 -99
- package/dist/typeguards.d.ts +0 -4
- package/dist/types/abi.d.ts +0 -5
- package/dist/types/index.d.ts +0 -4
- package/dist/types/index.js +0 -4
- package/dist/types/internal.types.d.ts +0 -142
- package/dist/types/internal.types.js +0 -1
- package/dist/utils/getMaxPriorityFeePerGas.d.ts +0 -2
- package/dist/utils/index.d.ts +0 -5
- package/dist/utils/index.js +0 -5
- package/dist/utils/median.d.ts +0 -1
- package/dist/version.d.ts +0 -2
- package/dist/version.js +0 -2
|
@@ -1,260 +0,0 @@
|
|
|
1
|
-
import { publicActions } from 'viem';
|
|
2
|
-
import ApiService from '../services/ApiService';
|
|
3
|
-
import ChainsService from '../services/ChainsService';
|
|
4
|
-
import ConfigService from '../services/ConfigService';
|
|
5
|
-
import { getMaxPriorityFeePerGas } from '../utils';
|
|
6
|
-
import { LiFiErrorCode, TransactionError, ValidationError, } from '../utils/errors';
|
|
7
|
-
import { getTransactionFailedMessage, parseError } from '../utils/parseError';
|
|
8
|
-
import { isZeroAddress } from '../utils/utils';
|
|
9
|
-
import { checkAllowance } from './checkAllowance';
|
|
10
|
-
import { checkBalance } from './checkBalance';
|
|
11
|
-
import { updateMultisigRouteProcess } from './multisig';
|
|
12
|
-
import { stepComparison } from './stepComparison';
|
|
13
|
-
import { switchChain } from './switchChain';
|
|
14
|
-
import { getSubstatusMessage } from './utils';
|
|
15
|
-
import { waitForReceivingTransaction } from './waitForReceivingTransaction';
|
|
16
|
-
export class StepExecutionManager {
|
|
17
|
-
constructor() {
|
|
18
|
-
this.allowUserInteraction = true;
|
|
19
|
-
this.allowInteraction = (value) => {
|
|
20
|
-
this.allowUserInteraction = value;
|
|
21
|
-
};
|
|
22
|
-
this.execute = async ({ walletClient, step, statusManager, settings, }) => {
|
|
23
|
-
const client = walletClient.extend(publicActions);
|
|
24
|
-
const config = ConfigService.getInstance().getConfig();
|
|
25
|
-
const isMultisigWalletClient = !!config.multisig?.isMultisigWalletClient;
|
|
26
|
-
const multisigBatchTransactions = [];
|
|
27
|
-
const shouldBatchTransactions = config.multisig?.shouldBatchTransactions &&
|
|
28
|
-
!!config.multisig.sendBatchTransaction;
|
|
29
|
-
step.execution = statusManager.initExecutionObject(step);
|
|
30
|
-
const chainsService = ChainsService.getInstance();
|
|
31
|
-
const fromChain = await chainsService.getChainById(step.action.fromChainId);
|
|
32
|
-
const toChain = await chainsService.getChainById(step.action.toChainId);
|
|
33
|
-
const isBridgeExecution = fromChain.id !== toChain.id;
|
|
34
|
-
const currentProcessType = isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP';
|
|
35
|
-
// STEP 1: Check allowance
|
|
36
|
-
const existingProcess = step.execution.process.find((p) => p.type === currentProcessType);
|
|
37
|
-
// Check token approval only if fromToken is not the native token => no approval needed in that case
|
|
38
|
-
const checkForAllowance = !existingProcess?.txHash &&
|
|
39
|
-
!isZeroAddress(step.action.fromToken.address) &&
|
|
40
|
-
(shouldBatchTransactions || !isMultisigWalletClient);
|
|
41
|
-
if (checkForAllowance) {
|
|
42
|
-
const data = await checkAllowance(client, step, statusManager, settings, fromChain, this.allowUserInteraction, shouldBatchTransactions);
|
|
43
|
-
if (data) {
|
|
44
|
-
// allowance doesn't need value
|
|
45
|
-
const baseTransaction = {
|
|
46
|
-
to: step.action.fromToken.address,
|
|
47
|
-
data,
|
|
48
|
-
};
|
|
49
|
-
multisigBatchTransactions.push(baseTransaction);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
// STEP 2: Get transaction
|
|
53
|
-
let process = statusManager.findOrCreateProcess(step, currentProcessType);
|
|
54
|
-
if (process.status !== 'DONE') {
|
|
55
|
-
const multisigProcess = step.execution.process.find((p) => !!p.multisigTxHash);
|
|
56
|
-
try {
|
|
57
|
-
if (isMultisigWalletClient && multisigProcess) {
|
|
58
|
-
const multisigTxHash = multisigProcess.multisigTxHash;
|
|
59
|
-
if (!multisigTxHash) {
|
|
60
|
-
throw new ValidationError('Multisig internal transaction hash is undefined.');
|
|
61
|
-
}
|
|
62
|
-
await updateMultisigRouteProcess(multisigTxHash, step, statusManager, process.type, fromChain);
|
|
63
|
-
}
|
|
64
|
-
let txHash;
|
|
65
|
-
if (process.txHash) {
|
|
66
|
-
// Make sure that the chain is still correct
|
|
67
|
-
const updatedWalletClient = await switchChain(walletClient, statusManager, step, settings.switchChainHook, this.allowUserInteraction);
|
|
68
|
-
if (!updatedWalletClient) {
|
|
69
|
-
// Chain switch was not successful, stop execution here
|
|
70
|
-
return step.execution;
|
|
71
|
-
}
|
|
72
|
-
walletClient = updatedWalletClient;
|
|
73
|
-
// Load exiting transaction
|
|
74
|
-
txHash = process.txHash;
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
process = statusManager.updateProcess(step, process.type, 'STARTED');
|
|
78
|
-
// Check balance
|
|
79
|
-
await checkBalance(client.account.address, step);
|
|
80
|
-
// Create new transaction
|
|
81
|
-
if (!step.transactionRequest) {
|
|
82
|
-
const updatedStep = await ApiService.getStepTransaction(step);
|
|
83
|
-
const comparedStep = await stepComparison(statusManager, step, updatedStep, settings, this.allowUserInteraction);
|
|
84
|
-
step = {
|
|
85
|
-
...comparedStep,
|
|
86
|
-
execution: step.execution,
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
let transactionRequest = {
|
|
90
|
-
to: step.transactionRequest?.to,
|
|
91
|
-
from: step.transactionRequest?.from,
|
|
92
|
-
data: step.transactionRequest?.data,
|
|
93
|
-
value: step.transactionRequest?.value
|
|
94
|
-
? BigInt(step.transactionRequest.value)
|
|
95
|
-
: undefined,
|
|
96
|
-
maxPriorityFeePerGas: walletClient.account?.type === 'local'
|
|
97
|
-
? await getMaxPriorityFeePerGas(client)
|
|
98
|
-
: undefined,
|
|
99
|
-
// gas: step.transactionRequest?.gasLimit
|
|
100
|
-
// ? BigInt(step.transactionRequest.gasLimit as string)
|
|
101
|
-
// : undefined,
|
|
102
|
-
// gasPrice: step.transactionRequest?.gasPrice
|
|
103
|
-
// ? BigInt(step.transactionRequest.gasPrice as string)
|
|
104
|
-
// : undefined,
|
|
105
|
-
// maxFeePerGas: step.transactionRequest?.maxFeePerGas
|
|
106
|
-
// ? BigInt(step.transactionRequest.maxFeePerGas as string)
|
|
107
|
-
// : undefined,
|
|
108
|
-
// maxPriorityFeePerGas: step.transactionRequest?.maxPriorityFeePerGas
|
|
109
|
-
// ? BigInt(step.transactionRequest.maxPriorityFeePerGas as string)
|
|
110
|
-
// : undefined,
|
|
111
|
-
};
|
|
112
|
-
if (!transactionRequest) {
|
|
113
|
-
throw new TransactionError(LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
|
|
114
|
-
}
|
|
115
|
-
// STEP 3: Send the transaction
|
|
116
|
-
// Make sure that the chain is still correct
|
|
117
|
-
const updatedWalletClient = await switchChain(walletClient, statusManager, step, settings.switchChainHook, this.allowUserInteraction);
|
|
118
|
-
if (!updatedWalletClient) {
|
|
119
|
-
// Chain switch was not successful, stop execution here
|
|
120
|
-
return step.execution;
|
|
121
|
-
}
|
|
122
|
-
walletClient = updatedWalletClient;
|
|
123
|
-
process = statusManager.updateProcess(step, process.type, 'ACTION_REQUIRED');
|
|
124
|
-
if (!this.allowUserInteraction) {
|
|
125
|
-
return step.execution;
|
|
126
|
-
}
|
|
127
|
-
if (settings.updateTransactionRequestHook) {
|
|
128
|
-
const customizedTransactionRequest = await settings.updateTransactionRequestHook(transactionRequest);
|
|
129
|
-
transactionRequest = {
|
|
130
|
-
...transactionRequest,
|
|
131
|
-
...customizedTransactionRequest,
|
|
132
|
-
};
|
|
133
|
-
}
|
|
134
|
-
if (shouldBatchTransactions &&
|
|
135
|
-
config.multisig?.sendBatchTransaction) {
|
|
136
|
-
if (transactionRequest.to && transactionRequest.data) {
|
|
137
|
-
const populatedTransaction = {
|
|
138
|
-
value: transactionRequest.value,
|
|
139
|
-
to: transactionRequest.to,
|
|
140
|
-
data: transactionRequest.data,
|
|
141
|
-
};
|
|
142
|
-
multisigBatchTransactions.push(populatedTransaction);
|
|
143
|
-
txHash = await config.multisig?.sendBatchTransaction(multisigBatchTransactions);
|
|
144
|
-
}
|
|
145
|
-
else {
|
|
146
|
-
throw new TransactionError(LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
else {
|
|
150
|
-
txHash = await walletClient.sendTransaction({
|
|
151
|
-
to: transactionRequest.to,
|
|
152
|
-
account: walletClient.account,
|
|
153
|
-
data: transactionRequest.data,
|
|
154
|
-
maxPriorityFeePerGas: transactionRequest.maxPriorityFeePerGas,
|
|
155
|
-
chain: null,
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
// STEP 4: Wait for the transaction
|
|
159
|
-
if (isMultisigWalletClient) {
|
|
160
|
-
process = statusManager.updateProcess(step, process.type, 'ACTION_REQUIRED', {
|
|
161
|
-
multisigTxHash: txHash,
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
else {
|
|
165
|
-
process = statusManager.updateProcess(step, process.type, 'PENDING', {
|
|
166
|
-
txHash: txHash,
|
|
167
|
-
txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${txHash}`,
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
let replacementReason;
|
|
172
|
-
const transactionReceipt = await client.waitForTransactionReceipt({
|
|
173
|
-
hash: txHash,
|
|
174
|
-
onReplaced(response) {
|
|
175
|
-
replacementReason = response.reason;
|
|
176
|
-
statusManager.updateProcess(step, process.type, 'PENDING', {
|
|
177
|
-
txHash: response.transaction.hash,
|
|
178
|
-
txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${response.transaction.hash}`,
|
|
179
|
-
});
|
|
180
|
-
},
|
|
181
|
-
});
|
|
182
|
-
if (replacementReason === 'cancelled') {
|
|
183
|
-
throw new TransactionError(LiFiErrorCode.TransactionCanceled, 'User canceled transaction.');
|
|
184
|
-
}
|
|
185
|
-
// if it's multisig wallet client and the process is in ACTION_REQUIRED
|
|
186
|
-
// then signatures are still needed
|
|
187
|
-
if (isMultisigWalletClient && process.status === 'ACTION_REQUIRED') {
|
|
188
|
-
await updateMultisigRouteProcess(transactionReceipt.transactionHash, step, statusManager, process.type, fromChain);
|
|
189
|
-
}
|
|
190
|
-
if (!isMultisigWalletClient) {
|
|
191
|
-
process = statusManager.updateProcess(step, process.type, 'PENDING', {
|
|
192
|
-
txHash: transactionReceipt.transactionHash,
|
|
193
|
-
txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${transactionReceipt.transactionHash}`,
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
if (isBridgeExecution) {
|
|
197
|
-
process = statusManager.updateProcess(step, process.type, 'DONE');
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
catch (e) {
|
|
201
|
-
const error = await parseError(e, step, process);
|
|
202
|
-
process = statusManager.updateProcess(step, process.type, 'FAILED', {
|
|
203
|
-
error: {
|
|
204
|
-
message: error.message,
|
|
205
|
-
htmlMessage: error.htmlMessage,
|
|
206
|
-
code: error.code,
|
|
207
|
-
},
|
|
208
|
-
});
|
|
209
|
-
statusManager.updateExecution(step, 'FAILED');
|
|
210
|
-
throw error;
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
// STEP 5: Wait for the receiving chain
|
|
214
|
-
const processTxHash = process.txHash;
|
|
215
|
-
if (isBridgeExecution) {
|
|
216
|
-
process = statusManager.findOrCreateProcess(step, 'RECEIVING_CHAIN', 'PENDING');
|
|
217
|
-
}
|
|
218
|
-
let statusResponse;
|
|
219
|
-
try {
|
|
220
|
-
if (!processTxHash) {
|
|
221
|
-
throw new Error('Transaction hash is undefined.');
|
|
222
|
-
}
|
|
223
|
-
statusResponse = (await waitForReceivingTransaction(processTxHash, statusManager, process.type, step));
|
|
224
|
-
const statusReceiving = statusResponse.receiving;
|
|
225
|
-
process = statusManager.updateProcess(step, process.type, 'DONE', {
|
|
226
|
-
substatus: statusResponse.substatus,
|
|
227
|
-
substatusMessage: statusResponse.substatusMessage ||
|
|
228
|
-
getSubstatusMessage(statusResponse.status, statusResponse.substatus),
|
|
229
|
-
txHash: statusReceiving?.txHash,
|
|
230
|
-
txLink: `${toChain.metamask.blockExplorerUrls[0]}tx/${statusReceiving?.txHash}`,
|
|
231
|
-
});
|
|
232
|
-
statusManager.updateExecution(step, 'DONE', {
|
|
233
|
-
fromAmount: statusResponse.sending.amount,
|
|
234
|
-
toAmount: statusReceiving?.amount,
|
|
235
|
-
toToken: statusReceiving?.token,
|
|
236
|
-
gasAmount: statusResponse.sending.gasAmount,
|
|
237
|
-
gasAmountUSD: statusResponse.sending.gasAmountUSD,
|
|
238
|
-
gasPrice: statusResponse.sending.gasPrice,
|
|
239
|
-
gasToken: statusResponse.sending.gasToken,
|
|
240
|
-
gasUsed: statusResponse.sending.gasUsed,
|
|
241
|
-
});
|
|
242
|
-
}
|
|
243
|
-
catch (e) {
|
|
244
|
-
const htmlMessage = await getTransactionFailedMessage(step, process.txLink);
|
|
245
|
-
process = statusManager.updateProcess(step, process.type, 'FAILED', {
|
|
246
|
-
error: {
|
|
247
|
-
code: LiFiErrorCode.TransactionFailed,
|
|
248
|
-
message: 'Failed while waiting for receiving chain.',
|
|
249
|
-
htmlMessage,
|
|
250
|
-
},
|
|
251
|
-
});
|
|
252
|
-
statusManager.updateExecution(step, 'FAILED');
|
|
253
|
-
console.warn(e);
|
|
254
|
-
throw e;
|
|
255
|
-
}
|
|
256
|
-
// DONE
|
|
257
|
-
return step.execution;
|
|
258
|
-
};
|
|
259
|
-
}
|
|
260
|
-
}
|
|
@@ -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,58 +0,0 @@
|
|
|
1
|
-
import { StepExecutionManager } from './StepExecutionManager';
|
|
2
|
-
import { switchChain } from './switchChain';
|
|
3
|
-
// Please be careful when changing the defaults as it may break the behavior (e.g., background execution)
|
|
4
|
-
const defaultInteractionSettings = {
|
|
5
|
-
allowInteraction: true,
|
|
6
|
-
allowUpdates: true,
|
|
7
|
-
stopExecution: false,
|
|
8
|
-
};
|
|
9
|
-
export class StepExecutor {
|
|
10
|
-
constructor(statusManager, settings) {
|
|
11
|
-
this.allowUserInteraction = true;
|
|
12
|
-
this.executionStopped = false;
|
|
13
|
-
this.setInteraction = (settings) => {
|
|
14
|
-
const interactionSettings = {
|
|
15
|
-
...defaultInteractionSettings,
|
|
16
|
-
...settings,
|
|
17
|
-
};
|
|
18
|
-
this.allowUserInteraction = interactionSettings.allowInteraction;
|
|
19
|
-
this.stepExecutionManager.allowInteraction(interactionSettings.allowInteraction);
|
|
20
|
-
this.statusManager.allowUpdates(interactionSettings.allowUpdates);
|
|
21
|
-
this.executionStopped = interactionSettings.stopExecution;
|
|
22
|
-
};
|
|
23
|
-
// TODO: add checkChain method and update wallet client inside executors
|
|
24
|
-
// This can come in handy when we execute multiple routes simultaneously and
|
|
25
|
-
// should be sure that we are on the right chain when waiting for transactions.
|
|
26
|
-
this.checkChain = () => {
|
|
27
|
-
throw new Error('checkChain is not implemented.');
|
|
28
|
-
};
|
|
29
|
-
this.executeStep = async (walletClient, step) => {
|
|
30
|
-
// Make sure that the chain is still correct
|
|
31
|
-
// Find if it's bridging and the step is waiting for a transaction on the receiving chain
|
|
32
|
-
const recievingChainProcess = step.execution?.process.find((process) => process.type === 'RECEIVING_CHAIN');
|
|
33
|
-
// If the step is waiting for a transaction on the receiving chain, we do not switch the chain
|
|
34
|
-
// All changes are already done from the source chain
|
|
35
|
-
// Return the step
|
|
36
|
-
if (recievingChainProcess?.substatus !== 'WAIT_DESTINATION_TRANSACTION' ||
|
|
37
|
-
!recievingChainProcess) {
|
|
38
|
-
const updatedWalletClient = await switchChain(walletClient, this.statusManager, step, this.settings.switchChainHook, this.allowUserInteraction);
|
|
39
|
-
if (!updatedWalletClient) {
|
|
40
|
-
// Chain switch was not successful, stop execution here
|
|
41
|
-
return step;
|
|
42
|
-
}
|
|
43
|
-
walletClient = updatedWalletClient;
|
|
44
|
-
}
|
|
45
|
-
const parameters = {
|
|
46
|
-
walletClient,
|
|
47
|
-
step,
|
|
48
|
-
settings: this.settings,
|
|
49
|
-
statusManager: this.statusManager,
|
|
50
|
-
};
|
|
51
|
-
await this.stepExecutionManager.execute(parameters);
|
|
52
|
-
return step;
|
|
53
|
-
};
|
|
54
|
-
this.stepExecutionManager = new StepExecutionManager();
|
|
55
|
-
this.statusManager = statusManager;
|
|
56
|
-
this.settings = settings;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
@@ -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 +0,0 @@
|
|
|
1
|
-
export * from './StatusManager';
|
package/dist/execution/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './StatusManager';
|
|
@@ -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,61 +0,0 @@
|
|
|
1
|
-
import { publicActions } from 'viem';
|
|
2
|
-
import { LiFiErrorCode } from '../utils/errors';
|
|
3
|
-
export const prepareRestart = async (route, walletClient) => {
|
|
4
|
-
for (let index = 0; index < route.steps.length; index++) {
|
|
5
|
-
const step = route.steps[index];
|
|
6
|
-
const stepHasFailed = step.execution?.status === 'FAILED';
|
|
7
|
-
if (stepHasFailed) {
|
|
8
|
-
await handleErrorType(walletClient, step);
|
|
9
|
-
deleteFailedProcesses(step);
|
|
10
|
-
deleteTransactionData(step);
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
};
|
|
14
|
-
const handleErrorType = async (walletClient, step) => {
|
|
15
|
-
const client = walletClient.extend(publicActions);
|
|
16
|
-
const isGasLimitError = step.execution?.process.some((p) => p.error?.code === LiFiErrorCode.GasLimitError);
|
|
17
|
-
const isGasPriceError = step.execution?.process.some((p) => p.error?.code === LiFiErrorCode.TransactionUnderpriced);
|
|
18
|
-
const { transactionRequest } = step;
|
|
19
|
-
// if (isGasLimitError) {
|
|
20
|
-
// if (transactionRequest) {
|
|
21
|
-
// let gasLimit = transactionRequest.gasLimit
|
|
22
|
-
// try {
|
|
23
|
-
// gasLimit = await client.estimateGas(transactionRequest)
|
|
24
|
-
// } catch (error) {}
|
|
25
|
-
// if (gasLimit) {
|
|
26
|
-
// transactionRequest.gasLimit = BigNumber.from(
|
|
27
|
-
// `${(BigInt(gasLimit.toString()) * 125n) / 100n}`
|
|
28
|
-
// )
|
|
29
|
-
// }
|
|
30
|
-
// }
|
|
31
|
-
// step.estimate.gasCosts?.forEach(
|
|
32
|
-
// (gasCost) =>
|
|
33
|
-
// (gasCost.limit = `${Math.round(Number(gasCost.limit) * 1.25)}`)
|
|
34
|
-
// )
|
|
35
|
-
// }
|
|
36
|
-
// if (isGasPriceError) {
|
|
37
|
-
// if (transactionRequest) {
|
|
38
|
-
// let gasPrice = transactionRequest.gasPrice
|
|
39
|
-
// try {
|
|
40
|
-
// gasPrice = await client.getGasPrice()
|
|
41
|
-
// } catch (error) {}
|
|
42
|
-
// if (gasPrice) {
|
|
43
|
-
// transactionRequest.gasPrice = BigNumber.from(
|
|
44
|
-
// `${(BigInt(gasPrice.toString()) * 125n) / 100n}`
|
|
45
|
-
// )
|
|
46
|
-
// }
|
|
47
|
-
// }
|
|
48
|
-
// step.estimate.gasCosts?.forEach(
|
|
49
|
-
// (gasCost) =>
|
|
50
|
-
// (gasCost.price = `${Math.round(Number(gasCost.price) * 1.25)}`)
|
|
51
|
-
// )
|
|
52
|
-
// }
|
|
53
|
-
};
|
|
54
|
-
const deleteFailedProcesses = (step) => {
|
|
55
|
-
if (step.execution) {
|
|
56
|
-
step.execution.process = step.execution.process.filter((process) => process.status === 'DONE');
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
const deleteTransactionData = (step) => {
|
|
60
|
-
step.transactionRequest = undefined;
|
|
61
|
-
};
|
|
@@ -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,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>;
|
package/dist/index.d.ts
DELETED
package/dist/index.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import type { ConnectionsRequest, ConnectionsResponse, ContractCallQuoteRequest, GasRecommendationRequest, GasRecommendationResponse, GetStatusRequest, LifiStep, QuoteRequest, RequestOptions, TokensRequest, TokensResponse } from '@lifi/types';
|
|
2
|
-
import type { ChainId, ChainKey, ExtendedChain, PossibilitiesRequest, PossibilitiesResponse, RoutesRequest, RoutesResponse, StatusResponse, Token, ToolsRequest, ToolsResponse } from '../types';
|
|
3
|
-
declare const _default: {
|
|
4
|
-
getChains: (options?: RequestOptions | undefined) => Promise<ExtendedChain[]>;
|
|
5
|
-
getContractCallQuote: (requestConfig: ContractCallQuoteRequest, options?: RequestOptions | undefined) => Promise<LifiStep>;
|
|
6
|
-
getGasRecommendation: ({ chainId, fromChain, fromToken }: GasRecommendationRequest, options?: RequestOptions | undefined) => Promise<GasRecommendationResponse>;
|
|
7
|
-
getPossibilities: (requestConfig?: PossibilitiesRequest | undefined, options?: RequestOptions | undefined) => Promise<PossibilitiesResponse>;
|
|
8
|
-
getQuote: (requestConfig: QuoteRequest, options?: RequestOptions | undefined) => Promise<LifiStep>;
|
|
9
|
-
getRoutes: (requestConfig: RoutesRequest, options?: RequestOptions | undefined) => Promise<RoutesResponse>;
|
|
10
|
-
getStatus: (requestConfig: GetStatusRequest, options?: RequestOptions | undefined) => Promise<StatusResponse>;
|
|
11
|
-
getStepTransaction: (step: LifiStep, options?: RequestOptions | undefined) => Promise<LifiStep>;
|
|
12
|
-
getToken: (chain: ChainId | ChainKey, token: string, options?: RequestOptions | undefined) => Promise<Token>;
|
|
13
|
-
getTokens: (requestConfig?: TokensRequest | undefined, options?: RequestOptions | undefined) => Promise<TokensResponse>;
|
|
14
|
-
getTools: (requestConfig?: ToolsRequest | undefined, options?: RequestOptions | undefined) => Promise<ToolsResponse>;
|
|
15
|
-
getAvailableConnections: (connectionRequest: ConnectionsRequest) => Promise<ConnectionsResponse>;
|
|
16
|
-
};
|
|
17
|
-
export default _default;
|