@lifi/sdk 3.0.0-alpha.9 → 3.0.0-beta.0
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 +40 -98
- package/src/_cjs/config.js +90 -0
- package/src/_cjs/config.js.map +1 -0
- package/{dist/cjs → src/_cjs}/constants.js +3 -5
- package/src/_cjs/constants.js.map +1 -0
- package/src/_cjs/core/BaseStepExecutor.js +55 -0
- package/src/_cjs/core/BaseStepExecutor.js.map +1 -0
- package/src/_cjs/core/EVM/EVM.js +43 -0
- package/src/_cjs/core/EVM/EVM.js.map +1 -0
- package/src/_cjs/core/EVM/EVMStepExecutor.js +304 -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 +19 -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/src/_cjs/core/EVM/getENSAddress.js +20 -0
- package/src/_cjs/core/EVM/getENSAddress.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 -8
- package/src/_cjs/core/EVM/multisig.js.map +1 -0
- package/src/_cjs/core/EVM/publicClient.js +43 -0
- package/src/_cjs/core/EVM/publicClient.js.map +1 -0
- package/{dist/cjs/allowance → src/_cjs/core/EVM}/setAllowance.js +11 -12
- package/src/_cjs/core/EVM/setAllowance.js.map +1 -0
- package/src/_cjs/core/EVM/switchChain.js +38 -0
- package/src/_cjs/core/EVM/switchChain.js.map +1 -0
- package/src/_cjs/core/EVM/types.js +9 -0
- package/src/_cjs/core/EVM/types.js.map +1 -0
- package/{dist/cjs/utils/getMaxPriorityFeePerGas.js → src/_cjs/core/EVM/utils.js} +13 -3
- package/src/_cjs/core/EVM/utils.js.map +1 -0
- package/src/_cjs/core/Solana/KeypairWalletAdapter.js +88 -0
- package/src/_cjs/core/Solana/KeypairWalletAdapter.js.map +1 -0
- package/src/_cjs/core/Solana/Solana.js +38 -0
- package/src/_cjs/core/Solana/Solana.js.map +1 -0
- package/src/_cjs/core/Solana/SolanaStepExecutor.js +200 -0
- package/src/_cjs/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/src/_cjs/core/Solana/connection.js +19 -0
- package/src/_cjs/core/Solana/connection.js.map +1 -0
- package/src/_cjs/core/Solana/getSNSAddress.js +26 -0
- package/src/_cjs/core/Solana/getSNSAddress.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/isAddress.js +15 -0
- package/src/_cjs/core/Solana/isAddress.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 +6 -6
- package/src/_cjs/core/checkBalance.js.map +1 -0
- package/src/_cjs/core/execution.js +138 -0
- package/src/_cjs/core/execution.js.map +1 -0
- package/src/_cjs/core/executionState.js +29 -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/rpc.js +18 -0
- package/src/_cjs/core/rpc.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 +2 -11
- package/src/_cjs/core/utils.js.map +1 -0
- package/{dist/cjs/execution → src/_cjs/core}/waitForReceivingTransaction.js +13 -14
- package/src/_cjs/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_cjs/createConfig.js +34 -0
- package/src/_cjs/createConfig.js.map +1 -0
- package/src/_cjs/helpers.js +50 -0
- package/src/_cjs/helpers.js.map +1 -0
- package/src/_cjs/index.js +30 -0
- package/src/_cjs/index.js.map +1 -0
- package/src/_cjs/package.json +1 -0
- package/{dist/cjs → src/_cjs}/request.js +18 -15
- package/src/_cjs/request.js.map +1 -0
- package/src/_cjs/services/api.js +309 -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/src/_cjs/services/getNameServiceAddress.js +29 -0
- package/src/_cjs/services/getNameServiceAddress.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 → src/_cjs}/types/internal.js +1 -0
- package/src/_cjs/types/internal.js.map +1 -0
- package/src/_cjs/utils/base64ToUint8Array.js +14 -0
- package/src/_cjs/utils/base64ToUint8Array.js.map +1 -0
- package/{dist/cjs → src/_cjs}/utils/errors.js +26 -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 +69 -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 +87 -0
- package/src/_esm/config.js.map +1 -0
- package/{dist → src/_esm}/constants.js +2 -4
- package/src/_esm/constants.js.map +1 -0
- package/src/_esm/core/BaseStepExecutor.js +52 -0
- package/src/_esm/core/BaseStepExecutor.js.map +1 -0
- package/src/_esm/core/EVM/EVM.js +39 -0
- package/src/_esm/core/EVM/EVM.js.map +1 -0
- package/src/_esm/core/EVM/EVMStepExecutor.js +329 -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 +14 -5
- 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/src/_esm/core/EVM/getENSAddress.js +17 -0
- package/src/_esm/core/EVM/getENSAddress.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 +46 -0
- package/src/_esm/core/EVM/publicClient.js.map +1 -0
- package/{dist/allowance → src/_esm/core/EVM}/setAllowance.js +23 -4
- package/src/_esm/core/EVM/setAllowance.js.map +1 -0
- package/{dist/execution → src/_esm/core/EVM}/switchChain.js +6 -4
- package/src/_esm/core/EVM/switchChain.js.map +1 -0
- package/src/_esm/core/EVM/types.js +6 -0
- package/src/_esm/core/EVM/types.js.map +1 -0
- package/{dist/utils/getMaxPriorityFeePerGas.js → src/_esm/core/EVM/utils.js} +12 -1
- package/src/_esm/core/EVM/utils.js.map +1 -0
- package/src/_esm/core/Solana/KeypairWalletAdapter.js +92 -0
- package/src/_esm/core/Solana/KeypairWalletAdapter.js.map +1 -0
- package/src/_esm/core/Solana/Solana.js +34 -0
- package/src/_esm/core/Solana/Solana.js.map +1 -0
- package/src/_esm/core/Solana/SolanaStepExecutor.js +214 -0
- package/src/_esm/core/Solana/SolanaStepExecutor.js.map +1 -0
- package/src/_esm/core/Solana/connection.js +20 -0
- package/src/_esm/core/Solana/connection.js.map +1 -0
- package/src/_esm/core/Solana/getSNSAddress.js +26 -0
- package/src/_esm/core/Solana/getSNSAddress.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/isAddress.js +11 -0
- package/src/_esm/core/Solana/isAddress.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 +4 -3
- package/src/_esm/core/checkBalance.js.map +1 -0
- package/src/_esm/core/execution.js +176 -0
- package/src/_esm/core/execution.js.map +1 -0
- package/src/_esm/core/executionState.js +26 -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/src/_esm/core/rpc.js +14 -0
- package/src/_esm/core/rpc.js.map +1 -0
- package/{dist/execution → src/_esm/core}/stepComparison.js +6 -4
- 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 +4 -3
- package/src/_esm/core/utils.js.map +1 -0
- package/{dist/execution → src/_esm/core}/waitForReceivingTransaction.js +11 -9
- package/src/_esm/core/waitForReceivingTransaction.js.map +1 -0
- package/src/_esm/createConfig.js +30 -0
- package/src/_esm/createConfig.js.map +1 -0
- package/{dist → src/_esm}/helpers.js +6 -30
- package/src/_esm/helpers.js.map +1 -0
- package/src/_esm/index.js +17 -0
- package/src/_esm/index.js.map +1 -0
- package/src/_esm/package.json +1 -0
- package/{dist → src/_esm}/request.js +14 -10
- package/src/_esm/request.js.map +1 -0
- package/src/_esm/services/api.js +378 -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/src/_esm/services/getNameServiceAddress.js +25 -0
- package/src/_esm/services/getNameServiceAddress.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/src/_esm/utils/base64ToUint8Array.js +10 -0
- package/src/_esm/utils/base64ToUint8Array.js.map +1 -0
- package/{dist → src/_esm}/utils/errors.js +26 -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 +6 -53
- package/src/_esm/utils/parseError.js.map +1 -0
- package/{dist → src/_esm}/utils/utils.js +2 -1
- package/src/_esm/utils/utils.js.map +1 -0
- package/src/_esm/version.js +3 -0
- package/src/_esm/version.js.map +1 -0
- package/src/_types/config.d.ts +15 -0
- package/src/_types/config.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/constants.d.ts +2 -4
- package/src/_types/constants.d.ts.map +1 -0
- package/src/_types/core/BaseStepExecutor.d.ts +13 -0
- package/src/_types/core/BaseStepExecutor.d.ts.map +1 -0
- package/src/_types/core/EVM/EVM.d.ts +3 -0
- package/src/_types/core/EVM/EVM.d.ts.map +1 -0
- package/src/_types/core/EVM/EVMStepExecutor.d.ts +17 -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/getENSAddress.d.ts +2 -0
- package/src/_types/core/EVM/getENSAddress.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/execution → src/_types/core/EVM}/switchChain.d.ts +4 -4
- package/src/_types/core/EVM/switchChain.d.ts.map +1 -0
- package/src/_types/core/EVM/types.d.ts +55 -0
- package/src/_types/core/EVM/types.d.ts.map +1 -0
- package/src/_types/core/EVM/utils.d.ts +10 -0
- package/src/_types/core/EVM/utils.d.ts.map +1 -0
- package/src/_types/core/Solana/KeypairWalletAdapter.d.ts +28 -0
- package/src/_types/core/Solana/KeypairWalletAdapter.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 +13 -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/getSNSAddress.d.ts +2 -0
- package/src/_types/core/Solana/getSNSAddress.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/isAddress.d.ts +2 -0
- package/src/_types/core/Solana/isAddress.d.ts.map +1 -0
- package/src/_types/core/Solana/types.d.ts +11 -0
- package/src/_types/core/Solana/types.d.ts.map +1 -0
- package/{dist/cjs/execution → src/_types/core}/StatusManager.d.ts +14 -28
- package/src/_types/core/StatusManager.d.ts.map +1 -0
- package/{dist/cjs/execution → src/_types/core}/checkBalance.d.ts +1 -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 +17 -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/src/_types/core/rpc.d.ts +4 -0
- package/src/_types/core/rpc.d.ts.map +1 -0
- package/{dist/execution → src/_types/core}/stepComparison.d.ts +5 -3
- package/src/_types/core/stepComparison.d.ts.map +1 -0
- package/src/_types/core/types.d.ts +81 -0
- package/src/_types/core/types.d.ts.map +1 -0
- package/{dist/execution → src/_types/core}/utils.d.ts +2 -1
- package/src/_types/core/utils.d.ts.map +1 -0
- package/{dist/cjs/execution → src/_types/core}/waitForReceivingTransaction.d.ts +2 -1
- package/src/_types/core/waitForReceivingTransaction.d.ts.map +1 -0
- package/src/_types/createConfig.d.ts +4 -0
- package/src/_types/createConfig.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/helpers.d.ts +3 -9
- package/src/_types/helpers.d.ts.map +1 -0
- package/src/_types/index.d.ts +18 -0
- package/src/_types/index.d.ts.map +1 -0
- package/{dist → src/_types}/request.d.ts +1 -0
- package/src/_types/request.d.ts.map +1 -0
- package/src/_types/services/api.d.ts +89 -0
- package/src/_types/services/api.d.ts.map +1 -0
- package/src/_types/services/balance.d.ts +30 -0
- package/src/_types/services/balance.d.ts.map +1 -0
- package/src/_types/services/getNameServiceAddress.d.ts +3 -0
- package/src/_types/services/getNameServiceAddress.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/typeguards.d.ts +1 -0
- 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/{dist → src/_types}/types/internal.d.ts +14 -15
- package/src/_types/types/internal.d.ts.map +1 -0
- package/src/_types/utils/base64ToUint8Array.d.ts +2 -0
- package/src/_types/utils/base64ToUint8Array.d.ts.map +1 -0
- package/{dist/cjs → src/_types}/utils/errors.d.ts +3 -1
- 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 +2 -4
- 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 +91 -0
- package/src/constants.ts +4 -0
- package/src/core/BaseStepExecutor.ts +40 -0
- package/src/core/EVM/EVM.ts +47 -0
- package/src/core/EVM/EVMStepExecutor.ts +500 -0
- package/src/core/EVM/abi.ts +47 -0
- package/src/core/EVM/checkAllowance.ts +168 -0
- package/src/core/EVM/getAllowance.ts +144 -0
- package/src/core/EVM/getENSAddress.ts +18 -0
- package/src/core/EVM/getEVMBalance.ts +118 -0
- package/src/core/EVM/multisig.ts +53 -0
- package/src/core/EVM/publicClient.ts +54 -0
- package/src/core/EVM/setAllowance.ts +143 -0
- package/src/core/EVM/switchChain.ts +77 -0
- package/src/core/EVM/types.ts +73 -0
- package/src/core/EVM/utils.ts +48 -0
- package/src/core/Solana/KeypairWalletAdapter.ts +100 -0
- package/src/core/Solana/Solana.ts +41 -0
- package/src/core/Solana/SolanaStepExecutor.ts +331 -0
- package/src/core/Solana/connection.ts +20 -0
- package/src/core/Solana/getSNSAddress.ts +33 -0
- package/src/core/Solana/getSolanaBalance.ts +72 -0
- package/src/core/Solana/isAddress.ts +10 -0
- package/src/core/Solana/types.ts +17 -0
- package/src/core/StatusManager.ts +231 -0
- package/src/core/checkBalance.ts +48 -0
- package/src/core/execution.ts +214 -0
- package/src/core/executionState.ts +44 -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/rpc.ts +15 -0
- package/src/core/stepComparison.ts +51 -0
- package/src/core/types.ts +118 -0
- package/src/core/utils.ts +105 -0
- package/src/core/waitForReceivingTransaction.ts +74 -0
- package/src/createConfig.ts +35 -0
- package/src/helpers.ts +69 -0
- package/src/index.ts +24 -0
- package/src/request.ts +79 -0
- package/src/services/api.ts +509 -0
- package/src/services/balance.ts +93 -0
- package/src/services/getNameServiceAddress.ts +30 -0
- package/src/typeguards.ts +89 -0
- package/src/types/index.ts +1 -0
- package/src/types/internal.ts +62 -0
- package/src/utils/base64ToUint8Array.ts +9 -0
- package/src/utils/errors.ts +232 -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 +210 -0
- package/src/utils/utils.ts +48 -0
- package/src/version.ts +2 -0
- package/dist/LiFi.d.ts +0 -178
- package/dist/LiFi.js +0 -253
- 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 -6
- 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 -178
- package/dist/cjs/LiFi.js +0 -283
- 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 -6
- 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 -72
- package/dist/cjs/execution/BaseStepExecutor.d.ts +0 -12
- package/dist/cjs/execution/BaseStepExecutor.js +0 -27
- package/dist/cjs/execution/EVMStepExecutor.d.ts +0 -13
- package/dist/cjs/execution/EVMStepExecutor.js +0 -292
- package/dist/cjs/execution/RouteExecutionManager.d.ts +0 -60
- package/dist/cjs/execution/RouteExecutionManager.js +0 -204
- package/dist/cjs/execution/StatusManager.js +0 -171
- package/dist/cjs/execution/StepExecutionManager.d.ts +0 -7
- package/dist/cjs/execution/StepExecutionManager.js +0 -272
- package/dist/cjs/execution/checkAllowance.d.ts +0 -5
- package/dist/cjs/execution/index.d.ts +0 -2
- package/dist/cjs/execution/index.js +0 -18
- package/dist/cjs/execution/multisig.d.ts +0 -4
- package/dist/cjs/execution/prepareRestart.d.ts +0 -2
- package/dist/cjs/execution/prepareRestart.js +0 -65
- package/dist/cjs/execution/stepComparison.d.ts +0 -15
- package/dist/cjs/execution/stepComparison.js +0 -37
- package/dist/cjs/execution/switchChain.d.ts +0 -22
- package/dist/cjs/execution/switchChain.js +0 -55
- package/dist/cjs/execution/types.d.ts +0 -82
- package/dist/cjs/execution/types.js +0 -2
- package/dist/cjs/execution/utils.d.ts +0 -12
- package/dist/cjs/helpers.js +0 -84
- package/dist/cjs/index.d.ts +0 -9
- package/dist/cjs/index.js +0 -30
- package/dist/cjs/providers/EVM.d.ts +0 -10
- package/dist/cjs/providers/EVM.js +0 -34
- package/dist/cjs/providers/Solana.d.ts +0 -9
- package/dist/cjs/providers/Solana.js +0 -38
- package/dist/cjs/providers/index.d.ts +0 -1
- package/dist/cjs/providers/index.js +0 -17
- package/dist/cjs/providers/types.d.ts +0 -12
- package/dist/cjs/providers/types.js +0 -8
- package/dist/cjs/request.d.ts +0 -9
- package/dist/cjs/services/ApiService.d.ts +0 -16
- package/dist/cjs/services/ApiService.js +0 -323
- package/dist/cjs/services/ChainsService.d.ts +0 -11
- package/dist/cjs/services/ChainsService.js +0 -40
- package/dist/cjs/services/ConfigService.d.ts +0 -26
- package/dist/cjs/services/ConfigService.js +0 -104
- package/dist/cjs/types/index.d.ts +0 -2
- package/dist/cjs/types/index.js +0 -18
- package/dist/cjs/types/internal.d.ts +0 -60
- 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 -154
- 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/BaseStepExecutor.d.ts +0 -12
- package/dist/execution/BaseStepExecutor.js +0 -23
- package/dist/execution/EVMStepExecutor.d.ts +0 -13
- package/dist/execution/EVMStepExecutor.js +0 -285
- package/dist/execution/RouteExecutionManager.d.ts +0 -60
- package/dist/execution/RouteExecutionManager.js +0 -200
- package/dist/execution/StatusManager.d.ts +0 -68
- package/dist/execution/StatusManager.js +0 -167
- package/dist/execution/StepExecutionManager.d.ts +0 -7
- package/dist/execution/StepExecutionManager.js +0 -265
- package/dist/execution/checkAllowance.d.ts +0 -5
- package/dist/execution/checkBalance.d.ts +0 -2
- package/dist/execution/index.d.ts +0 -2
- package/dist/execution/index.js +0 -2
- package/dist/execution/multisig.d.ts +0 -4
- package/dist/execution/prepareRestart.d.ts +0 -2
- package/dist/execution/prepareRestart.js +0 -61
- package/dist/execution/types.d.ts +0 -82
- package/dist/execution/types.js +0 -1
- package/dist/execution/waitForReceivingTransaction.d.ts +0 -3
- package/dist/helpers.d.ts +0 -18
- package/dist/index.d.ts +0 -9
- package/dist/index.js +0 -9
- package/dist/providers/EVM.d.ts +0 -10
- package/dist/providers/EVM.js +0 -29
- package/dist/providers/Solana.d.ts +0 -9
- package/dist/providers/Solana.js +0 -33
- package/dist/providers/index.d.ts +0 -1
- package/dist/providers/index.js +0 -1
- package/dist/providers/types.d.ts +0 -12
- package/dist/providers/types.js +0 -5
- package/dist/services/ApiService.d.ts +0 -16
- 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 -26
- package/dist/services/ConfigService.js +0 -100
- package/dist/typeguards.d.ts +0 -4
- package/dist/types/abi.d.ts +0 -5
- package/dist/types/index.d.ts +0 -2
- package/dist/types/index.js +0 -2
- package/dist/types/internal.js +0 -1
- package/dist/utils/errors.d.ts +0 -107
- 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
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { ChainId } from '@lifi/types';
|
|
2
|
+
import { createPublicClient, fallback, http } from 'viem';
|
|
3
|
+
import { mainnet } from 'viem/chains';
|
|
4
|
+
import { config } from '../../config.js';
|
|
5
|
+
import { getRpcUrls } from '../rpc.js';
|
|
6
|
+
// cached providers
|
|
7
|
+
const publicClients = {};
|
|
8
|
+
/**
|
|
9
|
+
* Get an instance of a provider for a specific chain
|
|
10
|
+
* @param chainId - Id of the chain the provider is for
|
|
11
|
+
* @returns The public client for the given chain
|
|
12
|
+
*/
|
|
13
|
+
export const getPublicClient = async (chainId) => {
|
|
14
|
+
if (!publicClients[chainId]) {
|
|
15
|
+
const urls = await getRpcUrls(chainId);
|
|
16
|
+
const fallbackTransports = urls.map((url) => http(url, {
|
|
17
|
+
batch: true,
|
|
18
|
+
}));
|
|
19
|
+
const _chain = await config.getChainById(chainId);
|
|
20
|
+
const chain = {
|
|
21
|
+
..._chain,
|
|
22
|
+
..._chain.metamask,
|
|
23
|
+
name: _chain.metamask.chainName,
|
|
24
|
+
rpcUrls: {
|
|
25
|
+
default: { http: _chain.metamask.rpcUrls },
|
|
26
|
+
public: { http: _chain.metamask.rpcUrls },
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
// Add ENS contracts
|
|
30
|
+
if (chain.id === ChainId.ETH) {
|
|
31
|
+
chain.contracts = {
|
|
32
|
+
...mainnet.contracts,
|
|
33
|
+
...chain.contracts,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
publicClients[chainId] = createPublicClient({
|
|
37
|
+
chain: chain,
|
|
38
|
+
transport: fallback(fallbackTransports),
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
if (!publicClients[chainId]) {
|
|
42
|
+
throw new Error(`Unable to configure provider for chain ${chainId}`);
|
|
43
|
+
}
|
|
44
|
+
return publicClients[chainId];
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=publicClient.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"publicClient.js","sourceRoot":"","sources":["../../../core/EVM/publicClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AACzD,OAAO,EAAE,OAAO,EAAc,MAAM,aAAa,CAAA;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA;AAEtC,mBAAmB;AACnB,MAAM,aAAa,GAAiC,EAAE,CAAA;AAEtD;;;;GAIG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAClC,OAAe,EACQ,EAAE;IACzB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,CAAA;QACtC,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAC1C,IAAI,CAAC,GAAG,EAAE;YACR,KAAK,EAAE,IAAI;SACZ,CAAC,CACH,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,MAAM,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,oBAAoB;QACpB,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,GAAG,EAAE,CAAC;YAC7B,KAAK,CAAC,SAAS,GAAG;gBAChB,GAAG,OAAO,CAAC,SAAS;gBACpB,GAAG,KAAK,CAAC,SAAS;aACnB,CAAA;QACH,CAAC;QACD,aAAa,CAAC,OAAO,CAAC,GAAG,kBAAkB,CAAC;YAC1C,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,QAAQ,CAAC,kBAAkB,CAAC;SACxC,CAAC,CAAA;IACJ,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,KAAK,CAAC,0CAA0C,OAAO,EAAE,CAAC,CAAA;IACtE,CAAC;IAED,OAAO,aAAa,CAAC,OAAO,CAAC,CAAA;AAC/B,CAAC,CAAA"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { encodeFunctionData, maxUint256, publicActions } from 'viem';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
2
|
+
import { isNativeTokenAddress } from '../../utils/utils.js';
|
|
3
|
+
import { approveAbi } from './abi.js';
|
|
4
|
+
import { getAllowance } from './getAllowance.js';
|
|
5
|
+
import { getMaxPriorityFeePerGas } from './utils.js';
|
|
6
6
|
export const setAllowance = async (walletClient, tokenAddress, contractAddress, amount, settings, returnPopulatedTransaction) => {
|
|
7
7
|
const data = encodeFunctionData({
|
|
8
8
|
abi: approveAbi,
|
|
@@ -41,6 +41,16 @@ export const setAllowance = async (walletClient, tokenAddress, contractAddress,
|
|
|
41
41
|
chain: null,
|
|
42
42
|
});
|
|
43
43
|
};
|
|
44
|
+
/**
|
|
45
|
+
* Set approval for a certain token and amount.
|
|
46
|
+
* @param request - The approval request
|
|
47
|
+
* @param request.walletClient
|
|
48
|
+
* @param request.token
|
|
49
|
+
* @param request.spenderAddress
|
|
50
|
+
* @param request.amount
|
|
51
|
+
* @param request.infiniteApproval
|
|
52
|
+
* @returns Returns Hash or nothing
|
|
53
|
+
*/
|
|
44
54
|
export const setTokenAllowance = async ({ walletClient, token, spenderAddress, amount, infiniteApproval = false, }) => {
|
|
45
55
|
// native token don't need approval
|
|
46
56
|
if (isNativeTokenAddress(token.address)) {
|
|
@@ -53,6 +63,14 @@ export const setTokenAllowance = async ({ walletClient, token, spenderAddress, a
|
|
|
53
63
|
return approveTx;
|
|
54
64
|
}
|
|
55
65
|
};
|
|
66
|
+
/**
|
|
67
|
+
* Revoke approval for a certain token.
|
|
68
|
+
* @param request - The revoke request
|
|
69
|
+
* @param request.walletClient
|
|
70
|
+
* @param request.token
|
|
71
|
+
* @param request.spenderAddress
|
|
72
|
+
* @returns Returns Hash or nothing
|
|
73
|
+
*/
|
|
56
74
|
export const revokeTokenApproval = async ({ walletClient, token, spenderAddress, }) => {
|
|
57
75
|
// native token don't need approval
|
|
58
76
|
if (isNativeTokenAddress(token.address)) {
|
|
@@ -64,3 +82,4 @@ export const revokeTokenApproval = async ({ walletClient, token, spenderAddress,
|
|
|
64
82
|
return approveTx;
|
|
65
83
|
}
|
|
66
84
|
};
|
|
85
|
+
//# 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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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { LiFiErrorCode, ProviderError } from '
|
|
1
|
+
import { LiFiErrorCode, ProviderError } from '../../utils/errors.js';
|
|
2
2
|
/**
|
|
3
3
|
* This method checks whether the wallet client is configured for the correct chain.
|
|
4
4
|
* If yes it returns the wallet clien.
|
|
@@ -16,9 +16,10 @@ import { LiFiErrorCode, ProviderError } from '../utils/errors';
|
|
|
16
16
|
* @param allowUserInteraction
|
|
17
17
|
* @returns New WalletClient
|
|
18
18
|
*/
|
|
19
|
-
export const switchChain = async (walletClient, statusManager, step,
|
|
19
|
+
export const switchChain = async (walletClient, statusManager, step, allowUserInteraction, switchChainHook) => {
|
|
20
20
|
// if we are already on the correct chain we can proceed directly
|
|
21
|
-
|
|
21
|
+
const currentChainId = await walletClient.getChainId();
|
|
22
|
+
if (currentChainId === step.action.fromChainId) {
|
|
22
23
|
return walletClient;
|
|
23
24
|
}
|
|
24
25
|
// -> set status message
|
|
@@ -29,7 +30,7 @@ export const switchChain = async (walletClient, statusManager, step, switchChain
|
|
|
29
30
|
return;
|
|
30
31
|
}
|
|
31
32
|
try {
|
|
32
|
-
const updatedWalletClient = await switchChainHook(step.action.fromChainId);
|
|
33
|
+
const updatedWalletClient = await switchChainHook?.(step.action.fromChainId);
|
|
33
34
|
const updatedChainId = await updatedWalletClient?.getChainId();
|
|
34
35
|
if (updatedChainId !== step.action.fromChainId) {
|
|
35
36
|
throw new ProviderError(LiFiErrorCode.ChainSwitchError, 'Chain switch required.');
|
|
@@ -49,3 +50,4 @@ export const switchChain = async (walletClient, statusManager, step, switchChain
|
|
|
49
50
|
throw error;
|
|
50
51
|
}
|
|
51
52
|
};
|
|
53
|
+
//# sourceMappingURL=switchChain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchChain.js","sourceRoot":"","sources":["../../../core/EVM/switchChain.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAIpE;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,EAC9B,YAA0B,EAC1B,aAA4B,EAC5B,IAAsB,EACtB,oBAA6B,EAC7B,eAAiC,EACE,EAAE;IACrC,iEAAiE;IACjE,MAAM,cAAc,GAAG,MAAM,YAAY,CAAC,UAAU,EAAE,CAAA;IACtD,IAAI,cAAc,KAAK,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;QAC/C,OAAO,YAAY,CAAA;IACrB,CAAC;IAED,wBAAwB;IACxB,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,CAAC;QAC1B,OAAM;IACR,CAAC;IAED,IAAI,CAAC;QACH,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,CAAC;YAC/C,MAAM,IAAI,aAAa,CACrB,aAAa,CAAC,gBAAgB,EAC9B,wBAAwB,CACzB,CAAA;QACH,CAAC;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;IAC5B,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,aAAa,CAAC,aAAa,CAAC,IAAI,EAAE,aAAa,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC9D,KAAK,EAAE;gBACL,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,IAAI,EAAE,aAAa,CAAC,gBAAgB;aACrC;SACF,CAAC,CAAA;QACF,aAAa,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;QAC7C,MAAM,KAAK,CAAA;IACb,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../core/EVM/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,MAAM,aAAa,CAAA;AAGnD,OAAO,EAAoB,MAAM,aAAa,CAAA;AAa9C,MAAM,UAAU,KAAK,CAAC,QAAqB;IACzC,OAAO,QAAQ,CAAC,IAAI,KAAK,SAAS,CAAC,GAAG,CAAA;AACxC,CAAC"}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {} from '@lifi/types';
|
|
2
|
+
import { config } from '../../config.js';
|
|
3
|
+
import { median } from '../../utils/median.js';
|
|
2
4
|
export const getMaxPriorityFeePerGas = async (client) => {
|
|
3
5
|
const block = await client.getBlock({
|
|
4
6
|
includeTransactions: true,
|
|
@@ -16,3 +18,12 @@ export const getMaxPriorityFeePerGas = async (client) => {
|
|
|
16
18
|
? maxPriorityFeePerGasAvg
|
|
17
19
|
: maxPriorityFeePerGasMedian;
|
|
18
20
|
};
|
|
21
|
+
// Multicall
|
|
22
|
+
export const getMulticallAddress = async (chainId) => {
|
|
23
|
+
const chains = await config.getChains();
|
|
24
|
+
return chains.find((chain) => chain.id === chainId)?.multicallAddress;
|
|
25
|
+
};
|
|
26
|
+
// Modified viem retryDelay exponential backoff function.
|
|
27
|
+
export const retryDelay = ({ count }) => Math.min(~~(1 << count) * 200, 3000);
|
|
28
|
+
export const retryCount = 20;
|
|
29
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../core/EVM/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,aAAa,CAAA;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAA;AAE9C,MAAM,CAAC,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,CAAC;QACrC,OAAM;IACR,CAAC;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,MAAM,CAAC,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;AAED,YAAY;AACZ,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EACtC,OAAgB,EACa,EAAE;IAC/B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,SAAS,EAAE,CAAA;IACvC,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,gBAAgB,CAAA;AACvE,CAAC,CAAA;AAED,yDAAyD;AACzD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAE,KAAK,EAAmC,EAAE,EAAE,CACvE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,GAAG,EAAE,IAAI,CAAC,CAAA;AAEtC,MAAM,CAAC,MAAM,UAAU,GAAG,EAAE,CAAA"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { ed25519 } from '@noble/curves/ed25519';
|
|
2
|
+
import { BaseSignerWalletAdapter, WalletConfigError, WalletNotConnectedError, WalletReadyState, isVersionedTransaction, } from '@solana/wallet-adapter-base';
|
|
3
|
+
import { Keypair } from '@solana/web3.js';
|
|
4
|
+
import { decode } from 'bs58';
|
|
5
|
+
export const KeypairWalletName = 'Keypair Wallet';
|
|
6
|
+
/**
|
|
7
|
+
* This keypair wallet adapter is unsafe to use on the frontend and is only included to provide an easy way for applications to test
|
|
8
|
+
* Wallet Adapter without using a third-party wallet.
|
|
9
|
+
*/
|
|
10
|
+
export class KeypairWalletAdapter extends BaseSignerWalletAdapter {
|
|
11
|
+
constructor(privateKey) {
|
|
12
|
+
if (!privateKey) {
|
|
13
|
+
throw new WalletConfigError();
|
|
14
|
+
}
|
|
15
|
+
super();
|
|
16
|
+
Object.defineProperty(this, "name", {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
configurable: true,
|
|
19
|
+
writable: true,
|
|
20
|
+
value: KeypairWalletName
|
|
21
|
+
});
|
|
22
|
+
Object.defineProperty(this, "url", {
|
|
23
|
+
enumerable: true,
|
|
24
|
+
configurable: true,
|
|
25
|
+
writable: true,
|
|
26
|
+
value: 'https://github.com/anza-xyz/wallet-adapter'
|
|
27
|
+
});
|
|
28
|
+
Object.defineProperty(this, "icon", {
|
|
29
|
+
enumerable: true,
|
|
30
|
+
configurable: true,
|
|
31
|
+
writable: true,
|
|
32
|
+
value: ''
|
|
33
|
+
});
|
|
34
|
+
Object.defineProperty(this, "supportedTransactionVersions", {
|
|
35
|
+
enumerable: true,
|
|
36
|
+
configurable: true,
|
|
37
|
+
writable: true,
|
|
38
|
+
value: new Set([
|
|
39
|
+
'legacy',
|
|
40
|
+
0,
|
|
41
|
+
])
|
|
42
|
+
});
|
|
43
|
+
/**
|
|
44
|
+
* Storing a keypair locally like this is not safe because any application using this adapter could retrieve the
|
|
45
|
+
* secret key, and because the keypair will be lost any time the wallet is disconnected or the window is refreshed.
|
|
46
|
+
*/
|
|
47
|
+
Object.defineProperty(this, "_keypair", {
|
|
48
|
+
enumerable: true,
|
|
49
|
+
configurable: true,
|
|
50
|
+
writable: true,
|
|
51
|
+
value: void 0
|
|
52
|
+
});
|
|
53
|
+
this._keypair = Keypair.fromSecretKey(decode(privateKey));
|
|
54
|
+
}
|
|
55
|
+
get connecting() {
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
get publicKey() {
|
|
59
|
+
return this._keypair?.publicKey || null;
|
|
60
|
+
}
|
|
61
|
+
get readyState() {
|
|
62
|
+
return WalletReadyState.Loadable;
|
|
63
|
+
}
|
|
64
|
+
async connect(privateKey) {
|
|
65
|
+
if (!privateKey) {
|
|
66
|
+
throw new WalletConfigError();
|
|
67
|
+
}
|
|
68
|
+
this._keypair = Keypair.fromSecretKey(decode(privateKey));
|
|
69
|
+
}
|
|
70
|
+
async disconnect() {
|
|
71
|
+
this._keypair = undefined;
|
|
72
|
+
}
|
|
73
|
+
async signTransaction(transaction) {
|
|
74
|
+
if (!this._keypair) {
|
|
75
|
+
throw new WalletNotConnectedError();
|
|
76
|
+
}
|
|
77
|
+
if (isVersionedTransaction(transaction)) {
|
|
78
|
+
transaction.sign([this._keypair]);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
transaction.partialSign(this._keypair);
|
|
82
|
+
}
|
|
83
|
+
return transaction;
|
|
84
|
+
}
|
|
85
|
+
async signMessage(message) {
|
|
86
|
+
if (!this._keypair) {
|
|
87
|
+
throw new WalletNotConnectedError();
|
|
88
|
+
}
|
|
89
|
+
return ed25519.sign(message, this._keypair.secretKey.slice(0, 32));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=KeypairWalletAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeypairWalletAdapter.js","sourceRoot":"","sources":["../../../core/Solana/KeypairWalletAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAA;AAK/C,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,uBAAuB,EACvB,gBAAgB,EAChB,sBAAsB,GACvB,MAAM,6BAA6B,CAAA;AAMpC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAE7B,MAAM,CAAC,MAAM,iBAAiB,GAC5B,gBAAgD,CAAA;AAElD;;;GAGG;AACH,MAAM,OAAO,oBACX,SAAQ,uBAAuB;IAiB/B,YAAY,UAAkB;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,iBAAiB,EAAE,CAAA;QAC/B,CAAC;QACD,KAAK,EAAE,CAAA;QAlBT;;;;mBAAO,iBAAiB;WAAA;QACxB;;;;mBAAM,4CAA4C;WAAA;QAClD;;;;mBAAO,EAAE;WAAA;QACT;;;;mBAAgE,IAAI,GAAG,CAAC;gBACtE,QAAQ;gBACR,CAAC;aACF,CAAC;WAAA;QAEF;;;WAGG;QACK;;;;;WAA6B;QAOnC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAA;IAC3D,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,KAAK,CAAA;IACd,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,QAAQ,EAAE,SAAS,IAAI,IAAI,CAAA;IACzC,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,gBAAgB,CAAC,QAAQ,CAAA;IAClC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,UAAmB;QAC/B,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,iBAAiB,EAAE,CAAA;QAC/B,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAA;IAC3D,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAA;IAC3B,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,WAAc;QAEd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,uBAAuB,EAAE,CAAA;QACrC,CAAC;QAED,IAAI,sBAAsB,CAAC,WAAW,CAAC,EAAE,CAAC;YACxC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAA;QACnC,CAAC;aAAM,CAAC;YACN,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QACxC,CAAC;QAED,OAAO,WAAW,CAAA;IACpB,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAmB;QACnC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,uBAAuB,EAAE,CAAA;QACrC,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IACpE,CAAC;CACF"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ChainType } from '@lifi/types';
|
|
2
|
+
import { SolanaStepExecutor } from './SolanaStepExecutor.js';
|
|
3
|
+
import { getSNSAddress } from './getSNSAddress.js';
|
|
4
|
+
import { getSolanaBalance } from './getSolanaBalance.js';
|
|
5
|
+
import { isAddress } from './isAddress.js';
|
|
6
|
+
export function Solana(options) {
|
|
7
|
+
const _options = options ?? {};
|
|
8
|
+
return {
|
|
9
|
+
get type() {
|
|
10
|
+
return ChainType.SVM;
|
|
11
|
+
},
|
|
12
|
+
isAddress,
|
|
13
|
+
resolveAddress: getSNSAddress,
|
|
14
|
+
getBalance: getSolanaBalance,
|
|
15
|
+
async getStepExecutor(options) {
|
|
16
|
+
if (!_options.getWalletAdapter) {
|
|
17
|
+
throw new Error(`getWalletAdapter is not provided.`);
|
|
18
|
+
}
|
|
19
|
+
const walletAdapter = await _options.getWalletAdapter();
|
|
20
|
+
const executor = new SolanaStepExecutor({
|
|
21
|
+
walletAdapter,
|
|
22
|
+
routeId: options.routeId,
|
|
23
|
+
executionOptions: {
|
|
24
|
+
...options.executionOptions,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
return executor;
|
|
28
|
+
},
|
|
29
|
+
setOptions(options) {
|
|
30
|
+
Object.assign(_options, options);
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=Solana.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Solana.js","sourceRoot":"","sources":["../../../core/Solana/Solana.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAEvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAG1C,MAAM,UAAU,MAAM,CAAC,OAA+B;IACpD,MAAM,QAAQ,GAA0B,OAAO,IAAI,EAAE,CAAA;IACrD,OAAO;QACL,IAAI,IAAI;YACN,OAAO,SAAS,CAAC,GAAG,CAAA;QACtB,CAAC;QACD,SAAS;QACT,cAAc,EAAE,aAAa;QAC7B,UAAU,EAAE,gBAAgB;QAC5B,KAAK,CAAC,eAAe,CACnB,OAA4B;YAE5B,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;gBAC/B,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;YACtD,CAAC;YAED,MAAM,aAAa,GAAG,MAAM,QAAQ,CAAC,gBAAgB,EAAE,CAAA;YAEvD,MAAM,QAAQ,GAAG,IAAI,kBAAkB,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"}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import {} from '@solana/wallet-adapter-base';
|
|
2
|
+
import { VersionedTransaction, } from '@solana/web3.js';
|
|
3
|
+
import { config } from '../../config.js';
|
|
4
|
+
import { getStepTransaction } from '../../services/api.js';
|
|
5
|
+
import { base64ToUint8Array } from '../../utils/base64ToUint8Array.js';
|
|
6
|
+
import { LiFiErrorCode, TransactionError, getTransactionFailedMessage, parseError, } from '../../utils/index.js';
|
|
7
|
+
import { BaseStepExecutor } from '../BaseStepExecutor.js';
|
|
8
|
+
import { checkBalance } from '../checkBalance.js';
|
|
9
|
+
import { stepComparison } from '../stepComparison.js';
|
|
10
|
+
import { getSubstatusMessage } from '../utils.js';
|
|
11
|
+
import { waitForReceivingTransaction } from '../waitForReceivingTransaction.js';
|
|
12
|
+
import { getSolanaConnection } from './connection.js';
|
|
13
|
+
const TX_RETRY_INTERVAL = 500;
|
|
14
|
+
// https://solana.com/docs/advanced/confirmation
|
|
15
|
+
const TIMEOUT_PERIOD = 60_000;
|
|
16
|
+
export class SolanaStepExecutor extends BaseStepExecutor {
|
|
17
|
+
constructor(options) {
|
|
18
|
+
super(options);
|
|
19
|
+
Object.defineProperty(this, "walletAdapter", {
|
|
20
|
+
enumerable: true,
|
|
21
|
+
configurable: true,
|
|
22
|
+
writable: true,
|
|
23
|
+
value: void 0
|
|
24
|
+
});
|
|
25
|
+
Object.defineProperty(this, "checkWalletAdapter", {
|
|
26
|
+
enumerable: true,
|
|
27
|
+
configurable: true,
|
|
28
|
+
writable: true,
|
|
29
|
+
value: (step) => {
|
|
30
|
+
// Prevent execution of the quote by wallet different from the one which requested the quote
|
|
31
|
+
if (this.walletAdapter.publicKey.toString() !== step.action.fromAddress) {
|
|
32
|
+
throw new TransactionError(LiFiErrorCode.WalletChangedDuringExecution, 'The wallet address that requested the quote does not match the wallet address attempting to sign the transaction.');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
Object.defineProperty(this, "executeStep", {
|
|
37
|
+
enumerable: true,
|
|
38
|
+
configurable: true,
|
|
39
|
+
writable: true,
|
|
40
|
+
value: async (step) => {
|
|
41
|
+
step.execution = this.statusManager.initExecutionObject(step);
|
|
42
|
+
const fromChain = await config.getChainById(step.action.fromChainId);
|
|
43
|
+
const toChain = await config.getChainById(step.action.toChainId);
|
|
44
|
+
const isBridgeExecution = fromChain.id !== toChain.id;
|
|
45
|
+
const currentProcessType = isBridgeExecution ? 'CROSS_CHAIN' : 'SWAP';
|
|
46
|
+
// STEP 2: Get transaction
|
|
47
|
+
let process = this.statusManager.findOrCreateProcess(step, currentProcessType);
|
|
48
|
+
if (process.status !== 'DONE') {
|
|
49
|
+
try {
|
|
50
|
+
const connection = await getSolanaConnection();
|
|
51
|
+
process = this.statusManager.updateProcess(step, process.type, 'STARTED');
|
|
52
|
+
// Check balance
|
|
53
|
+
await checkBalance(this.walletAdapter.publicKey.toString(), step);
|
|
54
|
+
// Create new transaction
|
|
55
|
+
if (!step.transactionRequest) {
|
|
56
|
+
const updatedStep = await getStepTransaction(step);
|
|
57
|
+
const comparedStep = await stepComparison(this.statusManager, step, updatedStep, this.allowUserInteraction, this.executionOptions);
|
|
58
|
+
step = {
|
|
59
|
+
...comparedStep,
|
|
60
|
+
execution: step.execution,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
if (!step.transactionRequest?.data) {
|
|
64
|
+
throw new TransactionError(LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
|
|
65
|
+
}
|
|
66
|
+
process = this.statusManager.updateProcess(step, process.type, 'ACTION_REQUIRED');
|
|
67
|
+
if (!this.allowUserInteraction) {
|
|
68
|
+
return step;
|
|
69
|
+
}
|
|
70
|
+
let transactionRequest = {
|
|
71
|
+
data: step.transactionRequest.data,
|
|
72
|
+
};
|
|
73
|
+
if (this.executionOptions?.updateTransactionRequestHook) {
|
|
74
|
+
const customizedTransactionRequest = await this.executionOptions.updateTransactionRequestHook({
|
|
75
|
+
requestType: 'transaction',
|
|
76
|
+
...transactionRequest,
|
|
77
|
+
});
|
|
78
|
+
transactionRequest = {
|
|
79
|
+
...transactionRequest,
|
|
80
|
+
...customizedTransactionRequest,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
if (!transactionRequest.data) {
|
|
84
|
+
throw new TransactionError(LiFiErrorCode.TransactionUnprepared, 'Unable to prepare transaction.');
|
|
85
|
+
}
|
|
86
|
+
const versionedTransaction = VersionedTransaction.deserialize(base64ToUint8Array(transactionRequest.data));
|
|
87
|
+
const blockhashResult = await connection.getLatestBlockhashAndContext({
|
|
88
|
+
commitment: 'confirmed',
|
|
89
|
+
});
|
|
90
|
+
// Update transaction recent blockhash with the latest blockhash
|
|
91
|
+
versionedTransaction.message.recentBlockhash =
|
|
92
|
+
blockhashResult.value.blockhash;
|
|
93
|
+
this.checkWalletAdapter(step);
|
|
94
|
+
const signedTx = await this.walletAdapter.signTransaction(versionedTransaction);
|
|
95
|
+
process = this.statusManager.updateProcess(step, process.type, 'PENDING');
|
|
96
|
+
const rawTransactionOptions = {
|
|
97
|
+
// Skipping preflight i.e. tx simulation by RPC as we simulated the tx above
|
|
98
|
+
skipPreflight: true,
|
|
99
|
+
// Setting max retries to 0 as we are handling retries manually
|
|
100
|
+
// Set this manually so that the default is skipped
|
|
101
|
+
maxRetries: 0,
|
|
102
|
+
// https://solana.com/docs/advanced/confirmation#use-an-appropriate-preflight-commitment-level
|
|
103
|
+
preflightCommitment: 'confirmed',
|
|
104
|
+
// minContextSlot: blockhashResult.context.slot,
|
|
105
|
+
};
|
|
106
|
+
const txSignature = await connection.sendRawTransaction(signedTx.serialize(), rawTransactionOptions);
|
|
107
|
+
// In the following section, we wait and constantly check for the transaction to be confirmed
|
|
108
|
+
// and resend the transaction if it is not confirmed within a certain time interval
|
|
109
|
+
// thus handling tx retries on the client side rather than relying on the RPC
|
|
110
|
+
const confirmTransactionPromise = connection
|
|
111
|
+
.confirmTransaction({
|
|
112
|
+
signature: txSignature,
|
|
113
|
+
blockhash: blockhashResult.value.blockhash,
|
|
114
|
+
lastValidBlockHeight: blockhashResult.value.lastValidBlockHeight,
|
|
115
|
+
}, 'confirmed')
|
|
116
|
+
.then((result) => result.value);
|
|
117
|
+
let confirmedTx = null;
|
|
118
|
+
const startTime = Date.now();
|
|
119
|
+
while (!confirmedTx && Date.now() - startTime <= TIMEOUT_PERIOD) {
|
|
120
|
+
confirmedTx = await Promise.race([
|
|
121
|
+
confirmTransactionPromise,
|
|
122
|
+
new Promise((resolve) => setTimeout(() => {
|
|
123
|
+
resolve(null);
|
|
124
|
+
}, TX_RETRY_INTERVAL)),
|
|
125
|
+
]);
|
|
126
|
+
if (confirmedTx) {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
await connection.sendRawTransaction(signedTx.serialize(), rawTransactionOptions);
|
|
130
|
+
}
|
|
131
|
+
if (confirmedTx?.err) {
|
|
132
|
+
throw new TransactionError(LiFiErrorCode.TransactionFailed, `Transaction failed: ${confirmedTx?.err}`);
|
|
133
|
+
}
|
|
134
|
+
if (!confirmedTx) {
|
|
135
|
+
throw new TransactionError(LiFiErrorCode.TransactionFailed, 'Failed to land the transaction');
|
|
136
|
+
}
|
|
137
|
+
// Transaction has been confirmed and we can update the process
|
|
138
|
+
process = this.statusManager.updateProcess(step, process.type, 'PENDING', {
|
|
139
|
+
txHash: txSignature,
|
|
140
|
+
txLink: `${fromChain.metamask.blockExplorerUrls[0]}tx/${txSignature}`,
|
|
141
|
+
});
|
|
142
|
+
if (isBridgeExecution) {
|
|
143
|
+
process = this.statusManager.updateProcess(step, process.type, 'DONE');
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
catch (e) {
|
|
147
|
+
const error = await parseError(e, step, process);
|
|
148
|
+
process = this.statusManager.updateProcess(step, process.type, 'FAILED', {
|
|
149
|
+
error: {
|
|
150
|
+
message: error.message,
|
|
151
|
+
htmlMessage: error.htmlMessage,
|
|
152
|
+
code: error.code,
|
|
153
|
+
},
|
|
154
|
+
});
|
|
155
|
+
this.statusManager.updateExecution(step, 'FAILED');
|
|
156
|
+
throw error;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
// STEP 5: Wait for the receiving chain
|
|
160
|
+
if (isBridgeExecution) {
|
|
161
|
+
process = this.statusManager.findOrCreateProcess(step, 'RECEIVING_CHAIN', 'PENDING');
|
|
162
|
+
}
|
|
163
|
+
let statusResponse;
|
|
164
|
+
try {
|
|
165
|
+
if (!process.txHash) {
|
|
166
|
+
throw new Error('Transaction hash is undefined.');
|
|
167
|
+
}
|
|
168
|
+
statusResponse = (await waitForReceivingTransaction(process.txHash, this.statusManager, process.type, step));
|
|
169
|
+
const statusReceiving = statusResponse.receiving;
|
|
170
|
+
process = this.statusManager.updateProcess(step, process.type, 'DONE', {
|
|
171
|
+
substatus: statusResponse.substatus,
|
|
172
|
+
substatusMessage: statusResponse.substatusMessage ||
|
|
173
|
+
getSubstatusMessage(statusResponse.status, statusResponse.substatus),
|
|
174
|
+
txHash: statusReceiving?.txHash,
|
|
175
|
+
txLink: `${toChain.metamask.blockExplorerUrls[0]}tx/${statusReceiving?.txHash}`,
|
|
176
|
+
});
|
|
177
|
+
this.statusManager.updateExecution(step, 'DONE', {
|
|
178
|
+
fromAmount: statusResponse.sending.amount,
|
|
179
|
+
toAmount: statusReceiving?.amount,
|
|
180
|
+
toToken: statusReceiving?.token,
|
|
181
|
+
gasCosts: [
|
|
182
|
+
{
|
|
183
|
+
amount: statusResponse.sending.gasAmount,
|
|
184
|
+
amountUSD: statusResponse.sending.gasAmountUSD,
|
|
185
|
+
token: statusResponse.sending.gasToken,
|
|
186
|
+
estimate: statusResponse.sending.gasUsed,
|
|
187
|
+
limit: statusResponse.sending.gasUsed,
|
|
188
|
+
price: statusResponse.sending.gasPrice,
|
|
189
|
+
type: 'SEND',
|
|
190
|
+
},
|
|
191
|
+
],
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
catch (e) {
|
|
195
|
+
const htmlMessage = await getTransactionFailedMessage(step, process.txLink);
|
|
196
|
+
process = this.statusManager.updateProcess(step, process.type, 'FAILED', {
|
|
197
|
+
error: {
|
|
198
|
+
code: LiFiErrorCode.TransactionFailed,
|
|
199
|
+
message: 'Failed while waiting for receiving chain.',
|
|
200
|
+
htmlMessage,
|
|
201
|
+
},
|
|
202
|
+
});
|
|
203
|
+
this.statusManager.updateExecution(step, 'FAILED');
|
|
204
|
+
console.warn(e);
|
|
205
|
+
throw e;
|
|
206
|
+
}
|
|
207
|
+
// DONE
|
|
208
|
+
return step;
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
this.walletAdapter = options.walletAdapter;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
//# sourceMappingURL=SolanaStepExecutor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SolanaStepExecutor.js","sourceRoot":"","sources":["../../../core/Solana/SolanaStepExecutor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ChainId } from '@lifi/types';
|
|
2
|
+
import { Connection } from '@solana/web3.js';
|
|
3
|
+
import { getRpcUrl } from '../rpc.js';
|
|
4
|
+
let connection = undefined;
|
|
5
|
+
/**
|
|
6
|
+
* getSolanaConnection is just a thin wrapper around getting the
|
|
7
|
+
* connection (rpc provider) for Solana
|
|
8
|
+
* @returns - Solana rpc connection
|
|
9
|
+
*/
|
|
10
|
+
export const getSolanaConnection = async () => {
|
|
11
|
+
if (!connection) {
|
|
12
|
+
const rpcUrl = await getRpcUrl(ChainId.SOL);
|
|
13
|
+
connection = new Connection(rpcUrl);
|
|
14
|
+
return connection;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
return connection;
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=connection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection.js","sourceRoot":"","sources":["../../../core/Solana/connection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAA;AAErC,IAAI,UAAU,GAA2B,SAAS,CAAA;AAElD;;;;GAIG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,IAAyB,EAAE;IACjE,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC3C,UAAU,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAA;QACnC,OAAO,UAAU,CAAA;IACnB,CAAC;SAAM,CAAC;QACN,OAAO,UAAU,CAAA;IACnB,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { isAddress } from './isAddress.js';
|
|
2
|
+
// Subject to change
|
|
3
|
+
// https://github.com/Bonfida/sns-sdk?tab=readme-ov-file#sdk-proxy
|
|
4
|
+
export const getSNSAddress = async (name) => {
|
|
5
|
+
try {
|
|
6
|
+
if (!name.endsWith('.sol')) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
// const rpcUrl = await getRpcUrl(ChainId.SOL)
|
|
10
|
+
const snsWorkerUrl = `https://sns-sdk-proxy.bonfida.workers.dev/resolve/${name}`;
|
|
11
|
+
const response = await fetch(snsWorkerUrl);
|
|
12
|
+
if (!response.ok) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const data = await response.json();
|
|
16
|
+
if (!isAddress(data.result)) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
return data.result;
|
|
20
|
+
}
|
|
21
|
+
catch (_) {
|
|
22
|
+
// ignore
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=getSNSAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getSNSAddress.js","sourceRoot":"","sources":["../../../core/Solana/getSNSAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAO1C,oBAAoB;AACpB,kEAAkE;AAClE,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,EAAE,IAAY,EAAE,EAAE;IAClD,IAAI,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,OAAM;QACR,CAAC;QACD,8CAA8C;QAC9C,MAAM,YAAY,GAAG,qDAAqD,IAAI,EAAE,CAAA;QAChF,MAAM,QAAQ,GAAa,MAAM,KAAK,CAAC,YAAY,CAAC,CAAA;QACpD,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,OAAM;QACR,CAAC;QAED,MAAM,IAAI,GAAc,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;QAE7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5B,OAAM;QACR,CAAC;QAED,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,SAAS;QACT,OAAM;IACR,CAAC;AACH,CAAC,CAAA"}
|