@lifi/sdk 3.0.0-alpha.2 → 3.0.0-alpha.20
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/dist/cjs/config.js +48 -0
- package/dist/cjs/config.js.map +1 -0
- package/dist/cjs/constants.js +2 -4
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/core/BaseStepExecutor.js +55 -0
- package/dist/cjs/core/BaseStepExecutor.js.map +1 -0
- package/dist/cjs/core/EVM/EVM.js +46 -0
- package/dist/cjs/core/EVM/EVM.js.map +1 -0
- package/dist/cjs/core/EVM/EVMStepExecutor.js +276 -0
- package/dist/cjs/core/EVM/EVMStepExecutor.js.map +1 -0
- package/dist/cjs/{types → core/EVM}/abi.js +1 -0
- package/dist/cjs/core/EVM/abi.js.map +1 -0
- package/dist/cjs/{execution → core/EVM}/checkAllowance.js +12 -12
- package/dist/cjs/core/EVM/checkAllowance.js.map +1 -0
- package/dist/cjs/{allowance → core/EVM}/getAllowance.js +15 -17
- package/dist/cjs/core/EVM/getAllowance.js.map +1 -0
- package/dist/cjs/{balance/getBalance.js → core/EVM/getEVMBalance.js} +22 -22
- package/dist/cjs/core/EVM/getEVMBalance.js.map +1 -0
- package/dist/cjs/{execution → core/EVM}/multisig.js +7 -11
- package/dist/cjs/core/EVM/multisig.js.map +1 -0
- package/dist/cjs/core/EVM/publicClient.js +35 -0
- package/dist/cjs/core/EVM/publicClient.js.map +1 -0
- package/dist/cjs/core/EVM/setAllowance.js +71 -0
- package/dist/cjs/core/EVM/setAllowance.js.map +1 -0
- package/dist/cjs/core/EVM/switchChain.js +37 -0
- package/dist/cjs/core/EVM/switchChain.js.map +1 -0
- package/dist/cjs/core/EVM/types.js +9 -0
- package/dist/cjs/core/EVM/types.js.map +1 -0
- package/dist/cjs/{utils/getMaxPriorityFeePerGas.js → core/EVM/utils.js} +11 -3
- package/dist/cjs/core/EVM/utils.js.map +1 -0
- package/dist/cjs/core/Solana/Solana.js +44 -0
- package/dist/cjs/core/Solana/Solana.js.map +1 -0
- package/dist/cjs/core/Solana/SolanaStepExecutor.js +157 -0
- package/dist/cjs/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/dist/cjs/core/Solana/connection.js +18 -0
- package/dist/cjs/core/Solana/connection.js.map +1 -0
- package/dist/cjs/core/Solana/getSolanaBalance.js +50 -0
- package/dist/cjs/core/Solana/getSolanaBalance.js.map +1 -0
- package/dist/cjs/core/Solana/types.js +10 -0
- package/dist/cjs/core/Solana/types.js.map +1 -0
- package/dist/cjs/core/StatusManager.js +167 -0
- package/dist/cjs/core/StatusManager.js.map +1 -0
- package/dist/cjs/{execution → core}/checkBalance.js +5 -5
- package/dist/cjs/core/checkBalance.js.map +1 -0
- package/dist/cjs/core/execution.js +134 -0
- package/dist/cjs/core/execution.js.map +1 -0
- package/dist/cjs/core/executionState.js +23 -0
- package/dist/cjs/core/executionState.js.map +1 -0
- package/dist/cjs/core/index.js +7 -0
- package/dist/cjs/core/index.js.map +1 -0
- package/dist/cjs/core/prepareRestart.js +23 -0
- package/dist/cjs/core/prepareRestart.js.map +1 -0
- package/dist/cjs/core/provider.js +15 -0
- package/dist/cjs/core/provider.js.map +1 -0
- package/dist/cjs/core/stepComparison.js +25 -0
- package/dist/cjs/core/stepComparison.js.map +1 -0
- package/dist/cjs/{allowance → core}/types.js +1 -0
- package/dist/cjs/core/types.js.map +1 -0
- package/dist/cjs/{execution → core}/utils.js +16 -10
- package/dist/cjs/core/utils.js.map +1 -0
- package/dist/cjs/{execution → core}/waitForReceivingTransaction.js +10 -12
- package/dist/cjs/core/waitForReceivingTransaction.js.map +1 -0
- package/dist/cjs/createConfig.js +48 -0
- package/dist/cjs/createConfig.js.map +1 -0
- package/dist/cjs/helpers.js +11 -25
- package/dist/cjs/helpers.js.map +1 -0
- package/dist/cjs/index.js +18 -22
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/request.js +22 -16
- package/dist/cjs/request.js.map +1 -0
- package/dist/cjs/services/api.js +284 -0
- package/dist/cjs/services/api.js.map +1 -0
- package/dist/cjs/services/balance.js +49 -0
- package/dist/cjs/services/balance.js.map +1 -0
- package/dist/cjs/typeguards.js +1 -0
- package/dist/cjs/typeguards.js.map +1 -0
- package/dist/cjs/types/index.js +3 -20
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/{internal.types.js → internal.js} +1 -0
- package/dist/cjs/types/internal.js.map +1 -0
- package/dist/cjs/utils/errors.js +25 -3
- package/dist/cjs/utils/errors.js.map +1 -0
- package/dist/cjs/utils/getTransactionMessage.js +31 -0
- package/dist/cjs/utils/getTransactionMessage.js.map +1 -0
- package/dist/cjs/utils/index.js +7 -19
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/median.js +1 -0
- package/dist/cjs/utils/median.js.map +1 -0
- package/dist/cjs/utils/parseBackendError.js +27 -0
- package/dist/cjs/utils/parseBackendError.js.map +1 -0
- package/dist/cjs/utils/parseError.js +34 -124
- package/dist/cjs/utils/parseError.js.map +1 -0
- package/dist/cjs/utils/utils.js +5 -11
- package/dist/cjs/utils/utils.js.map +1 -0
- package/dist/cjs/version.js +2 -1
- package/dist/cjs/version.js.map +1 -0
- package/dist/esm/config.js +45 -0
- package/dist/esm/config.js.map +1 -0
- package/dist/{constants.js → esm/constants.js} +1 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/core/BaseStepExecutor.js +52 -0
- package/dist/esm/core/BaseStepExecutor.js.map +1 -0
- package/dist/esm/core/EVM/EVM.js +42 -0
- package/dist/esm/core/EVM/EVM.js.map +1 -0
- package/dist/esm/core/EVM/EVMStepExecutor.js +304 -0
- package/dist/esm/core/EVM/EVMStepExecutor.js.map +1 -0
- package/dist/{types → esm/core/EVM}/abi.js +1 -0
- package/dist/esm/core/EVM/abi.js.map +1 -0
- package/dist/{execution → esm/core/EVM}/checkAllowance.js +8 -6
- package/dist/esm/core/EVM/checkAllowance.js.map +1 -0
- package/dist/{allowance → esm/core/EVM}/getAllowance.js +20 -5
- package/dist/esm/core/EVM/getAllowance.js.map +1 -0
- package/dist/{balance/getBalance.js → esm/core/EVM/getEVMBalance.js} +11 -11
- package/dist/esm/core/EVM/getEVMBalance.js.map +1 -0
- package/dist/{execution → esm/core/EVM}/multisig.js +5 -6
- package/dist/esm/core/EVM/multisig.js.map +1 -0
- package/dist/esm/core/EVM/publicClient.js +37 -0
- package/dist/esm/core/EVM/publicClient.js.map +1 -0
- package/dist/{allowance → esm/core/EVM}/setAllowance.js +46 -11
- package/dist/esm/core/EVM/setAllowance.js.map +1 -0
- package/dist/{execution → esm/core/EVM}/switchChain.js +5 -3
- package/dist/esm/core/EVM/switchChain.js.map +1 -0
- package/dist/esm/core/EVM/types.js +6 -0
- package/dist/esm/core/EVM/types.js.map +1 -0
- package/dist/{utils/getMaxPriorityFeePerGas.js → esm/core/EVM/utils.js} +9 -1
- package/dist/esm/core/EVM/utils.js.map +1 -0
- package/dist/esm/core/Solana/Solana.js +40 -0
- package/dist/esm/core/Solana/Solana.js.map +1 -0
- package/dist/esm/core/Solana/SolanaStepExecutor.js +158 -0
- package/dist/esm/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/dist/esm/core/Solana/connection.js +19 -0
- package/dist/esm/core/Solana/connection.js.map +1 -0
- package/dist/esm/core/Solana/getSolanaBalance.js +46 -0
- package/dist/esm/core/Solana/getSolanaBalance.js.map +1 -0
- package/dist/esm/core/Solana/types.js +7 -0
- package/dist/esm/core/Solana/types.js.map +1 -0
- package/dist/esm/core/StatusManager.js +203 -0
- package/dist/esm/core/StatusManager.js.map +1 -0
- package/dist/{execution → esm/core}/checkBalance.js +3 -2
- package/dist/esm/core/checkBalance.js.map +1 -0
- package/dist/esm/core/execution.js +173 -0
- package/dist/esm/core/execution.js.map +1 -0
- package/dist/esm/core/executionState.js +20 -0
- package/dist/esm/core/executionState.js.map +1 -0
- package/dist/esm/core/index.js +4 -0
- package/dist/esm/core/index.js.map +1 -0
- package/dist/esm/core/prepareRestart.js +64 -0
- package/dist/esm/core/prepareRestart.js.map +1 -0
- package/dist/esm/core/provider.js +11 -0
- package/dist/esm/core/provider.js.map +1 -0
- package/dist/{execution → esm/core}/stepComparison.js +7 -5
- package/dist/esm/core/stepComparison.js.map +1 -0
- package/dist/esm/core/types.js +2 -0
- package/dist/esm/core/types.js.map +1 -0
- package/dist/{execution → esm/core}/utils.js +14 -0
- package/dist/esm/core/utils.js.map +1 -0
- package/dist/{execution → esm/core}/waitForReceivingTransaction.js +8 -7
- package/dist/esm/core/waitForReceivingTransaction.js.map +1 -0
- package/dist/esm/createConfig.js +45 -0
- package/dist/esm/createConfig.js.map +1 -0
- package/dist/{helpers.js → esm/helpers.js} +4 -3
- package/dist/esm/helpers.js.map +1 -0
- package/dist/esm/index.js +12 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/{request.js → esm/request.js} +19 -9
- package/dist/esm/request.js.map +1 -0
- package/dist/esm/services/api.js +353 -0
- package/dist/esm/services/api.js.map +1 -0
- package/dist/esm/services/balance.js +65 -0
- package/dist/esm/services/balance.js.map +1 -0
- package/dist/{typeguards.js → esm/typeguards.js} +1 -0
- package/dist/esm/typeguards.js.map +1 -0
- package/dist/esm/types/index.js +2 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/internal.js +2 -0
- package/dist/esm/types/internal.js.map +1 -0
- package/dist/{utils → esm/utils}/errors.js +25 -0
- package/dist/esm/utils/errors.js.map +1 -0
- package/dist/esm/utils/getTransactionMessage.js +28 -0
- package/dist/esm/utils/getTransactionMessage.js.map +1 -0
- package/dist/esm/utils/index.js +6 -0
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/{utils → esm/utils}/median.js +1 -0
- package/dist/esm/utils/median.js.map +1 -0
- package/dist/esm/utils/parseBackendError.js +24 -0
- package/dist/esm/utils/parseBackendError.js.map +1 -0
- package/dist/{utils → esm/utils}/parseError.js +4 -53
- package/dist/esm/utils/parseError.js.map +1 -0
- package/dist/{utils → esm/utils}/utils.js +2 -1
- package/dist/esm/utils/utils.js.map +1 -0
- package/dist/esm/version.js +3 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/types/config.d.ts +11 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/{cjs → types}/constants.d.ts +1 -0
- package/dist/types/constants.d.ts.map +1 -0
- package/dist/types/core/BaseStepExecutor.d.ts +13 -0
- package/dist/types/core/BaseStepExecutor.d.ts.map +1 -0
- package/dist/types/core/EVM/EVM.d.ts +3 -0
- package/dist/types/core/EVM/EVM.d.ts.map +1 -0
- package/dist/types/core/EVM/EVMStepExecutor.d.ts +17 -0
- package/dist/types/core/EVM/EVMStepExecutor.d.ts.map +1 -0
- package/dist/{cjs/types → types/core/EVM}/abi.d.ts +1 -0
- package/dist/types/core/EVM/abi.d.ts.map +1 -0
- package/dist/types/core/EVM/checkAllowance.d.ts +6 -0
- package/dist/types/core/EVM/checkAllowance.d.ts.map +1 -0
- package/dist/{cjs/allowance → types/core/EVM}/getAllowance.d.ts +15 -1
- package/dist/types/core/EVM/getAllowance.d.ts.map +1 -0
- package/dist/types/core/EVM/getEVMBalance.d.ts +3 -0
- package/dist/types/core/EVM/getEVMBalance.d.ts.map +1 -0
- package/dist/types/core/EVM/multisig.d.ts +6 -0
- package/dist/types/core/EVM/multisig.d.ts.map +1 -0
- package/dist/types/core/EVM/publicClient.d.ts +8 -0
- package/dist/types/core/EVM/publicClient.d.ts.map +1 -0
- package/dist/types/core/EVM/setAllowance.d.ts +25 -0
- package/dist/types/core/EVM/setAllowance.d.ts.map +1 -0
- package/dist/{execution → types/core/EVM}/switchChain.d.ts +6 -4
- package/dist/types/core/EVM/switchChain.d.ts.map +1 -0
- package/dist/types/core/EVM/types.d.ts +57 -0
- package/dist/types/core/EVM/types.d.ts.map +1 -0
- package/dist/types/core/EVM/utils.d.ts +5 -0
- package/dist/types/core/EVM/utils.d.ts.map +1 -0
- package/dist/types/core/Solana/Solana.d.ts +3 -0
- package/dist/types/core/Solana/Solana.d.ts.map +1 -0
- package/dist/types/core/Solana/SolanaStepExecutor.d.ts +13 -0
- package/dist/types/core/Solana/SolanaStepExecutor.d.ts.map +1 -0
- package/dist/types/core/Solana/connection.d.ts +8 -0
- package/dist/types/core/Solana/connection.d.ts.map +1 -0
- package/dist/types/core/Solana/getSolanaBalance.d.ts +3 -0
- package/dist/types/core/Solana/getSolanaBalance.d.ts.map +1 -0
- package/dist/types/core/Solana/types.d.ts +13 -0
- package/dist/types/core/Solana/types.d.ts.map +1 -0
- package/dist/{cjs/execution → types/core}/StatusManager.d.ts +12 -16
- package/dist/types/core/StatusManager.d.ts.map +1 -0
- package/dist/types/core/checkBalance.d.ts +3 -0
- package/dist/types/core/checkBalance.d.ts.map +1 -0
- package/dist/types/core/execution.d.ts +42 -0
- package/dist/types/core/execution.d.ts.map +1 -0
- package/dist/types/core/executionState.d.ts +16 -0
- package/dist/types/core/executionState.d.ts.map +1 -0
- package/dist/types/core/index.d.ts +4 -0
- package/dist/types/core/index.d.ts.map +1 -0
- package/dist/types/core/prepareRestart.d.ts +3 -0
- package/dist/types/core/prepareRestart.d.ts.map +1 -0
- package/dist/types/core/provider.d.ts +3 -0
- package/dist/types/core/provider.d.ts.map +1 -0
- package/dist/{cjs/execution → types/core}/stepComparison.d.ts +7 -4
- package/dist/types/core/stepComparison.d.ts.map +1 -0
- package/dist/types/core/types.d.ts +71 -0
- package/dist/types/core/types.d.ts.map +1 -0
- package/dist/{execution → types/core}/utils.d.ts +5 -2
- package/dist/types/core/utils.d.ts.map +1 -0
- package/dist/types/core/waitForReceivingTransaction.d.ts +4 -0
- package/dist/types/core/waitForReceivingTransaction.d.ts.map +1 -0
- package/dist/types/createConfig.d.ts +7 -0
- package/dist/types/createConfig.d.ts.map +1 -0
- package/dist/{helpers.d.ts → types/helpers.d.ts} +4 -3
- package/dist/types/helpers.d.ts.map +1 -0
- package/dist/types/index.d.ts +11 -3
- package/dist/types/index.d.ts.map +1 -0
- package/dist/{request.d.ts → types/request.d.ts} +1 -0
- package/dist/types/request.d.ts.map +1 -0
- package/dist/types/services/api.d.ts +87 -0
- package/dist/types/services/api.d.ts.map +1 -0
- package/dist/types/services/balance.d.ts +30 -0
- package/dist/types/services/balance.d.ts.map +1 -0
- package/dist/{cjs → types}/typeguards.d.ts +3 -2
- package/dist/types/typeguards.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +2 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/internal.d.ts +56 -0
- package/dist/types/types/internal.d.ts.map +1 -0
- package/dist/{utils → types/utils}/errors.d.ts +1 -0
- package/dist/types/utils/errors.d.ts.map +1 -0
- package/dist/types/utils/getTransactionMessage.d.ts +4 -0
- package/dist/types/utils/getTransactionMessage.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +6 -0
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/{cjs → types}/utils/median.d.ts +1 -0
- package/dist/types/utils/median.d.ts.map +1 -0
- package/dist/types/utils/parseBackendError.d.ts +3 -0
- package/dist/types/utils/parseBackendError.d.ts.map +1 -0
- package/dist/{utils → types/utils}/parseError.d.ts +4 -6
- package/dist/types/utils/parseError.d.ts.map +1 -0
- package/dist/{cjs → types}/utils/utils.d.ts +1 -0
- package/dist/types/utils/utils.d.ts.map +1 -0
- package/dist/types/version.d.ts +3 -0
- package/dist/types/version.d.ts.map +1 -0
- package/package.json +26 -85
- 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.js +0 -37
- package/dist/cjs/execution/switchChain.d.ts +0 -21
- 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/index.d.ts +0 -5
- package/dist/cjs/request.d.ts +0 -9
- 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/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/parseError.d.ts +0 -37
- 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/stepComparison.d.ts +0 -14
- 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.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/utils/utils.d.ts +0 -10
- package/dist/version.d.ts +0 -2
- 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 +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,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,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>;
|
package/dist/cjs/helpers.d.ts
DELETED
|
@@ -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>;
|
package/dist/cjs/index.d.ts
DELETED
package/dist/cjs/request.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export declare const requestSettings: {
|
|
2
|
-
retries: number;
|
|
3
|
-
};
|
|
4
|
-
interface ExtendedRequestInit extends RequestInit {
|
|
5
|
-
retries?: number;
|
|
6
|
-
skipTrackingHeaders?: boolean;
|
|
7
|
-
}
|
|
8
|
-
export declare const request: <T = Response>(url: RequestInfo | URL, options?: ExtendedRequestInit) => Promise<T>;
|
|
9
|
-
export {};
|
|
@@ -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;
|