@eth-optimism/actions-sdk 0.2.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 -4
- package/dist/__mocks__/MockAssets.js.map +1 -1
- package/dist/__tests__/actions.test.js +1 -5
- package/dist/__tests__/actions.test.js.map +1 -1
- package/dist/actions.d.ts +23 -9
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +68 -36
- package/dist/actions.js.map +1 -1
- package/dist/constants/assets.d.ts +217 -2
- package/dist/constants/assets.d.ts.map +1 -1
- package/dist/constants/assets.js +744 -6
- package/dist/constants/assets.js.map +1 -1
- package/dist/constants/contracts.d.ts +4 -0
- package/dist/constants/contracts.d.ts.map +1 -0
- package/dist/constants/contracts.js +3 -0
- package/dist/constants/contracts.js.map +1 -0
- 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 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -2
- 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 -14
- package/dist/lend/core/LendProvider.d.ts.map +1 -1
- package/dist/lend/core/LendProvider.js +16 -31
- package/dist/lend/core/LendProvider.js.map +1 -1
- package/dist/lend/core/__tests__/LendProvider.test.js +2 -4
- package/dist/lend/core/__tests__/LendProvider.test.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 -41
- package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
- package/dist/lend/providers/morpho/api.d.ts +3 -3
- 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 -54
- 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 +50 -0
- package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
- package/dist/swap/__mocks__/MockSwapProvider.js +161 -0
- package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -0
- package/dist/swap/core/SwapProvider.d.ts +145 -0
- package/dist/swap/core/SwapProvider.d.ts.map +1 -0
- package/dist/swap/core/SwapProvider.js +359 -0
- package/dist/swap/core/SwapProvider.js.map +1 -0
- package/dist/swap/core/__tests__/SwapProvider.test.d.ts +2 -0
- package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
- package/dist/swap/core/__tests__/SwapProvider.test.js +435 -0
- package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -0
- 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 +9 -0
- package/dist/swap/index.d.ts.map +1 -0
- package/dist/swap/index.js +9 -0
- package/dist/swap/index.js.map +1 -0
- package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +8 -0
- package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
- package/dist/swap/namespaces/ActionsSwapNamespace.js +8 -0
- package/dist/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts +73 -0
- package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
- package/dist/swap/namespaces/BaseSwapNamespace.js +181 -0
- package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -0
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts +34 -0
- package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
- package/dist/swap/namespaces/WalletSwapNamespace.js +84 -0
- package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -0
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +2 -0
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +245 -0
- package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +2 -0
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +209 -0
- package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
- package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +35 -0
- package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/UniswapSwapProvider.js +148 -0
- package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +2 -0
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +258 -0
- package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
- package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts +2 -0
- package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/__tests__/sdk.test.js +312 -0
- package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
- package/dist/swap/providers/uniswap/abis.d.ts +227 -0
- package/dist/swap/providers/uniswap/abis.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/abis.js +138 -0
- package/dist/swap/providers/uniswap/abis.js.map +1 -0
- package/dist/swap/providers/uniswap/addresses.d.ts +26 -0
- package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/addresses.js +81 -0
- package/dist/swap/providers/uniswap/addresses.js.map +1 -0
- package/dist/swap/providers/uniswap/encoding.d.ts +77 -0
- package/dist/swap/providers/uniswap/encoding.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/encoding.js +233 -0
- package/dist/swap/providers/uniswap/encoding.js.map +1 -0
- 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 +21 -0
- package/dist/swap/providers/uniswap/types.d.ts.map +1 -0
- package/dist/swap/providers/uniswap/types.js +2 -0
- package/dist/swap/providers/uniswap/types.js.map +1 -0
- 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 +60 -11
- 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/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/lend/base.d.ts +9 -19
- 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 +338 -0
- package/dist/types/swap/base.d.ts.map +1 -0
- package/dist/types/swap/base.js +4 -0
- package/dist/types/swap/base.js.map +1 -0
- package/dist/types/swap/index.d.ts +2 -0
- package/dist/types/swap/index.d.ts.map +1 -0
- package/dist/types/swap/index.js +2 -0
- package/dist/types/swap/index.js.map +1 -0
- package/dist/types/transaction.d.ts +14 -0
- package/dist/types/transaction.d.ts.map +1 -0
- package/dist/types/transaction.js +2 -0
- package/dist/types/transaction.js.map +1 -0
- package/dist/utils/approve.d.ts +82 -0
- package/dist/utils/approve.d.ts.map +1 -0
- package/dist/utils/approve.js +134 -0
- 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/approve.test.js +203 -0
- package/dist/utils/approve.test.js.map +1 -0
- package/dist/utils/assets.d.ts +10 -5
- package/dist/utils/assets.d.ts.map +1 -1
- package/dist/utils/assets.js +14 -11
- package/dist/utils/assets.js.map +1 -1
- package/dist/utils/assets.test.js +13 -1
- package/dist/utils/assets.test.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/utils/validation.d.ts +12 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +44 -0
- package/dist/utils/validation.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 -10
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js +2 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/hosted/types/index.d.ts +6 -7
- package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +5 -6
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js +5 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +2 -2
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts +12 -12
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.js +9 -4
- 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 +5 -7
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +6 -5
- 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 +4 -6
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -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 +8 -9
- 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 +3 -6
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +4 -2
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +4 -6
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js +4 -3
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +3 -6
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +6 -6
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +7 -2
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -0
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +5 -6
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +6 -2
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -0
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +5 -8
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +6 -4
- 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 +7 -6
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +5 -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 -6
- 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 -6
- 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 +4 -3
- package/src/__mocks__/MockAssets.ts +54 -4
- package/src/__tests__/actions.test.ts +1 -5
- package/src/actions.ts +106 -71
- package/src/constants/assets.ts +792 -5
- package/src/constants/contracts.ts +5 -0
- package/src/constants/providers.ts +5 -0
- package/src/constants/supportedChains.ts +22 -2
- package/src/index.ts +76 -6
- package/src/lend/__mocks__/MockLendProvider.ts +8 -3
- package/src/lend/core/LendProvider.ts +28 -41
- package/src/lend/core/__tests__/LendProvider.test.ts +2 -5
- 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 -42
- package/src/lend/providers/morpho/api.ts +7 -4
- package/src/lend/providers/morpho/contracts.ts +62 -13
- package/src/lend/providers/morpho/sdk.ts +85 -54
- 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 +251 -0
- package/src/swap/core/SwapProvider.ts +577 -0
- package/src/swap/core/__tests__/SwapProvider.test.ts +620 -0
- package/src/swap/core/markets.ts +104 -0
- package/src/swap/index.ts +19 -0
- package/src/swap/namespaces/ActionsSwapNamespace.ts +7 -0
- package/src/swap/namespaces/BaseSwapNamespace.ts +258 -0
- package/src/swap/namespaces/WalletSwapNamespace.ts +121 -0
- package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +365 -0
- package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +257 -0
- package/src/swap/providers/uniswap/UniswapSwapProvider.ts +217 -0
- package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +299 -0
- package/src/swap/providers/uniswap/__tests__/sdk.test.ts +369 -0
- package/src/swap/providers/uniswap/abis.ts +144 -0
- package/src/swap/providers/uniswap/addresses.ts +110 -0
- package/src/swap/providers/uniswap/encoding.ts +406 -0
- package/src/swap/providers/uniswap/markets.ts +84 -0
- package/src/swap/providers/uniswap/types.ts +25 -0
- 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 +68 -12
- package/src/types/asset.ts +12 -9
- package/src/types/chain.ts +2 -2
- package/src/types/index.ts +2 -0
- package/src/types/lend/base.ts +10 -20
- package/src/types/lend/contracts.ts +5 -1
- package/src/types/providers.ts +22 -0
- package/src/types/swap/base.ts +372 -0
- package/src/types/swap/index.ts +1 -0
- package/src/types/transaction.ts +14 -0
- package/src/utils/approve.test.ts +258 -0
- package/src/utils/approve.ts +197 -0
- package/src/utils/assets.test.ts +16 -1
- package/src/utils/assets.ts +27 -10
- package/src/utils/validateAddresses.test.ts +439 -0
- package/src/utils/validateAddresses.ts +153 -0
- package/src/utils/validation.ts +76 -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 +6 -10
- package/src/wallet/core/providers/hosted/types/index.ts +9 -7
- package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +10 -10
- package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +2 -0
- package/src/wallet/core/wallets/abstract/Wallet.ts +23 -14
- 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 +11 -14
- package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +0 -1
- package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +11 -7
- package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +16 -8
- package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +4 -4
- package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +6 -7
- package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +8 -11
- package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +7 -11
- package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +11 -7
- package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -0
- package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +10 -7
- package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -0
- package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +10 -9
- package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +38 -13
- package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +6 -6
- package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +13 -11
- package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +2 -6
- package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +11 -11
- package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +11 -11
- package/dist/supported/tokens.d.ts +0 -25
- package/dist/supported/tokens.d.ts.map +0 -1
- package/dist/supported/tokens.js +0 -37
- package/dist/supported/tokens.js.map +0 -1
- package/src/supported/tokens.ts +0 -52
|
@@ -1,8 +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 {
|
|
4
|
+
import type { Asset } from '../../../../../types/asset.js';
|
|
5
|
+
import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
|
|
6
6
|
import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
|
|
7
7
|
/**
|
|
8
8
|
* Turnkey wallet implementation
|
|
@@ -37,10 +37,9 @@ export declare class TurnkeyWallet extends EOAWallet {
|
|
|
37
37
|
organizationId: string;
|
|
38
38
|
signWith: string;
|
|
39
39
|
ethereumAddress?: string;
|
|
40
|
-
lendProviders?:
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
};
|
|
40
|
+
lendProviders?: LendProviders;
|
|
41
|
+
swapProviders?: SwapProviders;
|
|
42
|
+
supportedAssets?: Asset[];
|
|
44
43
|
}): Promise<TurnkeyWallet>;
|
|
45
44
|
protected performInitialization(): Promise<void>;
|
|
46
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, } = params;
|
|
10
|
-
super(chainManager, lendProviders);
|
|
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":"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,
|
|
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",
|
|
@@ -81,9 +82,9 @@
|
|
|
81
82
|
"clean": "rm -rf dist types tsconfig.tsbuildinfo",
|
|
82
83
|
"docs": "typedoc",
|
|
83
84
|
"lint": "eslint \"**/*.{ts,tsx}\" && prettier --check \"**/*.{ts,tsx}\"",
|
|
84
|
-
"lint:fix": "eslint \"**/*.{ts,tsx}\" --fix && prettier \"**/*.{ts,tsx}\" --write --
|
|
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,13 +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
|
-
|
|
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,
|
|
11
17
|
},
|
|
12
18
|
metadata: {
|
|
13
19
|
decimals: 6,
|
|
@@ -18,11 +24,16 @@ export const MockUSDCAsset: Asset = {
|
|
|
18
24
|
}
|
|
19
25
|
|
|
20
26
|
/**
|
|
21
|
-
* Mock WETH asset for testing
|
|
27
|
+
* Mock WETH asset for testing.
|
|
28
|
+
* Uses the standard OP Stack WETH predeploy address on all chains.
|
|
22
29
|
*/
|
|
23
30
|
export const MockWETHAsset: Asset = {
|
|
24
31
|
address: {
|
|
25
|
-
|
|
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,
|
|
26
37
|
},
|
|
27
38
|
metadata: {
|
|
28
39
|
decimals: 18,
|
|
@@ -31,3 +42,42 @@ export const MockWETHAsset: Asset = {
|
|
|
31
42
|
},
|
|
32
43
|
type: 'erc20',
|
|
33
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
|
|
|
@@ -499,7 +499,6 @@ describe('Actions SDK', () => {
|
|
|
499
499
|
chainId: unichain.id,
|
|
500
500
|
},
|
|
501
501
|
],
|
|
502
|
-
lend: {},
|
|
503
502
|
wallet: {
|
|
504
503
|
hostedWalletConfig: {
|
|
505
504
|
provider: {
|
|
@@ -551,7 +550,6 @@ describe('Actions SDK', () => {
|
|
|
551
550
|
chainId: unichain.id,
|
|
552
551
|
},
|
|
553
552
|
],
|
|
554
|
-
lend: {},
|
|
555
553
|
wallet: {
|
|
556
554
|
hostedWalletConfig: {
|
|
557
555
|
provider: {
|
|
@@ -636,7 +634,6 @@ describe('Actions SDK', () => {
|
|
|
636
634
|
chainId: unichain.id,
|
|
637
635
|
},
|
|
638
636
|
],
|
|
639
|
-
lend: {},
|
|
640
637
|
wallet: {
|
|
641
638
|
hostedWalletConfig: {
|
|
642
639
|
provider: {
|
|
@@ -696,7 +693,6 @@ describe('Actions SDK', () => {
|
|
|
696
693
|
chainId: unichain.id,
|
|
697
694
|
},
|
|
698
695
|
],
|
|
699
|
-
lend: {},
|
|
700
696
|
wallet: {
|
|
701
697
|
hostedWalletConfig: {
|
|
702
698
|
provider: {
|
package/src/actions.ts
CHANGED
|
@@ -1,14 +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 {
|
|
4
|
+
import { UniswapSwapProvider, VelodromeSwapProvider } from '@/swap/index.js'
|
|
5
|
+
import { ActionsSwapNamespace } from '@/swap/namespaces/ActionsSwapNamespace.js'
|
|
6
6
|
import type {
|
|
7
7
|
ActionsConfig,
|
|
8
8
|
AssetsConfig,
|
|
9
|
-
|
|
9
|
+
LendProviders,
|
|
10
|
+
SwapProviders,
|
|
11
|
+
SwapSettings,
|
|
10
12
|
} from '@/types/actions.js'
|
|
11
13
|
import type { Asset } from '@/types/asset.js'
|
|
14
|
+
import { getAllAssetAddresses } from '@/utils/assets.js'
|
|
15
|
+
import { validateConfigAddresses } from '@/utils/validateAddresses.js'
|
|
12
16
|
import { WalletNamespace } from '@/wallet/core/namespace/WalletNamespace.js'
|
|
13
17
|
import type { HostedWalletProvider } from '@/wallet/core/providers/hosted/abstract/HostedWalletProvider.js'
|
|
14
18
|
import type { HostedWalletProviderRegistry } from '@/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js'
|
|
@@ -44,13 +48,11 @@ export class Actions<
|
|
|
44
48
|
>
|
|
45
49
|
private chainManager: ChainManager
|
|
46
50
|
private _lend?: ActionsLendNamespace
|
|
47
|
-
private _lendProviders: {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
+
private _lendProviders: LendProviders = {}
|
|
52
|
+
private _swap?: ActionsSwapNamespace
|
|
53
|
+
private _swapProviders: SwapProviders = {}
|
|
54
|
+
private _swapSettings?: SwapSettings
|
|
51
55
|
private _assetsConfig?: AssetsConfig
|
|
52
|
-
private hostedWalletProvider!: THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType]
|
|
53
|
-
private smartWalletProvider!: SmartWalletProvider
|
|
54
56
|
private hostedWalletProviderRegistry: HostedWalletProviderRegistry<
|
|
55
57
|
THostedWalletProvidersSchema['providerInstances'],
|
|
56
58
|
THostedWalletProvidersSchema['providerConfigs'],
|
|
@@ -72,27 +74,45 @@ export class Actions<
|
|
|
72
74
|
this.chainManager = new ChainManager(config.chains)
|
|
73
75
|
this.hostedWalletProviderRegistry = deps.hostedWalletProviderRegistry
|
|
74
76
|
this._assetsConfig = config.assets
|
|
77
|
+
validateConfigAddresses(config)
|
|
75
78
|
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
this.
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
79
|
+
if (config.lend?.morpho) {
|
|
80
|
+
this._lendProviders.morpho = new MorphoLendProvider(
|
|
81
|
+
config.lend.morpho,
|
|
82
|
+
this.chainManager,
|
|
83
|
+
)
|
|
84
|
+
}
|
|
85
|
+
if (config.lend?.aave) {
|
|
86
|
+
this._lendProviders.aave = new AaveLendProvider(
|
|
87
|
+
config.lend.aave,
|
|
88
|
+
this.chainManager,
|
|
89
|
+
)
|
|
90
|
+
}
|
|
91
|
+
if (this._lendProviders.morpho || this._lendProviders.aave) {
|
|
92
|
+
this._lend = new ActionsLendNamespace(this._lendProviders)
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const swapSettings = config.swap?.settings
|
|
96
|
+
if (config.swap?.uniswap) {
|
|
97
|
+
this._swapProviders.uniswap = new UniswapSwapProvider(
|
|
98
|
+
config.swap.uniswap,
|
|
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,
|
|
115
|
+
)
|
|
96
116
|
}
|
|
97
117
|
|
|
98
118
|
this.wallet = this.createWalletNamespace(config.wallet)
|
|
@@ -118,47 +138,59 @@ export class Actions<
|
|
|
118
138
|
* Get the lend provider instances
|
|
119
139
|
* @returns Object containing configured lend providers
|
|
120
140
|
*/
|
|
121
|
-
get lendProviders(): {
|
|
122
|
-
morpho?: LendProvider<LendProviderConfig>
|
|
123
|
-
aave?: LendProvider<LendProviderConfig>
|
|
124
|
-
} {
|
|
141
|
+
get lendProviders(): LendProviders {
|
|
125
142
|
return this._lendProviders
|
|
126
143
|
}
|
|
127
144
|
|
|
145
|
+
/**
|
|
146
|
+
* Get swap operations interface
|
|
147
|
+
* @description Access to swap operations like price quotes and markets.
|
|
148
|
+
* Throws an error if no swap provider is configured in ActionsConfig.
|
|
149
|
+
* @returns ActionsSwapNamespace for swap operations
|
|
150
|
+
* @throws Error if swap provider not configured
|
|
151
|
+
*/
|
|
152
|
+
get swap(): ActionsSwapNamespace {
|
|
153
|
+
if (!this._swap) {
|
|
154
|
+
throw new Error(
|
|
155
|
+
'Swap provider not configured. Please add swap configuration to ActionsConfig.',
|
|
156
|
+
)
|
|
157
|
+
}
|
|
158
|
+
return this._swap
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Get the swap provider instances
|
|
163
|
+
* @returns Object containing configured swap providers
|
|
164
|
+
*/
|
|
165
|
+
get swapProviders(): SwapProviders {
|
|
166
|
+
return this._swapProviders
|
|
167
|
+
}
|
|
168
|
+
|
|
128
169
|
/**
|
|
129
170
|
* Get the list of supported assets based on configuration
|
|
130
171
|
* @description Returns filtered assets based on allow/block lists in assets config.
|
|
131
|
-
* 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.
|
|
132
174
|
* @returns Array of supported assets
|
|
133
175
|
*/
|
|
134
176
|
public getSupportedAssets(): Asset[] {
|
|
135
|
-
// If no assets config, return all supported tokens
|
|
136
177
|
if (!this._assetsConfig) {
|
|
137
|
-
return
|
|
178
|
+
return []
|
|
138
179
|
}
|
|
139
180
|
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
return this._assetsConfig.allow
|
|
143
|
-
}
|
|
181
|
+
const allow = this._assetsConfig.allow ?? []
|
|
182
|
+
const block = this._assetsConfig.block
|
|
144
183
|
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
const blockedAddresses = new Set(
|
|
148
|
-
this._assetsConfig.block.flatMap((asset) =>
|
|
149
|
-
Object.values(asset.address).map((addr) => addr.toLowerCase()),
|
|
150
|
-
),
|
|
151
|
-
)
|
|
152
|
-
return SUPPORTED_TOKENS.filter((token) => {
|
|
153
|
-
const tokenAddresses = Object.values(token.address).map((addr) =>
|
|
154
|
-
addr.toLowerCase(),
|
|
155
|
-
)
|
|
156
|
-
return !tokenAddresses.some((addr) => blockedAddresses.has(addr))
|
|
157
|
-
})
|
|
184
|
+
if (!block?.length) {
|
|
185
|
+
return allow
|
|
158
186
|
}
|
|
159
187
|
|
|
160
|
-
|
|
161
|
-
|
|
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
|
+
})
|
|
162
194
|
}
|
|
163
195
|
|
|
164
196
|
/**
|
|
@@ -166,16 +198,18 @@ export class Actions<
|
|
|
166
198
|
* @param config - Wallet configuration
|
|
167
199
|
* @returns WalletProvider instance
|
|
168
200
|
*/
|
|
169
|
-
private createWalletProvider(
|
|
201
|
+
private async createWalletProvider(
|
|
170
202
|
config: ActionsConfig<
|
|
171
203
|
THostedWalletProviderType,
|
|
172
204
|
THostedWalletProvidersSchema['providerConfigs']
|
|
173
205
|
>['wallet'],
|
|
174
|
-
):
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
206
|
+
): Promise<
|
|
207
|
+
WalletProvider<
|
|
208
|
+
THostedWalletProviderType,
|
|
209
|
+
THostedWalletProvidersSchema['providerToActionsOptions'],
|
|
210
|
+
THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
|
|
211
|
+
SmartWalletProvider
|
|
212
|
+
>
|
|
179
213
|
> {
|
|
180
214
|
const hostedWalletProviderConfig = config.hostedWalletConfig.provider
|
|
181
215
|
const factory = this.hostedWalletProviderRegistry.getFactory(
|
|
@@ -191,22 +225,26 @@ export class Actions<
|
|
|
191
225
|
`Invalid options for hosted wallet provider: ${hostedWalletProviderConfig.type}`,
|
|
192
226
|
)
|
|
193
227
|
}
|
|
194
|
-
|
|
228
|
+
const hostedWalletProvider = await factory.create(
|
|
195
229
|
{
|
|
196
230
|
chainManager: this.chainManager,
|
|
197
231
|
lendProviders: this._lendProviders,
|
|
232
|
+
swapProviders: this._swapProviders,
|
|
198
233
|
supportedAssets: this.getSupportedAssets(),
|
|
234
|
+
swapSettings: this._swapSettings,
|
|
199
235
|
},
|
|
200
236
|
options,
|
|
201
237
|
)
|
|
202
238
|
|
|
239
|
+
let smartWalletProvider: SmartWalletProvider
|
|
203
240
|
if (
|
|
204
241
|
!config.smartWalletConfig ||
|
|
205
242
|
config.smartWalletConfig.provider.type === 'default'
|
|
206
243
|
) {
|
|
207
|
-
|
|
244
|
+
smartWalletProvider = new DefaultSmartWalletProvider(
|
|
208
245
|
this.chainManager,
|
|
209
246
|
this._lendProviders,
|
|
247
|
+
this._swapProviders,
|
|
210
248
|
this.getSupportedAssets(),
|
|
211
249
|
config.smartWalletConfig.provider.attributionSuffix,
|
|
212
250
|
)
|
|
@@ -216,16 +254,13 @@ export class Actions<
|
|
|
216
254
|
)
|
|
217
255
|
}
|
|
218
256
|
|
|
219
|
-
|
|
220
|
-
this.hostedWalletProvider,
|
|
221
|
-
this.smartWalletProvider,
|
|
222
|
-
)
|
|
223
|
-
|
|
224
|
-
return walletProvider
|
|
257
|
+
return new WalletProvider(hostedWalletProvider, smartWalletProvider)
|
|
225
258
|
}
|
|
226
259
|
|
|
227
260
|
/**
|
|
228
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.
|
|
229
264
|
* @param config - Wallet configuration
|
|
230
265
|
* @returns WalletNamespace instance
|
|
231
266
|
*/
|
|
@@ -235,12 +270,12 @@ export class Actions<
|
|
|
235
270
|
THostedWalletProvidersSchema['providerConfigs']
|
|
236
271
|
>['wallet'],
|
|
237
272
|
) {
|
|
238
|
-
const
|
|
273
|
+
const providerFactory = () => this.createWalletProvider(config)
|
|
239
274
|
return new WalletNamespace<
|
|
240
275
|
THostedWalletProviderType,
|
|
241
276
|
THostedWalletProvidersSchema['providerToActionsOptions'],
|
|
242
277
|
THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
|
|
243
278
|
SmartWalletProvider
|
|
244
|
-
>(
|
|
279
|
+
>(providerFactory)
|
|
245
280
|
}
|
|
246
281
|
}
|