@eth-optimism/actions-sdk 0.3.0 → 0.5.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/__mocks__/MockAssets.d.ts +17 -2
- package/dist/__mocks__/MockAssets.d.ts.map +1 -1
- package/dist/__mocks__/MockAssets.js +49 -6
- package/dist/__mocks__/MockAssets.js.map +1 -1
- package/dist/__tests__/actions.test.js +1 -1
- package/dist/__tests__/actions.test.js.map +1 -1
- package/dist/actions.d.ts +17 -13
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +46 -27
- package/dist/actions.js.map +1 -1
- package/dist/constants/assets.d.ts +215 -4
- package/dist/constants/assets.d.ts.map +1 -1
- package/dist/constants/assets.js +734 -11
- package/dist/constants/assets.js.map +1 -1
- package/dist/constants/providers.d.ts +6 -0
- package/dist/constants/providers.d.ts.map +1 -0
- package/dist/constants/providers.js +6 -0
- package/dist/constants/providers.js.map +1 -0
- package/dist/constants/supportedChains.d.ts +2 -2
- package/dist/constants/supportedChains.d.ts.map +1 -1
- package/dist/constants/supportedChains.js +12 -2
- package/dist/constants/supportedChains.js.map +1 -1
- package/dist/ens/EnsNamespace.d.ts +57 -0
- package/dist/ens/EnsNamespace.d.ts.map +1 -0
- package/dist/ens/EnsNamespace.js +158 -0
- package/dist/ens/EnsNamespace.js.map +1 -0
- package/dist/ens/EnsNamespace.spec.d.ts +2 -0
- package/dist/ens/EnsNamespace.spec.d.ts.map +1 -0
- package/dist/ens/EnsNamespace.spec.js +144 -0
- package/dist/ens/EnsNamespace.spec.js.map +1 -0
- package/dist/ens/errors.d.ts +24 -0
- package/dist/ens/errors.d.ts.map +1 -0
- package/dist/ens/errors.js +35 -0
- package/dist/ens/errors.js.map +1 -0
- package/dist/ens/index.d.ts +4 -0
- package/dist/ens/index.d.ts.map +1 -0
- package/dist/ens/index.js +4 -0
- package/dist/ens/index.js.map +1 -0
- package/dist/ens/types.d.ts +63 -0
- package/dist/ens/types.d.ts.map +1 -0
- package/dist/ens/types.js +14 -0
- package/dist/ens/types.js.map +1 -0
- package/dist/index.d.ts +6 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -4
- package/dist/index.js.map +1 -1
- package/dist/lend/__mocks__/MockLendProvider.d.ts +1 -1
- package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -1
- package/dist/lend/__mocks__/MockLendProvider.js +7 -2
- package/dist/lend/__mocks__/MockLendProvider.js.map +1 -1
- package/dist/lend/core/LendProvider.d.ts +12 -8
- package/dist/lend/core/LendProvider.d.ts.map +1 -1
- package/dist/lend/core/LendProvider.js +15 -21
- package/dist/lend/core/LendProvider.js.map +1 -1
- package/dist/lend/namespaces/BaseLendNamespace.d.ts +2 -6
- package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -1
- package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -1
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +7 -4
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -1
- package/dist/lend/providers/aave/AaveLendProvider.d.ts +1 -6
- package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -1
- package/dist/lend/providers/aave/AaveLendProvider.js +3 -6
- package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -1
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +14 -6
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -1
- package/dist/lend/providers/aave/addresses.d.ts +13 -39
- package/dist/lend/providers/aave/addresses.d.ts.map +1 -1
- package/dist/lend/providers/aave/addresses.js +65 -60
- package/dist/lend/providers/aave/addresses.js.map +1 -1
- package/dist/lend/providers/aave/sdk.d.ts +2 -2
- package/dist/lend/providers/aave/sdk.d.ts.map +1 -1
- package/dist/lend/providers/aave/sdk.js +6 -28
- package/dist/lend/providers/aave/sdk.js.map +1 -1
- package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +1 -6
- package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
- package/dist/lend/providers/morpho/MorphoLendProvider.js +4 -13
- package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
- package/dist/lend/providers/morpho/__tests__/api.test.js +52 -43
- package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
- package/dist/lend/providers/morpho/__tests__/sdk.test.js +41 -42
- package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
- package/dist/lend/providers/morpho/api.d.ts +3 -7
- package/dist/lend/providers/morpho/api.d.ts.map +1 -1
- package/dist/lend/providers/morpho/api.js +2 -2
- package/dist/lend/providers/morpho/api.js.map +1 -1
- package/dist/lend/providers/morpho/contracts.d.ts +11 -10
- package/dist/lend/providers/morpho/contracts.d.ts.map +1 -1
- package/dist/lend/providers/morpho/contracts.js +43 -10
- package/dist/lend/providers/morpho/contracts.js.map +1 -1
- package/dist/lend/providers/morpho/sdk.d.ts +7 -2
- package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
- package/dist/lend/providers/morpho/sdk.js +67 -63
- package/dist/lend/providers/morpho/sdk.js.map +1 -1
- package/dist/nodeActionsFactory.d.ts +1 -1
- package/dist/reactActionsFactory.d.ts +1 -1
- package/dist/services/ChainManager.d.ts +15 -8
- package/dist/services/ChainManager.d.ts.map +1 -1
- package/dist/services/ChainManager.js +9 -0
- package/dist/services/ChainManager.js.map +1 -1
- package/dist/services/__mocks__/MockChainManager.d.ts +5 -4
- 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/tokenBalance.d.ts +1 -1
- package/dist/services/tokenBalance.d.ts.map +1 -1
- package/dist/services/tokenBalance.js +31 -30
- package/dist/services/tokenBalance.js.map +1 -1
- package/dist/services/tokenBalance.spec.js +20 -24
- package/dist/services/tokenBalance.spec.js.map +1 -1
- package/dist/swap/__mocks__/MockSwapProvider.d.ts +20 -8
- package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -1
- package/dist/swap/__mocks__/MockSwapProvider.js +52 -29
- package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -1
- package/dist/swap/core/SwapProvider.d.ts +105 -16
- package/dist/swap/core/SwapProvider.d.ts.map +1 -1
- package/dist/swap/core/SwapProvider.js +215 -37
- package/dist/swap/core/SwapProvider.js.map +1 -1
- package/dist/swap/core/__tests__/SwapProvider.test.js +115 -9
- package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -1
- package/dist/swap/core/markets.d.ts +47 -0
- package/dist/swap/core/markets.d.ts.map +1 -0
- package/dist/swap/core/markets.js +65 -0
- package/dist/swap/core/markets.js.map +1 -0
- package/dist/swap/index.d.ts +2 -0
- package/dist/swap/index.d.ts.map +1 -1
- package/dist/swap/index.js +1 -0
- package/dist/swap/index.js.map +1 -1
- package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +2 -2
- package/dist/swap/namespaces/ActionsSwapNamespace.js +2 -2
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts +50 -8
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -1
- package/dist/swap/namespaces/BaseSwapNamespace.js +144 -16
- package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -1
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts +20 -7
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -1
- package/dist/swap/namespaces/WalletSwapNamespace.js +44 -15
- package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -1
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +150 -11
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -1
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +85 -8
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -1
- package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +10 -42
- package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -1
- package/dist/swap/providers/uniswap/UniswapSwapProvider.js +81 -139
- package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -1
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +10 -9
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -1
- package/dist/swap/providers/uniswap/__tests__/sdk.test.js +17 -17
- package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -1
- package/dist/swap/providers/uniswap/addresses.d.ts +5 -0
- package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -1
- package/dist/swap/providers/uniswap/addresses.js +1 -1
- package/dist/swap/providers/uniswap/addresses.js.map +1 -1
- package/dist/swap/providers/uniswap/encoding.d.ts +4 -4
- package/dist/swap/providers/uniswap/encoding.js +17 -17
- package/dist/swap/providers/uniswap/markets.d.ts +19 -0
- package/dist/swap/providers/uniswap/markets.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/markets.js +48 -0
- package/dist/swap/providers/uniswap/markets.js.map +1 -0
- package/dist/swap/providers/uniswap/types.d.ts +4 -3
- package/dist/swap/providers/uniswap/types.d.ts.map +1 -1
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts +50 -0
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.js +140 -0
- package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +2 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +255 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +2 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +166 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +2 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +420 -0
- package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts +2 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js +51 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts +14 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js +13 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts +2 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js +173 -0
- package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
- package/dist/swap/providers/velodrome/abis.d.ts +396 -0
- package/dist/swap/providers/velodrome/abis.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/abis.js +257 -0
- package/dist/swap/providers/velodrome/abis.js.map +1 -0
- package/dist/swap/providers/velodrome/addresses.d.ts +39 -0
- package/dist/swap/providers/velodrome/addresses.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/addresses.js +57 -0
- package/dist/swap/providers/velodrome/addresses.js.map +1 -0
- package/dist/swap/providers/velodrome/config.d.ts +22 -0
- package/dist/swap/providers/velodrome/config.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/config.js +29 -0
- package/dist/swap/providers/velodrome/config.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/helpers.d.ts +37 -0
- package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/helpers.js +60 -0
- package/dist/swap/providers/velodrome/encoding/helpers.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/index.d.ts +8 -0
- package/dist/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/index.js +5 -0
- package/dist/swap/providers/velodrome/encoding/index.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts +39 -0
- package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/poolRouter.js +83 -0
- package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +15 -0
- package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/approval.js +33 -0
- package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts +40 -0
- package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/cl.js +80 -0
- package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts +42 -0
- package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/encoding/routers/v2.js +166 -0
- package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
- package/dist/swap/providers/velodrome/markets.d.ts +21 -0
- package/dist/swap/providers/velodrome/markets.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/markets.js +69 -0
- package/dist/swap/providers/velodrome/markets.js.map +1 -0
- package/dist/swap/providers/velodrome/types.d.ts +31 -0
- package/dist/swap/providers/velodrome/types.d.ts.map +1 -0
- package/dist/swap/providers/velodrome/types.js +2 -0
- package/dist/swap/providers/velodrome/types.js.map +1 -0
- package/dist/types/actions.d.ts +44 -9
- package/dist/types/actions.d.ts.map +1 -1
- package/dist/types/asset.d.ts +7 -9
- package/dist/types/asset.d.ts.map +1 -1
- package/dist/types/chain.d.ts +2 -2
- package/dist/types/chain.d.ts.map +1 -1
- package/dist/types/lend/base.d.ts +6 -6
- package/dist/types/lend/base.d.ts.map +1 -1
- package/dist/types/lend/base.js.map +1 -1
- package/dist/types/lend/contracts.d.ts +2 -1
- package/dist/types/lend/contracts.d.ts.map +1 -1
- package/dist/types/providers.d.ts +21 -0
- package/dist/types/providers.d.ts.map +1 -0
- package/dist/types/providers.js +2 -0
- package/dist/types/providers.js.map +1 -0
- package/dist/types/swap/base.d.ts +136 -35
- package/dist/types/swap/base.d.ts.map +1 -1
- package/dist/types/swap/base.js.map +1 -1
- package/dist/utils/approve.d.ts +82 -0
- package/dist/utils/approve.d.ts.map +1 -0
- package/dist/utils/{permit2.js → approve.js} +48 -14
- package/dist/utils/approve.js.map +1 -0
- package/dist/utils/approve.test.d.ts +2 -0
- package/dist/utils/approve.test.d.ts.map +1 -0
- package/dist/utils/{permit2.test.js → approve.test.js} +95 -2
- package/dist/utils/approve.test.js.map +1 -0
- package/dist/utils/assets.d.ts +6 -0
- package/dist/utils/assets.d.ts.map +1 -1
- package/dist/utils/assets.js +10 -0
- package/dist/utils/assets.js.map +1 -1
- package/dist/utils/ens.d.ts +25 -0
- package/dist/utils/ens.d.ts.map +1 -0
- package/dist/utils/ens.js +53 -0
- package/dist/utils/ens.js.map +1 -0
- package/dist/utils/ens.test.d.ts +2 -0
- package/dist/utils/ens.test.d.ts.map +1 -0
- package/dist/utils/ens.test.js +75 -0
- package/dist/utils/ens.test.js.map +1 -0
- package/dist/utils/validateAddresses.d.ts +32 -0
- package/dist/utils/validateAddresses.d.ts.map +1 -0
- package/dist/utils/validateAddresses.js +103 -0
- package/dist/utils/validateAddresses.js.map +1 -0
- package/dist/utils/validateAddresses.test.d.ts +2 -0
- package/dist/utils/validateAddresses.test.d.ts.map +1 -0
- package/dist/utils/validateAddresses.test.js +314 -0
- package/dist/utils/validateAddresses.test.js.map +1 -0
- package/dist/utils/validation.d.ts +5 -0
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +10 -0
- package/dist/utils/validation.js.map +1 -1
- package/dist/wallet/core/namespace/WalletNamespace.d.ts +21 -9
- package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
- package/dist/wallet/core/namespace/WalletNamespace.js +44 -15
- package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +4 -4
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +4 -16
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/hosted/types/index.d.ts +6 -11
- package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +2 -9
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts +6 -17
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.js +7 -6
- package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +10 -1
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js +2 -2
- package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +12 -4
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +3 -10
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -10
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts +2 -4
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +6 -8
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +4 -4
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +2 -9
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +3 -10
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +3 -10
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +3 -9
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +3 -2
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -9
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -2
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +3 -9
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +3 -2
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts +2 -4
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -1
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +11 -13
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +6 -6
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +5 -10
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +3 -3
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts +2 -6
- package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +5 -10
- package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
- package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +3 -3
- package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -10
- package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
- package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
- package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
- package/package.json +3 -2
- package/src/__mocks__/MockAssets.ts +54 -6
- package/src/__tests__/actions.test.ts +1 -1
- package/src/actions.ts +73 -61
- package/src/constants/assets.ts +781 -10
- package/src/constants/providers.ts +5 -0
- package/src/constants/supportedChains.ts +22 -2
- package/src/ens/EnsNamespace.spec.ts +171 -0
- package/src/ens/EnsNamespace.ts +210 -0
- package/src/ens/errors.ts +45 -0
- package/src/ens/index.ts +12 -0
- package/src/ens/types.ts +76 -0
- package/src/index.ts +59 -8
- package/src/lend/__mocks__/MockLendProvider.ts +8 -3
- package/src/lend/core/LendProvider.ts +27 -28
- package/src/lend/namespaces/BaseLendNamespace.ts +2 -6
- package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +12 -5
- package/src/lend/providers/aave/AaveLendProvider.ts +3 -7
- package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +16 -7
- package/src/lend/providers/aave/addresses.ts +82 -64
- package/src/lend/providers/aave/sdk.ts +11 -36
- package/src/lend/providers/morpho/MorphoLendProvider.ts +4 -16
- package/src/lend/providers/morpho/__tests__/api.test.ts +65 -44
- package/src/lend/providers/morpho/__tests__/sdk.test.ts +43 -43
- package/src/lend/providers/morpho/api.ts +7 -8
- package/src/lend/providers/morpho/contracts.ts +62 -13
- package/src/lend/providers/morpho/sdk.ts +85 -63
- package/src/services/ChainManager.ts +22 -21
- package/src/services/__mocks__/MockChainManager.ts +12 -7
- package/src/services/tokenBalance.spec.ts +20 -24
- package/src/services/tokenBalance.ts +39 -33
- package/src/swap/__mocks__/MockSwapProvider.ts +77 -42
- package/src/swap/core/SwapProvider.ts +309 -50
- package/src/swap/core/__tests__/SwapProvider.test.ts +151 -9
- package/src/swap/core/markets.ts +104 -0
- package/src/swap/index.ts +5 -0
- package/src/swap/namespaces/ActionsSwapNamespace.ts +2 -2
- package/src/swap/namespaces/BaseSwapNamespace.ts +215 -18
- package/src/swap/namespaces/WalletSwapNamespace.ts +61 -14
- package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +245 -14
- package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +103 -8
- package/src/swap/providers/uniswap/UniswapSwapProvider.ts +110 -195
- package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +12 -12
- package/src/swap/providers/uniswap/__tests__/sdk.test.ts +19 -20
- package/src/swap/providers/uniswap/addresses.ts +3 -1
- package/src/swap/providers/uniswap/encoding.ts +22 -22
- package/src/swap/providers/uniswap/markets.ts +84 -0
- package/src/swap/providers/uniswap/types.ts +4 -3
- package/src/swap/providers/velodrome/VelodromeSwapProvider.ts +226 -0
- package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +341 -0
- package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +202 -0
- package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +507 -0
- package/src/swap/providers/velodrome/__tests__/encoding.cl.test.ts +69 -0
- package/src/swap/providers/velodrome/__tests__/encoding.helpers.ts +20 -0
- package/src/swap/providers/velodrome/__tests__/encoding.v2.test.ts +235 -0
- package/src/swap/providers/velodrome/abis.ts +264 -0
- package/src/swap/providers/velodrome/addresses.ts +107 -0
- package/src/swap/providers/velodrome/config.ts +46 -0
- package/src/swap/providers/velodrome/encoding/helpers.ts +82 -0
- package/src/swap/providers/velodrome/encoding/index.ts +7 -0
- package/src/swap/providers/velodrome/encoding/poolRouter.ts +124 -0
- package/src/swap/providers/velodrome/encoding/routers/approval.ts +45 -0
- package/src/swap/providers/velodrome/encoding/routers/cl.ts +156 -0
- package/src/swap/providers/velodrome/encoding/routers/v2.ts +267 -0
- package/src/swap/providers/velodrome/markets.ts +100 -0
- package/src/swap/providers/velodrome/types.ts +30 -0
- package/src/types/actions.ts +49 -9
- package/src/types/asset.ts +12 -9
- package/src/types/chain.ts +2 -2
- package/src/types/lend/base.ts +6 -6
- package/src/types/lend/contracts.ts +5 -1
- package/src/types/providers.ts +22 -0
- package/src/types/swap/base.ts +150 -36
- package/src/utils/{permit2.test.ts → approve.test.ts} +117 -1
- package/src/utils/{permit2.ts → approve.ts} +67 -14
- package/src/utils/assets.ts +14 -0
- package/src/utils/ens.test.ts +104 -0
- package/src/utils/ens.ts +85 -0
- package/src/utils/validateAddresses.test.ts +439 -0
- package/src/utils/validateAddresses.ts +153 -0
- package/src/utils/validation.ts +11 -0
- package/src/wallet/core/namespace/WalletNamespace.ts +70 -16
- package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +8 -4
- package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +5 -17
- package/src/wallet/core/providers/hosted/types/index.ts +9 -11
- package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +5 -17
- package/src/wallet/core/wallets/abstract/Wallet.ts +18 -22
- package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +13 -1
- package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +21 -5
- package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +5 -17
- package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +0 -1
- package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +3 -10
- package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +8 -8
- package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +4 -4
- package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +3 -10
- package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +5 -17
- package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +5 -17
- package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +7 -11
- package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +7 -11
- package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +7 -11
- package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +23 -10
- package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +6 -6
- package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +10 -18
- package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +2 -6
- package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +10 -18
- package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +10 -18
- package/dist/supported/tokens.d.ts +0 -25
- package/dist/supported/tokens.d.ts.map +0 -1
- package/dist/supported/tokens.js +0 -44
- package/dist/supported/tokens.js.map +0 -1
- package/dist/utils/permit2.d.ts +0 -46
- package/dist/utils/permit2.d.ts.map +0 -1
- package/dist/utils/permit2.js.map +0 -1
- package/dist/utils/permit2.test.d.ts +0 -2
- package/dist/utils/permit2.test.d.ts.map +0 -1
- package/dist/utils/permit2.test.js.map +0 -1
- package/src/supported/tokens.ts +0 -66
|
@@ -1,16 +1,26 @@
|
|
|
1
1
|
import {
|
|
2
2
|
base,
|
|
3
3
|
baseSepolia,
|
|
4
|
+
bob,
|
|
5
|
+
celo,
|
|
6
|
+
fraxtal,
|
|
7
|
+
ink,
|
|
8
|
+
lisk,
|
|
4
9
|
mainnet,
|
|
10
|
+
metalL2,
|
|
11
|
+
mode,
|
|
5
12
|
optimism,
|
|
6
13
|
optimismSepolia,
|
|
7
14
|
sepolia,
|
|
15
|
+
soneium,
|
|
16
|
+
superseed,
|
|
17
|
+
swellchain,
|
|
8
18
|
unichain,
|
|
9
19
|
unichainSepolia,
|
|
10
20
|
worldchain,
|
|
11
21
|
} from 'viem/chains'
|
|
12
22
|
|
|
13
|
-
export const
|
|
23
|
+
export const ACTIONS_SUPPORTED_CHAIN_IDS = [
|
|
14
24
|
mainnet.id,
|
|
15
25
|
sepolia.id,
|
|
16
26
|
optimism.id,
|
|
@@ -20,6 +30,16 @@ export const SUPPORTED_CHAIN_IDS = [
|
|
|
20
30
|
unichain.id,
|
|
21
31
|
unichainSepolia.id,
|
|
22
32
|
worldchain.id,
|
|
33
|
+
bob.id,
|
|
34
|
+
celo.id,
|
|
35
|
+
fraxtal.id,
|
|
36
|
+
ink.id,
|
|
37
|
+
lisk.id,
|
|
38
|
+
metalL2.id,
|
|
39
|
+
mode.id,
|
|
40
|
+
soneium.id,
|
|
41
|
+
superseed.id,
|
|
42
|
+
swellchain.id,
|
|
23
43
|
] as const
|
|
24
44
|
|
|
25
|
-
export type SupportedChainId = (typeof
|
|
45
|
+
export type SupportedChainId = (typeof ACTIONS_SUPPORTED_CHAIN_IDS)[number]
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import type { Address, PublicClient } from 'viem'
|
|
2
|
+
import { describe, expect, it, vi } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import type { ChainManager } from '@/services/ChainManager.js'
|
|
5
|
+
|
|
6
|
+
import { EnsNamespace } from './EnsNamespace.js'
|
|
7
|
+
import { EnsResolutionError, EnsRpcError } from './errors.js'
|
|
8
|
+
import type { EnsName } from './types.js'
|
|
9
|
+
|
|
10
|
+
const REAL_ADDRESS = '0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045' as Address
|
|
11
|
+
const ENS_NAME = 'vitalik.eth' as EnsName
|
|
12
|
+
|
|
13
|
+
function mockChainManager(client?: Partial<PublicClient>): ChainManager {
|
|
14
|
+
const tryGetPublicClient = client
|
|
15
|
+
? vi.fn().mockReturnValue(client)
|
|
16
|
+
: vi.fn().mockReturnValue(undefined)
|
|
17
|
+
return { tryGetPublicClient } as unknown as ChainManager
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function mockClient(
|
|
21
|
+
overrides: Partial<PublicClient> = {},
|
|
22
|
+
): Partial<PublicClient> {
|
|
23
|
+
return {
|
|
24
|
+
getEnsAddress: vi.fn().mockResolvedValue(REAL_ADDRESS),
|
|
25
|
+
getEnsName: vi.fn().mockResolvedValue(ENS_NAME),
|
|
26
|
+
getEnsText: vi.fn().mockResolvedValue(null),
|
|
27
|
+
...overrides,
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
describe('EnsNamespace', () => {
|
|
32
|
+
describe('getAddress', () => {
|
|
33
|
+
it('resolves a hex address directly', async () => {
|
|
34
|
+
const ens = new EnsNamespace(mockChainManager())
|
|
35
|
+
expect(await ens.getAddress(REAL_ADDRESS)).toBe(REAL_ADDRESS)
|
|
36
|
+
})
|
|
37
|
+
|
|
38
|
+
it('resolves an ENS name via mainnet client', async () => {
|
|
39
|
+
const client = mockClient()
|
|
40
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
41
|
+
expect(await ens.getAddress(ENS_NAME)).toBe(REAL_ADDRESS)
|
|
42
|
+
expect(client.getEnsAddress).toHaveBeenCalledWith({ name: ENS_NAME })
|
|
43
|
+
})
|
|
44
|
+
|
|
45
|
+
it('caches resolved addresses on subsequent calls', async () => {
|
|
46
|
+
const client = mockClient()
|
|
47
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
48
|
+
await ens.getAddress(ENS_NAME)
|
|
49
|
+
await ens.getAddress(ENS_NAME)
|
|
50
|
+
expect(client.getEnsAddress).toHaveBeenCalledTimes(1)
|
|
51
|
+
})
|
|
52
|
+
})
|
|
53
|
+
|
|
54
|
+
describe('getName', () => {
|
|
55
|
+
it('returns ENS name for a known address', async () => {
|
|
56
|
+
const client = mockClient()
|
|
57
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
58
|
+
expect(await ens.getName(REAL_ADDRESS)).toBe(ENS_NAME)
|
|
59
|
+
expect(client.getEnsName).toHaveBeenCalledWith({ address: REAL_ADDRESS })
|
|
60
|
+
})
|
|
61
|
+
|
|
62
|
+
it('returns null when no primary name is set', async () => {
|
|
63
|
+
const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) })
|
|
64
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
65
|
+
expect(await ens.getName(REAL_ADDRESS)).toBeNull()
|
|
66
|
+
})
|
|
67
|
+
|
|
68
|
+
it('throws EnsRpcError on RPC failure', async () => {
|
|
69
|
+
const client = mockClient({
|
|
70
|
+
getEnsName: vi.fn().mockRejectedValue(new Error('rpc down')),
|
|
71
|
+
})
|
|
72
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
73
|
+
await expect(ens.getName(REAL_ADDRESS)).rejects.toThrow(EnsRpcError)
|
|
74
|
+
})
|
|
75
|
+
|
|
76
|
+
it('caches results on subsequent calls', async () => {
|
|
77
|
+
const client = mockClient()
|
|
78
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
79
|
+
await ens.getName(REAL_ADDRESS)
|
|
80
|
+
await ens.getName(REAL_ADDRESS)
|
|
81
|
+
expect(client.getEnsName).toHaveBeenCalledTimes(1)
|
|
82
|
+
})
|
|
83
|
+
|
|
84
|
+
it('caches null results', async () => {
|
|
85
|
+
const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) })
|
|
86
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
87
|
+
await ens.getName(REAL_ADDRESS)
|
|
88
|
+
await ens.getName(REAL_ADDRESS)
|
|
89
|
+
expect(client.getEnsName).toHaveBeenCalledTimes(1)
|
|
90
|
+
})
|
|
91
|
+
})
|
|
92
|
+
|
|
93
|
+
describe('getInfo', () => {
|
|
94
|
+
it('returns all-null EnsInfo when address has no primary name', async () => {
|
|
95
|
+
const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) })
|
|
96
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
97
|
+
const info = await ens.getInfo(REAL_ADDRESS)
|
|
98
|
+
expect(info).toEqual({
|
|
99
|
+
avatar: null,
|
|
100
|
+
display: null,
|
|
101
|
+
description: null,
|
|
102
|
+
url: null,
|
|
103
|
+
email: null,
|
|
104
|
+
keywords: null,
|
|
105
|
+
twitter: null,
|
|
106
|
+
github: null,
|
|
107
|
+
discord: null,
|
|
108
|
+
reddit: null,
|
|
109
|
+
})
|
|
110
|
+
})
|
|
111
|
+
|
|
112
|
+
it('returns all text record fields when name is given', async () => {
|
|
113
|
+
const client = mockClient({
|
|
114
|
+
getEnsText: vi.fn().mockResolvedValue('test-value'),
|
|
115
|
+
})
|
|
116
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
117
|
+
const info = await ens.getInfo(ENS_NAME)
|
|
118
|
+
expect(info.avatar).toBe('test-value')
|
|
119
|
+
expect(info.twitter).toBe('test-value')
|
|
120
|
+
expect(info.github).toBe('test-value')
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
it('returns null fields when text records are not set', async () => {
|
|
124
|
+
const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) })
|
|
125
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
126
|
+
const info = await ens.getInfo(ENS_NAME)
|
|
127
|
+
expect(info.avatar).toBeNull()
|
|
128
|
+
expect(info.twitter).toBeNull()
|
|
129
|
+
})
|
|
130
|
+
|
|
131
|
+
it('fetches all 10 standard keys in parallel', async () => {
|
|
132
|
+
const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) })
|
|
133
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
134
|
+
await ens.getInfo(ENS_NAME)
|
|
135
|
+
expect(client.getEnsText).toHaveBeenCalledTimes(10)
|
|
136
|
+
})
|
|
137
|
+
|
|
138
|
+
it('throws EnsRpcError on text lookup RPC failure', async () => {
|
|
139
|
+
const client = mockClient({
|
|
140
|
+
getEnsText: vi.fn().mockRejectedValue(new Error('rpc down')),
|
|
141
|
+
})
|
|
142
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
143
|
+
await expect(ens.getInfo(ENS_NAME)).rejects.toThrow(EnsRpcError)
|
|
144
|
+
})
|
|
145
|
+
|
|
146
|
+
it('throws EnsResolutionError when the resolved name fails normalization', async () => {
|
|
147
|
+
const client = mockClient({
|
|
148
|
+
getEnsName: vi.fn().mockResolvedValue('not!valid.eth'),
|
|
149
|
+
})
|
|
150
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
151
|
+
await expect(ens.getInfo(REAL_ADDRESS)).rejects.toThrow(
|
|
152
|
+
EnsResolutionError,
|
|
153
|
+
)
|
|
154
|
+
})
|
|
155
|
+
|
|
156
|
+
it('skips reverse resolution when input is already an EnsName', async () => {
|
|
157
|
+
const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) })
|
|
158
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
159
|
+
await ens.getInfo(ENS_NAME)
|
|
160
|
+
expect(client.getEnsName).not.toHaveBeenCalled()
|
|
161
|
+
})
|
|
162
|
+
|
|
163
|
+
it('caches results on subsequent calls', async () => {
|
|
164
|
+
const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) })
|
|
165
|
+
const ens = new EnsNamespace(mockChainManager(client))
|
|
166
|
+
await ens.getInfo(ENS_NAME)
|
|
167
|
+
await ens.getInfo(ENS_NAME)
|
|
168
|
+
expect(client.getEnsText).toHaveBeenCalledTimes(10)
|
|
169
|
+
})
|
|
170
|
+
})
|
|
171
|
+
})
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { type Address, createPublicClient, http } from 'viem'
|
|
2
|
+
import { mainnet } from 'viem/chains'
|
|
3
|
+
import { normalize } from 'viem/ens'
|
|
4
|
+
|
|
5
|
+
import type { ChainManager } from '@/services/ChainManager.js'
|
|
6
|
+
import { resolveAddress } from '@/utils/ens.js'
|
|
7
|
+
|
|
8
|
+
import { EnsResolutionError, EnsRpcError } from './errors.js'
|
|
9
|
+
import {
|
|
10
|
+
type EnsInfo,
|
|
11
|
+
type EnsName,
|
|
12
|
+
isEnsName,
|
|
13
|
+
type NameServiceProvider,
|
|
14
|
+
} from './types.js'
|
|
15
|
+
|
|
16
|
+
/** Default TTL for cached ENS lookups — 5 minutes */
|
|
17
|
+
const DEFAULT_CACHE_TTL_MS = 5 * 60 * 1000
|
|
18
|
+
|
|
19
|
+
/** Public mainnet RPC used as fallback when mainnet is not in chain config */
|
|
20
|
+
const FALLBACK_MAINNET_RPC = 'https://cloudflare-eth.com'
|
|
21
|
+
|
|
22
|
+
/** ENSIP-5 / ENSIP-18 standard text record keys mapped to EnsInfo field names */
|
|
23
|
+
const ENS_TEXT_KEYS = {
|
|
24
|
+
avatar: 'avatar',
|
|
25
|
+
display: 'display',
|
|
26
|
+
description: 'description',
|
|
27
|
+
url: 'url',
|
|
28
|
+
email: 'email',
|
|
29
|
+
keywords: 'keywords',
|
|
30
|
+
twitter: 'com.twitter',
|
|
31
|
+
github: 'com.github',
|
|
32
|
+
discord: 'com.discord',
|
|
33
|
+
reddit: 'org.reddit',
|
|
34
|
+
} as const satisfies Record<keyof EnsInfo, string>
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Namespace for human-readable name resolution on Ethereum.
|
|
38
|
+
* Currently backed by ENS (Ethereum Name Service) on mainnet.
|
|
39
|
+
*
|
|
40
|
+
* Implements {@link NameServiceProvider} — designed to be extensible: future
|
|
41
|
+
* versions could support alternative name services alongside ENS (e.g. Basename,
|
|
42
|
+
* Unstoppable Domains, Lens handles). The natural evolution is additional
|
|
43
|
+
* NameServiceProvider implementations registered under their own namespace
|
|
44
|
+
* (e.g. `actions.basename`).
|
|
45
|
+
*
|
|
46
|
+
* Falls back to a public mainnet RPC automatically if mainnet is not included
|
|
47
|
+
* in your chain configuration, so ENS works even in L2-only setups.
|
|
48
|
+
*/
|
|
49
|
+
export class EnsNamespace implements NameServiceProvider {
|
|
50
|
+
private chainManager: ChainManager
|
|
51
|
+
private readonly cacheTtlMs: number
|
|
52
|
+
private addressCache = new Map<
|
|
53
|
+
string,
|
|
54
|
+
{ value: Address; expiresAt: number }
|
|
55
|
+
>()
|
|
56
|
+
private nameCache = new Map<
|
|
57
|
+
Address,
|
|
58
|
+
{ value: EnsName | null; expiresAt: number }
|
|
59
|
+
>()
|
|
60
|
+
private infoCache = new Map<string, { value: EnsInfo; expiresAt: number }>()
|
|
61
|
+
|
|
62
|
+
constructor(chainManager: ChainManager, cacheTtlMs = DEFAULT_CACHE_TTL_MS) {
|
|
63
|
+
this.chainManager = chainManager
|
|
64
|
+
this.cacheTtlMs = cacheTtlMs
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Resolve an ENS name or hex address to a checksummed hex address.
|
|
69
|
+
* Hex addresses are returned as-is after format validation.
|
|
70
|
+
*
|
|
71
|
+
* If you need to resolve outside of an {@link Actions} instance (e.g. in a
|
|
72
|
+
* provider or script), use the lower-level `resolveAddress` utility instead.
|
|
73
|
+
* @param input - Hex address (0x...) or ENS name (e.g. "vitalik.eth")
|
|
74
|
+
* @returns Resolved hex address
|
|
75
|
+
* @throws {EnsResolutionError} If the name cannot be resolved
|
|
76
|
+
* @throws {EnsRpcError} If the RPC call fails
|
|
77
|
+
*/
|
|
78
|
+
async getAddress(input: Address | EnsName): Promise<Address> {
|
|
79
|
+
const cached = this.addressCache.get(input)
|
|
80
|
+
if (cached && Date.now() < cached.expiresAt) return cached.value
|
|
81
|
+
const value = await resolveAddress(input, this.getMainnetClient())
|
|
82
|
+
this.addressCache.set(input, {
|
|
83
|
+
value,
|
|
84
|
+
expiresAt: Date.now() + this.cacheTtlMs,
|
|
85
|
+
})
|
|
86
|
+
return value
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Reverse-resolve an address to its primary ENS name.
|
|
91
|
+
* @param address - Hex address to look up
|
|
92
|
+
* @returns ENS name, or null if none is set
|
|
93
|
+
* @throws {EnsRpcError} If the RPC call fails
|
|
94
|
+
*/
|
|
95
|
+
async getName(address: Address): Promise<EnsName | null> {
|
|
96
|
+
const cached = this.nameCache.get(address)
|
|
97
|
+
if (cached && Date.now() < cached.expiresAt) return cached.value
|
|
98
|
+
const name = await this.getMainnetClient()
|
|
99
|
+
.getEnsName({ address })
|
|
100
|
+
.catch((cause: unknown) => {
|
|
101
|
+
throw new EnsRpcError(
|
|
102
|
+
`ENS reverse resolution failed for "${address}": RPC error`,
|
|
103
|
+
address,
|
|
104
|
+
{ cause },
|
|
105
|
+
)
|
|
106
|
+
})
|
|
107
|
+
const value = name && isEnsName(name) ? name : null
|
|
108
|
+
this.nameCache.set(address, {
|
|
109
|
+
value,
|
|
110
|
+
expiresAt: Date.now() + this.cacheTtlMs,
|
|
111
|
+
})
|
|
112
|
+
return value
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Fetch all standard ENS profile text record fields (ENSIP-5 / ENSIP-18)
|
|
117
|
+
* for an ENS name or address in a single batched call.
|
|
118
|
+
*
|
|
119
|
+
* All fields are null when not set. Returns all-null if the address has
|
|
120
|
+
* no primary ENS name.
|
|
121
|
+
* @param input - Hex address (0x...) or ENS name
|
|
122
|
+
* @returns EnsInfo object with all standard text record fields
|
|
123
|
+
* @throws {EnsResolutionError} If the name cannot be normalized
|
|
124
|
+
* @throws {EnsRpcError} If the RPC call fails
|
|
125
|
+
*/
|
|
126
|
+
async getInfo(input: Address | EnsName): Promise<EnsInfo> {
|
|
127
|
+
const name = isEnsName(input) ? input : await this.getName(input)
|
|
128
|
+
if (!name) return nullInfo()
|
|
129
|
+
|
|
130
|
+
const cached = this.infoCache.get(name)
|
|
131
|
+
if (cached && Date.now() < cached.expiresAt) return cached.value
|
|
132
|
+
|
|
133
|
+
const normalized = (() => {
|
|
134
|
+
try {
|
|
135
|
+
return normalize(name)
|
|
136
|
+
} catch (cause) {
|
|
137
|
+
throw new EnsResolutionError(
|
|
138
|
+
`ENS name "${name}" is invalid and cannot be normalized`,
|
|
139
|
+
name,
|
|
140
|
+
{ cause },
|
|
141
|
+
)
|
|
142
|
+
}
|
|
143
|
+
})()
|
|
144
|
+
|
|
145
|
+
const client = this.getMainnetClient()
|
|
146
|
+
const fetchKey = (key: string) =>
|
|
147
|
+
client.getEnsText({ name: normalized, key }).catch((cause: unknown) => {
|
|
148
|
+
throw new EnsRpcError(
|
|
149
|
+
`ENS text record lookup failed for "${name}" key "${key}": RPC error`,
|
|
150
|
+
name,
|
|
151
|
+
{ cause },
|
|
152
|
+
)
|
|
153
|
+
})
|
|
154
|
+
|
|
155
|
+
const [
|
|
156
|
+
avatar,
|
|
157
|
+
display,
|
|
158
|
+
description,
|
|
159
|
+
url,
|
|
160
|
+
email,
|
|
161
|
+
keywords,
|
|
162
|
+
twitter,
|
|
163
|
+
github,
|
|
164
|
+
discord,
|
|
165
|
+
reddit,
|
|
166
|
+
] = await Promise.all(Object.values(ENS_TEXT_KEYS).map(fetchKey))
|
|
167
|
+
|
|
168
|
+
const value: EnsInfo = {
|
|
169
|
+
avatar: avatar ?? null,
|
|
170
|
+
display: display ?? null,
|
|
171
|
+
description: description ?? null,
|
|
172
|
+
url: url ?? null,
|
|
173
|
+
email: email ?? null,
|
|
174
|
+
keywords: keywords ?? null,
|
|
175
|
+
twitter: twitter ?? null,
|
|
176
|
+
github: github ?? null,
|
|
177
|
+
discord: discord ?? null,
|
|
178
|
+
reddit: reddit ?? null,
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
this.infoCache.set(name, { value, expiresAt: Date.now() + this.cacheTtlMs })
|
|
182
|
+
return value
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
private getMainnetClient() {
|
|
186
|
+
return (
|
|
187
|
+
this.chainManager.tryGetPublicClient(mainnet.id) ??
|
|
188
|
+
createPublicClient({
|
|
189
|
+
chain: mainnet,
|
|
190
|
+
transport: http(FALLBACK_MAINNET_RPC),
|
|
191
|
+
batch: { multicall: true },
|
|
192
|
+
})
|
|
193
|
+
)
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
function nullInfo(): EnsInfo {
|
|
198
|
+
return {
|
|
199
|
+
avatar: null,
|
|
200
|
+
display: null,
|
|
201
|
+
description: null,
|
|
202
|
+
url: null,
|
|
203
|
+
email: null,
|
|
204
|
+
keywords: null,
|
|
205
|
+
twitter: null,
|
|
206
|
+
github: null,
|
|
207
|
+
discord: null,
|
|
208
|
+
reddit: null,
|
|
209
|
+
}
|
|
210
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { mainnet } from 'viem/chains'
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Thrown when an ENS operation is attempted but the required chain is not
|
|
5
|
+
* included in the Actions chain configuration.
|
|
6
|
+
*/
|
|
7
|
+
export class EnsNotConfiguredError extends Error {
|
|
8
|
+
chainId: number
|
|
9
|
+
|
|
10
|
+
constructor(chainId = mainnet.id) {
|
|
11
|
+
super(
|
|
12
|
+
`ENS operations require Ethereum mainnet. ` +
|
|
13
|
+
`Add chain ID ${chainId} to your chain configuration.`,
|
|
14
|
+
)
|
|
15
|
+
this.name = 'EnsNotConfiguredError'
|
|
16
|
+
this.chainId = chainId
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Thrown when an ENS name cannot be resolved to an address — e.g. the name
|
|
22
|
+
* is unregistered, resolves to the zero address, or fails normalization.
|
|
23
|
+
*/
|
|
24
|
+
export class EnsResolutionError extends Error {
|
|
25
|
+
input: string
|
|
26
|
+
|
|
27
|
+
constructor(message: string, input: string, options?: ErrorOptions) {
|
|
28
|
+
super(message, options)
|
|
29
|
+
this.name = 'EnsResolutionError'
|
|
30
|
+
this.input = input
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Thrown when an ENS RPC call fails due to a network or provider error.
|
|
36
|
+
*/
|
|
37
|
+
export class EnsRpcError extends Error {
|
|
38
|
+
input: string
|
|
39
|
+
|
|
40
|
+
constructor(message: string, input: string, options?: ErrorOptions) {
|
|
41
|
+
super(message, options)
|
|
42
|
+
this.name = 'EnsRpcError'
|
|
43
|
+
this.input = input
|
|
44
|
+
}
|
|
45
|
+
}
|
package/src/ens/index.ts
ADDED
package/src/ens/types.ts
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import type { Address } from 'viem'
|
|
2
|
+
|
|
3
|
+
import type { SwapExecuteParams, SwapQuoteParams } from '@/types/swap/base.js'
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* A dot-separated ENS name (e.g. `vitalik.eth`, `sub.vitalik.eth`, `example.com`).
|
|
7
|
+
*
|
|
8
|
+
* ENS is not limited to `.eth` — it supports any DNSSEC-enabled DNS TLD as well
|
|
9
|
+
* as ENS-native TLDs (`.eth`, `.test`). Subdomains of arbitrary depth are valid.
|
|
10
|
+
*
|
|
11
|
+
* This type is a structural constraint (at least one dot) mirroring viem's Address type.
|
|
12
|
+
* True validity is determined at runtime by `normalize()` (ENSIP-15): a name is valid
|
|
13
|
+
* if and only if it does not throw during normalization.
|
|
14
|
+
*/
|
|
15
|
+
export type EnsName = `${string}.${string}`
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Type guard for EnsName. Mirrors the pattern of viem's isAddress.
|
|
19
|
+
* Rejects obviously invalid forms (leading/trailing dots, consecutive dots)
|
|
20
|
+
* but does not run full ENSIP-15 normalization — use normalize() for that.
|
|
21
|
+
* @param value - String to check
|
|
22
|
+
* @returns True if the value satisfies the EnsName structural constraint
|
|
23
|
+
*/
|
|
24
|
+
export function isEnsName(value: string): value is EnsName {
|
|
25
|
+
return (
|
|
26
|
+
value.includes('.') &&
|
|
27
|
+
!value.startsWith('.') &&
|
|
28
|
+
!value.endsWith('.') &&
|
|
29
|
+
!value.includes('..')
|
|
30
|
+
)
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Standard ENS profile text record fields as defined by ENSIP-5 and ENSIP-18.
|
|
35
|
+
* All fields are null when not set on the resolver.
|
|
36
|
+
*/
|
|
37
|
+
export interface EnsInfo {
|
|
38
|
+
avatar: string | null
|
|
39
|
+
display: string | null
|
|
40
|
+
description: string | null
|
|
41
|
+
url: string | null
|
|
42
|
+
email: string | null
|
|
43
|
+
keywords: string | null
|
|
44
|
+
/** com.twitter */
|
|
45
|
+
twitter: string | null
|
|
46
|
+
/** com.github */
|
|
47
|
+
github: string | null
|
|
48
|
+
/** com.discord */
|
|
49
|
+
discord: string | null
|
|
50
|
+
/** org.reddit */
|
|
51
|
+
reddit: string | null
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/** SwapExecuteParams with recipient narrowed to Address after ENS resolution */
|
|
55
|
+
export type SwapExecuteParamsResolved = Omit<SwapExecuteParams, 'recipient'> & {
|
|
56
|
+
recipient?: Address
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/** SwapQuoteParams with recipient narrowed to Address after ENS resolution */
|
|
60
|
+
export type SwapQuoteParamsResolved = Omit<SwapQuoteParams, 'recipient'> & {
|
|
61
|
+
recipient?: Address
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Common interface for human-readable name service providers.
|
|
66
|
+
* Implemented by {@link EnsNamespace}; designed to support future providers
|
|
67
|
+
* such as Basename, Lens, Unstoppable Domains, etc.
|
|
68
|
+
*/
|
|
69
|
+
export interface NameServiceProvider {
|
|
70
|
+
/** Resolve a name or address to a checksummed hex address. */
|
|
71
|
+
getAddress(input: Address | EnsName): Promise<Address>
|
|
72
|
+
/** Reverse-resolve an address to its primary name, or null if not set. */
|
|
73
|
+
getName(address: Address): Promise<EnsName | null>
|
|
74
|
+
/** Fetch all standard profile text record fields in a single batched call. */
|
|
75
|
+
getInfo(input: Address | EnsName): Promise<EnsInfo>
|
|
76
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -1,28 +1,74 @@
|
|
|
1
1
|
export type { Actions } from '@/actions.js'
|
|
2
2
|
export {
|
|
3
|
+
AAVE,
|
|
4
|
+
ARB,
|
|
5
|
+
BAL,
|
|
6
|
+
CBBTC,
|
|
7
|
+
CBETH,
|
|
8
|
+
COMP,
|
|
9
|
+
CRV,
|
|
10
|
+
DAI,
|
|
11
|
+
EETH,
|
|
12
|
+
ENA,
|
|
13
|
+
ENS,
|
|
3
14
|
ETH,
|
|
15
|
+
ETHFI,
|
|
16
|
+
FRAX,
|
|
17
|
+
GRT,
|
|
18
|
+
LDO,
|
|
19
|
+
LINK,
|
|
20
|
+
MKR,
|
|
4
21
|
MORPHO,
|
|
22
|
+
NATIVELY_SUPPORTED_ASSETS,
|
|
23
|
+
ONDO,
|
|
24
|
+
ONEINCH,
|
|
25
|
+
OP,
|
|
5
26
|
OP_DEMO,
|
|
27
|
+
PENDLE,
|
|
28
|
+
PEPE,
|
|
29
|
+
POL,
|
|
30
|
+
PYUSD,
|
|
31
|
+
RENDER,
|
|
32
|
+
RETH,
|
|
33
|
+
RPL,
|
|
34
|
+
SHIB,
|
|
35
|
+
SKY,
|
|
36
|
+
SNX,
|
|
37
|
+
STETH,
|
|
38
|
+
SUSHI,
|
|
39
|
+
UNI,
|
|
6
40
|
USDC,
|
|
7
41
|
USDC_DEMO,
|
|
42
|
+
USDE,
|
|
43
|
+
USDT,
|
|
44
|
+
WBTC,
|
|
45
|
+
WEETH,
|
|
8
46
|
WETH,
|
|
47
|
+
WLD,
|
|
48
|
+
WSTETH,
|
|
9
49
|
} from '@/constants/assets.js'
|
|
10
50
|
export {
|
|
11
|
-
|
|
51
|
+
ACTIONS_SUPPORTED_CHAIN_IDS,
|
|
12
52
|
type SupportedChainId,
|
|
13
53
|
} from '@/constants/supportedChains.js'
|
|
14
54
|
export * from '@/core/error/errors.js'
|
|
15
|
-
export { LendProvider, MorphoLendProvider } from '@/lend/index.js'
|
|
16
55
|
export {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
56
|
+
type EnsInfo,
|
|
57
|
+
EnsNamespace,
|
|
58
|
+
EnsNotConfiguredError,
|
|
59
|
+
EnsResolutionError,
|
|
60
|
+
EnsRpcError,
|
|
61
|
+
type NameServiceProvider,
|
|
62
|
+
} from '@/ens/index.js'
|
|
63
|
+
export { LendProvider, MorphoLendProvider } from '@/lend/index.js'
|
|
21
64
|
export {
|
|
22
65
|
SwapProvider,
|
|
23
66
|
type UniswapMarketConfig,
|
|
24
67
|
UniswapSwapProvider,
|
|
25
68
|
type UniswapSwapProviderConfig,
|
|
69
|
+
type VelodromeMarketConfig,
|
|
70
|
+
VelodromeSwapProvider,
|
|
71
|
+
type VelodromeSwapProviderConfig,
|
|
26
72
|
} from '@/swap/index.js'
|
|
27
73
|
export type {
|
|
28
74
|
ActionsConfig,
|
|
@@ -45,11 +91,15 @@ export type {
|
|
|
45
91
|
SwapMarket,
|
|
46
92
|
SwapMarketConfig,
|
|
47
93
|
SwapMarketId,
|
|
48
|
-
SwapPrice,
|
|
49
|
-
SwapPriceParams,
|
|
50
94
|
SwapProviderConfig,
|
|
95
|
+
SwapProviderName,
|
|
96
|
+
SwapQuote,
|
|
97
|
+
SwapQuoteExecution,
|
|
98
|
+
SwapQuoteParams,
|
|
51
99
|
SwapReceipt,
|
|
52
100
|
SwapRoute,
|
|
101
|
+
SwapRoutingStrategy,
|
|
102
|
+
SwapSettings,
|
|
53
103
|
SwapTransaction,
|
|
54
104
|
TokenBalance,
|
|
55
105
|
TransactionData,
|
|
@@ -58,5 +108,6 @@ export type {
|
|
|
58
108
|
WalletSwapParams,
|
|
59
109
|
} from '@/types/index.js'
|
|
60
110
|
export { getAssetAddress, isAssetSupportedOnChain } from '@/utils/assets.js'
|
|
111
|
+
export { type EnsName, isEnsName, resolveAddress } from '@/utils/ens.js'
|
|
61
112
|
export { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
|
|
62
113
|
export { SmartWallet } from '@/wallet/core/wallets/smart/abstract/SmartWallet.js'
|
|
@@ -59,8 +59,6 @@ export class MockLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
59
59
|
) => Promise<LendTransaction>
|
|
60
60
|
>
|
|
61
61
|
|
|
62
|
-
protected readonly SUPPORTED_CHAIN_IDS = [1, 130, 8453, 84532] as const
|
|
63
|
-
|
|
64
62
|
protected readonly SUPPORTED_CHAINS = {
|
|
65
63
|
TESTNET: {
|
|
66
64
|
chainId: 84532,
|
|
@@ -70,6 +68,10 @@ export class MockLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
70
68
|
|
|
71
69
|
private mockConfig: MockLendProviderConfig
|
|
72
70
|
|
|
71
|
+
protocolSupportedChainIds(): number[] {
|
|
72
|
+
return [1, 130, 8453, 84532]
|
|
73
|
+
}
|
|
74
|
+
|
|
73
75
|
constructor(
|
|
74
76
|
config?: LendProviderConfig,
|
|
75
77
|
mockConfig?: Partial<MockLendProviderConfig>,
|
|
@@ -77,7 +79,10 @@ export class MockLendProvider extends LendProvider<LendProviderConfig> {
|
|
|
77
79
|
) {
|
|
78
80
|
super(
|
|
79
81
|
config || {},
|
|
80
|
-
chainManager ||
|
|
82
|
+
chainManager ||
|
|
83
|
+
(new MockChainManager({
|
|
84
|
+
supportedChains: [84532],
|
|
85
|
+
}) as unknown as ChainManager),
|
|
81
86
|
)
|
|
82
87
|
|
|
83
88
|
this.mockConfig = {
|