@eth-optimism/actions-sdk 0.4.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 +33 -18
- package/dist/actions/swap/core/SwapProvider.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/core/SwapProvider.js +59 -44
- 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 +27 -28
- package/dist/actions/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
- package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.js +73 -69
- 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/actions/swap/namespaces/WalletSwapNamespace.js +109 -0
- 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 +6 -6
- 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 +9 -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 +10 -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 +40 -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 +12 -2
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +56 -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 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -2
- package/dist/index.js.map +1 -1
- package/dist/services/ChainManager.d.ts +7 -0
- package/dist/services/ChainManager.d.ts.map +1 -1
- package/dist/services/ChainManager.js +35 -7
- package/dist/services/ChainManager.js.map +1 -1
- package/dist/services/__mocks__/MockChainManager.d.ts +1 -0
- package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
- package/dist/services/__mocks__/MockChainManager.js +5 -0
- package/dist/services/__mocks__/MockChainManager.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/services/nameservices/ens/EnsNamespace.d.ts +57 -0
- package/dist/services/nameservices/ens/EnsNamespace.d.ts.map +1 -0
- package/dist/services/nameservices/ens/EnsNamespace.js +158 -0
- package/dist/services/nameservices/ens/EnsNamespace.js.map +1 -0
- package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts +2 -0
- package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts.map +1 -0
- package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js +144 -0
- 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/services/nameservices/ens/__tests__/utils.spec.js +75 -0
- package/dist/services/nameservices/ens/__tests__/utils.spec.js.map +1 -0
- package/dist/services/nameservices/ens/errors.d.ts +24 -0
- package/dist/services/nameservices/ens/errors.d.ts.map +1 -0
- package/dist/services/nameservices/ens/errors.js +35 -0
- package/dist/services/nameservices/ens/errors.js.map +1 -0
- package/dist/services/nameservices/ens/index.d.ts +5 -0
- package/dist/services/nameservices/ens/index.d.ts.map +1 -0
- package/dist/services/nameservices/ens/index.js +5 -0
- package/dist/services/nameservices/ens/index.js.map +1 -0
- package/dist/services/nameservices/ens/types.d.ts +63 -0
- package/dist/services/nameservices/ens/types.d.ts.map +1 -0
- package/dist/services/nameservices/ens/types.js +14 -0
- package/dist/services/nameservices/ens/types.js.map +1 -0
- package/dist/services/nameservices/ens/utils.d.ts +25 -0
- package/dist/services/nameservices/ens/utils.d.ts.map +1 -0
- package/dist/services/nameservices/ens/utils.js +53 -0
- 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 +29 -16
- 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 +13 -1
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +38 -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 +15 -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 +99 -65
- 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 +127 -109
- package/src/actions/swap/namespaces/WalletSwapNamespace.ts +154 -0
- package/src/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.ts +10 -6
- package/src/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.ts +110 -22
- package/src/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.ts +37 -15
- 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 +74 -32
- 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 +47 -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 +82 -36
- package/src/core/error/__tests__/errors.test.ts +236 -0
- package/src/core/error/errors.ts +282 -22
- package/src/index.ts +25 -10
- package/src/services/ChainManager.ts +36 -9
- package/src/services/__mocks__/MockChainManager.ts +8 -0
- 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/services/nameservices/ens/EnsNamespace.ts +210 -0
- package/src/services/nameservices/ens/__tests__/EnsNamespace.spec.ts +173 -0
- package/src/services/nameservices/ens/__tests__/utils.spec.ts +105 -0
- package/src/services/nameservices/ens/errors.ts +45 -0
- package/src/services/nameservices/ens/index.ts +17 -0
- package/src/services/nameservices/ens/types.ts +76 -0
- package/src/services/nameservices/ens/utils.ts +85 -0
- 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 +29 -16
- 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 +53 -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 +19 -14
- 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/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 -34
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +0 -1
- package/dist/swap/namespaces/WalletSwapNamespace.js +0 -84
- 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/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 -121
- 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/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/utils/{assets.test.ts → __tests__/assets.test.ts} +0 -0
- /package/src/{core → wallet/core}/utils/retryOnStaleRead.ts +0 -0
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
import { BaseLendNamespace } from '@/actions/lend/namespaces/BaseLendNamespace.js'
|
|
1
2
|
import type { SupportedChainId } from '@/constants/supportedChains.js'
|
|
3
|
+
import { MarketIdRequiredError } from '@/core/error/errors.js'
|
|
2
4
|
import type {
|
|
3
5
|
ClosePositionParams,
|
|
4
6
|
GetPositionParams,
|
|
@@ -7,10 +9,10 @@ import type {
|
|
|
7
9
|
LendTransaction,
|
|
8
10
|
LendTransactionReceipt,
|
|
9
11
|
} from '@/types/lend/index.js'
|
|
12
|
+
import type { LendProviders } from '@/types/providers.js'
|
|
13
|
+
import { executeTransactionBatch } from '@/wallet/core/utils/executeTransactionBatch.js'
|
|
10
14
|
import type { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
|
|
11
15
|
|
|
12
|
-
import { BaseLendNamespace, type LendProviders } from './BaseLendNamespace.js'
|
|
13
|
-
|
|
14
16
|
/**
|
|
15
17
|
* Wallet Lend Namespace
|
|
16
18
|
* @description Full lending operations available on wallet.lend
|
|
@@ -27,8 +29,6 @@ export class WalletLendNamespace extends BaseLendNamespace {
|
|
|
27
29
|
* Open a lending position
|
|
28
30
|
* @description Signs and sends a lend transaction from the wallet for the given amount and asset
|
|
29
31
|
* @param params - Lending position parameters
|
|
30
|
-
* @param params.marketId - Market identifier to open position in
|
|
31
|
-
* @param params.amount - Amount to lend
|
|
32
32
|
* @returns Promise resolving to transaction receipt
|
|
33
33
|
*/
|
|
34
34
|
async openPosition(
|
|
@@ -41,19 +41,17 @@ export class WalletLendNamespace extends BaseLendNamespace {
|
|
|
41
41
|
walletAddress: this.wallet.address,
|
|
42
42
|
})
|
|
43
43
|
|
|
44
|
-
return this.
|
|
44
|
+
return this.dispatch(lendTransaction, params.marketId.chainId)
|
|
45
45
|
}
|
|
46
46
|
|
|
47
47
|
/**
|
|
48
48
|
* Get position information for this wallet
|
|
49
49
|
* @param params - Position query parameters
|
|
50
|
-
* @param params.marketId - Market identifier (required)
|
|
51
|
-
* @param params.asset - Asset filter (not yet supported)
|
|
52
50
|
* @returns Promise resolving to position information
|
|
53
51
|
*/
|
|
54
52
|
async getPosition(params: GetPositionParams): Promise<LendMarketPosition> {
|
|
55
53
|
if (!params.marketId) {
|
|
56
|
-
throw new
|
|
54
|
+
throw new MarketIdRequiredError()
|
|
57
55
|
}
|
|
58
56
|
|
|
59
57
|
const provider = this.getProviderForMarket(params.marketId)
|
|
@@ -68,8 +66,6 @@ export class WalletLendNamespace extends BaseLendNamespace {
|
|
|
68
66
|
/**
|
|
69
67
|
* Close a lending position (withdraw from market)
|
|
70
68
|
* @param params - Position closing parameters
|
|
71
|
-
* @param params.marketId - Market identifier to close position in
|
|
72
|
-
* @param params.amount - Amount to withdraw
|
|
73
69
|
* @returns Promise resolving to transaction receipt
|
|
74
70
|
*/
|
|
75
71
|
async closePosition(
|
|
@@ -82,25 +78,22 @@ export class WalletLendNamespace extends BaseLendNamespace {
|
|
|
82
78
|
walletAddress: this.wallet.address,
|
|
83
79
|
})
|
|
84
80
|
|
|
85
|
-
return this.
|
|
81
|
+
return this.dispatch(closeTransaction, params.marketId.chainId)
|
|
86
82
|
}
|
|
87
83
|
|
|
88
84
|
/**
|
|
89
|
-
*
|
|
85
|
+
* Send a lend transaction, batching an ERC-20 approval ahead of the
|
|
86
|
+
* position call when one was provided by the provider. Defers to
|
|
87
|
+
* `executeTransactionBatch` for the actual 1-vs-N send/sendBatch dispatch.
|
|
90
88
|
*/
|
|
91
|
-
private
|
|
89
|
+
private dispatch(
|
|
92
90
|
transaction: LendTransaction,
|
|
93
91
|
chainId: SupportedChainId,
|
|
94
92
|
): Promise<LendTransactionReceipt> {
|
|
95
93
|
const { transactionData } = transaction
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
chainId,
|
|
101
|
-
)
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
return this.wallet.send(transactionData.position, chainId)
|
|
94
|
+
const txs = transactionData.approval
|
|
95
|
+
? [transactionData.approval, transactionData.position]
|
|
96
|
+
: [transactionData.position]
|
|
97
|
+
return executeTransactionBatch(this.wallet, txs, chainId)
|
|
105
98
|
}
|
|
106
99
|
}
|
|
@@ -2,9 +2,9 @@ import type { Address } from 'viem'
|
|
|
2
2
|
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
3
3
|
|
|
4
4
|
import { getRandomAddress } from '@/__mocks__/utils.js'
|
|
5
|
-
import type { MockLendProvider } from '@/lend/__mocks__/MockLendProvider.js'
|
|
6
|
-
import { createMockLendProvider } from '@/lend/__mocks__/MockLendProvider.js'
|
|
7
|
-
import { ActionsLendNamespace } from '@/lend/namespaces/ActionsLendNamespace.js'
|
|
5
|
+
import type { MockLendProvider } from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
6
|
+
import { createMockLendProvider } from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
7
|
+
import { ActionsLendNamespace } from '@/actions/lend/namespaces/ActionsLendNamespace.js'
|
|
8
8
|
|
|
9
9
|
describe('ActionsLendNamespace', () => {
|
|
10
10
|
let mockProvider: MockLendProvider
|
|
@@ -2,12 +2,12 @@ import type { Address } from 'viem'
|
|
|
2
2
|
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
3
3
|
|
|
4
4
|
import { getRandomAddress } from '@/__mocks__/utils.js'
|
|
5
|
-
import type { MockLendProvider } from '@/lend/__mocks__/MockLendProvider.js'
|
|
5
|
+
import type { MockLendProvider } from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
6
6
|
import {
|
|
7
7
|
createMockLendProvider,
|
|
8
8
|
MockLendProvider as MockLendProviderClass,
|
|
9
|
-
} from '@/lend/__mocks__/MockLendProvider.js'
|
|
10
|
-
import { BaseLendNamespace } from '@/lend/namespaces/BaseLendNamespace.js'
|
|
9
|
+
} from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
10
|
+
import { BaseLendNamespace } from '@/actions/lend/namespaces/BaseLendNamespace.js'
|
|
11
11
|
import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
|
|
12
12
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
13
13
|
|
|
@@ -3,9 +3,9 @@ import type { WaitForUserOperationReceiptReturnType } from 'viem/account-abstrac
|
|
|
3
3
|
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
4
4
|
|
|
5
5
|
import { getRandomAddress } from '@/__mocks__/utils.js'
|
|
6
|
-
import type { MockLendProvider } from '@/lend/__mocks__/MockLendProvider.js'
|
|
7
|
-
import { createMockLendProvider } from '@/lend/__mocks__/MockLendProvider.js'
|
|
8
|
-
import { WalletLendNamespace } from '@/lend/namespaces/WalletLendNamespace.js'
|
|
6
|
+
import type { MockLendProvider } from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
7
|
+
import { createMockLendProvider } from '@/actions/lend/__mocks__/MockLendProvider.js'
|
|
8
|
+
import { WalletLendNamespace } from '@/actions/lend/namespaces/WalletLendNamespace.js'
|
|
9
9
|
import type { TransactionData } from '@/types/lend/index.js'
|
|
10
10
|
import { createMock as createSmartWalletMock } from '@/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.js'
|
|
11
11
|
import type { SmartWallet } from '@/wallet/core/wallets/smart/abstract/SmartWallet.js'
|
|
@@ -121,7 +121,7 @@ describe('WalletLendNamespace', () => {
|
|
|
121
121
|
const marketId = mockMarketId
|
|
122
122
|
const mockTransaction = {
|
|
123
123
|
amount: 1000000000n,
|
|
124
|
-
|
|
124
|
+
assetAddress: mockAsset.address[130] as Address,
|
|
125
125
|
marketId: marketId.address,
|
|
126
126
|
apy: 0.05,
|
|
127
127
|
transactionData: {
|
|
@@ -169,7 +169,7 @@ describe('WalletLendNamespace', () => {
|
|
|
169
169
|
|
|
170
170
|
const mockTransaction = {
|
|
171
171
|
amount: 100n,
|
|
172
|
-
|
|
172
|
+
assetAddress: getRandomAddress(),
|
|
173
173
|
marketId: closeParams.marketId.address,
|
|
174
174
|
apy: 0.05,
|
|
175
175
|
transactionData: {
|
|
@@ -234,7 +234,7 @@ describe('WalletLendNamespace', () => {
|
|
|
234
234
|
}
|
|
235
235
|
const mockTransaction = {
|
|
236
236
|
amount: 1000000000n,
|
|
237
|
-
|
|
237
|
+
assetAddress: mockAsset.address[130] as Address,
|
|
238
238
|
marketId: marketId.address,
|
|
239
239
|
apy: 0.05,
|
|
240
240
|
timestamp: Date.now(),
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type { Address } from 'viem'
|
|
2
2
|
import { encodeFunctionData, erc20Abi, formatUnits } from 'viem'
|
|
3
3
|
|
|
4
|
+
import { LendProvider } from '@/actions/lend/core/LendProvider.js'
|
|
4
5
|
import { WETH } from '@/constants/assets.js'
|
|
5
|
-
import {
|
|
6
|
+
import { ChainNotSupportedError } from '@/core/error/errors.js'
|
|
6
7
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
7
|
-
import type { LendProviderConfig } from '@/types/actions.js'
|
|
8
|
+
import type { LendProviderConfig, LendSettings } from '@/types/actions.js'
|
|
8
9
|
import type {
|
|
9
10
|
GetLendMarketsParams,
|
|
10
11
|
GetMarketBalanceParams,
|
|
@@ -12,6 +13,7 @@ import type {
|
|
|
12
13
|
LendMarket,
|
|
13
14
|
LendMarketId,
|
|
14
15
|
LendMarketPosition,
|
|
16
|
+
LendOpenPosition,
|
|
15
17
|
LendOpenPositionInternalParams,
|
|
16
18
|
LendTransaction,
|
|
17
19
|
} from '@/types/lend/index.js'
|
|
@@ -30,35 +32,38 @@ import { getATokenAddress, getReserve, getReserves } from './sdk.js'
|
|
|
30
32
|
* @description Lending provider implementation using Aave V3 protocol
|
|
31
33
|
*/
|
|
32
34
|
export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
+
constructor(
|
|
36
|
+
config: LendProviderConfig,
|
|
37
|
+
chainManager: ChainManager,
|
|
38
|
+
settings?: LendSettings,
|
|
39
|
+
) {
|
|
40
|
+
super(config, chainManager, settings)
|
|
35
41
|
}
|
|
36
42
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
* @param config - Aave lending configuration
|
|
40
|
-
* @param chainManager - Chain manager for blockchain interactions
|
|
41
|
-
*/
|
|
42
|
-
constructor(config: LendProviderConfig, chainManager: ChainManager) {
|
|
43
|
-
super(config, chainManager)
|
|
43
|
+
protocolSupportedChainIds(): number[] {
|
|
44
|
+
return getSupportedChainIds()
|
|
44
45
|
}
|
|
45
46
|
|
|
46
47
|
/**
|
|
47
|
-
*
|
|
48
|
-
*
|
|
49
|
-
*
|
|
50
|
-
*
|
|
48
|
+
* Describe an Aave deposit. The base class wraps this into a
|
|
49
|
+
* `LendTransaction` with the appropriate ERC-20 approval based on
|
|
50
|
+
* `params.approvalMode`. Native-ETH paths return `spender: undefined` since
|
|
51
|
+
* deposits via the WETHGateway send value as `msg.value` rather than via
|
|
52
|
+
* `transferFrom`.
|
|
53
|
+
* @param params - Position opening parameters (amount in wei, walletAddress, approvalMode)
|
|
54
|
+
* @returns Spender + deposit calldata + APY snapshot
|
|
51
55
|
*/
|
|
52
56
|
protected async _openPosition(
|
|
53
57
|
params: LendOpenPositionInternalParams,
|
|
54
|
-
): Promise<
|
|
58
|
+
): Promise<LendOpenPosition> {
|
|
55
59
|
try {
|
|
56
60
|
// Get Pool address for this chain
|
|
57
61
|
const poolAddress = getPoolAddress(params.marketId.chainId)
|
|
58
62
|
if (!poolAddress) {
|
|
59
|
-
throw new
|
|
60
|
-
|
|
61
|
-
|
|
63
|
+
throw new ChainNotSupportedError({
|
|
64
|
+
chainId: params.marketId.chainId,
|
|
65
|
+
supportedChainIds: this.supportedChainIds(),
|
|
66
|
+
})
|
|
62
67
|
}
|
|
63
68
|
|
|
64
69
|
// Get market information for APY
|
|
@@ -67,13 +72,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
67
72
|
chainId: params.marketId.chainId,
|
|
68
73
|
})
|
|
69
74
|
|
|
70
|
-
// Check if this is a native ETH market
|
|
71
75
|
if (isNativeAsset(params.asset)) {
|
|
72
|
-
return this.
|
|
76
|
+
return this._buildETHOpenPosition(params, poolAddress, marketInfo)
|
|
73
77
|
}
|
|
74
|
-
|
|
75
|
-
// Standard ERC-20 flow
|
|
76
|
-
return this._openERC20Position(params, poolAddress, marketInfo)
|
|
78
|
+
return this._buildERC20OpenPosition(params, poolAddress, marketInfo)
|
|
77
79
|
} catch {
|
|
78
80
|
throw new Error(
|
|
79
81
|
`Failed to open position with ${params.amountWei} of ${params.asset.metadata.symbol}`,
|
|
@@ -94,9 +96,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
94
96
|
// Get Pool address for this chain
|
|
95
97
|
const poolAddress = getPoolAddress(params.marketId.chainId)
|
|
96
98
|
if (!poolAddress) {
|
|
97
|
-
throw new
|
|
98
|
-
|
|
99
|
-
|
|
99
|
+
throw new ChainNotSupportedError({
|
|
100
|
+
chainId: params.marketId.chainId,
|
|
101
|
+
supportedChainIds: this.supportedChainIds(),
|
|
102
|
+
})
|
|
100
103
|
}
|
|
101
104
|
|
|
102
105
|
const marketInfo = await this.getMarket({
|
|
@@ -162,9 +165,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
162
165
|
const poolAddress = getPoolAddress(params.marketId.chainId)
|
|
163
166
|
|
|
164
167
|
if (!poolAddress) {
|
|
165
|
-
throw new
|
|
166
|
-
|
|
167
|
-
|
|
168
|
+
throw new ChainNotSupportedError({
|
|
169
|
+
chainId: params.marketId.chainId,
|
|
170
|
+
supportedChainIds: this.supportedChainIds(),
|
|
171
|
+
})
|
|
168
172
|
}
|
|
169
173
|
|
|
170
174
|
// Get the aToken address from Pool.getReserveData
|
|
@@ -206,22 +210,22 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
206
210
|
}
|
|
207
211
|
|
|
208
212
|
/**
|
|
209
|
-
*
|
|
210
|
-
*
|
|
213
|
+
* Describe a native-ETH deposit via Aave's WETHGateway. ETH is sent as
|
|
214
|
+
* `msg.value` and wrapped to aWETH inline — no ERC-20 approval needed.
|
|
211
215
|
*/
|
|
212
|
-
private async
|
|
216
|
+
private async _buildETHOpenPosition(
|
|
213
217
|
params: LendOpenPositionInternalParams,
|
|
214
218
|
poolAddress: Address,
|
|
215
219
|
marketInfo: LendMarket,
|
|
216
|
-
): Promise<
|
|
220
|
+
): Promise<LendOpenPosition> {
|
|
217
221
|
const gatewayAddress = getWETHGatewayAddress(params.marketId.chainId)
|
|
218
222
|
if (!gatewayAddress) {
|
|
219
|
-
throw new
|
|
220
|
-
|
|
221
|
-
|
|
223
|
+
throw new ChainNotSupportedError({
|
|
224
|
+
chainId: params.marketId.chainId,
|
|
225
|
+
supportedChainIds: this.supportedChainIds(),
|
|
226
|
+
})
|
|
222
227
|
}
|
|
223
228
|
|
|
224
|
-
// Generate depositETH transaction
|
|
225
229
|
const depositCallData = encodeFunctionData({
|
|
226
230
|
abi: WETH_GATEWAY_ABI,
|
|
227
231
|
functionName: 'depositETH',
|
|
@@ -235,33 +239,28 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
235
239
|
const wethAddress = getAssetAddress(WETH, params.marketId.chainId)
|
|
236
240
|
|
|
237
241
|
return {
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
position: {
|
|
244
|
-
to: gatewayAddress,
|
|
245
|
-
data: depositCallData,
|
|
246
|
-
value: params.amountWei, // Send ETH as msg.value
|
|
247
|
-
},
|
|
242
|
+
assetAddress: wethAddress,
|
|
243
|
+
transaction: {
|
|
244
|
+
to: gatewayAddress,
|
|
245
|
+
data: depositCallData,
|
|
246
|
+
value: params.amountWei, // Send ETH as msg.value
|
|
248
247
|
},
|
|
248
|
+
apy: marketInfo.apy.total,
|
|
249
249
|
}
|
|
250
250
|
}
|
|
251
251
|
|
|
252
252
|
/**
|
|
253
|
-
*
|
|
254
|
-
*
|
|
253
|
+
* Describe a standard ERC-20 deposit. The base class builds the approval to
|
|
254
|
+
* `poolAddress` based on `params.approvalMode`.
|
|
255
255
|
*/
|
|
256
|
-
private async
|
|
256
|
+
private async _buildERC20OpenPosition(
|
|
257
257
|
params: LendOpenPositionInternalParams,
|
|
258
258
|
poolAddress: Address,
|
|
259
259
|
marketInfo: LendMarket,
|
|
260
|
-
): Promise<
|
|
260
|
+
): Promise<LendOpenPosition> {
|
|
261
261
|
// Get asset address for the chain (throws for native assets)
|
|
262
262
|
const assetAddress = getAssetAddress(params.asset, params.marketId.chainId)
|
|
263
263
|
|
|
264
|
-
// Generate supply transaction
|
|
265
264
|
const supplyCallData = encodeFunctionData({
|
|
266
265
|
abi: POOL_ABI,
|
|
267
266
|
functionName: 'supply',
|
|
@@ -274,22 +273,14 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
274
273
|
})
|
|
275
274
|
|
|
276
275
|
return {
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
assetAddress,
|
|
284
|
-
poolAddress,
|
|
285
|
-
params.amountWei,
|
|
286
|
-
),
|
|
287
|
-
position: {
|
|
288
|
-
to: poolAddress,
|
|
289
|
-
data: supplyCallData,
|
|
290
|
-
value: 0n,
|
|
291
|
-
},
|
|
276
|
+
spender: poolAddress,
|
|
277
|
+
assetAddress,
|
|
278
|
+
transaction: {
|
|
279
|
+
to: poolAddress,
|
|
280
|
+
data: supplyCallData,
|
|
281
|
+
value: 0n,
|
|
292
282
|
},
|
|
283
|
+
apy: marketInfo.apy.total,
|
|
293
284
|
}
|
|
294
285
|
}
|
|
295
286
|
|
|
@@ -304,9 +295,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
304
295
|
): Promise<LendTransaction> {
|
|
305
296
|
const gatewayAddress = getWETHGatewayAddress(params.marketId.chainId)
|
|
306
297
|
if (!gatewayAddress) {
|
|
307
|
-
throw new
|
|
308
|
-
|
|
309
|
-
|
|
298
|
+
throw new ChainNotSupportedError({
|
|
299
|
+
chainId: params.marketId.chainId,
|
|
300
|
+
supportedChainIds: this.supportedChainIds(),
|
|
301
|
+
})
|
|
310
302
|
}
|
|
311
303
|
|
|
312
304
|
const wethAddress = getAssetAddress(WETH, params.marketId.chainId)
|
|
@@ -331,7 +323,7 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
331
323
|
|
|
332
324
|
return {
|
|
333
325
|
amount: params.amount,
|
|
334
|
-
|
|
326
|
+
assetAddress: wethAddress,
|
|
335
327
|
marketId: params.marketId.address,
|
|
336
328
|
apy: marketInfo.apy.total,
|
|
337
329
|
transactionData: {
|
|
@@ -376,7 +368,7 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
376
368
|
|
|
377
369
|
return {
|
|
378
370
|
amount: params.amount,
|
|
379
|
-
|
|
371
|
+
assetAddress,
|
|
380
372
|
marketId: params.marketId.address,
|
|
381
373
|
apy: marketInfo.apy.total,
|
|
382
374
|
transactionData: {
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest'
|
|
2
2
|
|
|
3
|
-
import { MockReceiverAddress } from '@/lend/__mocks__/MockMarkets.js'
|
|
3
|
+
import { MockReceiverAddress } from '@/actions/lend/__mocks__/MockMarkets.js'
|
|
4
4
|
import {
|
|
5
5
|
createMockAaveReserve,
|
|
6
6
|
createMockWETHReserve,
|
|
7
|
-
} from '@/lend/providers/aave/__mocks__/mockReserve.js'
|
|
8
|
-
import { AaveLendProvider } from '@/lend/providers/aave/AaveLendProvider.js'
|
|
9
|
-
import * as aaveSdk from '@/lend/providers/aave/sdk.js'
|
|
7
|
+
} from '@/actions/lend/providers/aave/__mocks__/mockReserve.js'
|
|
8
|
+
import { AaveLendProvider } from '@/actions/lend/providers/aave/AaveLendProvider.js'
|
|
9
|
+
import * as aaveSdk from '@/actions/lend/providers/aave/sdk.js'
|
|
10
10
|
import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
|
|
11
11
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
12
12
|
import type { LendProviderConfig } from '@/types/actions.js'
|
|
13
13
|
import type { Asset, LendMarketConfig } from '@/types/index.js'
|
|
14
14
|
|
|
15
15
|
// Mock the Aave SDK modules
|
|
16
|
-
vi.mock('@/lend/providers/aave/sdk.js', () => ({
|
|
16
|
+
vi.mock('@/actions/lend/providers/aave/sdk.js', () => ({
|
|
17
17
|
getReserve: vi.fn(),
|
|
18
18
|
getReserves: vi.fn(),
|
|
19
19
|
getATokenAddress: vi.fn(),
|
|
@@ -139,7 +139,7 @@ describe('AaveLendProvider', () => {
|
|
|
139
139
|
|
|
140
140
|
expect(lendTransaction).toHaveProperty('amount', BigInt('1000000000'))
|
|
141
141
|
expect(lendTransaction).toHaveProperty(
|
|
142
|
-
'
|
|
142
|
+
'assetAddress',
|
|
143
143
|
asset.address[marketId.chainId],
|
|
144
144
|
)
|
|
145
145
|
expect(lendTransaction).toHaveProperty('marketId', marketId.address)
|
|
@@ -228,7 +228,7 @@ describe('AaveLendProvider', () => {
|
|
|
228
228
|
|
|
229
229
|
expect(withdrawTransaction).toHaveProperty('amount', BigInt('500000000'))
|
|
230
230
|
expect(withdrawTransaction).toHaveProperty(
|
|
231
|
-
'
|
|
231
|
+
'assetAddress',
|
|
232
232
|
asset.address[marketId.chainId],
|
|
233
233
|
)
|
|
234
234
|
expect(withdrawTransaction).toHaveProperty('marketId', marketId.address)
|
|
@@ -3,13 +3,17 @@ import { formatReserves } from '@aave/math-utils'
|
|
|
3
3
|
import { providers } from 'ethers'
|
|
4
4
|
import type { Address } from 'viem'
|
|
5
5
|
|
|
6
|
-
import {
|
|
7
|
-
import type { SupportedChainId } from '@/constants/supportedChains.js'
|
|
8
|
-
import { POOL_GET_RESERVE_DATA_ABI } from '@/lend/providers/aave/abis/pool.js'
|
|
6
|
+
import { POOL_GET_RESERVE_DATA_ABI } from '@/actions/lend/providers/aave/abis/pool.js'
|
|
9
7
|
import {
|
|
10
8
|
getAaveAddresses,
|
|
11
9
|
getPoolAddress,
|
|
12
|
-
} from '@/lend/providers/aave/addresses.js'
|
|
10
|
+
} from '@/actions/lend/providers/aave/addresses.js'
|
|
11
|
+
import { WETH } from '@/constants/assets.js'
|
|
12
|
+
import type { SupportedChainId } from '@/constants/supportedChains.js'
|
|
13
|
+
import {
|
|
14
|
+
ChainNotSupportedError,
|
|
15
|
+
MarketNotAllowedError,
|
|
16
|
+
} from '@/core/error/errors.js'
|
|
13
17
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
14
18
|
import type { LendProviderConfig } from '@/types/actions.js'
|
|
15
19
|
import type {
|
|
@@ -95,14 +99,16 @@ export async function getReserve(
|
|
|
95
99
|
: undefined
|
|
96
100
|
|
|
97
101
|
if (!marketConfig) {
|
|
98
|
-
throw new
|
|
99
|
-
|
|
100
|
-
|
|
102
|
+
throw new MarketNotAllowedError({
|
|
103
|
+
address: params.marketId.address,
|
|
104
|
+
chainId: params.marketId.chainId,
|
|
105
|
+
reason: 'Market not found in allowlist',
|
|
106
|
+
})
|
|
101
107
|
}
|
|
102
108
|
|
|
103
109
|
const addresses = getAaveAddresses(params.marketId.chainId)
|
|
104
110
|
if (!addresses) {
|
|
105
|
-
throw new
|
|
111
|
+
throw new ChainNotSupportedError({ chainId: params.marketId.chainId })
|
|
106
112
|
}
|
|
107
113
|
|
|
108
114
|
const poolAddress = addresses.pool
|
|
@@ -244,7 +250,7 @@ export async function getATokenAddress(params: {
|
|
|
244
250
|
}): Promise<Address> {
|
|
245
251
|
const poolAddress = getPoolAddress(params.chainId)
|
|
246
252
|
if (!poolAddress) {
|
|
247
|
-
throw new
|
|
253
|
+
throw new ChainNotSupportedError({ chainId: params.chainId })
|
|
248
254
|
}
|
|
249
255
|
|
|
250
256
|
try {
|