@lifi/sdk 3.0.0-alpha.3 → 3.0.0-alpha.30
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 +48 -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 +46 -0
- package/src/_cjs/core/EVM/EVM.js.map +1 -0
- package/src/_cjs/core/EVM/EVMStepExecutor.js +276 -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 +37 -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} +13 -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 +157 -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 +10 -12
- package/src/_cjs/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_cjs/createConfig.js +50 -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 +20 -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 +304 -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 +45 -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 +42 -0
- package/src/_esm/core/EVM/EVM.js.map +1 -0
- package/src/_esm/core/EVM/EVMStepExecutor.js +304 -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 +5 -3
- 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} +11 -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 +158 -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 +8 -7
- package/src/_esm/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_esm/createConfig.js +47 -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 +12 -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 +372 -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 +11 -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 +57 -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 +13 -16
- 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 +7 -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 +12 -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 +88 -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 +56 -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 +47 -0
- package/src/constants.ts +4 -0
- package/src/core/BaseStepExecutor.ts +40 -0
- package/src/core/EVM/EVM.ts +50 -0
- package/src/core/EVM/EVMStepExecutor.ts +472 -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 +76 -0
- package/src/core/EVM/types.ts +75 -0
- package/src/core/EVM/utils.ts +47 -0
- package/src/core/Solana/Solana.ts +46 -0
- package/src/core/Solana/SolanaStepExecutor.ts +253 -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 +243 -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 +73 -0
- package/src/createConfig.ts +56 -0
- package/src/helpers.ts +83 -0
- package/src/index.ts +11 -0
- package/src/request.ts +79 -0
- package/src/services/api.ts +507 -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 +58 -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
|
@@ -2,33 +2,32 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.checkAllowance = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
|
|
5
|
+
const index_js_1 = require("../../utils/index.js");
|
|
6
|
+
const parseError_js_1 = require("../../utils/parseError.js");
|
|
7
|
+
const getAllowance_js_1 = require("./getAllowance.js");
|
|
8
|
+
const setAllowance_js_1 = require("./setAllowance.js");
|
|
9
|
+
const checkAllowance = async (chain, step, walletClient, statusManager, settings, allowUserInteraction = false, shouldBatchTransactions = false) => {
|
|
10
10
|
let allowanceProcess = statusManager.findOrCreateProcess(step, 'TOKEN_ALLOWANCE');
|
|
11
|
-
// Check allowance
|
|
12
11
|
try {
|
|
13
12
|
if (allowanceProcess.txHash && allowanceProcess.status !== 'DONE') {
|
|
14
13
|
await waitForApprovalTransaction(walletClient, allowanceProcess.txHash, allowanceProcess.type, step, chain, statusManager);
|
|
15
14
|
}
|
|
16
15
|
else {
|
|
17
|
-
const approved = await (0,
|
|
16
|
+
const approved = await (0, getAllowance_js_1.getAllowance)(chain.id, step.action.fromToken.address, walletClient.account.address, step.estimate.approvalAddress);
|
|
18
17
|
const fromAmount = BigInt(step.action.fromAmount);
|
|
19
18
|
if (fromAmount > approved) {
|
|
20
19
|
if (!allowUserInteraction) {
|
|
21
20
|
return;
|
|
22
21
|
}
|
|
23
|
-
const approvalAmount = settings
|
|
22
|
+
const approvalAmount = settings?.infiniteApproval
|
|
24
23
|
? viem_1.maxUint256
|
|
25
24
|
: fromAmount;
|
|
26
25
|
if (shouldBatchTransactions) {
|
|
27
|
-
const approveTxHash = await (0,
|
|
26
|
+
const approveTxHash = await (0, setAllowance_js_1.setAllowance)(walletClient, step.action.fromToken.address, step.estimate.approvalAddress, approvalAmount, settings, true);
|
|
28
27
|
allowanceProcess = statusManager.updateProcess(step, allowanceProcess.type, 'DONE');
|
|
29
28
|
return approveTxHash;
|
|
30
29
|
}
|
|
31
|
-
const approveTxHash = await (0,
|
|
30
|
+
const approveTxHash = await (0, setAllowance_js_1.setAllowance)(walletClient, step.action.fromToken.address, step.estimate.approvalAddress, approvalAmount);
|
|
32
31
|
await waitForApprovalTransaction(walletClient, approveTxHash, allowanceProcess.type, step, chain, statusManager);
|
|
33
32
|
}
|
|
34
33
|
else {
|
|
@@ -37,7 +36,7 @@ const checkAllowance = async (walletClient, step, statusManager, settings, chain
|
|
|
37
36
|
}
|
|
38
37
|
}
|
|
39
38
|
catch (e) {
|
|
40
|
-
const error = await (0,
|
|
39
|
+
const error = await (0, parseError_js_1.parseError)(e, step, allowanceProcess);
|
|
41
40
|
allowanceProcess = statusManager.updateProcess(step, allowanceProcess.type, 'FAILED', {
|
|
42
41
|
error: {
|
|
43
42
|
message: error.message,
|
|
@@ -68,10 +67,11 @@ const waitForApprovalTransaction = async (walletClient, txHash, processType, ste
|
|
|
68
67
|
},
|
|
69
68
|
});
|
|
70
69
|
if (replacementReason === 'cancelled') {
|
|
71
|
-
throw new
|
|
70
|
+
throw new index_js_1.TransactionError(index_js_1.LiFiErrorCode.TransactionCanceled, 'User canceled transaction.');
|
|
72
71
|
}
|
|
73
72
|
statusManager.updateProcess(step, processType, 'DONE', {
|
|
74
73
|
txHash: transactionReceipt.transactionHash,
|
|
75
74
|
txLink: `${chain.metamask.blockExplorerUrls[0]}tx/${transactionReceipt.transactionHash}`,
|
|
76
75
|
});
|
|
77
76
|
};
|
|
77
|
+
//# sourceMappingURL=checkAllowance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkAllowance.js","sourceRoot":"","sources":["../../../core/EVM/checkAllowance.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,16 +2,16 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getTokenAllowanceMulticall = exports.getTokenAllowance = exports.getAllowanceMulticall = exports.getAllowance = void 0;
|
|
4
4
|
const viem_1 = require("viem");
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
5
|
+
const utils_js_1 = require("../../utils/utils.js");
|
|
6
|
+
const abi_js_1 = require("./abi.js");
|
|
7
|
+
const publicClient_js_1 = require("./publicClient.js");
|
|
8
|
+
const utils_js_2 = require("./utils.js");
|
|
9
9
|
const getAllowance = async (chainId, tokenAddress, ownerAddress, spenderAddress) => {
|
|
10
|
-
const client = await (0,
|
|
10
|
+
const client = await (0, publicClient_js_1.getPublicClient)(chainId);
|
|
11
11
|
const contract = (0, viem_1.getContract)({
|
|
12
12
|
address: tokenAddress,
|
|
13
|
-
abi:
|
|
14
|
-
|
|
13
|
+
abi: abi_js_1.allowanceAbi,
|
|
14
|
+
client: client,
|
|
15
15
|
});
|
|
16
16
|
try {
|
|
17
17
|
const approved = (await contract.read.allowance([
|
|
@@ -29,21 +29,20 @@ const getAllowanceMulticall = async (chainId, tokens, ownerAddress) => {
|
|
|
29
29
|
if (!tokens.length) {
|
|
30
30
|
return [];
|
|
31
31
|
}
|
|
32
|
-
const multicallAddress = await (0,
|
|
32
|
+
const multicallAddress = await (0, utils_js_2.getMulticallAddress)(chainId);
|
|
33
33
|
if (!multicallAddress) {
|
|
34
34
|
throw new Error(`No multicall address configured for chainId ${chainId}.`);
|
|
35
35
|
}
|
|
36
|
-
const client = await (0,
|
|
36
|
+
const client = await (0, publicClient_js_1.getPublicClient)(chainId);
|
|
37
37
|
const contracts = tokens.map((token) => ({
|
|
38
38
|
address: token.token.address,
|
|
39
|
-
abi:
|
|
39
|
+
abi: abi_js_1.allowanceAbi,
|
|
40
40
|
functionName: 'allowance',
|
|
41
41
|
args: [ownerAddress, token.spenderAddress],
|
|
42
42
|
}));
|
|
43
43
|
const results = await client.multicall({
|
|
44
44
|
contracts,
|
|
45
45
|
multicallAddress: multicallAddress,
|
|
46
|
-
batchSize: constants_1.MulticallBatchSize,
|
|
47
46
|
});
|
|
48
47
|
if (!results.length) {
|
|
49
48
|
throw new Error(`Couldn't load allowance from chainId ${chainId} using multicall.`);
|
|
@@ -56,8 +55,7 @@ const getAllowanceMulticall = async (chainId, tokens, ownerAddress) => {
|
|
|
56
55
|
};
|
|
57
56
|
exports.getAllowanceMulticall = getAllowanceMulticall;
|
|
58
57
|
const getTokenAllowance = async (token, ownerAddress, spenderAddress) => {
|
|
59
|
-
|
|
60
|
-
if ((0, utils_1.isNativeTokenAddress)(token.address)) {
|
|
58
|
+
if ((0, utils_js_1.isNativeTokenAddress)(token.address)) {
|
|
61
59
|
return;
|
|
62
60
|
}
|
|
63
61
|
const approved = await (0, exports.getAllowance)(token.chainId, token.address, ownerAddress, spenderAddress);
|
|
@@ -65,9 +63,7 @@ const getTokenAllowance = async (token, ownerAddress, spenderAddress) => {
|
|
|
65
63
|
};
|
|
66
64
|
exports.getTokenAllowance = getTokenAllowance;
|
|
67
65
|
const getTokenAllowanceMulticall = async (ownerAddress, tokens) => {
|
|
68
|
-
|
|
69
|
-
const filteredTokens = tokens.filter(({ token }) => !(0, utils_1.isNativeTokenAddress)(token.address));
|
|
70
|
-
// group by chain
|
|
66
|
+
const filteredTokens = tokens.filter(({ token }) => !(0, utils_js_1.isNativeTokenAddress)(token.address));
|
|
71
67
|
const tokenDataByChain = {};
|
|
72
68
|
filteredTokens.forEach((data) => {
|
|
73
69
|
if (!tokenDataByChain[data.token.chainId]) {
|
|
@@ -77,9 +73,9 @@ const getTokenAllowanceMulticall = async (ownerAddress, tokens) => {
|
|
|
77
73
|
});
|
|
78
74
|
const chainKeys = Object.keys(tokenDataByChain).map(Number.parseInt);
|
|
79
75
|
const allowances = (await Promise.all(chainKeys.map(async (chainId) => {
|
|
80
|
-
// get allowances for current chain and token list
|
|
81
76
|
return (0, exports.getAllowanceMulticall)(chainId, tokenDataByChain[chainId], ownerAddress);
|
|
82
77
|
}))).flat();
|
|
83
78
|
return allowances;
|
|
84
79
|
};
|
|
85
80
|
exports.getTokenAllowanceMulticall = getTokenAllowanceMulticall;
|
|
81
|
+
//# sourceMappingURL=getAllowance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAllowance.js","sourceRoot":"","sources":["../../../core/EVM/getAllowance.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
3
|
+
exports.getEVMBalance = void 0;
|
|
4
|
+
const utils_js_1 = require("../../utils/utils.js");
|
|
5
|
+
const abi_js_1 = require("./abi.js");
|
|
6
|
+
const publicClient_js_1 = require("./publicClient.js");
|
|
7
|
+
const utils_js_2 = require("./utils.js");
|
|
8
|
+
const getEVMBalance = async (walletAddress, tokens) => {
|
|
9
9
|
if (tokens.length === 0) {
|
|
10
10
|
return [];
|
|
11
11
|
}
|
|
@@ -13,32 +13,31 @@ const getBalance = async (walletAddress, tokens) => {
|
|
|
13
13
|
tokens.forEach((token) => {
|
|
14
14
|
if (token.chainId !== chainId) {
|
|
15
15
|
console.warn(`Requested tokens have to be on the same chain.`);
|
|
16
|
-
return [];
|
|
17
16
|
}
|
|
18
17
|
});
|
|
19
|
-
const multicallAddress = await (0,
|
|
18
|
+
const multicallAddress = await (0, utils_js_2.getMulticallAddress)(chainId);
|
|
20
19
|
if (multicallAddress && tokens.length > 1) {
|
|
21
|
-
return
|
|
20
|
+
return getEVMBalanceMulticall(chainId, tokens, walletAddress, multicallAddress);
|
|
22
21
|
}
|
|
23
22
|
else {
|
|
24
|
-
return
|
|
23
|
+
return getEVMBalanceDefault(chainId, tokens, walletAddress);
|
|
25
24
|
}
|
|
26
25
|
};
|
|
27
|
-
exports.
|
|
28
|
-
const
|
|
29
|
-
const client = await (0,
|
|
26
|
+
exports.getEVMBalance = getEVMBalance;
|
|
27
|
+
const getEVMBalanceMulticall = async (chainId, tokens, walletAddress, multicallAddress) => {
|
|
28
|
+
const client = await (0, publicClient_js_1.getPublicClient)(chainId);
|
|
30
29
|
const contracts = tokens.map((token) => {
|
|
31
|
-
if ((0,
|
|
30
|
+
if ((0, utils_js_1.isZeroAddress)(token.address)) {
|
|
32
31
|
return {
|
|
33
32
|
address: multicallAddress,
|
|
34
|
-
abi:
|
|
33
|
+
abi: abi_js_1.getEthBalanceAbi,
|
|
35
34
|
functionName: 'getEthBalance',
|
|
36
35
|
args: [walletAddress],
|
|
37
36
|
};
|
|
38
37
|
}
|
|
39
38
|
return {
|
|
40
39
|
address: token.address,
|
|
41
|
-
abi:
|
|
40
|
+
abi: abi_js_1.balanceOfAbi,
|
|
42
41
|
functionName: 'balanceOf',
|
|
43
42
|
args: [walletAddress],
|
|
44
43
|
};
|
|
@@ -48,7 +47,6 @@ const getBalanceMulticall = async (chainId, tokens, walletAddress, multicallAddr
|
|
|
48
47
|
contracts,
|
|
49
48
|
multicallAddress: multicallAddress,
|
|
50
49
|
blockNumber,
|
|
51
|
-
batchSize: constants_1.MulticallBatchSize,
|
|
52
50
|
});
|
|
53
51
|
if (!results.length) {
|
|
54
52
|
return [];
|
|
@@ -61,18 +59,18 @@ const getBalanceMulticall = async (chainId, tokens, walletAddress, multicallAddr
|
|
|
61
59
|
};
|
|
62
60
|
});
|
|
63
61
|
};
|
|
64
|
-
const
|
|
65
|
-
const client = await (0,
|
|
62
|
+
const getEVMBalanceDefault = async (chainId, tokens, walletAddress) => {
|
|
63
|
+
const client = await (0, publicClient_js_1.getPublicClient)(chainId);
|
|
66
64
|
const blockNumber = await client.getBlockNumber();
|
|
67
65
|
const queue = tokens.map((token) => {
|
|
68
|
-
if ((0,
|
|
66
|
+
if ((0, utils_js_1.isZeroAddress)(token.address)) {
|
|
69
67
|
return client.getBalance({
|
|
70
68
|
address: walletAddress,
|
|
71
69
|
});
|
|
72
70
|
}
|
|
73
71
|
return client.readContract({
|
|
74
72
|
address: token.address,
|
|
75
|
-
abi:
|
|
73
|
+
abi: abi_js_1.balanceOfAbi,
|
|
76
74
|
functionName: 'balanceOf',
|
|
77
75
|
args: [walletAddress],
|
|
78
76
|
});
|
|
@@ -81,7 +79,6 @@ const getBalanceDefault = async (chainId, tokens, walletAddress) => {
|
|
|
81
79
|
const tokenAmounts = tokens.map((token, index) => {
|
|
82
80
|
const result = results[index];
|
|
83
81
|
if (result.status === 'rejected') {
|
|
84
|
-
console.warn(result.reason);
|
|
85
82
|
return {
|
|
86
83
|
...token,
|
|
87
84
|
blockNumber,
|
|
@@ -95,3 +92,4 @@ const getBalanceDefault = async (chainId, tokens, walletAddress) => {
|
|
|
95
92
|
});
|
|
96
93
|
return tokenAmounts;
|
|
97
94
|
};
|
|
95
|
+
//# sourceMappingURL=getEVMBalance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getEVMBalance.js","sourceRoot":"","sources":["../../../core/EVM/getEVMBalance.ts"],"names":[],"mappings":";;;AAEA,mDAAoD;AACpD,qCAAyD;AACzD,uDAAmD;AACnD,yCAAgD;AAEzC,MAAM,aAAa,GAAG,KAAK,EAChC,aAAqB,EACrB,MAAe,EACS,EAAE;IAC1B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,OAAO,EAAE,CAAA;KACV;IACD,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;IAC7B,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;QACvB,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,EAAE;YAC7B,OAAO,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAA;SAC/D;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,gBAAgB,GAAG,MAAM,IAAA,8BAAmB,EAAC,OAAO,CAAC,CAAA;IAE3D,IAAI,gBAAgB,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;QACzC,OAAO,sBAAsB,CAC3B,OAAO,EACP,MAAM,EACN,aAAa,EACb,gBAAgB,CACjB,CAAA;KACF;SAAM;QACL,OAAO,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,CAAA;KAC5D;AACH,CAAC,CAAA;AA1BY,QAAA,aAAa,iBA0BzB;AAED,MAAM,sBAAsB,GAAG,KAAK,EAClC,OAAgB,EAChB,MAAe,EACf,aAAqB,EACrB,gBAAwB,EACA,EAAE;IAC1B,MAAM,MAAM,GAAG,MAAM,IAAA,iCAAe,EAAC,OAAO,CAAC,CAAA;IAE7C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACrC,IAAI,IAAA,wBAAa,EAAC,KAAK,CAAC,OAAO,CAAC,EAAE;YAChC,OAAO;gBACL,OAAO,EAAE,gBAA2B;gBACpC,GAAG,EAAE,yBAAgB;gBACrB,YAAY,EAAE,eAAe;gBAC7B,IAAI,EAAE,CAAC,aAAa,CAAC;aACtB,CAAA;SACF;QACD,OAAO;YACL,OAAO,EAAE,KAAK,CAAC,OAAkB;YACjC,GAAG,EAAE,qBAAY;YACjB,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,CAAC,aAAa,CAAC;SACtB,CAAA;IACH,CAAC,CAAC,CAAA;IACF,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,cAAc,EAAE,CAAA;IACjD,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,SAAS,CAAC;QACrC,SAAS;QACT,gBAAgB,EAAE,gBAA2B;QAC7C,WAAW;KACZ,CAAC,CAAA;IAEF,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;QACnB,OAAO,EAAE,CAAA;KACV;IAED,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAS,EAAE,EAAE;QACrC,OAAO;YACL,GAAG,KAAK;YACR,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,MAAgB;YACnC,WAAW;SACZ,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,MAAM,oBAAoB,GAAG,KAAK,EAChC,OAAgB,EAChB,MAAe,EACf,aAAqB,EACG,EAAE;IAC1B,MAAM,MAAM,GAAG,MAAM,IAAA,iCAAe,EAAC,OAAO,CAAC,CAAA;IAC7C,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,cAAc,EAAE,CAAA;IACjD,MAAM,KAAK,GAAsB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACpD,IAAI,IAAA,wBAAa,EAAC,KAAK,CAAC,OAAO,CAAC,EAAE;YAChC,OAAO,MAAM,CAAC,UAAU,CAAC;gBACvB,OAAO,EAAE,aAAwB;aAClC,CAAC,CAAA;SACH;QACD,OAAO,MAAM,CAAC,YAAY,CAAC;YACzB,OAAO,EAAE,KAAK,CAAC,OAAkB;YACjC,GAAG,EAAE,qBAAY;YACjB,YAAY,EAAE,WAAW;YACzB,IAAI,EAAE,CAAC,aAAa,CAAC;SACtB,CAAoB,CAAA;IACvB,CAAC,CAAC,CAAA;IAEF,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;IAE/C,MAAM,YAAY,GAAkB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QAC9D,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;QAC7B,IAAI,MAAM,CAAC,MAAM,KAAK,UAAU,EAAE;YAChC,OAAO;gBACL,GAAG,KAAK;gBACR,WAAW;aACZ,CAAA;SACF;QACD,OAAO;YACL,GAAG,KAAK;YACR,MAAM,EAAE,MAAM,CAAC,KAAK;YACpB,WAAW;SACZ,CAAA;IACH,CAAC,CAAC,CAAA;IACF,OAAO,YAAY,CAAA;AACrB,CAAC,CAAA"}
|
|
@@ -1,20 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
3
|
exports.updateMultisigRouteProcess = void 0;
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
const config = ConfigService_1.default.getInstance().getConfig();
|
|
11
|
-
if (!config.multisig?.getMultisigTransactionDetails) {
|
|
4
|
+
const errors_js_1 = require("../../utils/errors.js");
|
|
5
|
+
const updateMultisigRouteProcess = async (internalTxHash, step, processType, fromChain, statusManager, multisig) => {
|
|
6
|
+
if (!multisig?.getMultisigTransactionDetails) {
|
|
12
7
|
throw new Error('getMultisigTransactionDetails is missing in multisig config.');
|
|
13
8
|
}
|
|
14
9
|
const updateIntermediateMultisigStatus = () => {
|
|
15
10
|
statusManager.updateProcess(step, processType, 'PENDING');
|
|
16
11
|
};
|
|
17
|
-
const multisigStatusResponse = await
|
|
12
|
+
const multisigStatusResponse = await multisig?.getMultisigTransactionDetails(internalTxHash, fromChain.id, updateIntermediateMultisigStatus);
|
|
18
13
|
if (multisigStatusResponse.status === 'DONE') {
|
|
19
14
|
statusManager.updateProcess(step, processType, 'PENDING', {
|
|
20
15
|
txHash: multisigStatusResponse.txHash,
|
|
@@ -23,10 +18,11 @@ const updateMultisigRouteProcess = async (internalTxHash, step, statusManager, p
|
|
|
23
18
|
});
|
|
24
19
|
}
|
|
25
20
|
if (multisigStatusResponse.status === 'FAILED') {
|
|
26
|
-
throw new
|
|
21
|
+
throw new errors_js_1.TransactionError(errors_js_1.LiFiErrorCode.TransactionFailed, 'Multisig transaction failed.');
|
|
27
22
|
}
|
|
28
23
|
if (multisigStatusResponse.status === 'CANCELLED') {
|
|
29
|
-
throw new
|
|
24
|
+
throw new errors_js_1.TransactionError(errors_js_1.LiFiErrorCode.SignatureRejected, 'Transaction was rejected by user.');
|
|
30
25
|
}
|
|
31
26
|
};
|
|
32
27
|
exports.updateMultisigRouteProcess = updateMultisigRouteProcess;
|
|
28
|
+
//# sourceMappingURL=multisig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multisig.js","sourceRoot":"","sources":["../../../core/EVM/multisig.ts"],"names":[],"mappings":";;;AAEA,qDAAuE;AAIhE,MAAM,0BAA0B,GAAG,KAAK,EAC7C,cAAoB,EACpB,IAAc,EACd,WAAwB,EACxB,SAAwB,EACxB,aAA4B,EAC5B,QAAyB,EACzB,EAAE;IACF,IAAI,CAAC,QAAQ,EAAE,6BAA6B,EAAE;QAC5C,MAAM,IAAI,KAAK,CACb,8DAA8D,CAC/D,CAAA;KACF;IAED,MAAM,gCAAgC,GAAG,GAAG,EAAE;QAC5C,aAAa,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,CAAC,CAAA;IAC3D,CAAC,CAAA;IAED,MAAM,sBAAsB,GAC1B,MAAM,QAAQ,EAAE,6BAA6B,CAC3C,cAAc,EACd,SAAS,CAAC,EAAE,EACZ,gCAAgC,CACjC,CAAA;IAEH,IAAI,sBAAsB,CAAC,MAAM,KAAK,MAAM,EAAE;QAC5C,aAAa,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,EAAE;YACxD,MAAM,EAAE,sBAAsB,CAAC,MAAM;YACrC,cAAc,EAAE,SAAS;YACzB,MAAM,EAAE,GAAG,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC,CAAC,MAAM,sBAAsB,CAAC,MAAM,EAAE;SACxF,CAAC,CAAA;KACH;IAED,IAAI,sBAAsB,CAAC,MAAM,KAAK,QAAQ,EAAE;QAC9C,MAAM,IAAI,4BAAgB,CACxB,yBAAa,CAAC,iBAAiB,EAC/B,8BAA8B,CAC/B,CAAA;KACF;IAED,IAAI,sBAAsB,CAAC,MAAM,KAAK,WAAW,EAAE;QACjD,MAAM,IAAI,4BAAgB,CACxB,yBAAa,CAAC,iBAAiB,EAC/B,mCAAmC,CACpC,CAAA;KACF;AACH,CAAC,CAAA;AA9CY,QAAA,0BAA0B,8BA8CtC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getPublicClient = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const config_js_1 = require("../../config.js");
|
|
6
|
+
const utils_js_1 = require("../utils.js");
|
|
7
|
+
const publicClients = {};
|
|
8
|
+
const getPublicClient = async (chainId) => {
|
|
9
|
+
if (!publicClients[chainId]) {
|
|
10
|
+
const urls = await (0, utils_js_1.getRpcUrls)(chainId);
|
|
11
|
+
const fallbackTransports = urls.map((url) => (0, viem_1.http)(url, {
|
|
12
|
+
batch: true,
|
|
13
|
+
}));
|
|
14
|
+
const _chain = await config_js_1.config.getChainById(chainId);
|
|
15
|
+
const chain = {
|
|
16
|
+
..._chain,
|
|
17
|
+
..._chain.metamask,
|
|
18
|
+
name: _chain.metamask.chainName,
|
|
19
|
+
rpcUrls: {
|
|
20
|
+
default: { http: _chain.metamask.rpcUrls },
|
|
21
|
+
public: { http: _chain.metamask.rpcUrls },
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
publicClients[chainId] = (0, viem_1.createPublicClient)({
|
|
25
|
+
chain: chain,
|
|
26
|
+
transport: (0, viem_1.fallback)(fallbackTransports),
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
if (!publicClients[chainId]) {
|
|
30
|
+
throw new Error(`Unable to configure provider for chain ${chainId}`);
|
|
31
|
+
}
|
|
32
|
+
return publicClients[chainId];
|
|
33
|
+
};
|
|
34
|
+
exports.getPublicClient = getPublicClient;
|
|
35
|
+
//# sourceMappingURL=publicClient.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"publicClient.js","sourceRoot":"","sources":["../../../core/EVM/publicClient.ts"],"names":[],"mappings":";;;AACA,+BAAyD;AAEzD,+CAAwC;AACxC,0CAAwC;AAGxC,MAAM,aAAa,GAAiC,EAAE,CAAA;AAO/C,MAAM,eAAe,GAAG,KAAK,EAClC,OAAe,EACQ,EAAE;IACzB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE;QAC3B,MAAM,IAAI,GAAG,MAAM,IAAA,qBAAU,EAAC,OAAO,CAAC,CAAA;QACtC,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAC1C,IAAA,WAAI,EAAC,GAAG,EAAE;YACR,KAAK,EAAE,IAAI;SACZ,CAAC,CACH,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,kBAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;QACjD,MAAM,KAAK,GAAU;YACnB,GAAG,MAAM;YACT,GAAG,MAAM,CAAC,QAAQ;YAClB,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,SAAS;YAC/B,OAAO,EAAE;gBACP,OAAO,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE;gBAC1C,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE;aAC1C;SACF,CAAA;QACD,aAAa,CAAC,OAAO,CAAC,GAAG,IAAA,yBAAkB,EAAC;YAC1C,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,IAAA,eAAQ,EAAC,kBAAkB,CAAC;SACxC,CAAC,CAAA;KACH;IAED,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,OAAO,EAAE,CAAC,CAAA;KACrE;IAED,OAAO,aAAa,CAAC,OAAO,CAAC,CAAA;AAC/B,CAAC,CAAA;AA/BY,QAAA,eAAe,mBA+B3B"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.revokeTokenApproval = exports.setTokenAllowance = exports.setAllowance = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const utils_js_1 = require("../../utils/utils.js");
|
|
6
|
+
const abi_js_1 = require("./abi.js");
|
|
7
|
+
const getAllowance_js_1 = require("./getAllowance.js");
|
|
8
|
+
const utils_js_2 = require("./utils.js");
|
|
9
|
+
const setAllowance = async (walletClient, tokenAddress, contractAddress, amount, settings, returnPopulatedTransaction) => {
|
|
10
|
+
const data = (0, viem_1.encodeFunctionData)({
|
|
11
|
+
abi: abi_js_1.approveAbi,
|
|
12
|
+
functionName: 'approve',
|
|
13
|
+
args: [contractAddress, amount],
|
|
14
|
+
});
|
|
15
|
+
if (returnPopulatedTransaction) {
|
|
16
|
+
return data;
|
|
17
|
+
}
|
|
18
|
+
const client = walletClient.extend(viem_1.publicActions);
|
|
19
|
+
let transactionRequest = {
|
|
20
|
+
to: tokenAddress,
|
|
21
|
+
data,
|
|
22
|
+
maxPriorityFeePerGas: walletClient.account?.type === 'local'
|
|
23
|
+
? await (0, utils_js_2.getMaxPriorityFeePerGas)(client)
|
|
24
|
+
: undefined,
|
|
25
|
+
};
|
|
26
|
+
if (settings?.updateTransactionRequestHook) {
|
|
27
|
+
const customizedTransactionRequest = await settings.updateTransactionRequestHook({
|
|
28
|
+
requestType: 'approve',
|
|
29
|
+
...transactionRequest,
|
|
30
|
+
});
|
|
31
|
+
transactionRequest = {
|
|
32
|
+
...transactionRequest,
|
|
33
|
+
...customizedTransactionRequest,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
return client.sendTransaction({
|
|
37
|
+
to: transactionRequest.to,
|
|
38
|
+
account: walletClient.account,
|
|
39
|
+
data: transactionRequest.data,
|
|
40
|
+
gas: transactionRequest.gas,
|
|
41
|
+
gasPrice: transactionRequest.gasPrice,
|
|
42
|
+
maxFeePerGas: transactionRequest.maxFeePerGas,
|
|
43
|
+
maxPriorityFeePerGas: transactionRequest.maxPriorityFeePerGas,
|
|
44
|
+
chain: null,
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
exports.setAllowance = setAllowance;
|
|
48
|
+
const setTokenAllowance = async ({ walletClient, token, spenderAddress, amount, infiniteApproval = false, }) => {
|
|
49
|
+
if ((0, utils_js_1.isNativeTokenAddress)(token.address)) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const approvedAmount = await (0, getAllowance_js_1.getAllowance)(token.chainId, token.address, walletClient.account.address, spenderAddress);
|
|
53
|
+
if (amount > approvedAmount) {
|
|
54
|
+
const approvalAmount = infiniteApproval ? viem_1.maxUint256 : amount;
|
|
55
|
+
const approveTx = await (0, exports.setAllowance)(walletClient, token.address, spenderAddress, approvalAmount);
|
|
56
|
+
return approveTx;
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
exports.setTokenAllowance = setTokenAllowance;
|
|
60
|
+
const revokeTokenApproval = async ({ walletClient, token, spenderAddress, }) => {
|
|
61
|
+
if ((0, utils_js_1.isNativeTokenAddress)(token.address)) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const approvedAmount = await (0, getAllowance_js_1.getAllowance)(token.chainId, token.address, walletClient.account.address, spenderAddress);
|
|
65
|
+
if (approvedAmount > 0) {
|
|
66
|
+
const approveTx = await (0, exports.setAllowance)(walletClient, token.address, spenderAddress, 0n);
|
|
67
|
+
return approveTx;
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
exports.revokeTokenApproval = revokeTokenApproval;
|
|
71
|
+
//# sourceMappingURL=setAllowance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setAllowance.js","sourceRoot":"","sources":["../../../core/EVM/setAllowance.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.switchChain = void 0;
|
|
4
|
+
const errors_js_1 = require("../../utils/errors.js");
|
|
5
|
+
const switchChain = async (walletClient, statusManager, step, allowUserInteraction, switchChainHook) => {
|
|
6
|
+
if ((await walletClient.getChainId()) === step.action.fromChainId) {
|
|
7
|
+
return walletClient;
|
|
8
|
+
}
|
|
9
|
+
step.execution = statusManager.initExecutionObject(step);
|
|
10
|
+
statusManager.updateExecution(step, 'ACTION_REQUIRED');
|
|
11
|
+
let switchProcess = statusManager.findOrCreateProcess(step, 'SWITCH_CHAIN', 'ACTION_REQUIRED');
|
|
12
|
+
if (!allowUserInteraction) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
try {
|
|
16
|
+
const updatedWalletClient = await switchChainHook?.(step.action.fromChainId);
|
|
17
|
+
const updatedChainId = await updatedWalletClient?.getChainId();
|
|
18
|
+
if (updatedChainId !== step.action.fromChainId) {
|
|
19
|
+
throw new errors_js_1.ProviderError(errors_js_1.LiFiErrorCode.ChainSwitchError, 'Chain switch required.');
|
|
20
|
+
}
|
|
21
|
+
switchProcess = statusManager.updateProcess(step, switchProcess.type, 'DONE');
|
|
22
|
+
statusManager.updateExecution(step, 'PENDING');
|
|
23
|
+
return updatedWalletClient;
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
statusManager.updateProcess(step, switchProcess.type, 'FAILED', {
|
|
27
|
+
error: {
|
|
28
|
+
message: error.message,
|
|
29
|
+
code: errors_js_1.LiFiErrorCode.ChainSwitchError,
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
statusManager.updateExecution(step, 'FAILED');
|
|
33
|
+
throw error;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.switchChain = switchChain;
|
|
37
|
+
//# sourceMappingURL=switchChain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchChain.js","sourceRoot":"","sources":["../../../core/EVM/switchChain.ts"],"names":[],"mappings":";;;AACA,qDAAoE;AAqB7D,MAAM,WAAW,GAAG,KAAK,EAC9B,YAA0B,EAC1B,aAA4B,EAC5B,IAAsB,EACtB,oBAA6B,EAC7B,eAAiC,EACE,EAAE;IAErC,IAAI,CAAC,MAAM,YAAY,CAAC,UAAU,EAAE,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;QACjE,OAAO,YAAY,CAAA;KACpB;IAGD,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAA;IACxD,aAAa,CAAC,eAAe,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAA;IAEtD,IAAI,aAAa,GAAG,aAAa,CAAC,mBAAmB,CACnD,IAAI,EACJ,cAAc,EACd,iBAAiB,CAClB,CAAA;IAED,IAAI,CAAC,oBAAoB,EAAE;QACzB,OAAM;KACP;IAED,IAAI;QACF,MAAM,mBAAmB,GAAG,MAAM,eAAe,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;QAC5E,MAAM,cAAc,GAAG,MAAM,mBAAmB,EAAE,UAAU,EAAE,CAAA;QAC9D,IAAI,cAAc,KAAK,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC9C,MAAM,IAAI,yBAAa,CACrB,yBAAa,CAAC,gBAAgB,EAC9B,wBAAwB,CACzB,CAAA;SACF;QAED,aAAa,GAAG,aAAa,CAAC,aAAa,CACzC,IAAI,EACJ,aAAa,CAAC,IAAI,EAClB,MAAM,CACP,CAAA;QACD,aAAa,CAAC,eAAe,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;QAC9C,OAAO,mBAAmB,CAAA;KAC3B;IAAC,OAAO,KAAU,EAAE;QACnB,aAAa,CAAC,aAAa,CAAC,IAAI,EAAE,aAAa,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC9D,KAAK,EAAE;gBACL,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,IAAI,EAAE,yBAAa,CAAC,gBAAgB;aACrC;SACF,CAAC,CAAA;QACF,aAAa,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;QAC7C,MAAM,KAAK,CAAA;KACZ;AACH,CAAC,CAAA;AArDY,QAAA,WAAW,eAqDvB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isEVM = void 0;
|
|
4
|
+
const types_1 = require("@lifi/types");
|
|
5
|
+
function isEVM(provider) {
|
|
6
|
+
return provider.type === types_1.ChainType.EVM;
|
|
7
|
+
}
|
|
8
|
+
exports.isEVM = isEVM;
|
|
9
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../core/EVM/types.ts"],"names":[],"mappings":";;;AAAA,uCAAiE;AAkBjE,SAAgB,KAAK,CAAC,QAAqB;IACzC,OAAO,QAAQ,CAAC,IAAI,KAAK,iBAAS,CAAC,GAAG,CAAA;AACxC,CAAC;AAFD,sBAEC"}
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getMaxPriorityFeePerGas = void 0;
|
|
4
|
-
const
|
|
3
|
+
exports.getMulticallAddress = exports.getMaxPriorityFeePerGas = void 0;
|
|
4
|
+
const types_1 = require("@lifi/types");
|
|
5
|
+
const config_js_1 = require("../../config.js");
|
|
6
|
+
const median_js_1 = require("../../utils/median.js");
|
|
7
|
+
const provider_js_1 = require("../provider.js");
|
|
5
8
|
const getMaxPriorityFeePerGas = async (client) => {
|
|
6
9
|
const block = await client.getBlock({
|
|
7
10
|
includeTransactions: true,
|
|
@@ -13,10 +16,17 @@ const getMaxPriorityFeePerGas = async (client) => {
|
|
|
13
16
|
return;
|
|
14
17
|
}
|
|
15
18
|
const maxPriorityFeePerGasSum = maxPriorityFeePerGasList.reduce((acc, value) => (acc += value), 0n);
|
|
16
|
-
const maxPriorityFeePerGasMedian = (0,
|
|
19
|
+
const maxPriorityFeePerGasMedian = (0, median_js_1.median)(maxPriorityFeePerGasList) ?? 0n;
|
|
17
20
|
const maxPriorityFeePerGasAvg = maxPriorityFeePerGasSum / BigInt(maxPriorityFeePerGasList.length);
|
|
18
21
|
return maxPriorityFeePerGasMedian > maxPriorityFeePerGasAvg
|
|
19
22
|
? maxPriorityFeePerGasAvg
|
|
20
23
|
: maxPriorityFeePerGasMedian;
|
|
21
24
|
};
|
|
22
25
|
exports.getMaxPriorityFeePerGas = getMaxPriorityFeePerGas;
|
|
26
|
+
const getMulticallAddress = async (chainId) => {
|
|
27
|
+
const provider = (0, provider_js_1.getProvider)(types_1.ChainType.EVM);
|
|
28
|
+
return (provider.multicall?.[chainId] ??
|
|
29
|
+
config_js_1.config.chains.find((chain) => chain.id === chainId)?.multicallAddress);
|
|
30
|
+
};
|
|
31
|
+
exports.getMulticallAddress = getMulticallAddress;
|
|
32
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../core/EVM/utils.ts"],"names":[],"mappings":";;;AAAA,uCAAqD;AAErD,+CAAwC;AACxC,qDAA8C;AAC9C,gDAA4C;AAGrC,MAAM,uBAAuB,GAAG,KAAK,EAC1C,MAAoB,EACS,EAAE;IAC/B,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC;QAClC,mBAAmB,EAAE,IAAI;KAC1B,CAAC,CAAA;IAEF,MAAM,wBAAwB,GAAI,KAAK,CAAC,YAA8B;SACnE,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,oBAAoB,CAAC;SACvC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,oBAAoB,CAAa,CAAA;IAEnD,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE;QACpC,OAAM;KACP;IAED,MAAM,uBAAuB,GAAG,wBAAwB,CAAC,MAAM,CAC7D,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,EAC9B,EAAE,CACH,CAAA;IAED,MAAM,0BAA0B,GAAG,IAAA,kBAAM,EAAC,wBAAwB,CAAC,IAAI,EAAE,CAAA;IAEzE,MAAM,uBAAuB,GAC3B,uBAAuB,GAAG,MAAM,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAA;IAEnE,OAAO,0BAA0B,GAAG,uBAAuB;QACzD,CAAC,CAAC,uBAAuB;QACzB,CAAC,CAAC,0BAA0B,CAAA;AAChC,CAAC,CAAA;AA5BY,QAAA,uBAAuB,2BA4BnC;AAGM,MAAM,mBAAmB,GAAG,KAAK,EACtC,OAAgB,EACa,EAAE;IAC/B,MAAM,QAAQ,GAAG,IAAA,yBAAW,EAAc,iBAAS,CAAC,GAAG,CAAC,CAAA;IACxD,OAAO,CACL,QAAQ,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC;QAC7B,kBAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,gBAAgB,CACtE,CAAA;AACH,CAAC,CAAA;AARY,QAAA,mBAAmB,uBAQ/B"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Solana = void 0;
|
|
4
|
+
const types_1 = require("@lifi/types");
|
|
5
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
6
|
+
const SolanaStepExecutor_js_1 = require("./SolanaStepExecutor.js");
|
|
7
|
+
const getSolanaBalance_js_1 = require("./getSolanaBalance.js");
|
|
8
|
+
function Solana(options) {
|
|
9
|
+
const _options = options ?? {};
|
|
10
|
+
return {
|
|
11
|
+
get type() {
|
|
12
|
+
return types_1.ChainType.SVM;
|
|
13
|
+
},
|
|
14
|
+
isAddress(address) {
|
|
15
|
+
try {
|
|
16
|
+
new web3_js_1.PublicKey(address);
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
getBalance: getSolanaBalance_js_1.getSolanaBalance,
|
|
24
|
+
async getStepExecutor(options) {
|
|
25
|
+
if (!_options.getWalletAdapter) {
|
|
26
|
+
throw new Error(`getWalletAdapter is not provided.`);
|
|
27
|
+
}
|
|
28
|
+
const walletAdapter = await _options.getWalletAdapter();
|
|
29
|
+
const executor = new SolanaStepExecutor_js_1.SolanaStepExecutor({
|
|
30
|
+
walletAdapter,
|
|
31
|
+
routeId: options.routeId,
|
|
32
|
+
executionOptions: {
|
|
33
|
+
...options.executionOptions,
|
|
34
|
+
},
|
|
35
|
+
});
|
|
36
|
+
return executor;
|
|
37
|
+
},
|
|
38
|
+
setOptions(options) {
|
|
39
|
+
Object.assign(_options, options);
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
exports.Solana = Solana;
|
|
44
|
+
//# sourceMappingURL=Solana.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Solana.js","sourceRoot":"","sources":["../../../core/Solana/Solana.ts"],"names":[],"mappings":";;;AAAA,uCAAuC;AACvC,6CAA2C;AAE3C,mEAA4D;AAC5D,+DAAwD;AAGxD,SAAgB,MAAM,CAAC,OAA+B;IACpD,MAAM,QAAQ,GAA0B,OAAO,IAAI,EAAE,CAAA;IACrD,OAAO;QACL,IAAI,IAAI;YACN,OAAO,iBAAS,CAAC,GAAG,CAAA;QACtB,CAAC;QACD,SAAS,CAAC,OAAe;YACvB,IAAI;gBACF,IAAI,mBAAS,CAAC,OAAO,CAAC,CAAA;gBACtB,OAAO,IAAI,CAAA;aACZ;YAAC,OAAO,KAAK,EAAE;gBACd,OAAO,KAAK,CAAA;aACb;QACH,CAAC;QACD,UAAU,EAAE,sCAAgB;QAC5B,KAAK,CAAC,eAAe,CACnB,OAA4B;YAE5B,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE;gBAC9B,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;aACrD;YAED,MAAM,aAAa,GAAG,MAAM,QAAQ,CAAC,gBAAgB,EAAE,CAAA;YAEvD,MAAM,QAAQ,GAAG,IAAI,0CAAkB,CAAC;gBACtC,aAAa;gBACb,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,gBAAgB,EAAE;oBAChB,GAAG,OAAO,CAAC,gBAAgB;iBAC5B;aACF,CAAC,CAAA;YAEF,OAAO,QAAQ,CAAA;QACjB,CAAC;QACD,UAAU,CAAC,OAA8B;YACvC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;QAClC,CAAC;KACF,CAAA;AACH,CAAC;AAtCD,wBAsCC"}
|