@eth-optimism/actions-sdk 0.5.0 → 0.6.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/dist/__tests__/actions.test.js +1 -1
- package/dist/__tests__/actions.test.js.map +1 -1
- package/dist/{lend → actions/lend}/__mocks__/MockLendProvider.d.ts +6 -6
- package/dist/actions/lend/__mocks__/MockLendProvider.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/__mocks__/MockLendProvider.js +20 -7
- package/dist/actions/lend/__mocks__/MockLendProvider.js.map +1 -0
- package/dist/{lend → actions/lend}/__mocks__/MockMarkets.d.ts +1 -1
- package/dist/actions/lend/__mocks__/MockMarkets.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/__mocks__/MockMarkets.js +1 -1
- package/dist/actions/lend/__mocks__/MockMarkets.js.map +1 -0
- package/dist/{lend → actions/lend}/__mocks__/mockLendTransaction.d.ts +2 -2
- package/dist/actions/lend/__mocks__/mockLendTransaction.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/__mocks__/mockLendTransaction.js +1 -1
- package/dist/actions/lend/__mocks__/mockLendTransaction.js.map +1 -0
- package/dist/{lend → actions/lend}/core/LendProvider.d.ts +38 -22
- package/dist/actions/lend/core/LendProvider.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/core/LendProvider.js +61 -22
- package/dist/actions/lend/core/LendProvider.js.map +1 -0
- package/dist/actions/lend/core/__tests__/LendProvider.test.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.js +57 -3
- package/dist/actions/lend/core/__tests__/LendProvider.test.js.map +1 -0
- package/dist/actions/lend/index.d.ts.map +1 -0
- package/dist/actions/lend/index.js.map +1 -0
- package/dist/actions/lend/namespaces/ActionsLendNamespace.d.ts.map +1 -0
- package/dist/actions/lend/namespaces/ActionsLendNamespace.js.map +1 -0
- package/dist/actions/lend/namespaces/BaseLendNamespace.d.ts +33 -0
- package/dist/actions/lend/namespaces/BaseLendNamespace.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/BaseLendNamespace.js +11 -24
- package/dist/actions/lend/namespaces/BaseLendNamespace.js.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/WalletLendNamespace.d.ts +8 -11
- package/dist/actions/lend/namespaces/WalletLendNamespace.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/WalletLendNamespace.js +13 -15
- package/dist/actions/lend/namespaces/WalletLendNamespace.js.map +1 -0
- package/dist/actions/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.js +1 -1
- package/dist/actions/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +1 -0
- package/dist/actions/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.js +2 -2
- package/dist/actions/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -0
- package/dist/actions/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.js +5 -5
- package/dist/actions/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/AaveLendProvider.d.ts +18 -20
- package/dist/actions/lend/providers/aave/AaveLendProvider.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/AaveLendProvider.js +56 -54
- package/dist/actions/lend/providers/aave/AaveLendProvider.js.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.d.ts +1 -1
- package/dist/actions/lend/providers/aave/__mocks__/mockReserve.d.ts.map +1 -0
- package/dist/actions/lend/providers/aave/__mocks__/mockReserve.js.map +1 -0
- package/dist/actions/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.js +4 -4
- package/dist/actions/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -0
- package/dist/actions/lend/providers/aave/abis/pool.d.ts.map +1 -0
- package/dist/actions/lend/providers/aave/abis/pool.js.map +1 -0
- package/dist/actions/lend/providers/aave/addresses.d.ts.map +1 -0
- package/dist/actions/lend/providers/aave/addresses.js.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/sdk.d.ts +4 -4
- package/dist/actions/lend/providers/aave/sdk.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/aave/sdk.js +10 -5
- package/dist/actions/lend/providers/aave/sdk.js.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/MorphoLendProvider.d.ts +18 -14
- package/dist/actions/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/MorphoLendProvider.js +48 -44
- package/dist/actions/lend/providers/morpho/MorphoLendProvider.js.map +1 -0
- package/dist/actions/lend/providers/morpho/__mocks__/mockVault.d.ts.map +1 -0
- package/dist/actions/lend/providers/morpho/__mocks__/mockVault.js.map +1 -0
- package/dist/actions/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.js +58 -3
- package/dist/actions/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +1 -0
- package/dist/actions/lend/providers/morpho/__tests__/api.test.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.js +2 -2
- package/dist/actions/lend/providers/morpho/__tests__/api.test.js.map +1 -0
- package/dist/actions/lend/providers/morpho/__tests__/sdk.test.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.js +1 -1
- package/dist/actions/lend/providers/morpho/__tests__/sdk.test.js.map +1 -0
- package/dist/actions/lend/providers/morpho/api.d.ts.map +1 -0
- package/dist/actions/lend/providers/morpho/api.js.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/sdk.d.ts +4 -4
- package/dist/actions/lend/providers/morpho/sdk.d.ts.map +1 -0
- package/dist/{lend → actions/lend}/providers/morpho/sdk.js +18 -7
- package/dist/actions/lend/providers/morpho/sdk.js.map +1 -0
- package/dist/actions/lend/utils/markets.d.ts +26 -0
- package/dist/actions/lend/utils/markets.d.ts.map +1 -0
- package/dist/actions/lend/utils/markets.js +44 -0
- package/dist/actions/lend/utils/markets.js.map +1 -0
- package/dist/actions/shared/BaseNamespace.d.ts +29 -0
- package/dist/actions/shared/BaseNamespace.d.ts.map +1 -0
- package/dist/actions/shared/BaseNamespace.js +31 -0
- package/dist/actions/shared/BaseNamespace.js.map +1 -0
- package/dist/actions/shared/__tests__/BaseNamespace.spec.d.ts +2 -0
- package/dist/actions/shared/__tests__/BaseNamespace.spec.d.ts.map +1 -0
- package/dist/actions/shared/__tests__/BaseNamespace.spec.js +42 -0
- package/dist/actions/shared/__tests__/BaseNamespace.spec.js.map +1 -0
- package/dist/{lend/providers → actions/shared}/morpho/contracts.d.ts +1 -1
- package/dist/actions/shared/morpho/contracts.d.ts.map +1 -0
- package/dist/{lend/providers → actions/shared}/morpho/contracts.js.map +1 -1
- package/dist/{types/lend/contracts.d.ts → actions/shared/morpho/types.d.ts} +2 -2
- package/dist/actions/shared/morpho/types.d.ts.map +1 -0
- package/dist/actions/shared/morpho/types.js.map +1 -0
- package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.d.ts +7 -6
- package/dist/actions/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.js +5 -2
- package/dist/actions/swap/__mocks__/MockSwapProvider.js.map +1 -0
- package/dist/{swap → actions/swap}/core/SwapProvider.d.ts +29 -14
- package/dist/actions/swap/core/SwapProvider.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/core/SwapProvider.js +57 -38
- package/dist/actions/swap/core/SwapProvider.js.map +1 -0
- package/dist/actions/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.js +39 -0
- package/dist/actions/swap/core/__tests__/SwapProvider.test.js.map +1 -0
- package/dist/{swap → actions/swap}/core/markets.d.ts +3 -3
- package/dist/actions/swap/core/markets.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/core/markets.js +2 -1
- package/dist/actions/swap/core/markets.js.map +1 -0
- package/dist/actions/swap/index.d.ts.map +1 -0
- package/dist/actions/swap/index.js.map +1 -0
- package/dist/actions/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
- package/dist/actions/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.d.ts +25 -28
- package/dist/actions/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.js +58 -59
- package/dist/actions/swap/namespaces/BaseSwapNamespace.js.map +1 -0
- package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts +56 -0
- package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/WalletSwapNamespace.js +43 -23
- package/dist/actions/swap/namespaces/WalletSwapNamespace.js.map +1 -0
- package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.js +2 -2
- package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
- package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.js +83 -19
- package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.d.ts +8 -5
- package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.js +14 -5
- package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
- package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.js +1 -1
- package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
- package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.js +47 -1
- package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
- package/dist/actions/swap/providers/uniswap/abis.d.ts.map +1 -0
- package/dist/actions/swap/providers/uniswap/abis.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/addresses.d.ts +1 -1
- package/dist/actions/swap/providers/uniswap/addresses.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/addresses.js +6 -2
- package/dist/actions/swap/providers/uniswap/addresses.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/encoding.d.ts +3 -3
- package/dist/actions/swap/providers/uniswap/encoding.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/encoding.js +2 -2
- package/dist/actions/swap/providers/uniswap/encoding.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/markets.d.ts +3 -3
- package/dist/actions/swap/providers/uniswap/markets.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/markets.js +1 -1
- package/dist/actions/swap/providers/uniswap/markets.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/uniswap/types.d.ts +1 -1
- package/dist/actions/swap/providers/uniswap/types.d.ts.map +1 -0
- package/dist/actions/swap/providers/uniswap/types.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.d.ts +9 -4
- package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.js +37 -11
- package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +7 -6
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +39 -4
- package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.js +22 -1
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.d.ts +1 -1
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.js +25 -1
- package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
- package/dist/actions/swap/providers/velodrome/abis.d.ts.map +1 -0
- package/dist/actions/swap/providers/velodrome/abis.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/addresses.d.ts +1 -1
- package/dist/actions/swap/providers/velodrome/addresses.d.ts.map +1 -0
- package/dist/actions/swap/providers/velodrome/addresses.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/config.d.ts +1 -1
- package/dist/actions/swap/providers/velodrome/config.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/config.js +5 -1
- package/dist/actions/swap/providers/velodrome/config.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.d.ts +3 -3
- package/dist/actions/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.js +4 -3
- package/dist/actions/swap/providers/velodrome/encoding/helpers.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.d.ts +0 -1
- package/dist/actions/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.js +0 -1
- package/dist/actions/swap/providers/velodrome/encoding/index.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.d.ts +3 -3
- package/dist/actions/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.js +2 -1
- package/dist/actions/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.d.ts +24 -3
- package/dist/actions/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.js +22 -10
- package/dist/actions/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.d.ts +23 -3
- package/dist/actions/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.js +24 -13
- package/dist/actions/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/markets.d.ts +3 -3
- package/dist/actions/swap/providers/velodrome/markets.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/markets.js +4 -3
- package/dist/actions/swap/providers/velodrome/markets.js.map +1 -0
- package/dist/{swap → actions/swap}/providers/velodrome/types.d.ts +1 -1
- package/dist/actions/swap/providers/velodrome/types.d.ts.map +1 -0
- package/dist/actions/swap/providers/velodrome/types.js +2 -0
- package/dist/actions/swap/providers/velodrome/types.js.map +1 -0
- package/dist/actions.d.ts +4 -3
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +45 -22
- package/dist/actions.js.map +1 -1
- package/dist/core/error/__tests__/errors.test.d.ts +2 -0
- package/dist/core/error/__tests__/errors.test.d.ts.map +1 -0
- package/dist/core/error/__tests__/errors.test.js +195 -0
- package/dist/core/error/__tests__/errors.test.js.map +1 -0
- package/dist/core/error/errors.d.ts +131 -15
- package/dist/core/error/errors.d.ts.map +1 -1
- package/dist/core/error/errors.js +201 -17
- package/dist/core/error/errors.js.map +1 -1
- package/dist/index.d.ts +7 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -4
- package/dist/index.js.map +1 -1
- package/dist/services/ChainManager.d.ts.map +1 -1
- package/dist/services/ChainManager.js +26 -7
- package/dist/services/ChainManager.js.map +1 -1
- package/dist/services/__tests__/ChainManager.spec.d.ts.map +1 -0
- package/dist/services/{ChainManager.spec.js → __tests__/ChainManager.spec.js} +7 -7
- package/dist/services/__tests__/ChainManager.spec.js.map +1 -0
- package/dist/services/__tests__/tokenBalance.spec.d.ts.map +1 -0
- package/dist/services/{tokenBalance.spec.js → __tests__/tokenBalance.spec.js} +42 -5
- package/dist/services/__tests__/tokenBalance.spec.js.map +1 -0
- package/dist/{ens → services/nameservices/ens}/EnsNamespace.d.ts +1 -1
- package/dist/services/nameservices/ens/EnsNamespace.d.ts.map +1 -0
- package/dist/{ens → services/nameservices/ens}/EnsNamespace.js +1 -1
- package/dist/services/nameservices/ens/EnsNamespace.js.map +1 -0
- package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts.map +1 -0
- package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.js +2 -2
- package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js.map +1 -0
- package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts +2 -0
- package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts.map +1 -0
- package/dist/{utils/ens.test.js → services/nameservices/ens/__tests__/utils.spec.js} +3 -3
- package/dist/services/nameservices/ens/__tests__/utils.spec.js.map +1 -0
- package/dist/services/nameservices/ens/errors.d.ts.map +1 -0
- package/dist/services/nameservices/ens/errors.js.map +1 -0
- package/dist/{ens → services/nameservices/ens}/index.d.ts +1 -0
- package/dist/services/nameservices/ens/index.d.ts.map +1 -0
- package/dist/{ens → services/nameservices/ens}/index.js +1 -0
- package/dist/services/nameservices/ens/index.js.map +1 -0
- package/dist/{ens → services/nameservices/ens}/types.d.ts +1 -1
- package/dist/services/nameservices/ens/types.d.ts.map +1 -0
- package/dist/services/nameservices/ens/types.js.map +1 -0
- package/dist/{utils/ens.d.ts → services/nameservices/ens/utils.d.ts} +3 -3
- package/dist/services/nameservices/ens/utils.d.ts.map +1 -0
- package/dist/{utils/ens.js → services/nameservices/ens/utils.js} +3 -3
- package/dist/services/nameservices/ens/utils.js.map +1 -0
- package/dist/services/tokenBalance.d.ts +8 -5
- package/dist/services/tokenBalance.d.ts.map +1 -1
- package/dist/services/tokenBalance.js +15 -8
- package/dist/services/tokenBalance.js.map +1 -1
- package/dist/types/actions.d.ts +69 -7
- package/dist/types/actions.d.ts.map +1 -1
- package/dist/types/asset.d.ts +7 -0
- package/dist/types/asset.d.ts.map +1 -1
- package/dist/types/common/FilterAssetChain.d.ts +13 -0
- package/dist/types/common/FilterAssetChain.d.ts.map +1 -0
- package/dist/types/common/FilterAssetChain.js +2 -0
- package/dist/types/common/FilterAssetChain.js.map +1 -0
- package/dist/types/common/TransactionOptions.d.ts +13 -0
- package/dist/types/common/TransactionOptions.d.ts.map +1 -0
- package/dist/types/common/TransactionOptions.js +2 -0
- package/dist/types/common/TransactionOptions.js.map +1 -0
- package/dist/types/common/index.d.ts +3 -0
- package/dist/types/common/index.d.ts.map +1 -0
- package/dist/types/common/index.js +3 -0
- package/dist/types/common/index.js.map +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/lend/base.d.ts +44 -34
- package/dist/types/lend/base.d.ts.map +1 -1
- package/dist/types/lend/base.js +3 -3
- package/dist/types/lend/base.js.map +1 -1
- package/dist/types/lend/index.d.ts +0 -1
- package/dist/types/lend/index.d.ts.map +1 -1
- package/dist/types/lend/index.js +0 -1
- package/dist/types/lend/index.js.map +1 -1
- package/dist/types/providers.d.ts +2 -2
- package/dist/types/providers.d.ts.map +1 -1
- package/dist/types/swap/base.d.ts +25 -13
- package/dist/types/swap/base.d.ts.map +1 -1
- package/dist/types/swap/base.js +3 -3
- package/dist/types/swap/base.js.map +1 -1
- package/dist/utils/__tests__/approve.test.d.ts.map +1 -0
- package/dist/utils/{approve.test.js → __tests__/approve.test.js} +40 -18
- package/dist/utils/__tests__/approve.test.js.map +1 -0
- package/dist/utils/__tests__/assets.test.d.ts.map +1 -0
- package/dist/utils/{assets.test.js → __tests__/assets.test.js} +2 -2
- package/dist/utils/__tests__/assets.test.js.map +1 -0
- package/dist/utils/__tests__/serializers.test.d.ts +2 -0
- package/dist/utils/__tests__/serializers.test.d.ts.map +1 -0
- package/dist/utils/__tests__/serializers.test.js +43 -0
- package/dist/utils/__tests__/serializers.test.js.map +1 -0
- package/dist/utils/__tests__/validateAddresses.test.d.ts.map +1 -0
- package/dist/utils/{validateAddresses.test.js → __tests__/validateAddresses.test.js} +10 -10
- package/dist/utils/__tests__/validateAddresses.test.js.map +1 -0
- package/dist/utils/abi/permit2.d.ts +48 -0
- package/dist/utils/abi/permit2.d.ts.map +1 -0
- package/dist/utils/abi/permit2.js +34 -0
- package/dist/utils/abi/permit2.js.map +1 -0
- package/dist/utils/approve.d.ts +26 -3
- package/dist/utils/approve.d.ts.map +1 -1
- package/dist/utils/approve.js +34 -37
- package/dist/utils/approve.js.map +1 -1
- package/dist/utils/assets.d.ts.map +1 -1
- package/dist/utils/assets.js +3 -2
- package/dist/utils/assets.js.map +1 -1
- package/dist/utils/serializers.d.ts +16 -0
- package/dist/utils/serializers.d.ts.map +1 -0
- package/dist/utils/serializers.js +18 -0
- package/dist/utils/serializers.js.map +1 -0
- package/dist/utils/validation.d.ts +8 -1
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +28 -8
- package/dist/utils/validation.js.map +1 -1
- package/dist/wallet/core/error/errors.d.ts +21 -0
- package/dist/wallet/core/error/errors.d.ts.map +1 -0
- package/dist/wallet/core/error/errors.js +24 -0
- package/dist/wallet/core/error/errors.js.map +1 -0
- package/dist/wallet/core/namespace/WalletNamespace.d.ts +24 -8
- package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
- package/dist/wallet/core/namespace/WalletNamespace.js +48 -17
- package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +105 -10
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
- package/dist/wallet/core/providers/WalletProvider.d.ts +3 -2
- package/dist/wallet/core/providers/WalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/WalletProvider.js +8 -2
- package/dist/wallet/core/providers/WalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +1 -1
- package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
- package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts.map +1 -1
- package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js +2 -1
- package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js.map +1 -1
- package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +1 -1
- package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +1 -1
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
- package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts +2 -0
- package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts.map +1 -0
- package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js +31 -0
- package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js.map +1 -0
- package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +1 -0
- package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.js.map +1 -0
- package/dist/wallet/core/utils/executeTransactionBatch.d.ts +22 -0
- package/dist/wallet/core/utils/executeTransactionBatch.d.ts.map +1 -0
- package/dist/wallet/core/utils/executeTransactionBatch.js +26 -0
- package/dist/wallet/core/utils/executeTransactionBatch.js.map +1 -0
- package/dist/wallet/core/utils/retryOnStaleRead.d.ts.map +1 -0
- package/dist/wallet/core/utils/retryOnStaleRead.js.map +1 -0
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts +8 -8
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.js +13 -12
- package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +3 -3
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +28 -2
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
- package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts +1 -1
- package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/eoa/EOAWallet.js.map +1 -1
- package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts +1 -1
- package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +2 -2
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +1 -1
- package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
- package/dist/wallet/node/index.d.ts +1 -0
- package/dist/wallet/node/index.d.ts.map +1 -1
- package/dist/wallet/node/index.js +1 -0
- package/dist/wallet/node/index.js.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
- package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +1 -1
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/node/wallets/local/LocalWallet.d.ts +24 -0
- package/dist/wallet/node/wallets/local/LocalWallet.d.ts.map +1 -0
- package/dist/wallet/node/wallets/local/LocalWallet.js +21 -0
- package/dist/wallet/node/wallets/local/LocalWallet.js.map +1 -0
- package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts +2 -0
- package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts.map +1 -0
- package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js +51 -0
- package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js.map +1 -0
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
- package/package.json +2 -2
- package/src/__tests__/actions.test.ts +3 -1
- package/src/{lend → actions/lend}/__mocks__/MockLendProvider.ts +24 -9
- package/src/{lend → actions/lend}/__mocks__/mockLendTransaction.ts +2 -2
- package/src/{lend → actions/lend}/core/LendProvider.ts +123 -39
- package/src/{lend → actions/lend}/core/__tests__/LendProvider.test.ts +82 -3
- package/src/actions/lend/index.ts +3 -0
- package/src/{lend → actions/lend}/namespaces/BaseLendNamespace.ts +20 -37
- package/src/{lend → actions/lend}/namespaces/WalletLendNamespace.ts +15 -22
- package/src/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.ts +3 -3
- package/src/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.ts +3 -3
- package/src/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.ts +6 -6
- package/src/{lend → actions/lend}/providers/aave/AaveLendProvider.ts +65 -73
- package/src/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.ts +7 -7
- package/src/{lend → actions/lend}/providers/aave/sdk.ts +15 -9
- package/src/{lend → actions/lend}/providers/morpho/MorphoLendProvider.ts +67 -53
- package/src/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.ts +79 -5
- package/src/{lend → actions/lend}/providers/morpho/__tests__/api.test.ts +3 -3
- package/src/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.ts +2 -2
- package/src/{lend → actions/lend}/providers/morpho/sdk.ts +23 -12
- package/src/actions/lend/utils/markets.ts +62 -0
- package/src/actions/shared/BaseNamespace.ts +46 -0
- package/src/actions/shared/__tests__/BaseNamespace.spec.ts +58 -0
- package/src/{lend/providers → actions/shared}/morpho/contracts.ts +2 -2
- package/src/{swap → actions/swap}/__mocks__/MockSwapProvider.ts +6 -2
- package/src/{swap → actions/swap}/core/SwapProvider.ts +88 -55
- package/src/{swap → actions/swap}/core/__tests__/SwapProvider.test.ts +51 -1
- package/src/{swap → actions/swap}/core/markets.ts +2 -1
- package/src/actions/swap/index.ts +19 -0
- package/src/{swap → actions/swap}/namespaces/ActionsSwapNamespace.ts +1 -1
- package/src/{swap → actions/swap}/namespaces/BaseSwapNamespace.ts +92 -90
- package/src/actions/swap/namespaces/WalletSwapNamespace.ts +154 -0
- package/src/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.ts +6 -6
- package/src/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.ts +110 -22
- package/src/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.ts +34 -14
- package/src/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +2 -2
- package/src/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.ts +65 -3
- package/src/{swap → actions/swap}/providers/uniswap/addresses.ts +5 -1
- package/src/{swap → actions/swap}/providers/uniswap/encoding.ts +3 -3
- package/src/{swap → actions/swap}/providers/uniswap/markets.ts +2 -2
- package/src/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.ts +71 -31
- package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +2 -2
- package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +8 -7
- package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +46 -5
- package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.ts +31 -2
- package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.ts +34 -3
- package/src/{swap → actions/swap}/providers/velodrome/config.ts +5 -1
- package/src/{swap → actions/swap}/providers/velodrome/encoding/helpers.ts +3 -2
- package/src/{swap → actions/swap}/providers/velodrome/encoding/index.ts +0 -1
- package/src/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.ts +4 -3
- package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.ts +31 -23
- package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.ts +34 -27
- package/src/{swap → actions/swap}/providers/velodrome/markets.ts +4 -3
- package/src/actions.ts +68 -37
- package/src/core/error/__tests__/errors.test.ts +236 -0
- package/src/core/error/errors.ts +282 -22
- package/src/index.ts +18 -12
- package/src/services/ChainManager.ts +26 -9
- package/src/services/{ChainManager.spec.ts → __tests__/ChainManager.spec.ts} +6 -6
- package/src/services/{tokenBalance.spec.ts → __tests__/tokenBalance.spec.ts} +56 -1
- package/src/{ens → services/nameservices/ens}/EnsNamespace.ts +1 -1
- package/src/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.ts +6 -4
- package/src/{utils/ens.test.ts → services/nameservices/ens/__tests__/utils.spec.ts} +3 -2
- package/src/{ens → services/nameservices/ens}/index.ts +5 -0
- package/src/{utils/ens.ts → services/nameservices/ens/utils.ts} +3 -3
- package/src/services/tokenBalance.ts +16 -7
- package/src/types/actions.ts +72 -7
- package/src/types/asset.ts +8 -0
- package/src/types/common/FilterAssetChain.ts +13 -0
- package/src/types/common/TransactionOptions.ts +12 -0
- package/src/types/common/index.ts +2 -0
- package/src/types/index.ts +1 -0
- package/src/types/lend/base.ts +48 -36
- package/src/types/lend/index.ts +0 -1
- package/src/types/providers.ts +2 -2
- package/src/types/swap/base.ts +25 -13
- package/src/utils/{approve.test.ts → __tests__/approve.test.ts} +51 -18
- package/src/utils/__tests__/serializers.test.ts +53 -0
- package/src/utils/{validateAddresses.test.ts → __tests__/validateAddresses.test.ts} +9 -9
- package/src/utils/abi/permit2.ts +33 -0
- package/src/utils/approve.ts +48 -37
- package/src/utils/assets.ts +6 -6
- package/src/utils/serializers.ts +21 -0
- package/src/utils/validation.ts +42 -15
- package/src/wallet/core/error/errors.ts +30 -0
- package/src/wallet/core/namespace/WalletNamespace.ts +82 -20
- package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +141 -16
- package/src/wallet/core/providers/WalletProvider.ts +12 -3
- package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +1 -1
- package/src/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.ts +2 -1
- package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +1 -1
- package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +1 -1
- package/src/wallet/core/utils/__tests__/executeTransactionBatch.spec.ts +42 -0
- package/src/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.ts +1 -1
- package/src/wallet/core/utils/executeTransactionBatch.ts +37 -0
- package/src/wallet/core/wallets/abstract/Wallet.ts +17 -15
- package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +3 -3
- package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +54 -3
- package/src/wallet/core/wallets/eoa/EOAWallet.ts +1 -1
- package/src/wallet/core/wallets/smart/abstract/SmartWallet.ts +1 -1
- package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +3 -3
- package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +1 -1
- package/src/wallet/node/index.ts +1 -0
- package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
- package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +1 -1
- package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
- package/src/wallet/node/wallets/local/LocalWallet.ts +48 -0
- package/src/wallet/node/wallets/local/__tests__/LocalWallet.spec.ts +64 -0
- package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -1
- package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
- package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
- package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +1 -1
- package/dist/core/asset/__mocks__/mockAsset.d.ts +0 -6
- package/dist/core/asset/__mocks__/mockAsset.d.ts.map +0 -1
- package/dist/core/asset/__mocks__/mockAsset.js +0 -12
- package/dist/core/asset/__mocks__/mockAsset.js.map +0 -1
- package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +0 -1
- package/dist/core/utils/__tests__/retryOnStaleRead.spec.js.map +0 -1
- package/dist/core/utils/retryOnStaleRead.d.ts.map +0 -1
- package/dist/core/utils/retryOnStaleRead.js.map +0 -1
- package/dist/ens/EnsNamespace.d.ts.map +0 -1
- package/dist/ens/EnsNamespace.js.map +0 -1
- package/dist/ens/EnsNamespace.spec.d.ts.map +0 -1
- package/dist/ens/EnsNamespace.spec.js.map +0 -1
- package/dist/ens/errors.d.ts.map +0 -1
- package/dist/ens/errors.js.map +0 -1
- package/dist/ens/index.d.ts.map +0 -1
- package/dist/ens/index.js.map +0 -1
- package/dist/ens/types.d.ts.map +0 -1
- package/dist/ens/types.js.map +0 -1
- package/dist/lend/__mocks__/MockLendProvider.d.ts.map +0 -1
- package/dist/lend/__mocks__/MockLendProvider.js.map +0 -1
- package/dist/lend/__mocks__/MockMarkets.d.ts.map +0 -1
- package/dist/lend/__mocks__/MockMarkets.js.map +0 -1
- package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +0 -1
- package/dist/lend/__mocks__/mockLendTransaction.js.map +0 -1
- package/dist/lend/core/LendProvider.d.ts.map +0 -1
- package/dist/lend/core/LendProvider.js.map +0 -1
- package/dist/lend/core/__tests__/LendProvider.test.d.ts.map +0 -1
- package/dist/lend/core/__tests__/LendProvider.test.js.map +0 -1
- package/dist/lend/index.d.ts.map +0 -1
- package/dist/lend/index.js.map +0 -1
- package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +0 -1
- package/dist/lend/namespaces/ActionsLendNamespace.js.map +0 -1
- package/dist/lend/namespaces/BaseLendNamespace.d.ts +0 -43
- package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +0 -1
- package/dist/lend/namespaces/BaseLendNamespace.js.map +0 -1
- package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +0 -1
- package/dist/lend/namespaces/WalletLendNamespace.js.map +0 -1
- package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +0 -1
- package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +0 -1
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +0 -1
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +0 -1
- package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +0 -1
- package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +0 -1
- package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +0 -1
- package/dist/lend/providers/aave/AaveLendProvider.js.map +0 -1
- package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +0 -1
- package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +0 -1
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +0 -1
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +0 -1
- package/dist/lend/providers/aave/abis/pool.d.ts.map +0 -1
- package/dist/lend/providers/aave/abis/pool.js.map +0 -1
- package/dist/lend/providers/aave/addresses.d.ts.map +0 -1
- package/dist/lend/providers/aave/addresses.js.map +0 -1
- package/dist/lend/providers/aave/sdk.d.ts.map +0 -1
- package/dist/lend/providers/aave/sdk.js.map +0 -1
- package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +0 -1
- package/dist/lend/providers/morpho/MorphoLendProvider.js.map +0 -1
- package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts.map +0 -1
- package/dist/lend/providers/morpho/__mocks__/mockVault.js.map +0 -1
- package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +0 -1
- package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +0 -1
- package/dist/lend/providers/morpho/__tests__/api.test.d.ts.map +0 -1
- package/dist/lend/providers/morpho/__tests__/api.test.js.map +0 -1
- package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts.map +0 -1
- package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +0 -1
- package/dist/lend/providers/morpho/api.d.ts.map +0 -1
- package/dist/lend/providers/morpho/api.js.map +0 -1
- package/dist/lend/providers/morpho/contracts.d.ts.map +0 -1
- package/dist/lend/providers/morpho/sdk.d.ts.map +0 -1
- package/dist/lend/providers/morpho/sdk.js.map +0 -1
- package/dist/services/ChainManager.spec.d.ts.map +0 -1
- package/dist/services/ChainManager.spec.js.map +0 -1
- package/dist/services/tokenBalance.spec.d.ts.map +0 -1
- package/dist/services/tokenBalance.spec.js.map +0 -1
- package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +0 -1
- package/dist/swap/__mocks__/MockSwapProvider.js.map +0 -1
- package/dist/swap/core/SwapProvider.d.ts.map +0 -1
- package/dist/swap/core/SwapProvider.js.map +0 -1
- package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +0 -1
- package/dist/swap/core/__tests__/SwapProvider.test.js.map +0 -1
- package/dist/swap/core/markets.d.ts.map +0 -1
- package/dist/swap/core/markets.js.map +0 -1
- package/dist/swap/index.d.ts.map +0 -1
- package/dist/swap/index.js.map +0 -1
- package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +0 -1
- package/dist/swap/namespaces/ActionsSwapNamespace.js.map +0 -1
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +0 -1
- package/dist/swap/namespaces/BaseSwapNamespace.js.map +0 -1
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts +0 -35
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +0 -1
- package/dist/swap/namespaces/WalletSwapNamespace.js.map +0 -1
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +0 -1
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +0 -1
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +0 -1
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +0 -1
- package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +0 -1
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +0 -1
- package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +0 -1
- package/dist/swap/providers/uniswap/abis.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/abis.js.map +0 -1
- package/dist/swap/providers/uniswap/addresses.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/addresses.js.map +0 -1
- package/dist/swap/providers/uniswap/encoding.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/encoding.js.map +0 -1
- package/dist/swap/providers/uniswap/markets.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/markets.js.map +0 -1
- package/dist/swap/providers/uniswap/types.d.ts.map +0 -1
- package/dist/swap/providers/uniswap/types.js.map +0 -1
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +0 -1
- package/dist/swap/providers/velodrome/abis.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/abis.js.map +0 -1
- package/dist/swap/providers/velodrome/addresses.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/addresses.js.map +0 -1
- package/dist/swap/providers/velodrome/config.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/config.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/helpers.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/index.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/index.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +0 -15
- package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/approval.js +0 -33
- package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +0 -1
- package/dist/swap/providers/velodrome/markets.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/markets.js.map +0 -1
- package/dist/swap/providers/velodrome/types.d.ts.map +0 -1
- package/dist/swap/providers/velodrome/types.js.map +0 -1
- package/dist/types/lend/contracts.d.ts.map +0 -1
- package/dist/types/lend/contracts.js +0 -2
- package/dist/types/lend/contracts.js.map +0 -1
- package/dist/utils/approve.test.d.ts.map +0 -1
- package/dist/utils/approve.test.js.map +0 -1
- package/dist/utils/assets.test.d.ts.map +0 -1
- package/dist/utils/assets.test.js.map +0 -1
- package/dist/utils/ens.d.ts.map +0 -1
- package/dist/utils/ens.js.map +0 -1
- package/dist/utils/ens.test.d.ts +0 -2
- package/dist/utils/ens.test.d.ts.map +0 -1
- package/dist/utils/ens.test.js.map +0 -1
- package/dist/utils/markets.d.ts +0 -17
- package/dist/utils/markets.d.ts.map +0 -1
- package/dist/utils/markets.js +0 -25
- package/dist/utils/markets.js.map +0 -1
- package/dist/utils/validateAddresses.test.d.ts.map +0 -1
- package/dist/utils/validateAddresses.test.js.map +0 -1
- package/src/core/asset/__mocks__/mockAsset.ts +0 -13
- package/src/lend/index.ts +0 -3
- package/src/swap/index.ts +0 -19
- package/src/swap/namespaces/WalletSwapNamespace.ts +0 -129
- package/src/swap/providers/velodrome/encoding/routers/approval.ts +0 -45
- package/src/utils/markets.ts +0 -35
- /package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.d.ts +0 -0
- /package/dist/{lend → actions/lend}/index.d.ts +0 -0
- /package/dist/{lend → actions/lend}/index.js +0 -0
- /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.d.ts +0 -0
- /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.js +0 -0
- /package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.d.ts +0 -0
- /package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.d.ts +0 -0
- /package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.js +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/abis/pool.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/abis/pool.js +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/addresses.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/aave/addresses.js +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.js +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/api.d.ts +0 -0
- /package/dist/{lend → actions/lend}/providers/morpho/api.js +0 -0
- /package/dist/{lend/providers → actions/shared}/morpho/contracts.js +0 -0
- /package/dist/{swap/providers/uniswap → actions/shared/morpho}/types.js +0 -0
- /package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/index.d.ts +0 -0
- /package/dist/{swap → actions/swap}/index.js +0 -0
- /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.d.ts +0 -0
- /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.js +0 -0
- /package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +0 -0
- /package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/uniswap/abis.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/uniswap/abis.js +0 -0
- /package/dist/{swap/providers/velodrome → actions/swap/providers/uniswap}/types.js +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.js +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/abis.d.ts +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/abis.js +0 -0
- /package/dist/{swap → actions/swap}/providers/velodrome/addresses.js +0 -0
- /package/dist/services/{ChainManager.spec.d.ts → __tests__/ChainManager.spec.d.ts} +0 -0
- /package/dist/services/{tokenBalance.spec.d.ts → __tests__/tokenBalance.spec.d.ts} +0 -0
- /package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.d.ts +0 -0
- /package/dist/{ens → services/nameservices/ens}/errors.d.ts +0 -0
- /package/dist/{ens → services/nameservices/ens}/errors.js +0 -0
- /package/dist/{ens → services/nameservices/ens}/types.js +0 -0
- /package/dist/utils/{approve.test.d.ts → __tests__/approve.test.d.ts} +0 -0
- /package/dist/utils/{assets.test.d.ts → __tests__/assets.test.d.ts} +0 -0
- /package/dist/utils/{validateAddresses.test.d.ts → __tests__/validateAddresses.test.d.ts} +0 -0
- /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.d.ts +0 -0
- /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.js +0 -0
- /package/dist/{core → wallet/core}/utils/retryOnStaleRead.d.ts +0 -0
- /package/dist/{core → wallet/core}/utils/retryOnStaleRead.js +0 -0
- /package/src/{lend → actions/lend}/__mocks__/MockMarkets.ts +0 -0
- /package/src/{lend → actions/lend}/namespaces/ActionsLendNamespace.ts +0 -0
- /package/src/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.ts +0 -0
- /package/src/{lend → actions/lend}/providers/aave/abis/pool.ts +0 -0
- /package/src/{lend → actions/lend}/providers/aave/addresses.ts +0 -0
- /package/src/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.ts +0 -0
- /package/src/{lend → actions/lend}/providers/morpho/api.ts +0 -0
- /package/src/{types/lend/contracts.ts → actions/shared/morpho/types.ts} +0 -0
- /package/src/{swap → actions/swap}/providers/uniswap/abis.ts +0 -0
- /package/src/{swap → actions/swap}/providers/uniswap/types.ts +0 -0
- /package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.ts +0 -0
- /package/src/{swap → actions/swap}/providers/velodrome/abis.ts +0 -0
- /package/src/{swap → actions/swap}/providers/velodrome/addresses.ts +0 -0
- /package/src/{swap → actions/swap}/providers/velodrome/types.ts +0 -0
- /package/src/{ens → services/nameservices/ens}/errors.ts +0 -0
- /package/src/{ens → services/nameservices/ens}/types.ts +0 -0
- /package/src/utils/{assets.test.ts → __tests__/assets.test.ts} +0 -0
- /package/src/{core → wallet/core}/utils/retryOnStaleRead.ts +0 -0
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import { BaseError } from 'viem'
|
|
2
|
+
import { describe, expect, it } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
ActionsError,
|
|
6
|
+
AddressRequiredError,
|
|
7
|
+
AmountRequiredError,
|
|
8
|
+
AssetMetadataRequiredError,
|
|
9
|
+
AssetNotSupportedOnChainError,
|
|
10
|
+
ChainNotSupportedError,
|
|
11
|
+
ConflictingAmountsError,
|
|
12
|
+
ExactOutputNotSupportedError,
|
|
13
|
+
InvalidAmountError,
|
|
14
|
+
InvalidParamsError,
|
|
15
|
+
MarketIdRequiredError,
|
|
16
|
+
MarketNotAllowedError,
|
|
17
|
+
MarketNotFoundError,
|
|
18
|
+
NativeAssetAddressError,
|
|
19
|
+
ProviderNotConfiguredError,
|
|
20
|
+
QuoteExpiredError,
|
|
21
|
+
SameAssetError,
|
|
22
|
+
SlippageOutOfRangeError,
|
|
23
|
+
ZeroAddressError,
|
|
24
|
+
} from '@/core/error/errors.js'
|
|
25
|
+
|
|
26
|
+
describe('ActionsError hierarchy', () => {
|
|
27
|
+
it('ChainNotSupportedError', () => {
|
|
28
|
+
const err = new ChainNotSupportedError({
|
|
29
|
+
chainId: 999,
|
|
30
|
+
supportedChainIds: [10, 8453],
|
|
31
|
+
})
|
|
32
|
+
expect(err.name).toBe('ChainNotSupportedError')
|
|
33
|
+
expect(err.chainId).toBe(999)
|
|
34
|
+
expect(err.supportedChainIds).toEqual([10, 8453])
|
|
35
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
36
|
+
expect(err).toBeInstanceOf(BaseError)
|
|
37
|
+
expect(err.shortMessage).toContain('999')
|
|
38
|
+
})
|
|
39
|
+
|
|
40
|
+
it('MarketNotAllowedError with pair', () => {
|
|
41
|
+
const err = new MarketNotAllowedError({
|
|
42
|
+
assetInSymbol: 'ETH',
|
|
43
|
+
assetOutSymbol: 'USDC',
|
|
44
|
+
chainId: 10,
|
|
45
|
+
reason: 'Pair is blocked',
|
|
46
|
+
})
|
|
47
|
+
expect(err.name).toBe('MarketNotAllowedError')
|
|
48
|
+
expect(err.assetInSymbol).toBe('ETH')
|
|
49
|
+
expect(err.assetOutSymbol).toBe('USDC')
|
|
50
|
+
expect(err.chainId).toBe(10)
|
|
51
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
52
|
+
expect(err).toBeInstanceOf(BaseError)
|
|
53
|
+
expect(err.shortMessage).toContain('ETH/USDC')
|
|
54
|
+
})
|
|
55
|
+
|
|
56
|
+
it('MarketNotAllowedError with address', () => {
|
|
57
|
+
const err = new MarketNotAllowedError({
|
|
58
|
+
address: '0xabc',
|
|
59
|
+
chainId: 8453,
|
|
60
|
+
})
|
|
61
|
+
expect(err.address).toBe('0xabc')
|
|
62
|
+
expect(err.shortMessage).toContain('0xabc')
|
|
63
|
+
})
|
|
64
|
+
|
|
65
|
+
it('ProviderNotConfiguredError', () => {
|
|
66
|
+
const err = new ProviderNotConfiguredError({
|
|
67
|
+
provider: 'lend',
|
|
68
|
+
details: 'Please configure lend',
|
|
69
|
+
})
|
|
70
|
+
expect(err.name).toBe('ProviderNotConfiguredError')
|
|
71
|
+
expect(err.provider).toBe('lend')
|
|
72
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
73
|
+
expect(err.shortMessage).toContain('lend')
|
|
74
|
+
})
|
|
75
|
+
|
|
76
|
+
it('MarketIdRequiredError', () => {
|
|
77
|
+
const err = new MarketIdRequiredError()
|
|
78
|
+
expect(err.name).toBe('MarketIdRequiredError')
|
|
79
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
80
|
+
expect(err.shortMessage).toBe('marketId is required')
|
|
81
|
+
})
|
|
82
|
+
|
|
83
|
+
it('AmountRequiredError', () => {
|
|
84
|
+
const err = new AmountRequiredError()
|
|
85
|
+
expect(err.name).toBe('AmountRequiredError')
|
|
86
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
87
|
+
expect(err.shortMessage).toContain('amountIn or amountOut')
|
|
88
|
+
})
|
|
89
|
+
|
|
90
|
+
it('InvalidAmountError', () => {
|
|
91
|
+
const err = new InvalidAmountError(-5)
|
|
92
|
+
expect(err.name).toBe('InvalidAmountError')
|
|
93
|
+
expect(err.amount).toBe(-5)
|
|
94
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
95
|
+
})
|
|
96
|
+
|
|
97
|
+
it('ConflictingAmountsError', () => {
|
|
98
|
+
const err = new ConflictingAmountsError()
|
|
99
|
+
expect(err.name).toBe('ConflictingAmountsError')
|
|
100
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
101
|
+
})
|
|
102
|
+
|
|
103
|
+
it('SameAssetError', () => {
|
|
104
|
+
const err = new SameAssetError('USDC')
|
|
105
|
+
expect(err.name).toBe('SameAssetError')
|
|
106
|
+
expect(err.symbol).toBe('USDC')
|
|
107
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
it('QuoteExpiredError', () => {
|
|
111
|
+
const err = new QuoteExpiredError({ expiresAt: 1000, currentTime: 2000 })
|
|
112
|
+
expect(err.name).toBe('QuoteExpiredError')
|
|
113
|
+
expect(err.expiresAt).toBe(1000)
|
|
114
|
+
expect(err.currentTime).toBe(2000)
|
|
115
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
116
|
+
})
|
|
117
|
+
|
|
118
|
+
it('ExactOutputNotSupportedError', () => {
|
|
119
|
+
const err = new ExactOutputNotSupportedError('Velodrome')
|
|
120
|
+
expect(err.name).toBe('ExactOutputNotSupportedError')
|
|
121
|
+
expect(err.provider).toBe('Velodrome')
|
|
122
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
123
|
+
expect(err.shortMessage).toContain('Velodrome')
|
|
124
|
+
})
|
|
125
|
+
|
|
126
|
+
it('AddressRequiredError', () => {
|
|
127
|
+
const err = new AddressRequiredError('walletAddress')
|
|
128
|
+
expect(err.name).toBe('AddressRequiredError')
|
|
129
|
+
expect(err.label).toBe('walletAddress')
|
|
130
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
131
|
+
expect(err.shortMessage).toBe('walletAddress is required')
|
|
132
|
+
})
|
|
133
|
+
|
|
134
|
+
it('ZeroAddressError', () => {
|
|
135
|
+
const err = new ZeroAddressError('walletAddress', '0x0')
|
|
136
|
+
expect(err.name).toBe('ZeroAddressError')
|
|
137
|
+
expect(err.label).toBe('walletAddress')
|
|
138
|
+
expect(err.address).toBe('0x0')
|
|
139
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
140
|
+
expect(err.shortMessage).toContain('walletAddress')
|
|
141
|
+
})
|
|
142
|
+
|
|
143
|
+
it('SlippageOutOfRangeError', () => {
|
|
144
|
+
const err = new SlippageOutOfRangeError(0.6, 0.5)
|
|
145
|
+
expect(err.name).toBe('SlippageOutOfRangeError')
|
|
146
|
+
expect(err.slippage).toBe(0.6)
|
|
147
|
+
expect(err.maxSlippage).toBe(0.5)
|
|
148
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
149
|
+
expect(err.shortMessage).toContain('0.6')
|
|
150
|
+
})
|
|
151
|
+
|
|
152
|
+
it('AssetNotSupportedOnChainError', () => {
|
|
153
|
+
const err = new AssetNotSupportedOnChainError('USDC', 999)
|
|
154
|
+
expect(err.name).toBe('AssetNotSupportedOnChainError')
|
|
155
|
+
expect(err.symbol).toBe('USDC')
|
|
156
|
+
expect(err.chainId).toBe(999)
|
|
157
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
158
|
+
expect(err.shortMessage).toContain('USDC')
|
|
159
|
+
expect(err.shortMessage).toContain('999')
|
|
160
|
+
})
|
|
161
|
+
|
|
162
|
+
it('NativeAssetAddressError', () => {
|
|
163
|
+
const err = new NativeAssetAddressError('ETH')
|
|
164
|
+
expect(err.name).toBe('NativeAssetAddressError')
|
|
165
|
+
expect(err.symbol).toBe('ETH')
|
|
166
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
167
|
+
expect(err.shortMessage).toContain('ETH')
|
|
168
|
+
})
|
|
169
|
+
|
|
170
|
+
it('MarketNotFoundError with poolId', () => {
|
|
171
|
+
const err = new MarketNotFoundError({ chainId: 10, poolId: '0xabc' })
|
|
172
|
+
expect(err.name).toBe('MarketNotFoundError')
|
|
173
|
+
expect(err.chainId).toBe(10)
|
|
174
|
+
expect(err.poolId).toBe('0xabc')
|
|
175
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
176
|
+
expect(err).toBeInstanceOf(BaseError)
|
|
177
|
+
expect(err.shortMessage).toContain('0xabc')
|
|
178
|
+
expect(err.shortMessage).toContain('10')
|
|
179
|
+
})
|
|
180
|
+
|
|
181
|
+
it('MarketNotFoundError without poolId', () => {
|
|
182
|
+
const err = new MarketNotFoundError({ chainId: 8453 })
|
|
183
|
+
expect(err.chainId).toBe(8453)
|
|
184
|
+
expect(err.poolId).toBeUndefined()
|
|
185
|
+
expect(err.shortMessage).toContain('8453')
|
|
186
|
+
})
|
|
187
|
+
|
|
188
|
+
it('AssetMetadataRequiredError', () => {
|
|
189
|
+
const err = new AssetMetadataRequiredError('decimals field is missing')
|
|
190
|
+
expect(err.name).toBe('AssetMetadataRequiredError')
|
|
191
|
+
expect(err.context).toBe('decimals field is missing')
|
|
192
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
193
|
+
expect(err.shortMessage).toBe('Asset metadata is required')
|
|
194
|
+
})
|
|
195
|
+
|
|
196
|
+
it('all errors are instanceof BaseError', () => {
|
|
197
|
+
const errors = [
|
|
198
|
+
new AddressRequiredError('x'),
|
|
199
|
+
new ChainNotSupportedError({ chainId: 1 }),
|
|
200
|
+
new MarketNotAllowedError({ chainId: 1 }),
|
|
201
|
+
new MarketNotFoundError({ chainId: 1 }),
|
|
202
|
+
new ProviderNotConfiguredError({ provider: 'x' }),
|
|
203
|
+
new MarketIdRequiredError(),
|
|
204
|
+
new AmountRequiredError(),
|
|
205
|
+
new InvalidAmountError(0),
|
|
206
|
+
new ConflictingAmountsError(),
|
|
207
|
+
new SameAssetError('ETH'),
|
|
208
|
+
new QuoteExpiredError({ expiresAt: 0, currentTime: 1 }),
|
|
209
|
+
new ExactOutputNotSupportedError('X'),
|
|
210
|
+
new ZeroAddressError('label'),
|
|
211
|
+
new SlippageOutOfRangeError(1, 0.5),
|
|
212
|
+
new AssetNotSupportedOnChainError('X', 1),
|
|
213
|
+
new NativeAssetAddressError('ETH'),
|
|
214
|
+
new AssetMetadataRequiredError(),
|
|
215
|
+
new InvalidParamsError({ param: 'x', expected: 'y' }),
|
|
216
|
+
]
|
|
217
|
+
for (const err of errors) {
|
|
218
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
219
|
+
expect(err).toBeInstanceOf(BaseError)
|
|
220
|
+
}
|
|
221
|
+
})
|
|
222
|
+
|
|
223
|
+
it('InvalidParamsError carries param + expected (and optional received)', () => {
|
|
224
|
+
const err = new InvalidParamsError({
|
|
225
|
+
param: 'chainIds',
|
|
226
|
+
expected: 'SupportedChainId[] (non-empty)',
|
|
227
|
+
received: '[]',
|
|
228
|
+
})
|
|
229
|
+
expect(err.name).toBe('InvalidParamsError')
|
|
230
|
+
expect(err.param).toBe('chainIds')
|
|
231
|
+
expect(err.expected).toBe('SupportedChainId[] (non-empty)')
|
|
232
|
+
expect(err.received).toBe('[]')
|
|
233
|
+
expect(err.shortMessage).toContain('chainIds')
|
|
234
|
+
expect(err).toBeInstanceOf(ActionsError)
|
|
235
|
+
})
|
|
236
|
+
})
|
package/src/core/error/errors.ts
CHANGED
|
@@ -1,27 +1,287 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { BaseError } from 'viem'
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
7
|
-
* {@link TransactionReceipt | transaction receipt} is attached for
|
|
8
|
-
* post-mortem analysis (status, logs, gas usage, etc.).
|
|
4
|
+
* Abstract base class for all Actions SDK errors.
|
|
5
|
+
* Extends viem's BaseError so callers can use instanceof narrowing
|
|
6
|
+
* and structured metaMessages alongside the shortMessage.
|
|
9
7
|
*/
|
|
10
|
-
export class
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
8
|
+
export abstract class ActionsError extends BaseError {}
|
|
9
|
+
|
|
10
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
11
|
+
// Chain / Network
|
|
12
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
13
|
+
|
|
14
|
+
export class ChainNotSupportedError extends ActionsError {
|
|
15
|
+
override name = 'ChainNotSupportedError' as const
|
|
16
|
+
chainId: number
|
|
17
|
+
supportedChainIds: readonly number[]
|
|
18
|
+
|
|
19
|
+
constructor(params: {
|
|
20
|
+
chainId: number
|
|
21
|
+
supportedChainIds?: readonly number[]
|
|
22
|
+
}) {
|
|
23
|
+
super(`Chain ${params.chainId} is not supported`, {
|
|
24
|
+
metaMessages: params.supportedChainIds?.length
|
|
25
|
+
? [`Supported chains: ${params.supportedChainIds.join(', ')}`]
|
|
26
|
+
: undefined,
|
|
27
|
+
})
|
|
28
|
+
this.chainId = params.chainId
|
|
29
|
+
this.supportedChainIds = params.supportedChainIds ?? []
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
34
|
+
// Market / Provider
|
|
35
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
36
|
+
|
|
37
|
+
export class MarketNotAllowedError extends ActionsError {
|
|
38
|
+
override name = 'MarketNotAllowedError' as const
|
|
39
|
+
chainId: number
|
|
40
|
+
assetInSymbol?: string
|
|
41
|
+
assetOutSymbol?: string
|
|
42
|
+
address?: string
|
|
43
|
+
|
|
44
|
+
constructor(params: {
|
|
45
|
+
chainId: number
|
|
46
|
+
assetInSymbol?: string
|
|
47
|
+
assetOutSymbol?: string
|
|
48
|
+
address?: string
|
|
49
|
+
reason?: string
|
|
50
|
+
}) {
|
|
51
|
+
const pair =
|
|
52
|
+
params.assetInSymbol && params.assetOutSymbol
|
|
53
|
+
? `${params.assetInSymbol}/${params.assetOutSymbol}`
|
|
54
|
+
: (params.address ?? 'unknown')
|
|
55
|
+
super(`Market ${pair} not allowed on chain ${params.chainId}`, {
|
|
56
|
+
metaMessages: params.reason ? [params.reason] : undefined,
|
|
57
|
+
})
|
|
58
|
+
this.chainId = params.chainId
|
|
59
|
+
this.assetInSymbol = params.assetInSymbol
|
|
60
|
+
this.assetOutSymbol = params.assetOutSymbol
|
|
61
|
+
this.address = params.address
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export class MarketNotFoundError extends ActionsError {
|
|
66
|
+
override name = 'MarketNotFoundError' as const
|
|
67
|
+
chainId: number
|
|
68
|
+
poolId?: string
|
|
69
|
+
|
|
70
|
+
constructor(params: { chainId: number; poolId?: string; reason?: string }) {
|
|
71
|
+
super(
|
|
72
|
+
params.poolId
|
|
73
|
+
? `Market with poolId ${params.poolId} not found on chain ${params.chainId}`
|
|
74
|
+
: `Market not found on chain ${params.chainId}`,
|
|
75
|
+
{ metaMessages: params.reason ? [params.reason] : undefined },
|
|
76
|
+
)
|
|
77
|
+
this.chainId = params.chainId
|
|
78
|
+
this.poolId = params.poolId
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export class ProviderNotConfiguredError extends ActionsError {
|
|
83
|
+
override name = 'ProviderNotConfiguredError' as const
|
|
84
|
+
provider: string
|
|
85
|
+
|
|
86
|
+
constructor(params: { provider: string; details?: string }) {
|
|
87
|
+
super(`A '${params.provider}' provider is not configured`, {
|
|
88
|
+
metaMessages: params.details ? [params.details] : undefined,
|
|
89
|
+
})
|
|
90
|
+
this.provider = params.provider
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export class MarketIdRequiredError extends ActionsError {
|
|
95
|
+
override name = 'MarketIdRequiredError' as const
|
|
96
|
+
|
|
97
|
+
constructor(details?: string) {
|
|
98
|
+
super('marketId is required', {
|
|
99
|
+
metaMessages: details ? [details] : undefined,
|
|
100
|
+
})
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
105
|
+
// Amount / Swap Parameters
|
|
106
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
107
|
+
|
|
108
|
+
export class AmountRequiredError extends ActionsError {
|
|
109
|
+
override name = 'AmountRequiredError' as const
|
|
110
|
+
|
|
111
|
+
constructor() {
|
|
112
|
+
super('Either amountIn or amountOut must be provided')
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
export class InvalidAmountError extends ActionsError {
|
|
117
|
+
override name = 'InvalidAmountError' as const
|
|
118
|
+
amount: number
|
|
119
|
+
|
|
120
|
+
constructor(amount: number) {
|
|
121
|
+
super('Amount must be positive', {
|
|
122
|
+
metaMessages: [`Received: ${amount}`],
|
|
123
|
+
})
|
|
124
|
+
this.amount = amount
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
export class ConflictingAmountsError extends ActionsError {
|
|
129
|
+
override name = 'ConflictingAmountsError' as const
|
|
130
|
+
|
|
131
|
+
constructor() {
|
|
132
|
+
super('Provide either amountIn or amountOut, not both')
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
export class SameAssetError extends ActionsError {
|
|
137
|
+
override name = 'SameAssetError' as const
|
|
138
|
+
symbol: string
|
|
139
|
+
|
|
140
|
+
constructor(symbol: string) {
|
|
141
|
+
super('Cannot swap an asset for itself', {
|
|
142
|
+
metaMessages: [`Asset: ${symbol}`],
|
|
143
|
+
})
|
|
144
|
+
this.symbol = symbol
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
export class QuoteExpiredError extends ActionsError {
|
|
149
|
+
override name = 'QuoteExpiredError' as const
|
|
150
|
+
expiresAt: number
|
|
151
|
+
currentTime: number
|
|
152
|
+
|
|
153
|
+
constructor(params: { expiresAt: number; currentTime: number }) {
|
|
154
|
+
super('Quote expired', {
|
|
155
|
+
metaMessages: [
|
|
156
|
+
`Expired at: ${params.expiresAt}`,
|
|
157
|
+
`Current time: ${params.currentTime}`,
|
|
158
|
+
],
|
|
159
|
+
})
|
|
160
|
+
this.expiresAt = params.expiresAt
|
|
161
|
+
this.currentTime = params.currentTime
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
export class ExactOutputNotSupportedError extends ActionsError {
|
|
166
|
+
override name = 'ExactOutputNotSupportedError' as const
|
|
167
|
+
provider: string
|
|
168
|
+
|
|
169
|
+
constructor(provider: string) {
|
|
170
|
+
super(`${provider} does not support exact-output swaps`, {
|
|
171
|
+
metaMessages: ['Provide amountIn instead of amountOut'],
|
|
172
|
+
})
|
|
173
|
+
this.provider = provider
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
178
|
+
// Address
|
|
179
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
180
|
+
|
|
181
|
+
export class AddressRequiredError extends ActionsError {
|
|
182
|
+
override name = 'AddressRequiredError' as const
|
|
183
|
+
label: string
|
|
184
|
+
|
|
185
|
+
constructor(label: string) {
|
|
186
|
+
super(`${label} is required`)
|
|
187
|
+
this.label = label
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
export class ZeroAddressError extends ActionsError {
|
|
192
|
+
override name = 'ZeroAddressError' as const
|
|
193
|
+
label: string
|
|
194
|
+
address?: string
|
|
195
|
+
|
|
196
|
+
constructor(label: string, address?: string) {
|
|
197
|
+
super(`${label} cannot be the zero address`, {
|
|
198
|
+
metaMessages: address ? [`Address: ${address}`] : undefined,
|
|
199
|
+
})
|
|
200
|
+
this.label = label
|
|
201
|
+
this.address = address
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
206
|
+
// Slippage
|
|
207
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
208
|
+
|
|
209
|
+
export class SlippageOutOfRangeError extends ActionsError {
|
|
210
|
+
override name = 'SlippageOutOfRangeError' as const
|
|
211
|
+
slippage: number
|
|
212
|
+
maxSlippage: number
|
|
213
|
+
|
|
214
|
+
constructor(slippage: number, maxSlippage: number) {
|
|
215
|
+
super(`Slippage ${slippage} is out of range`, {
|
|
216
|
+
metaMessages: [`Allowed range: [0, ${maxSlippage * 100}%]`],
|
|
217
|
+
})
|
|
218
|
+
this.slippage = slippage
|
|
219
|
+
this.maxSlippage = maxSlippage
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
224
|
+
// Asset
|
|
225
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
226
|
+
|
|
227
|
+
export class AssetNotSupportedOnChainError extends ActionsError {
|
|
228
|
+
override name = 'AssetNotSupportedOnChainError' as const
|
|
229
|
+
symbol: string
|
|
230
|
+
chainId: number
|
|
231
|
+
|
|
232
|
+
constructor(symbol: string, chainId: number) {
|
|
233
|
+
super(`Asset ${symbol} is not supported on chain ${chainId}`)
|
|
234
|
+
this.symbol = symbol
|
|
235
|
+
this.chainId = chainId
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
export class NativeAssetAddressError extends ActionsError {
|
|
240
|
+
override name = 'NativeAssetAddressError' as const
|
|
241
|
+
symbol: string
|
|
242
|
+
|
|
243
|
+
constructor(symbol: string) {
|
|
244
|
+
super(`${symbol} is a native asset and has no contract address`)
|
|
245
|
+
this.symbol = symbol
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
export class AssetMetadataRequiredError extends ActionsError {
|
|
250
|
+
override name = 'AssetMetadataRequiredError' as const
|
|
251
|
+
context?: string
|
|
252
|
+
|
|
253
|
+
constructor(context?: string) {
|
|
254
|
+
super('Asset metadata is required', {
|
|
255
|
+
metaMessages: context ? [context] : undefined,
|
|
256
|
+
})
|
|
257
|
+
this.context = context
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
262
|
+
// Generic input validation
|
|
263
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
264
|
+
|
|
265
|
+
/**
|
|
266
|
+
* Thrown when a caller-supplied parameter does not match the expected shape
|
|
267
|
+
* (wrong type, empty when non-empty is required, etc.). The `expected` string
|
|
268
|
+
* documents the type signature the caller should have produced.
|
|
269
|
+
*/
|
|
270
|
+
export class InvalidParamsError extends ActionsError {
|
|
271
|
+
override name = 'InvalidParamsError' as const
|
|
272
|
+
param: string
|
|
273
|
+
expected: string
|
|
274
|
+
received?: string
|
|
275
|
+
|
|
276
|
+
constructor(params: { param: string; expected: string; received?: string }) {
|
|
277
|
+
super(`Invalid params: ${params.param}`, {
|
|
278
|
+
metaMessages: [
|
|
279
|
+
`Expected: ${params.expected}`,
|
|
280
|
+
...(params.received ? [`Received: ${params.received}`] : []),
|
|
281
|
+
],
|
|
282
|
+
})
|
|
283
|
+
this.param = params.param
|
|
284
|
+
this.expected = params.expected
|
|
285
|
+
this.received = params.received
|
|
26
286
|
}
|
|
27
287
|
}
|
package/src/index.ts
CHANGED
|
@@ -1,4 +1,14 @@
|
|
|
1
1
|
export type { Actions } from '@/actions.js'
|
|
2
|
+
export { LendProvider, MorphoLendProvider } from '@/actions/lend/index.js'
|
|
3
|
+
export {
|
|
4
|
+
SwapProvider,
|
|
5
|
+
type UniswapMarketConfig,
|
|
6
|
+
UniswapSwapProvider,
|
|
7
|
+
type UniswapSwapProviderConfig,
|
|
8
|
+
type VelodromeMarketConfig,
|
|
9
|
+
VelodromeSwapProvider,
|
|
10
|
+
type VelodromeSwapProviderConfig,
|
|
11
|
+
} from '@/actions/swap/index.js'
|
|
2
12
|
export {
|
|
3
13
|
AAVE,
|
|
4
14
|
ARB,
|
|
@@ -59,17 +69,12 @@ export {
|
|
|
59
69
|
EnsResolutionError,
|
|
60
70
|
EnsRpcError,
|
|
61
71
|
type NameServiceProvider,
|
|
62
|
-
} from '@/ens/index.js'
|
|
63
|
-
export { LendProvider, MorphoLendProvider } from '@/lend/index.js'
|
|
72
|
+
} from '@/services/nameservices/ens/index.js'
|
|
64
73
|
export {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
type VelodromeMarketConfig,
|
|
70
|
-
VelodromeSwapProvider,
|
|
71
|
-
type VelodromeSwapProviderConfig,
|
|
72
|
-
} from '@/swap/index.js'
|
|
74
|
+
type EnsName,
|
|
75
|
+
isEnsName,
|
|
76
|
+
resolveAddress,
|
|
77
|
+
} from '@/services/nameservices/ens/utils.js'
|
|
73
78
|
export type {
|
|
74
79
|
ActionsConfig,
|
|
75
80
|
ApyBreakdown,
|
|
@@ -82,7 +87,6 @@ export type {
|
|
|
82
87
|
LendMarketMetadata,
|
|
83
88
|
LendMarketPosition,
|
|
84
89
|
LendMarketSupply,
|
|
85
|
-
LendOptions,
|
|
86
90
|
LendProviderConfig,
|
|
87
91
|
LendTransaction,
|
|
88
92
|
LendTransactionReceipt,
|
|
@@ -103,11 +107,13 @@ export type {
|
|
|
103
107
|
SwapTransaction,
|
|
104
108
|
TokenBalance,
|
|
105
109
|
TransactionData,
|
|
110
|
+
TransactionOptions,
|
|
106
111
|
UserOperationTransactionReceipt,
|
|
107
112
|
WalletConfig,
|
|
108
113
|
WalletSwapParams,
|
|
109
114
|
} from '@/types/index.js'
|
|
110
115
|
export { getAssetAddress, isAssetSupportedOnChain } from '@/utils/assets.js'
|
|
111
|
-
export {
|
|
116
|
+
export { serializeBigInt } from '@/utils/serializers.js'
|
|
117
|
+
export * from '@/wallet/core/error/errors.js'
|
|
112
118
|
export { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
|
|
113
119
|
export { SmartWallet } from '@/wallet/core/wallets/smart/abstract/SmartWallet.js'
|
|
@@ -13,6 +13,7 @@ import type { BundlerClient, SmartAccount } from 'viem/account-abstraction'
|
|
|
13
13
|
import { createBundlerClient } from 'viem/account-abstraction'
|
|
14
14
|
|
|
15
15
|
import type { SupportedChainId } from '@/constants/supportedChains.js'
|
|
16
|
+
import { ChainNotSupportedError } from '@/core/error/errors.js'
|
|
16
17
|
import type { ChainConfig } from '@/types/chain.js'
|
|
17
18
|
|
|
18
19
|
/**
|
|
@@ -44,7 +45,10 @@ export class ChainManager {
|
|
|
44
45
|
getPublicClient(chainId: SupportedChainId): PublicClient {
|
|
45
46
|
const client = this.publicClients.get(chainId)
|
|
46
47
|
if (!client) {
|
|
47
|
-
throw new
|
|
48
|
+
throw new ChainNotSupportedError({
|
|
49
|
+
chainId,
|
|
50
|
+
supportedChainIds: this.getSupportedChains(),
|
|
51
|
+
})
|
|
48
52
|
}
|
|
49
53
|
return client
|
|
50
54
|
}
|
|
@@ -73,7 +77,10 @@ export class ChainManager {
|
|
|
73
77
|
const chainConfig = this.getChainConfig(chainId)
|
|
74
78
|
const bundlerConfig = chainConfig.bundler
|
|
75
79
|
if (!bundlerConfig) {
|
|
76
|
-
throw new
|
|
80
|
+
throw new ChainNotSupportedError({
|
|
81
|
+
chainId,
|
|
82
|
+
supportedChainIds: this.getSupportedChains(),
|
|
83
|
+
})
|
|
77
84
|
}
|
|
78
85
|
if (bundlerConfig.type === 'pimlico') {
|
|
79
86
|
return this.getPimlicoBundlerClient(
|
|
@@ -84,7 +91,10 @@ export class ChainManager {
|
|
|
84
91
|
}
|
|
85
92
|
const bundlerUrl = this.getBundlerUrl(chainId)
|
|
86
93
|
if (!bundlerUrl) {
|
|
87
|
-
throw new
|
|
94
|
+
throw new ChainNotSupportedError({
|
|
95
|
+
chainId,
|
|
96
|
+
supportedChainIds: this.getSupportedChains(),
|
|
97
|
+
})
|
|
88
98
|
}
|
|
89
99
|
const client = createPublicClient({
|
|
90
100
|
chain: this.getChain(chainId),
|
|
@@ -118,7 +128,10 @@ export class ChainManager {
|
|
|
118
128
|
getBundlerUrl(chainId: SupportedChainId): string | undefined {
|
|
119
129
|
const chainConfig = this.getChainConfig(chainId)
|
|
120
130
|
if (!chainConfig.bundler) {
|
|
121
|
-
throw new
|
|
131
|
+
throw new ChainNotSupportedError({
|
|
132
|
+
chainId,
|
|
133
|
+
supportedChainIds: this.getSupportedChains(),
|
|
134
|
+
})
|
|
122
135
|
}
|
|
123
136
|
return chainConfig.bundler.url
|
|
124
137
|
}
|
|
@@ -167,12 +180,13 @@ export class ChainManager {
|
|
|
167
180
|
for (const chainConfig of chains) {
|
|
168
181
|
const chain = chainById[chainConfig.chainId]
|
|
169
182
|
if (!chain) {
|
|
170
|
-
throw new
|
|
183
|
+
throw new ChainNotSupportedError({ chainId: chainConfig.chainId })
|
|
171
184
|
}
|
|
172
185
|
if (clients.has(chainConfig.chainId)) {
|
|
173
|
-
throw new
|
|
174
|
-
|
|
175
|
-
|
|
186
|
+
throw new ChainNotSupportedError({
|
|
187
|
+
chainId: chainConfig.chainId,
|
|
188
|
+
supportedChainIds: Array.from(clients.keys()),
|
|
189
|
+
})
|
|
176
190
|
}
|
|
177
191
|
const client = createPublicClient({
|
|
178
192
|
chain,
|
|
@@ -193,7 +207,10 @@ export class ChainManager {
|
|
|
193
207
|
private getChainConfig(chainId: SupportedChainId): ChainConfig {
|
|
194
208
|
const chainConfig = this.chainConfigs.find((c) => c.chainId === chainId)
|
|
195
209
|
if (!chainConfig) {
|
|
196
|
-
throw new
|
|
210
|
+
throw new ChainNotSupportedError({
|
|
211
|
+
chainId,
|
|
212
|
+
supportedChainIds: this.getSupportedChains(),
|
|
213
|
+
})
|
|
197
214
|
}
|
|
198
215
|
return chainConfig
|
|
199
216
|
}
|