@eth-optimism/actions-sdk 0.3.0 → 0.4.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 +8 -13
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +35 -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/index.d.ts +4 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -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 +8 -8
- package/dist/services/ChainManager.d.ts.map +1 -1
- package/dist/services/ChainManager.js.map +1 -1
- package/dist/services/__mocks__/MockChainManager.d.ts +4 -4
- package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
- 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 +218 -36
- 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 +48 -8
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -1
- package/dist/swap/namespaces/BaseSwapNamespace.js +139 -16
- package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -1
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts +19 -7
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -1
- package/dist/swap/namespaces/WalletSwapNamespace.js +39 -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 +9 -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 +49 -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 +419 -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 +133 -33
- package/dist/types/swap/base.d.ts.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/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/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 +5 -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 +58 -61
- package/src/constants/assets.ts +781 -10
- package/src/constants/providers.ts +5 -0
- package/src/constants/supportedChains.ts +22 -2
- package/src/index.ts +50 -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 +12 -21
- package/src/services/__mocks__/MockChainManager.ts +4 -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 +307 -49
- 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 +199 -18
- package/src/swap/namespaces/WalletSwapNamespace.ts +53 -14
- package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +241 -14
- package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +103 -8
- package/src/swap/providers/uniswap/UniswapSwapProvider.ts +108 -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 +224 -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 +506 -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 +147 -34
- 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/validateAddresses.test.ts +439 -0
- package/src/utils/validateAddresses.ts +153 -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 +15 -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,8 +1,7 @@
|
|
|
1
1
|
import { type Address, type LocalAccount } from 'viem';
|
|
2
|
-
import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
|
|
3
2
|
import type { ChainManager } from '../../../../../services/ChainManager.js';
|
|
4
|
-
import type {
|
|
5
|
-
import type {
|
|
3
|
+
import type { Asset } from '../../../../../types/asset.js';
|
|
4
|
+
import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
|
|
6
5
|
import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
|
|
7
6
|
import type { DynamicHostedWalletToActionsWalletOptions } from '../../../providers/hosted/types/index.js';
|
|
8
7
|
/**
|
|
@@ -24,13 +23,9 @@ export declare class DynamicWallet extends EOAWallet {
|
|
|
24
23
|
static create(params: {
|
|
25
24
|
dynamicWallet: DynamicHostedWalletToActionsWalletOptions['wallet'];
|
|
26
25
|
chainManager: ChainManager;
|
|
27
|
-
lendProviders?:
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
};
|
|
31
|
-
swapProviders?: {
|
|
32
|
-
uniswap?: SwapProvider<SwapProviderConfig>;
|
|
33
|
-
};
|
|
26
|
+
lendProviders?: LendProviders;
|
|
27
|
+
swapProviders?: SwapProviders;
|
|
28
|
+
supportedAssets?: Asset[];
|
|
34
29
|
}): Promise<DynamicWallet>;
|
|
35
30
|
/**
|
|
36
31
|
* Initialize the DynamicWallet by creating the signer account
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,MAAM,CAAA;AAEtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"DynamicWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,MAAM,CAAA;AAEtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAG/G;;;GAGG;AACH,qBAAa,aAAc,SAAQ,SAAS;IACnC,MAAM,EAAG,YAAY,CAAA;IACrB,OAAO,EAAG,OAAO,CAAA;IACxB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqD;IAEnF;;;;;;OAMG;IACH,OAAO;WAWM,MAAM,CAAC,MAAM,EAAE;QAC1B,aAAa,EAAE,yCAAyC,CAAC,QAAQ,CAAC,CAAA;QAClE,YAAY,EAAE,YAAY,CAAA;QAC1B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,aAAa,CAAC;IAY1B;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
|
|
@@ -12,12 +12,12 @@ export class DynamicWallet extends EOAWallet {
|
|
|
12
12
|
* @param lendProviders - Optional lend providers for DeFi operations
|
|
13
13
|
* @param swapProviders - Optional swap providers for trading operations
|
|
14
14
|
*/
|
|
15
|
-
constructor(chainManager, dynamicWallet, lendProviders, swapProviders) {
|
|
16
|
-
super(chainManager, lendProviders, swapProviders);
|
|
15
|
+
constructor(chainManager, dynamicWallet, lendProviders, swapProviders, supportedAssets) {
|
|
16
|
+
super(chainManager, lendProviders, swapProviders, supportedAssets);
|
|
17
17
|
this.dynamicWallet = dynamicWallet;
|
|
18
18
|
}
|
|
19
19
|
static async create(params) {
|
|
20
|
-
const wallet = new DynamicWallet(params.chainManager, params.dynamicWallet, params.lendProviders, params.swapProviders);
|
|
20
|
+
const wallet = new DynamicWallet(params.chainManager, params.dynamicWallet, params.lendProviders, params.swapProviders, params.supportedAssets);
|
|
21
21
|
await wallet.initialize();
|
|
22
22
|
return wallet;
|
|
23
23
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DynamicWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAElE,OAAO,EAAE,YAAY,EAAE,MAAM,6DAA6D,CAAA;AAE1F;;;GAGG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAK1C;;;;;;OAMG;IACH,YACE,YAA0B,EAC1B,aAAkE,EAClE,aAA6B,EAC7B,aAA6B,EAC7B,eAAyB;QAEzB,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,CAAC,CAAA;QAClE,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;IACpC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAMnB;QACC,MAAM,MAAM,GAAG,IAAI,aAAa,CAC9B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,CACvB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,MAAM,EAAE,IAAI,CAAC,aAAa;SAC3B,CAAC,CAAA;IACJ,CAAC;CACF"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import type { LendProvider } from '../../../../../../lend/core/LendProvider.js';
|
|
2
1
|
import type { ChainManager } from '../../../../../../services/ChainManager.js';
|
|
3
|
-
import type {
|
|
2
|
+
import type { LendProviders } from '../../../../../../types/providers.js';
|
|
4
3
|
import type { Wallet } from '../../../../../core/wallets/abstract/Wallet.js';
|
|
5
4
|
import type { DynamicHostedWalletToActionsWalletOptions } from '../../../../providers/hosted/types/index.js';
|
|
6
5
|
/**
|
|
@@ -13,10 +12,7 @@ export declare class DynamicWalletMock {
|
|
|
13
12
|
static readonly create: import("vitest").Mock<[_params: {
|
|
14
13
|
chainManager: ChainManager;
|
|
15
14
|
dynamicWallet: DynamicHostedWalletToActionsWalletOptions["wallet"];
|
|
16
|
-
lendProviders?:
|
|
17
|
-
morpho?: LendProvider<LendProviderConfig>;
|
|
18
|
-
aave?: LendProvider<LendProviderConfig>;
|
|
19
|
-
};
|
|
15
|
+
lendProviders?: LendProviders;
|
|
20
16
|
}], Promise<Wallet>>;
|
|
21
17
|
}
|
|
22
18
|
//# sourceMappingURL=DynamicWalletMock.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicWalletMock.d.ts","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"DynamicWalletMock.d.ts","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACzD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAA;AACtE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAE/G;;;;;GAKG;AACH,qBAAa,iBAAiB;IAC5B,MAAM,CAAC,QAAQ,CAAC,MAAM;sBAEJ,YAAY;uBACX,yCAAyC,CAAC,QAAQ,CAAC;wBAClD,aAAa;yBAIhC;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicWalletMock.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;
|
|
1
|
+
{"version":3,"file":"DynamicWalletMock.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAO3B;;;;;GAKG;AACH,MAAM,OAAO,iBAAiB;;;AACZ,wBAAM,GAAG,EAAE,CAAC,EAAE,CAC5B,KAAK,EAAE,OAIN,EAAmB,EAAE;IACpB,OAAO,EAAuB,CAAA;AAChC,CAAC,CACF,AARqB,CAQrB"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import type { ConnectedWallet } from '@privy-io/react-auth';
|
|
2
2
|
import type { Address, LocalAccount } from 'viem';
|
|
3
|
-
import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
|
|
4
3
|
import type { ChainManager } from '../../../../../services/ChainManager.js';
|
|
5
|
-
import type {
|
|
6
|
-
import type {
|
|
4
|
+
import type { Asset } from '../../../../../types/asset.js';
|
|
5
|
+
import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
|
|
7
6
|
import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
|
|
8
7
|
/**
|
|
9
8
|
* Privy wallet implementation
|
|
@@ -17,13 +16,9 @@ export declare class PrivyWallet extends EOAWallet {
|
|
|
17
16
|
static create(params: {
|
|
18
17
|
chainManager: ChainManager;
|
|
19
18
|
connectedWallet: ConnectedWallet;
|
|
20
|
-
lendProviders?:
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
};
|
|
24
|
-
swapProviders?: {
|
|
25
|
-
uniswap?: SwapProvider<SwapProviderConfig>;
|
|
26
|
-
};
|
|
19
|
+
lendProviders?: LendProviders;
|
|
20
|
+
swapProviders?: SwapProviders;
|
|
21
|
+
supportedAssets?: Asset[];
|
|
27
22
|
}): Promise<PrivyWallet>;
|
|
28
23
|
/**
|
|
29
24
|
* Initialize the PrivyWallet by creating the signer account
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PrivyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"PrivyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAGlE;;;GAGG;AACH,qBAAa,WAAY,SAAQ,SAAS;IACjC,OAAO,EAAG,OAAO,CAAA;IACjB,MAAM,EAAG,YAAY,CAAA;IAE5B,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAiB;IAEjD,OAAO;WAWM,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,YAAY,CAAA;QAC1B,eAAe,EAAE,eAAe,CAAA;QAChC,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,WAAW,CAAC;IAYxB;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
|
|
@@ -5,12 +5,12 @@ import { createSigner } from './utils/createSigner.js';
|
|
|
5
5
|
* @description Wallet implementation using Privy service
|
|
6
6
|
*/
|
|
7
7
|
export class PrivyWallet extends EOAWallet {
|
|
8
|
-
constructor(chainManager, connectedWallet, lendProviders, swapProviders) {
|
|
9
|
-
super(chainManager, lendProviders, swapProviders);
|
|
8
|
+
constructor(chainManager, connectedWallet, lendProviders, swapProviders, supportedAssets) {
|
|
9
|
+
super(chainManager, lendProviders, swapProviders, supportedAssets);
|
|
10
10
|
this.connectedWallet = connectedWallet;
|
|
11
11
|
}
|
|
12
12
|
static async create(params) {
|
|
13
|
-
const wallet = new PrivyWallet(params.chainManager, params.connectedWallet, params.lendProviders, params.swapProviders);
|
|
13
|
+
const wallet = new PrivyWallet(params.chainManager, params.connectedWallet, params.lendProviders, params.swapProviders, params.supportedAssets);
|
|
14
14
|
await wallet.initialize();
|
|
15
15
|
return wallet;
|
|
16
16
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PrivyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PrivyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAA;AAExF;;;GAGG;AACH,MAAM,OAAO,WAAY,SAAQ,SAAS;IAMxC,YACE,YAA0B,EAC1B,eAAgC,EAChC,aAA6B,EAC7B,aAA6B,EAC7B,eAAyB;QAEzB,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,CAAC,CAAA;QAClE,IAAI,CAAC,eAAe,GAAG,eAAe,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAMnB;QACC,MAAM,MAAM,GAAG,IAAI,WAAW,CAC5B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,CACvB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAA;IACJ,CAAC;CACF"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import type { TurnkeySDKClientBase } from '@turnkey/react-wallet-kit';
|
|
2
2
|
import type { Address, LocalAccount } from 'viem';
|
|
3
|
-
import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
|
|
4
3
|
import type { ChainManager } from '../../../../../services/ChainManager.js';
|
|
5
|
-
import type {
|
|
6
|
-
import type {
|
|
4
|
+
import type { Asset } from '../../../../../types/asset.js';
|
|
5
|
+
import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
|
|
7
6
|
import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
|
|
8
7
|
/**
|
|
9
8
|
* Turnkey wallet implementation
|
|
@@ -38,13 +37,9 @@ export declare class TurnkeyWallet extends EOAWallet {
|
|
|
38
37
|
organizationId: string;
|
|
39
38
|
signWith: string;
|
|
40
39
|
ethereumAddress?: string;
|
|
41
|
-
lendProviders?:
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
};
|
|
45
|
-
swapProviders?: {
|
|
46
|
-
uniswap?: SwapProvider<SwapProviderConfig>;
|
|
47
|
-
};
|
|
40
|
+
lendProviders?: LendProviders;
|
|
41
|
+
swapProviders?: SwapProviders;
|
|
42
|
+
supportedAssets?: Asset[];
|
|
48
43
|
}): Promise<TurnkeyWallet>;
|
|
49
44
|
protected performInitialization(): Promise<void>;
|
|
50
45
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TurnkeyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AACrE,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"TurnkeyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AACrE,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAGlE;;;GAGG;AACH,qBAAa,aAAc,SAAQ,SAAS;IACnC,OAAO,EAAG,OAAO,CAAA;IACjB,MAAM,EAAG,YAAY,CAAA;IAC5B;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;IAC7C;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAQ;IACvC;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAQ;IACjC;;;;;OAKG;IACH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAQ;IAEzC,OAAO;WA2BM,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,YAAY,CAAA;QAC1B,MAAM,EAAE,oBAAoB,CAAA;QAC5B,cAAc,EAAE,MAAM,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAA;QAChB,eAAe,CAAC,EAAE,MAAM,CAAA;QACxB,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,aAAa,CAAC;cAMV,qBAAqB;IAKrC;;;;;;;;OAQG;YACW,YAAY;CAQ3B"}
|
|
@@ -6,8 +6,8 @@ import { createSigner } from './utils/createSigner.js';
|
|
|
6
6
|
*/
|
|
7
7
|
export class TurnkeyWallet extends EOAWallet {
|
|
8
8
|
constructor(params) {
|
|
9
|
-
const { chainManager, client, organizationId, signWith, ethereumAddress, lendProviders, swapProviders, } = params;
|
|
10
|
-
super(chainManager, lendProviders, swapProviders);
|
|
9
|
+
const { chainManager, client, organizationId, signWith, ethereumAddress, lendProviders, swapProviders, supportedAssets, } = params;
|
|
10
|
+
super(chainManager, lendProviders, swapProviders, supportedAssets);
|
|
11
11
|
this.client = client;
|
|
12
12
|
this.organizationId = organizationId;
|
|
13
13
|
this.signWith = signWith;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TurnkeyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TurnkeyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,6DAA6D,CAAA;AAE1F;;;GAGG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAuB1C,YAAoB,MASnB;QACC,MAAM,EACJ,YAAY,EACZ,MAAM,EACN,cAAc,EACd,QAAQ,EACR,eAAe,EACf,aAAa,EACb,aAAa,EACb,eAAe,GAChB,GAAG,MAAM,CAAA;QACV,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,CAAC,CAAA;QAClE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;QACpC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;QACxB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MASnB;QACC,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC,MAAM,CAAC,CAAA;QACxC,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAES,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;;OAQG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAA;IACJ,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -10,7 +10,8 @@
|
|
|
10
10
|
"url": "https://github.com/ethereum-optimism/actions/issues"
|
|
11
11
|
},
|
|
12
12
|
"type": "module",
|
|
13
|
-
"
|
|
13
|
+
"sideEffects": false,
|
|
14
|
+
"version": "0.4.0",
|
|
14
15
|
"description": "TypeScript SDK for Actions",
|
|
15
16
|
"main": "dist/index.js",
|
|
16
17
|
"types": "dist/index.d.ts",
|
|
@@ -83,7 +84,7 @@
|
|
|
83
84
|
"lint": "eslint \"**/*.{ts,tsx}\" && prettier --check \"**/*.{ts,tsx}\"",
|
|
84
85
|
"lint:fix": "eslint \"**/*.{ts,tsx}\" --fix && prettier \"**/*.{ts,tsx}\" --write --log-level=warn",
|
|
85
86
|
"test": "vitest --run --project unit",
|
|
86
|
-
"test:
|
|
87
|
+
"test:network": "vitest --run --project network",
|
|
87
88
|
"typecheck": "tsc --noEmit --emitDeclarationOnly false"
|
|
88
89
|
}
|
|
89
90
|
}
|
|
@@ -1,14 +1,19 @@
|
|
|
1
1
|
import type { Address } from 'viem'
|
|
2
|
+
import { base, baseSepolia, mode, optimism, unichain } from 'viem/chains'
|
|
2
3
|
|
|
3
4
|
import type { Asset } from '@/types/asset.js'
|
|
4
5
|
|
|
5
6
|
/**
|
|
6
|
-
* Mock USDC asset for testing
|
|
7
|
+
* Mock USDC asset for testing.
|
|
8
|
+
* Includes addresses for all commonly tested chains.
|
|
7
9
|
*/
|
|
8
10
|
export const MockUSDCAsset: Asset = {
|
|
9
11
|
address: {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
+
[optimism.id]: '0x1111111111111111111111111111111111111111' as Address,
|
|
13
|
+
[base.id]: '0x2222222222222222222222222222222222222222' as Address,
|
|
14
|
+
[baseSepolia.id]: '0x3333333333333333333333333333333333333333' as Address,
|
|
15
|
+
[unichain.id]: '0xA0b86991c431c924C2407E4C573C686cc8C6c5b7' as Address,
|
|
16
|
+
[mode.id]: '0x5555555555555555555555555555555555555555' as Address,
|
|
12
17
|
},
|
|
13
18
|
metadata: {
|
|
14
19
|
decimals: 6,
|
|
@@ -19,12 +24,16 @@ export const MockUSDCAsset: Asset = {
|
|
|
19
24
|
}
|
|
20
25
|
|
|
21
26
|
/**
|
|
22
|
-
* Mock WETH asset for testing
|
|
27
|
+
* Mock WETH asset for testing.
|
|
28
|
+
* Uses the standard OP Stack WETH predeploy address on all chains.
|
|
23
29
|
*/
|
|
24
30
|
export const MockWETHAsset: Asset = {
|
|
25
31
|
address: {
|
|
26
|
-
|
|
27
|
-
|
|
32
|
+
[optimism.id]: '0x4200000000000000000000000000000000000006' as Address,
|
|
33
|
+
[base.id]: '0x4200000000000000000000000000000000000006' as Address,
|
|
34
|
+
[baseSepolia.id]: '0x4200000000000000000000000000000000000006' as Address,
|
|
35
|
+
[unichain.id]: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2' as Address,
|
|
36
|
+
[mode.id]: '0x4200000000000000000000000000000000000006' as Address,
|
|
28
37
|
},
|
|
29
38
|
metadata: {
|
|
30
39
|
decimals: 18,
|
|
@@ -33,3 +42,42 @@ export const MockWETHAsset: Asset = {
|
|
|
33
42
|
},
|
|
34
43
|
type: 'erc20',
|
|
35
44
|
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Mock OP token for testing.
|
|
48
|
+
*/
|
|
49
|
+
export const MockOPAsset: Asset = {
|
|
50
|
+
address: {
|
|
51
|
+
[optimism.id]: '0x4200000000000000000000000000000000000042' as Address,
|
|
52
|
+
},
|
|
53
|
+
metadata: {
|
|
54
|
+
decimals: 18,
|
|
55
|
+
name: 'Optimism',
|
|
56
|
+
symbol: 'OP',
|
|
57
|
+
},
|
|
58
|
+
type: 'erc20',
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Mock native ETH asset for testing.
|
|
63
|
+
*/
|
|
64
|
+
export const MockETHAsset: Asset = {
|
|
65
|
+
address: {
|
|
66
|
+
[optimism.id]: 'native',
|
|
67
|
+
[base.id]: 'native',
|
|
68
|
+
[baseSepolia.id]: 'native',
|
|
69
|
+
},
|
|
70
|
+
metadata: {
|
|
71
|
+
decimals: 18,
|
|
72
|
+
name: 'Ether',
|
|
73
|
+
symbol: 'ETH',
|
|
74
|
+
},
|
|
75
|
+
type: 'native',
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/** Standard test wallet address */
|
|
79
|
+
export const MOCK_WALLET =
|
|
80
|
+
'0x000000000000000000000000000000000000dEaD' as Address
|
|
81
|
+
|
|
82
|
+
/** Standard mock pool address */
|
|
83
|
+
export const MOCK_POOL = '0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA' as Address
|
|
@@ -433,7 +433,7 @@ describe('Actions SDK', () => {
|
|
|
433
433
|
expect(actions.lend).toBeDefined()
|
|
434
434
|
const supportedIds = actions.lend.supportedChainIds()
|
|
435
435
|
expect(supportedIds).toContain(130) // Unichain
|
|
436
|
-
expect(supportedIds).toContain(
|
|
436
|
+
expect(supportedIds).toContain(84532) // Base Sepolia
|
|
437
437
|
})
|
|
438
438
|
})
|
|
439
439
|
|
package/src/actions.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import type { LendProvider } from '@/lend/index.js'
|
|
2
1
|
import { AaveLendProvider, MorphoLendProvider } from '@/lend/index.js'
|
|
3
2
|
import { ActionsLendNamespace } from '@/lend/namespaces/ActionsLendNamespace.js'
|
|
4
3
|
import { ChainManager } from '@/services/ChainManager.js'
|
|
5
|
-
import {
|
|
6
|
-
import type { SwapProvider } from '@/swap/index.js'
|
|
7
|
-
import { UniswapSwapProvider } from '@/swap/index.js'
|
|
4
|
+
import { UniswapSwapProvider, VelodromeSwapProvider } from '@/swap/index.js'
|
|
8
5
|
import { ActionsSwapNamespace } from '@/swap/namespaces/ActionsSwapNamespace.js'
|
|
9
6
|
import type {
|
|
10
7
|
ActionsConfig,
|
|
11
8
|
AssetsConfig,
|
|
12
|
-
|
|
13
|
-
|
|
9
|
+
LendProviders,
|
|
10
|
+
SwapProviders,
|
|
11
|
+
SwapSettings,
|
|
14
12
|
} from '@/types/actions.js'
|
|
15
13
|
import type { Asset } from '@/types/asset.js'
|
|
14
|
+
import { getAllAssetAddresses } from '@/utils/assets.js'
|
|
15
|
+
import { validateConfigAddresses } from '@/utils/validateAddresses.js'
|
|
16
16
|
import { WalletNamespace } from '@/wallet/core/namespace/WalletNamespace.js'
|
|
17
17
|
import type { HostedWalletProvider } from '@/wallet/core/providers/hosted/abstract/HostedWalletProvider.js'
|
|
18
18
|
import type { HostedWalletProviderRegistry } from '@/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js'
|
|
@@ -48,17 +48,11 @@ export class Actions<
|
|
|
48
48
|
>
|
|
49
49
|
private chainManager: ChainManager
|
|
50
50
|
private _lend?: ActionsLendNamespace
|
|
51
|
-
private _lendProviders: {
|
|
52
|
-
morpho?: LendProvider<LendProviderConfig>
|
|
53
|
-
aave?: LendProvider<LendProviderConfig>
|
|
54
|
-
} = {}
|
|
51
|
+
private _lendProviders: LendProviders = {}
|
|
55
52
|
private _swap?: ActionsSwapNamespace
|
|
56
|
-
private _swapProviders: {
|
|
57
|
-
|
|
58
|
-
} = {}
|
|
53
|
+
private _swapProviders: SwapProviders = {}
|
|
54
|
+
private _swapSettings?: SwapSettings
|
|
59
55
|
private _assetsConfig?: AssetsConfig
|
|
60
|
-
private hostedWalletProvider!: THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType]
|
|
61
|
-
private smartWalletProvider!: SmartWalletProvider
|
|
62
56
|
private hostedWalletProviderRegistry: HostedWalletProviderRegistry<
|
|
63
57
|
THostedWalletProvidersSchema['providerInstances'],
|
|
64
58
|
THostedWalletProvidersSchema['providerConfigs'],
|
|
@@ -80,6 +74,7 @@ export class Actions<
|
|
|
80
74
|
this.chainManager = new ChainManager(config.chains)
|
|
81
75
|
this.hostedWalletProviderRegistry = deps.hostedWalletProviderRegistry
|
|
82
76
|
this._assetsConfig = config.assets
|
|
77
|
+
validateConfigAddresses(config)
|
|
83
78
|
|
|
84
79
|
if (config.lend?.morpho) {
|
|
85
80
|
this._lendProviders.morpho = new MorphoLendProvider(
|
|
@@ -97,12 +92,27 @@ export class Actions<
|
|
|
97
92
|
this._lend = new ActionsLendNamespace(this._lendProviders)
|
|
98
93
|
}
|
|
99
94
|
|
|
95
|
+
const swapSettings = config.swap?.settings
|
|
100
96
|
if (config.swap?.uniswap) {
|
|
101
97
|
this._swapProviders.uniswap = new UniswapSwapProvider(
|
|
102
98
|
config.swap.uniswap,
|
|
103
99
|
this.chainManager,
|
|
100
|
+
swapSettings,
|
|
101
|
+
)
|
|
102
|
+
}
|
|
103
|
+
if (config.swap?.velodrome) {
|
|
104
|
+
this._swapProviders.velodrome = new VelodromeSwapProvider(
|
|
105
|
+
config.swap.velodrome,
|
|
106
|
+
this.chainManager,
|
|
107
|
+
swapSettings,
|
|
108
|
+
)
|
|
109
|
+
}
|
|
110
|
+
this._swapSettings = swapSettings
|
|
111
|
+
if (Object.values(this._swapProviders).some(Boolean)) {
|
|
112
|
+
this._swap = new ActionsSwapNamespace(
|
|
113
|
+
this._swapProviders,
|
|
114
|
+
this._swapSettings,
|
|
104
115
|
)
|
|
105
|
-
this._swap = new ActionsSwapNamespace(this._swapProviders)
|
|
106
116
|
}
|
|
107
117
|
|
|
108
118
|
this.wallet = this.createWalletNamespace(config.wallet)
|
|
@@ -128,10 +138,7 @@ export class Actions<
|
|
|
128
138
|
* Get the lend provider instances
|
|
129
139
|
* @returns Object containing configured lend providers
|
|
130
140
|
*/
|
|
131
|
-
get lendProviders(): {
|
|
132
|
-
morpho?: LendProvider<LendProviderConfig>
|
|
133
|
-
aave?: LendProvider<LendProviderConfig>
|
|
134
|
-
} {
|
|
141
|
+
get lendProviders(): LendProviders {
|
|
135
142
|
return this._lendProviders
|
|
136
143
|
}
|
|
137
144
|
|
|
@@ -155,46 +162,35 @@ export class Actions<
|
|
|
155
162
|
* Get the swap provider instances
|
|
156
163
|
* @returns Object containing configured swap providers
|
|
157
164
|
*/
|
|
158
|
-
get swapProviders(): {
|
|
159
|
-
uniswap?: SwapProvider<SwapProviderConfig>
|
|
160
|
-
} {
|
|
165
|
+
get swapProviders(): SwapProviders {
|
|
161
166
|
return this._swapProviders
|
|
162
167
|
}
|
|
163
168
|
|
|
164
169
|
/**
|
|
165
170
|
* Get the list of supported assets based on configuration
|
|
166
171
|
* @description Returns filtered assets based on allow/block lists in assets config.
|
|
167
|
-
* If no config provided, returns
|
|
172
|
+
* If no config provided, returns empty array. Developers must explicitly configure
|
|
173
|
+
* their supported assets via ActionsConfig.assets.allow.
|
|
168
174
|
* @returns Array of supported assets
|
|
169
175
|
*/
|
|
170
176
|
public getSupportedAssets(): Asset[] {
|
|
171
|
-
// If no assets config, return all supported tokens
|
|
172
177
|
if (!this._assetsConfig) {
|
|
173
|
-
return
|
|
178
|
+
return []
|
|
174
179
|
}
|
|
175
180
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
return this._assetsConfig.allow
|
|
179
|
-
}
|
|
181
|
+
const allow = this._assetsConfig.allow ?? []
|
|
182
|
+
const block = this._assetsConfig.block
|
|
180
183
|
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
const blockedAddresses = new Set(
|
|
184
|
-
this._assetsConfig.block.flatMap((asset) =>
|
|
185
|
-
Object.values(asset.address).map((addr) => addr.toLowerCase()),
|
|
186
|
-
),
|
|
187
|
-
)
|
|
188
|
-
return SUPPORTED_TOKENS.filter((token) => {
|
|
189
|
-
const tokenAddresses = Object.values(token.address).map((addr) =>
|
|
190
|
-
addr.toLowerCase(),
|
|
191
|
-
)
|
|
192
|
-
return !tokenAddresses.some((addr) => blockedAddresses.has(addr))
|
|
193
|
-
})
|
|
184
|
+
if (!block?.length) {
|
|
185
|
+
return allow
|
|
194
186
|
}
|
|
195
187
|
|
|
196
|
-
|
|
197
|
-
|
|
188
|
+
const blockedAddresses = new Set(block.flatMap(getAllAssetAddresses))
|
|
189
|
+
|
|
190
|
+
return allow.filter((asset) => {
|
|
191
|
+
const addresses = getAllAssetAddresses(asset)
|
|
192
|
+
return !addresses.some((addr) => blockedAddresses.has(addr))
|
|
193
|
+
})
|
|
198
194
|
}
|
|
199
195
|
|
|
200
196
|
/**
|
|
@@ -202,16 +198,18 @@ export class Actions<
|
|
|
202
198
|
* @param config - Wallet configuration
|
|
203
199
|
* @returns WalletProvider instance
|
|
204
200
|
*/
|
|
205
|
-
private createWalletProvider(
|
|
201
|
+
private async createWalletProvider(
|
|
206
202
|
config: ActionsConfig<
|
|
207
203
|
THostedWalletProviderType,
|
|
208
204
|
THostedWalletProvidersSchema['providerConfigs']
|
|
209
205
|
>['wallet'],
|
|
210
|
-
):
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
206
|
+
): Promise<
|
|
207
|
+
WalletProvider<
|
|
208
|
+
THostedWalletProviderType,
|
|
209
|
+
THostedWalletProvidersSchema['providerToActionsOptions'],
|
|
210
|
+
THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
|
|
211
|
+
SmartWalletProvider
|
|
212
|
+
>
|
|
215
213
|
> {
|
|
216
214
|
const hostedWalletProviderConfig = config.hostedWalletConfig.provider
|
|
217
215
|
const factory = this.hostedWalletProviderRegistry.getFactory(
|
|
@@ -227,21 +225,23 @@ export class Actions<
|
|
|
227
225
|
`Invalid options for hosted wallet provider: ${hostedWalletProviderConfig.type}`,
|
|
228
226
|
)
|
|
229
227
|
}
|
|
230
|
-
|
|
228
|
+
const hostedWalletProvider = await factory.create(
|
|
231
229
|
{
|
|
232
230
|
chainManager: this.chainManager,
|
|
233
231
|
lendProviders: this._lendProviders,
|
|
234
232
|
swapProviders: this._swapProviders,
|
|
235
233
|
supportedAssets: this.getSupportedAssets(),
|
|
234
|
+
swapSettings: this._swapSettings,
|
|
236
235
|
},
|
|
237
236
|
options,
|
|
238
237
|
)
|
|
239
238
|
|
|
239
|
+
let smartWalletProvider: SmartWalletProvider
|
|
240
240
|
if (
|
|
241
241
|
!config.smartWalletConfig ||
|
|
242
242
|
config.smartWalletConfig.provider.type === 'default'
|
|
243
243
|
) {
|
|
244
|
-
|
|
244
|
+
smartWalletProvider = new DefaultSmartWalletProvider(
|
|
245
245
|
this.chainManager,
|
|
246
246
|
this._lendProviders,
|
|
247
247
|
this._swapProviders,
|
|
@@ -254,16 +254,13 @@ export class Actions<
|
|
|
254
254
|
)
|
|
255
255
|
}
|
|
256
256
|
|
|
257
|
-
|
|
258
|
-
this.hostedWalletProvider,
|
|
259
|
-
this.smartWalletProvider,
|
|
260
|
-
)
|
|
261
|
-
|
|
262
|
-
return walletProvider
|
|
257
|
+
return new WalletProvider(hostedWalletProvider, smartWalletProvider)
|
|
263
258
|
}
|
|
264
259
|
|
|
265
260
|
/**
|
|
266
261
|
* Create the wallet namespace instance
|
|
262
|
+
* @description Creates a WalletNamespace with lazy provider initialization.
|
|
263
|
+
* The wallet provider is not created until the first wallet method is called.
|
|
267
264
|
* @param config - Wallet configuration
|
|
268
265
|
* @returns WalletNamespace instance
|
|
269
266
|
*/
|
|
@@ -273,12 +270,12 @@ export class Actions<
|
|
|
273
270
|
THostedWalletProvidersSchema['providerConfigs']
|
|
274
271
|
>['wallet'],
|
|
275
272
|
) {
|
|
276
|
-
const
|
|
273
|
+
const providerFactory = () => this.createWalletProvider(config)
|
|
277
274
|
return new WalletNamespace<
|
|
278
275
|
THostedWalletProviderType,
|
|
279
276
|
THostedWalletProvidersSchema['providerToActionsOptions'],
|
|
280
277
|
THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
|
|
281
278
|
SmartWalletProvider
|
|
282
|
-
>(
|
|
279
|
+
>(providerFactory)
|
|
283
280
|
}
|
|
284
281
|
}
|