@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
|
@@ -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 {
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { MetaMorphoAction } from '@morpho-org/blue-sdk-viem'
|
|
2
|
-
import { erc20Abi, formatUnits } from 'viem'
|
|
2
|
+
import { erc20Abi, erc4626Abi, formatUnits, type PublicClient } from 'viem'
|
|
3
3
|
|
|
4
|
-
import { LendProvider } from '@/lend/core/LendProvider.js'
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
4
|
+
import { LendProvider } from '@/actions/lend/core/LendProvider.js'
|
|
5
|
+
import { getVault, getVaults } from '@/actions/lend/providers/morpho/sdk.js'
|
|
6
|
+
import { findMarketInAllowlist } from '@/actions/lend/utils/markets.js'
|
|
7
|
+
import { getSupportedChainIds as getMorphoSupportedChainIds } from '@/actions/shared/morpho/contracts.js'
|
|
7
8
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
8
|
-
import type { LendProviderConfig } from '@/types/actions.js'
|
|
9
|
+
import type { LendProviderConfig, LendSettings } from '@/types/actions.js'
|
|
9
10
|
import type {
|
|
10
11
|
GetLendMarketsParams,
|
|
11
12
|
GetMarketBalanceParams,
|
|
@@ -13,6 +14,7 @@ import type {
|
|
|
13
14
|
LendMarket,
|
|
14
15
|
LendMarketId,
|
|
15
16
|
LendMarketPosition,
|
|
17
|
+
LendOpenPosition,
|
|
16
18
|
LendOpenPositionInternalParams,
|
|
17
19
|
LendTransaction,
|
|
18
20
|
} from '@/types/lend/index.js'
|
|
@@ -23,28 +25,28 @@ import { getAssetAddress } from '@/utils/assets.js'
|
|
|
23
25
|
* @description Lending provider implementation using Morpho protocol
|
|
24
26
|
*/
|
|
25
27
|
export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
+
constructor(
|
|
29
|
+
config: LendProviderConfig,
|
|
30
|
+
chainManager: ChainManager,
|
|
31
|
+
settings?: LendSettings,
|
|
32
|
+
) {
|
|
33
|
+
super(config, chainManager, settings)
|
|
28
34
|
}
|
|
29
35
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
* @param config - Morpho lending configuration
|
|
33
|
-
* @param chainManager - Chain manager for blockchain interactions
|
|
34
|
-
*/
|
|
35
|
-
constructor(config: LendProviderConfig, chainManager: ChainManager) {
|
|
36
|
-
super(config, chainManager)
|
|
36
|
+
protocolSupportedChainIds(): number[] {
|
|
37
|
+
return getMorphoSupportedChainIds()
|
|
37
38
|
}
|
|
38
39
|
|
|
39
40
|
/**
|
|
40
|
-
*
|
|
41
|
-
*
|
|
42
|
-
*
|
|
43
|
-
* @
|
|
41
|
+
* Describe a Morpho deposit. The base class wraps this into a
|
|
42
|
+
* `LendTransaction` with the appropriate ERC-20 approval based on
|
|
43
|
+
* `params.approvalMode`.
|
|
44
|
+
* @param params - Position opening parameters (amount in wei, walletAddress, approvalMode)
|
|
45
|
+
* @returns Spender + deposit calldata + APY snapshot
|
|
44
46
|
*/
|
|
45
47
|
protected async _openPosition(
|
|
46
48
|
params: LendOpenPositionInternalParams,
|
|
47
|
-
): Promise<
|
|
49
|
+
): Promise<LendOpenPosition> {
|
|
48
50
|
try {
|
|
49
51
|
// Get asset address for the chain (throws for native assets)
|
|
50
52
|
const assetAddress = getAssetAddress(
|
|
@@ -58,27 +60,20 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
58
60
|
chainId: params.marketId.chainId,
|
|
59
61
|
})
|
|
60
62
|
|
|
61
|
-
const
|
|
62
|
-
|
|
63
|
-
|
|
63
|
+
const depositCallData = MetaMorphoAction.deposit(
|
|
64
|
+
params.amountWei,
|
|
65
|
+
params.walletAddress,
|
|
66
|
+
)
|
|
64
67
|
|
|
65
68
|
return {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
assetAddress,
|
|
73
|
-
params.marketId.address,
|
|
74
|
-
params.amountWei,
|
|
75
|
-
),
|
|
76
|
-
position: {
|
|
77
|
-
to: params.marketId.address,
|
|
78
|
-
data: depositCallData,
|
|
79
|
-
value: 0n,
|
|
80
|
-
},
|
|
69
|
+
spender: params.marketId.address,
|
|
70
|
+
assetAddress,
|
|
71
|
+
transaction: {
|
|
72
|
+
to: params.marketId.address,
|
|
73
|
+
data: depositCallData,
|
|
74
|
+
value: 0n,
|
|
81
75
|
},
|
|
76
|
+
apy: vaultInfo.apy.total,
|
|
82
77
|
}
|
|
83
78
|
} catch {
|
|
84
79
|
throw new Error(
|
|
@@ -119,7 +114,7 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
119
114
|
|
|
120
115
|
return {
|
|
121
116
|
amount: params.amount,
|
|
122
|
-
|
|
117
|
+
assetAddress,
|
|
123
118
|
marketId: params.marketId.address,
|
|
124
119
|
apy: vaultInfo.apy.total,
|
|
125
120
|
transactionData: {
|
|
@@ -180,6 +175,10 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
180
175
|
const publicClient = this.chainManager.getPublicClient(
|
|
181
176
|
params.marketId.chainId,
|
|
182
177
|
)
|
|
178
|
+
const underlyingDecimals = await this.resolveUnderlyingDecimals(
|
|
179
|
+
publicClient,
|
|
180
|
+
params.marketId,
|
|
181
|
+
)
|
|
183
182
|
|
|
184
183
|
// Get user's market token balance (shares in the vault)
|
|
185
184
|
const shares = await publicClient.readContract({
|
|
@@ -192,28 +191,17 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
192
191
|
// Convert shares to underlying asset balance using convertToAssets
|
|
193
192
|
const balance = await publicClient.readContract({
|
|
194
193
|
address: params.marketId.address,
|
|
195
|
-
abi:
|
|
196
|
-
{
|
|
197
|
-
name: 'convertToAssets',
|
|
198
|
-
type: 'function',
|
|
199
|
-
stateMutability: 'view',
|
|
200
|
-
inputs: [{ name: 'shares', type: 'uint256' }],
|
|
201
|
-
outputs: [{ name: '', type: 'uint256' }],
|
|
202
|
-
},
|
|
203
|
-
],
|
|
194
|
+
abi: erc4626Abi,
|
|
204
195
|
functionName: 'convertToAssets',
|
|
205
196
|
args: [shares],
|
|
206
197
|
})
|
|
207
198
|
|
|
208
|
-
// Format the balances (USDC has 6 decimals)
|
|
209
|
-
const balanceFormatted = formatUnits(balance, 6)
|
|
210
|
-
const sharesFormatted = formatUnits(shares, 18) // Vault shares typically have 18 decimals
|
|
211
|
-
|
|
212
199
|
return {
|
|
213
200
|
balance,
|
|
214
|
-
balanceFormatted,
|
|
201
|
+
balanceFormatted: formatUnits(balance, underlyingDecimals),
|
|
215
202
|
shares,
|
|
216
|
-
|
|
203
|
+
// MetaMorpho vault shares are 18 decimals by contract invariant
|
|
204
|
+
sharesFormatted: formatUnits(shares, 18),
|
|
217
205
|
marketId: params.marketId,
|
|
218
206
|
}
|
|
219
207
|
} catch {
|
|
@@ -222,4 +210,30 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
222
210
|
)
|
|
223
211
|
}
|
|
224
212
|
}
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* Resolve the underlying asset decimals for a market.
|
|
216
|
+
* @description Prefers the allowlisted market config (free, no RPC).
|
|
217
|
+
* Falls back to an on-chain read of the vault's ERC-4626 `asset()` +
|
|
218
|
+
* ERC-20 `decimals()` when the allowlist is empty or doesn't contain the
|
|
219
|
+
* market (e.g. a provider configured without an allowlist).
|
|
220
|
+
*/
|
|
221
|
+
private async resolveUnderlyingDecimals(
|
|
222
|
+
publicClient: PublicClient,
|
|
223
|
+
marketId: LendMarketId,
|
|
224
|
+
): Promise<number> {
|
|
225
|
+
const match = findMarketInAllowlist(this._config.marketAllowlist, marketId)
|
|
226
|
+
if (match) return match.asset.metadata.decimals
|
|
227
|
+
|
|
228
|
+
const underlying = await publicClient.readContract({
|
|
229
|
+
address: marketId.address,
|
|
230
|
+
abi: erc4626Abi,
|
|
231
|
+
functionName: 'asset',
|
|
232
|
+
})
|
|
233
|
+
return publicClient.readContract({
|
|
234
|
+
address: underlying,
|
|
235
|
+
abi: erc20Abi,
|
|
236
|
+
functionName: 'decimals',
|
|
237
|
+
})
|
|
238
|
+
}
|
|
225
239
|
}
|
|
@@ -5,9 +5,9 @@ import {
|
|
|
5
5
|
MockGauntletUSDCMarket,
|
|
6
6
|
MockReceiverAddress,
|
|
7
7
|
MockWETHMarket,
|
|
8
|
-
} from '@/lend/__mocks__/MockMarkets.js'
|
|
9
|
-
import { createMockMorphoVault } from '@/lend/providers/morpho/__mocks__/mockVault.js'
|
|
10
|
-
import { MorphoLendProvider } from '@/lend/providers/morpho/MorphoLendProvider.js'
|
|
8
|
+
} from '@/actions/lend/__mocks__/MockMarkets.js'
|
|
9
|
+
import { createMockMorphoVault } from '@/actions/lend/providers/morpho/__mocks__/mockVault.js'
|
|
10
|
+
import { MorphoLendProvider } from '@/actions/lend/providers/morpho/MorphoLendProvider.js'
|
|
11
11
|
import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
|
|
12
12
|
import type { ChainManager } from '@/services/ChainManager.js'
|
|
13
13
|
import type { LendProviderConfig } from '@/types/actions.js'
|
|
@@ -101,7 +101,7 @@ describe('MorphoLendProvider', () => {
|
|
|
101
101
|
|
|
102
102
|
expect(withdrawTransaction).toHaveProperty('amount', BigInt('500000000'))
|
|
103
103
|
expect(withdrawTransaction).toHaveProperty(
|
|
104
|
-
'
|
|
104
|
+
'assetAddress',
|
|
105
105
|
asset.address[marketId.chainId],
|
|
106
106
|
)
|
|
107
107
|
expect(withdrawTransaction).toHaveProperty('marketId', marketId.address)
|
|
@@ -200,7 +200,7 @@ describe('MorphoLendProvider', () => {
|
|
|
200
200
|
|
|
201
201
|
expect(lendTransaction).toHaveProperty('amount', BigInt('1000000000'))
|
|
202
202
|
expect(lendTransaction).toHaveProperty(
|
|
203
|
-
'
|
|
203
|
+
'assetAddress',
|
|
204
204
|
asset.address[marketId.chainId],
|
|
205
205
|
)
|
|
206
206
|
expect(lendTransaction).toHaveProperty('marketId', marketId.address)
|
|
@@ -235,6 +235,80 @@ describe('MorphoLendProvider', () => {
|
|
|
235
235
|
})
|
|
236
236
|
})
|
|
237
237
|
|
|
238
|
+
describe('getPosition', () => {
|
|
239
|
+
it('formats balance using the allowlist asset decimals (USDC, 6)', async () => {
|
|
240
|
+
const client = mockChainManager.getPublicClient(
|
|
241
|
+
MockGauntletUSDCMarket.chainId,
|
|
242
|
+
)
|
|
243
|
+
const shares = 10n ** 18n // 1 share
|
|
244
|
+
const underlyingBalance = 10n ** 6n // 1 USDC
|
|
245
|
+
vi.mocked(client.readContract)
|
|
246
|
+
.mockResolvedValueOnce(shares)
|
|
247
|
+
.mockResolvedValueOnce(underlyingBalance)
|
|
248
|
+
|
|
249
|
+
const position = await provider.getPosition(MockReceiverAddress, {
|
|
250
|
+
address: MockGauntletUSDCMarket.address,
|
|
251
|
+
chainId: MockGauntletUSDCMarket.chainId,
|
|
252
|
+
})
|
|
253
|
+
|
|
254
|
+
expect(position.balance).toBe(underlyingBalance)
|
|
255
|
+
expect(position.balanceFormatted).toBe('1')
|
|
256
|
+
expect(position.shares).toBe(shares)
|
|
257
|
+
expect(position.sharesFormatted).toBe('1')
|
|
258
|
+
})
|
|
259
|
+
|
|
260
|
+
it('formats balance using the allowlist asset decimals (WETH, 18)', async () => {
|
|
261
|
+
const client = mockChainManager.getPublicClient(MockWETHMarket.chainId)
|
|
262
|
+
const shares = 10n ** 18n
|
|
263
|
+
const underlyingBalance = 10n ** 18n // 1 WETH
|
|
264
|
+
vi.mocked(client.readContract)
|
|
265
|
+
.mockResolvedValueOnce(shares)
|
|
266
|
+
.mockResolvedValueOnce(underlyingBalance)
|
|
267
|
+
|
|
268
|
+
const position = await provider.getPosition(MockReceiverAddress, {
|
|
269
|
+
address: MockWETHMarket.address,
|
|
270
|
+
chainId: MockWETHMarket.chainId,
|
|
271
|
+
})
|
|
272
|
+
|
|
273
|
+
expect(position.balance).toBe(underlyingBalance)
|
|
274
|
+
expect(position.balanceFormatted).toBe('1')
|
|
275
|
+
})
|
|
276
|
+
|
|
277
|
+
it('falls back to on-chain asset() + decimals() when no allowlist match', async () => {
|
|
278
|
+
const providerWithoutAllowlist = new MorphoLendProvider(
|
|
279
|
+
{},
|
|
280
|
+
mockChainManager,
|
|
281
|
+
)
|
|
282
|
+
const client = mockChainManager.getPublicClient(
|
|
283
|
+
MockGauntletUSDCMarket.chainId,
|
|
284
|
+
)
|
|
285
|
+
const underlyingAddr = '0xabcdefabcdefabcdefabcdefabcdefabcdefabcd'
|
|
286
|
+
const onchainDecimals = 8 // simulate a non-USDC underlying
|
|
287
|
+
const shares = 10n ** 18n
|
|
288
|
+
const underlyingBalance = 10n ** 8n
|
|
289
|
+
vi.mocked(client.readContract)
|
|
290
|
+
// resolveUnderlyingDecimals: asset()
|
|
291
|
+
.mockResolvedValueOnce(underlyingAddr)
|
|
292
|
+
// resolveUnderlyingDecimals: decimals()
|
|
293
|
+
.mockResolvedValueOnce(onchainDecimals)
|
|
294
|
+
// balanceOf
|
|
295
|
+
.mockResolvedValueOnce(shares)
|
|
296
|
+
// convertToAssets
|
|
297
|
+
.mockResolvedValueOnce(underlyingBalance)
|
|
298
|
+
|
|
299
|
+
const position = await providerWithoutAllowlist.getPosition(
|
|
300
|
+
MockReceiverAddress,
|
|
301
|
+
{
|
|
302
|
+
address: MockGauntletUSDCMarket.address,
|
|
303
|
+
chainId: MockGauntletUSDCMarket.chainId,
|
|
304
|
+
},
|
|
305
|
+
)
|
|
306
|
+
|
|
307
|
+
expect(position.balanceFormatted).toBe('1')
|
|
308
|
+
expect(position.sharesFormatted).toBe('1')
|
|
309
|
+
})
|
|
310
|
+
})
|
|
311
|
+
|
|
238
312
|
describe('market allowlist configuration', () => {
|
|
239
313
|
it('should work without market allowlist', () => {
|
|
240
314
|
const configWithoutAllowlist: LendProviderConfig = {}
|
|
@@ -2,12 +2,12 @@ import type { Address } from 'viem'
|
|
|
2
2
|
import { mainnet } from 'viem/chains'
|
|
3
3
|
import { afterEach, describe, expect, it, vi } from 'vitest'
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
import { fetchRewards } from '@/lend/providers/morpho/api.js'
|
|
5
|
+
import { fetchRewards } from '@/actions/lend/providers/morpho/api.js'
|
|
7
6
|
import {
|
|
8
7
|
calculateRewardsBreakdown,
|
|
9
8
|
fetchAndCalculateRewards,
|
|
10
|
-
} from '@/lend/providers/morpho/sdk.js'
|
|
9
|
+
} from '@/actions/lend/providers/morpho/sdk.js'
|
|
10
|
+
import { MORPHO, USDC } from '@/constants/assets.js'
|
|
11
11
|
import { externalTest } from '@/utils/test.js'
|
|
12
12
|
|
|
13
13
|
const CHAIN_ID = mainnet.id
|