@eth-optimism/actions-sdk 0.0.4 → 0.2.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/LICENSE +1 -1
- package/dist/__mocks__/MockAssets.d.ts.map +1 -0
- package/dist/__mocks__/MockAssets.js.map +1 -0
- package/dist/__mocks__/MockPrivyClient.d.ts.map +1 -0
- package/dist/__mocks__/MockPrivyClient.js.map +1 -0
- package/dist/__mocks__/utils.d.ts.map +1 -0
- package/dist/__mocks__/utils.js.map +1 -0
- package/dist/__tests__/actions.test.d.ts.map +1 -0
- package/dist/{actions.test.js → __tests__/actions.test.js} +35 -85
- package/dist/__tests__/actions.test.js.map +1 -0
- package/dist/actions.d.ts +19 -7
- package/dist/actions.d.ts.map +1 -1
- package/dist/actions.js +49 -19
- package/dist/actions.js.map +1 -1
- package/dist/constants/assets.d.ts +19 -0
- package/dist/constants/assets.d.ts.map +1 -1
- package/dist/constants/assets.js +84 -6
- package/dist/constants/assets.js.map +1 -1
- package/dist/constants/supportedChains.d.ts +1 -1
- package/dist/constants/supportedChains.d.ts.map +1 -1
- package/dist/constants/supportedChains.js +7 -3
- package/dist/constants/supportedChains.js.map +1 -1
- package/dist/core/asset/__mocks__/mockAsset.js +1 -1
- package/dist/core/asset/__mocks__/mockAsset.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/{test → lend/__mocks__}/MockLendProvider.d.ts +9 -7
- package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -0
- package/dist/{test → lend/__mocks__}/MockLendProvider.js +20 -21
- package/dist/lend/__mocks__/MockLendProvider.js.map +1 -0
- package/dist/{test → lend/__mocks__}/MockMarkets.d.ts +1 -1
- package/dist/lend/__mocks__/MockMarkets.d.ts.map +1 -0
- package/dist/{test → lend/__mocks__}/MockMarkets.js +1 -1
- package/dist/lend/__mocks__/MockMarkets.js.map +1 -0
- package/dist/lend/__mocks__/mockLendTransaction.d.ts +3 -12
- package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +1 -1
- package/dist/lend/__mocks__/mockLendTransaction.js +3 -19
- package/dist/lend/__mocks__/mockLendTransaction.js.map +1 -1
- package/dist/lend/core/LendProvider.d.ts +16 -3
- package/dist/lend/core/LendProvider.d.ts.map +1 -1
- package/dist/lend/core/LendProvider.js +23 -2
- package/dist/lend/core/LendProvider.js.map +1 -1
- package/dist/lend/core/__tests__/LendProvider.test.js +20 -50
- package/dist/lend/core/__tests__/LendProvider.test.js.map +1 -1
- package/dist/lend/index.d.ts +1 -0
- package/dist/lend/index.d.ts.map +1 -1
- package/dist/lend/index.js +1 -0
- package/dist/lend/index.js.map +1 -1
- package/dist/lend/namespaces/ActionsLendNamespace.d.ts +2 -9
- package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +1 -1
- package/dist/lend/namespaces/ActionsLendNamespace.js +2 -11
- package/dist/lend/namespaces/ActionsLendNamespace.js.map +1 -1
- package/dist/lend/namespaces/BaseLendNamespace.d.ts +47 -0
- package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -0
- package/dist/lend/namespaces/BaseLendNamespace.js +58 -0
- package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -0
- package/dist/lend/namespaces/WalletLendNamespace.d.ts +8 -9
- package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +1 -1
- package/dist/lend/namespaces/WalletLendNamespace.js +24 -31
- package/dist/lend/namespaces/WalletLendNamespace.js.map +1 -1
- package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js +25 -17
- package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +1 -1
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts +2 -0
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +1 -0
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +110 -0
- package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -0
- package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js +37 -21
- package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +1 -1
- package/dist/lend/providers/aave/AaveLendProvider.d.ts +74 -0
- package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -0
- package/dist/lend/providers/aave/AaveLendProvider.js +290 -0
- package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -0
- package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts +11 -0
- package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +1 -0
- package/dist/lend/providers/aave/__mocks__/mockReserve.js +80 -0
- package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +1 -0
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts +2 -0
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +1 -0
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +315 -0
- package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -0
- package/dist/lend/providers/aave/abis/pool.d.ts +153 -0
- package/dist/lend/providers/aave/abis/pool.d.ts.map +1 -0
- package/dist/lend/providers/aave/abis/pool.js +79 -0
- package/dist/lend/providers/aave/abis/pool.js.map +1 -0
- package/dist/lend/providers/aave/addresses.d.ts +57 -0
- package/dist/lend/providers/aave/addresses.d.ts.map +1 -0
- package/dist/lend/providers/aave/addresses.js +83 -0
- package/dist/lend/providers/aave/addresses.js.map +1 -0
- package/dist/lend/providers/aave/sdk.d.ts +57 -0
- package/dist/lend/providers/aave/sdk.d.ts.map +1 -0
- package/dist/lend/providers/aave/sdk.js +201 -0
- package/dist/lend/providers/aave/sdk.js.map +1 -0
- package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +4 -4
- package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
- package/dist/lend/providers/morpho/MorphoLendProvider.js +13 -28
- package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
- package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js +6 -57
- package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +1 -1
- package/dist/lend/providers/morpho/__tests__/api.test.js +248 -54
- package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
- package/dist/lend/providers/morpho/__tests__/sdk.test.js +1 -0
- package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
- package/dist/lend/providers/morpho/contracts.d.ts +19 -0
- package/dist/lend/providers/morpho/contracts.d.ts.map +1 -0
- package/dist/lend/providers/morpho/contracts.js +32 -0
- package/dist/lend/providers/morpho/contracts.js.map +1 -0
- package/dist/lend/providers/morpho/sdk.d.ts +4 -3
- package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
- package/dist/lend/providers/morpho/sdk.js +168 -71
- package/dist/lend/providers/morpho/sdk.js.map +1 -1
- package/dist/services/ChainManager.d.ts +1 -1
- package/dist/{test → services/__mocks__}/MockChainManager.d.ts +1 -1
- package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -0
- package/dist/services/__mocks__/MockChainManager.js.map +1 -0
- package/dist/services/tokenBalance.d.ts.map +1 -1
- package/dist/services/tokenBalance.js +4 -5
- package/dist/services/tokenBalance.js.map +1 -1
- package/dist/services/tokenBalance.spec.js +2 -2
- package/dist/services/tokenBalance.spec.js.map +1 -1
- package/dist/supported/tokens.d.ts +4 -4
- package/dist/supported/tokens.d.ts.map +1 -1
- package/dist/supported/tokens.js +5 -56
- package/dist/supported/tokens.js.map +1 -1
- package/dist/types/actions.d.ts +26 -2
- package/dist/types/actions.d.ts.map +1 -1
- package/dist/types/asset.d.ts +3 -3
- package/dist/types/asset.d.ts.map +1 -1
- package/dist/types/lend/base.d.ts +10 -28
- package/dist/types/lend/base.d.ts.map +1 -1
- package/dist/types/lend/contracts.d.ts +17 -0
- package/dist/types/lend/contracts.d.ts.map +1 -0
- package/dist/types/lend/contracts.js +2 -0
- package/dist/types/lend/contracts.js.map +1 -0
- package/dist/types/lend/index.d.ts +1 -0
- package/dist/types/lend/index.d.ts.map +1 -1
- package/dist/types/lend/index.js +1 -0
- package/dist/types/lend/index.js.map +1 -1
- package/dist/utils/assets.d.ts +7 -1
- package/dist/utils/assets.d.ts.map +1 -1
- package/dist/utils/assets.js +12 -1
- package/dist/utils/assets.js.map +1 -1
- package/dist/utils/assets.test.js +1 -1
- package/dist/utils/assets.test.js.map +1 -1
- package/dist/utils/constants.d.ts +5 -0
- package/dist/utils/constants.d.ts.map +1 -0
- package/dist/utils/constants.js +5 -0
- package/dist/utils/constants.js.map +1 -0
- package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
- package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +13 -13
- package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
- package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +12 -12
- package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +12 -3
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js +3 -2
- package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +2 -2
- package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/core/providers/hosted/types/index.d.ts +8 -2
- package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +14 -6
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js +10 -6
- package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +39 -16
- package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts +19 -7
- package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/abstract/Wallet.js +9 -7
- package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +2 -2
- package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
- package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js +2 -2
- package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +9 -3
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +4 -4
- package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +4 -4
- package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js +1 -1
- package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js.map +1 -1
- package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js +1 -1
- package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +10 -3
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js +5 -3
- package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +7 -6
- package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +5 -4
- package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +2 -2
- package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +9 -2
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +6 -3
- package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +5 -4
- package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +10 -3
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js +5 -4
- package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +3 -3
- package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +2 -2
- package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +8 -2
- 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/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -2
- package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +1 -1
- package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +6 -2
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +3 -3
- package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js.map +1 -1
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +22 -7
- package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +6 -2
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -3
- package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js +1 -1
- package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js.map +1 -1
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +8 -4
- package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +6 -2
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +3 -3
- package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
- package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +7 -4
- package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +6 -6
- package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
- package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +6 -2
- 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 +6 -0
- 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/dynamic/__tests__/DynamicWallet.spec.js +2 -2
- package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js +1 -1
- package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +6 -2
- 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/privy/__tests__/PrivyWallet.spec.js +2 -2
- package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +1 -1
- package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +6 -2
- 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/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -2
- package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
- package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +1 -1
- package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -1
- package/package.json +4 -1
- package/src/{test → __mocks__}/MockPrivyClient.ts +1 -1
- package/src/{actions.test.ts → __tests__/actions.test.ts} +34 -95
- package/src/actions.ts +82 -26
- package/src/constants/assets.ts +92 -8
- package/src/constants/supportedChains.ts +10 -2
- package/src/core/asset/__mocks__/mockAsset.ts +1 -1
- package/src/index.ts +2 -3
- package/src/{test → lend/__mocks__}/MockLendProvider.ts +24 -27
- package/src/{test → lend/__mocks__}/MockMarkets.ts +1 -1
- package/src/lend/__mocks__/mockLendTransaction.ts +4 -26
- package/src/lend/core/LendProvider.ts +40 -7
- package/src/lend/core/__tests__/LendProvider.test.ts +21 -63
- package/src/lend/index.ts +1 -0
- package/src/lend/namespaces/ActionsLendNamespace.ts +2 -21
- package/src/lend/namespaces/BaseLendNamespace.ts +89 -0
- package/src/lend/namespaces/WalletLendNamespace.ts +39 -55
- package/src/lend/namespaces/__tests__/ActionsLendNamespace.spec.ts +29 -22
- package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +137 -0
- package/src/lend/namespaces/__tests__/WalletLendNamespace.spec.ts +61 -26
- package/src/lend/providers/aave/AaveLendProvider.ts +395 -0
- package/src/lend/providers/aave/__mocks__/mockReserve.ts +84 -0
- package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +419 -0
- package/src/lend/providers/aave/abis/pool.ts +81 -0
- package/src/lend/providers/aave/addresses.ts +95 -0
- package/src/lend/providers/aave/sdk.ts +307 -0
- package/src/lend/providers/morpho/MorphoLendProvider.ts +23 -44
- package/src/lend/providers/morpho/__tests__/MorphoLendProvider.test.ts +13 -85
- package/src/lend/providers/morpho/__tests__/api.test.ts +277 -51
- package/src/lend/providers/morpho/__tests__/sdk.test.ts +1 -0
- package/src/lend/providers/morpho/contracts.ts +37 -0
- package/src/lend/providers/morpho/sdk.ts +235 -87
- package/src/services/tokenBalance.spec.ts +2 -2
- package/src/services/tokenBalance.ts +6 -7
- package/src/supported/tokens.ts +6 -57
- package/src/types/actions.ts +30 -2
- package/src/types/asset.ts +3 -3
- package/src/types/lend/base.ts +14 -33
- package/src/types/lend/contracts.ts +18 -0
- package/src/types/lend/index.ts +1 -0
- package/src/utils/assets.test.ts +1 -1
- package/src/utils/assets.ts +15 -1
- package/src/utils/constants.ts +4 -0
- package/src/wallet/core/namespace/WalletNamespace.ts +2 -4
- package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +15 -15
- package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +14 -14
- package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +15 -4
- package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +3 -3
- package/src/wallet/core/providers/hosted/types/index.ts +8 -2
- package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +24 -9
- package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +45 -55
- package/src/wallet/core/wallets/abstract/Wallet.ts +25 -17
- package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +2 -2
- package/src/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.ts +2 -2
- package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +17 -10
- package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +7 -10
- package/src/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.ts +1 -1
- package/src/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.ts +1 -1
- package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +13 -5
- package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +8 -8
- package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +6 -4
- package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +3 -3
- package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +13 -4
- package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +5 -5
- package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +18 -6
- package/src/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +4 -4
- package/src/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +2 -2
- package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +16 -5
- package/src/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -2
- package/src/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +1 -1
- package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +8 -4
- package/src/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.ts +1 -1
- package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +31 -17
- package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +8 -4
- package/src/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.ts +1 -1
- package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +10 -11
- package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +8 -4
- package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +7 -8
- package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +6 -6
- package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +5 -7
- package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +12 -5
- package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +6 -0
- package/src/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.ts +2 -2
- package/src/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.ts +1 -1
- package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +12 -5
- package/src/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +2 -2
- package/src/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +1 -1
- package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +12 -5
- package/src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -2
- package/src/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +1 -1
- package/dist/actions.test.d.ts.map +0 -1
- package/dist/actions.test.js.map +0 -1
- package/dist/constants/config.d.ts +0 -10
- package/dist/constants/config.d.ts.map +0 -1
- package/dist/constants/config.js +0 -10
- package/dist/constants/config.js.map +0 -1
- package/dist/test/MockAssets.d.ts.map +0 -1
- package/dist/test/MockAssets.js.map +0 -1
- package/dist/test/MockChainManager.d.ts.map +0 -1
- package/dist/test/MockChainManager.js.map +0 -1
- package/dist/test/MockLendProvider.d.ts.map +0 -1
- package/dist/test/MockLendProvider.js.map +0 -1
- package/dist/test/MockMarkets.d.ts.map +0 -1
- package/dist/test/MockMarkets.js.map +0 -1
- package/dist/test/MockPrivyClient.d.ts.map +0 -1
- package/dist/test/MockPrivyClient.js.map +0 -1
- package/dist/test/utils.d.ts.map +0 -1
- package/dist/test/utils.js.map +0 -1
- package/src/constants/config.ts +0 -9
- /package/dist/{test → __mocks__}/MockAssets.d.ts +0 -0
- /package/dist/{test → __mocks__}/MockAssets.js +0 -0
- /package/dist/{test → __mocks__}/MockPrivyClient.d.ts +0 -0
- /package/dist/{test → __mocks__}/MockPrivyClient.js +0 -0
- /package/dist/{test → __mocks__}/utils.d.ts +0 -0
- /package/dist/{test → __mocks__}/utils.js +0 -0
- /package/dist/{actions.test.d.ts → __tests__/actions.test.d.ts} +0 -0
- /package/dist/{test → services/__mocks__}/MockChainManager.js +0 -0
- /package/src/{test → __mocks__}/MockAssets.ts +0 -0
- /package/src/{test → __mocks__}/utils.ts +0 -0
- /package/src/{test → services/__mocks__}/MockChainManager.ts +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TurnkeyWallet.spec.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAE7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,MAAM,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;
|
|
1
|
+
{"version":3,"file":"TurnkeyWallet.spec.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { createAccount } from '@turnkey/viem';
|
|
2
2
|
import { describe, expect, it, vi } from 'vitest';
|
|
3
|
-
import { getRandomAddress } from '../../../../../../../
|
|
3
|
+
import { getRandomAddress } from '../../../../../../../__mocks__/utils.js';
|
|
4
4
|
import { createSigner } from '../createSigner.js';
|
|
5
5
|
vi.mock('@turnkey/viem', async () => ({
|
|
6
6
|
createAccount: vi.fn(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createSigner.spec.js","sourceRoot":"","sources":["../../../../../../../../src/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAE7C,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"createSigner.spec.js","sourceRoot":"","sources":["../../../../../../../../src/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAE7C,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,6DAA6D,CAAA;AAE1F,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;IACpC,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE;CACvB,CAAC,CAAC,CAAA;AAEH,SAAS,uBAAuB;IAC9B,OAAO;IACL,sEAAsE;KACpC,CAAA;AACtC,CAAC;AAED,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,MAAM,WAAW,GAAG,gBAAgB,EAAE,CAAA;IAEtC,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,MAAM,gBAAgB,GAAG;YACvB,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,EAAE,CAAC,EAAE,EAAE;YACpB,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;YACb,eAAe,EAAE,EAAE,CAAC,EAAE,EAAE;YACxB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE;SACI,CAAA;QAC5B,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAA;QAE5D,MAAM,MAAM,GAAG,uBAAuB,EAAE,CAAA;QACxC,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC;YAChC,MAAM;YACN,cAAc,EAAE,SAAS;YACzB,QAAQ,EAAE,SAAS;SACpB,CAAC,CAAA;QAEF,MAAM,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC;YACzC,MAAM;YACN,cAAc,EAAE,SAAS;YACzB,QAAQ,EAAE,SAAS;YACnB,eAAe,EAAE,SAAS;SAC3B,CAAC,CAAA;QACF,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;IACvC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,gBAAgB,GAAG;YACvB,OAAO,EAAE,WAAW;YACpB,IAAI,EAAE,OAAO;SACa,CAAA;QAC5B,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAA;QAE5D,MAAM,MAAM,GAAG,uBAAuB,EAAE,CAAA;QACxC,MAAM,eAAe,GAAG,gBAAgB,EAAE,CAAA;QAC1C,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC;YAChC,MAAM;YACN,cAAc,EAAE,SAAS;YACzB,QAAQ,EAAE,SAAS;YACnB,eAAe;SAChB,CAAC,CAAA;QAEF,MAAM,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC;YACzC,MAAM;YACN,cAAc,EAAE,SAAS;YACzB,QAAQ,EAAE,SAAS;YACnB,eAAe;SAChB,CAAC,CAAA;QACF,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;IACvC,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
"url": "https://github.com/ethereum-optimism/actions/issues"
|
|
11
11
|
},
|
|
12
12
|
"type": "module",
|
|
13
|
-
"version": "0.0
|
|
13
|
+
"version": "0.2.0",
|
|
14
14
|
"description": "TypeScript SDK for Actions",
|
|
15
15
|
"main": "dist/index.js",
|
|
16
16
|
"types": "dist/index.d.ts",
|
|
@@ -45,10 +45,13 @@
|
|
|
45
45
|
"author": "Optimism PBC",
|
|
46
46
|
"license": "MIT",
|
|
47
47
|
"dependencies": {
|
|
48
|
+
"@aave/contract-helpers": "^1.30.0",
|
|
49
|
+
"@aave/math-utils": "^1.30.0",
|
|
48
50
|
"@eth-optimism/viem": "^0.4.13",
|
|
49
51
|
"@morpho-org/blue-sdk": "^4.5.1",
|
|
50
52
|
"@morpho-org/blue-sdk-viem": "^3.1.1",
|
|
51
53
|
"@morpho-org/morpho-ts": "^2.4.1",
|
|
54
|
+
"ethers": "^5.7.2",
|
|
52
55
|
"permissionless": "^0.2.54",
|
|
53
56
|
"viem": "^2.24.1"
|
|
54
57
|
},
|
|
@@ -2,7 +2,7 @@ import type { AuthorizationContext, PrivyClient } from '@privy-io/node'
|
|
|
2
2
|
import type { Address } from 'viem'
|
|
3
3
|
import { generatePrivateKey } from 'viem/accounts'
|
|
4
4
|
|
|
5
|
-
import { getRandomAddress } from '@/
|
|
5
|
+
import { getRandomAddress } from '@/__mocks__/utils.js'
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Mock Privy Client for testing
|
|
@@ -2,12 +2,13 @@ import type { Address } from 'viem'
|
|
|
2
2
|
import { unichain } from 'viem/chains'
|
|
3
3
|
import { describe, expect, it } from 'vitest'
|
|
4
4
|
|
|
5
|
-
import { Actions } from '@/actions.js'
|
|
6
5
|
import {
|
|
7
6
|
createMockPrivyClient,
|
|
8
7
|
getMockAuthorizationContext,
|
|
9
|
-
} from '@/
|
|
10
|
-
import
|
|
8
|
+
} from '@/__mocks__/MockPrivyClient.js'
|
|
9
|
+
import { Actions } from '@/actions.js'
|
|
10
|
+
import type { LendProviderConfig } from '@/types/actions.js'
|
|
11
|
+
import type { LendMarketConfig } from '@/types/lend/index.js'
|
|
11
12
|
import { externalTest } from '@/utils/test.js'
|
|
12
13
|
import { HostedWalletProviderRegistry } from '@/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js'
|
|
13
14
|
import type { HostedWalletProvidersSchema } from '@/wallet/core/providers/hosted/types/index.js'
|
|
@@ -51,7 +52,7 @@ describe('Actions SDK', () => {
|
|
|
51
52
|
|
|
52
53
|
describe('Configuration', () => {
|
|
53
54
|
describe('Morpho Provider Configuration', () => {
|
|
54
|
-
it('should create Morpho provider when
|
|
55
|
+
it('should create Morpho provider when morpho config is provided', () => {
|
|
55
56
|
const actions = new Actions<
|
|
56
57
|
TestWalletProvider['providerTypes'],
|
|
57
58
|
TestWalletProvider,
|
|
@@ -60,7 +61,7 @@ describe('Actions SDK', () => {
|
|
|
60
61
|
{
|
|
61
62
|
chains: [{ chainId: unichain.id }],
|
|
62
63
|
lend: {
|
|
63
|
-
|
|
64
|
+
morpho: {},
|
|
64
65
|
},
|
|
65
66
|
wallet: {
|
|
66
67
|
hostedWalletConfig: {
|
|
@@ -90,8 +91,7 @@ describe('Actions SDK', () => {
|
|
|
90
91
|
expect(actions.lend.supportedChainIds()).toContain(130) // Unichain
|
|
91
92
|
})
|
|
92
93
|
|
|
93
|
-
it('should create Morpho provider with
|
|
94
|
-
const customSlippage = 150
|
|
94
|
+
it('should create Morpho provider with empty config', () => {
|
|
95
95
|
const actions = new Actions<
|
|
96
96
|
TestWalletProvider['providerTypes'],
|
|
97
97
|
TestWalletProvider,
|
|
@@ -100,8 +100,7 @@ describe('Actions SDK', () => {
|
|
|
100
100
|
{
|
|
101
101
|
chains: [{ chainId: unichain.id }],
|
|
102
102
|
lend: {
|
|
103
|
-
|
|
104
|
-
defaultSlippage: customSlippage,
|
|
103
|
+
morpho: {},
|
|
105
104
|
},
|
|
106
105
|
wallet: {
|
|
107
106
|
hostedWalletConfig: {
|
|
@@ -128,8 +127,7 @@ describe('Actions SDK', () => {
|
|
|
128
127
|
)
|
|
129
128
|
|
|
130
129
|
expect(actions.lend).toBeDefined()
|
|
131
|
-
expect(actions.lend.
|
|
132
|
-
expect(actions.lend.config.provider).toBe('morpho')
|
|
130
|
+
expect(actions.lend.supportedChainIds()).toContain(130) // Unichain
|
|
133
131
|
})
|
|
134
132
|
|
|
135
133
|
it('should create Morpho provider with market allowlist', () => {
|
|
@@ -160,8 +158,9 @@ describe('Actions SDK', () => {
|
|
|
160
158
|
{
|
|
161
159
|
chains: [{ chainId: unichain.id }],
|
|
162
160
|
lend: {
|
|
163
|
-
|
|
164
|
-
|
|
161
|
+
morpho: {
|
|
162
|
+
marketAllowlist: [mockMarket],
|
|
163
|
+
},
|
|
165
164
|
},
|
|
166
165
|
wallet: {
|
|
167
166
|
hostedWalletConfig: {
|
|
@@ -188,11 +187,9 @@ describe('Actions SDK', () => {
|
|
|
188
187
|
)
|
|
189
188
|
|
|
190
189
|
expect(actions.lend).toBeDefined()
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
expect(
|
|
194
|
-
expect(allowlist![0].address).toBe(mockMarket.address)
|
|
195
|
-
expect(allowlist![0].name).toBe(mockMarket.name)
|
|
190
|
+
// Verify Morpho provider is created with market allowlist
|
|
191
|
+
const morphoProvider = actions['lendProviders']['morpho']
|
|
192
|
+
expect(morphoProvider).toBeDefined()
|
|
196
193
|
})
|
|
197
194
|
|
|
198
195
|
it('should create Morpho provider with multiple markets in allowlist', () => {
|
|
@@ -243,8 +240,9 @@ describe('Actions SDK', () => {
|
|
|
243
240
|
{
|
|
244
241
|
chains: [{ chainId: unichain.id }],
|
|
245
242
|
lend: {
|
|
246
|
-
|
|
247
|
-
|
|
243
|
+
morpho: {
|
|
244
|
+
marketAllowlist: mockMarkets,
|
|
245
|
+
},
|
|
248
246
|
},
|
|
249
247
|
wallet: {
|
|
250
248
|
hostedWalletConfig: {
|
|
@@ -271,49 +269,9 @@ describe('Actions SDK', () => {
|
|
|
271
269
|
)
|
|
272
270
|
|
|
273
271
|
expect(actions.lend).toBeDefined()
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
expect(
|
|
277
|
-
expect(allowlist![0].name).toBe('Gauntlet USDC')
|
|
278
|
-
expect(allowlist![1].name).toBe('Test WETH Market')
|
|
279
|
-
})
|
|
280
|
-
|
|
281
|
-
it('should throw error for unsupported lending provider', () => {
|
|
282
|
-
expect(() => {
|
|
283
|
-
new Actions<
|
|
284
|
-
TestWalletProvider['providerTypes'],
|
|
285
|
-
TestWalletProvider,
|
|
286
|
-
'privy'
|
|
287
|
-
>(
|
|
288
|
-
{
|
|
289
|
-
chains: [{ chainId: unichain.id }],
|
|
290
|
-
lend: {
|
|
291
|
-
provider: 'invalid' as any,
|
|
292
|
-
},
|
|
293
|
-
wallet: {
|
|
294
|
-
hostedWalletConfig: {
|
|
295
|
-
provider: {
|
|
296
|
-
type: 'privy',
|
|
297
|
-
config: {
|
|
298
|
-
privyClient: createMockPrivyClient(
|
|
299
|
-
'test-id',
|
|
300
|
-
'test-secret',
|
|
301
|
-
),
|
|
302
|
-
authorizationContext: getMockAuthorizationContext(),
|
|
303
|
-
},
|
|
304
|
-
},
|
|
305
|
-
},
|
|
306
|
-
smartWalletConfig: {
|
|
307
|
-
provider: { type: 'default' },
|
|
308
|
-
},
|
|
309
|
-
},
|
|
310
|
-
},
|
|
311
|
-
{
|
|
312
|
-
hostedWalletProviderRegistry:
|
|
313
|
-
new TestHostedWalletProviderRegistry(),
|
|
314
|
-
},
|
|
315
|
-
)
|
|
316
|
-
}).toThrow('Unsupported lending provider: invalid')
|
|
272
|
+
// Verify Morpho provider is created with multiple markets
|
|
273
|
+
const morphoProvider = actions['lendProviders']['morpho']
|
|
274
|
+
expect(morphoProvider).toBeDefined()
|
|
317
275
|
})
|
|
318
276
|
|
|
319
277
|
it('should work without lend configuration', () => {
|
|
@@ -348,16 +306,14 @@ describe('Actions SDK', () => {
|
|
|
348
306
|
},
|
|
349
307
|
)
|
|
350
308
|
|
|
351
|
-
expect(actions['
|
|
309
|
+
expect(actions['lendProviders']).toEqual({})
|
|
352
310
|
expect(() => actions.lend).toThrow('Lend provider not configured')
|
|
353
311
|
})
|
|
354
312
|
})
|
|
355
313
|
|
|
356
314
|
describe('Lending Configuration Types', () => {
|
|
357
315
|
it('should accept valid MorphoLendConfig', () => {
|
|
358
|
-
const
|
|
359
|
-
provider: 'morpho',
|
|
360
|
-
defaultSlippage: 100,
|
|
316
|
+
const morphoConfig: LendProviderConfig = {
|
|
361
317
|
marketAllowlist: [],
|
|
362
318
|
}
|
|
363
319
|
|
|
@@ -369,7 +325,7 @@ describe('Actions SDK', () => {
|
|
|
369
325
|
>(
|
|
370
326
|
{
|
|
371
327
|
chains: [{ chainId: unichain.id }],
|
|
372
|
-
lend:
|
|
328
|
+
lend: { morpho: morphoConfig },
|
|
373
329
|
wallet: {
|
|
374
330
|
hostedWalletConfig: {
|
|
375
331
|
provider: {
|
|
@@ -397,9 +353,7 @@ describe('Actions SDK', () => {
|
|
|
397
353
|
})
|
|
398
354
|
|
|
399
355
|
it('should accept minimal MorphoLendConfig', () => {
|
|
400
|
-
const
|
|
401
|
-
provider: 'morpho',
|
|
402
|
-
}
|
|
356
|
+
const morphoConfig: LendProviderConfig = {}
|
|
403
357
|
|
|
404
358
|
expect(() => {
|
|
405
359
|
new Actions<
|
|
@@ -409,7 +363,7 @@ describe('Actions SDK', () => {
|
|
|
409
363
|
>(
|
|
410
364
|
{
|
|
411
365
|
chains: [{ chainId: unichain.id }],
|
|
412
|
-
lend:
|
|
366
|
+
lend: { morpho: morphoConfig },
|
|
413
367
|
wallet: {
|
|
414
368
|
hostedWalletConfig: {
|
|
415
369
|
provider: {
|
|
@@ -450,7 +404,7 @@ describe('Actions SDK', () => {
|
|
|
450
404
|
{ chainId: 84532 }, // Base Sepolia
|
|
451
405
|
],
|
|
452
406
|
lend: {
|
|
453
|
-
|
|
407
|
+
morpho: {},
|
|
454
408
|
},
|
|
455
409
|
wallet: {
|
|
456
410
|
hostedWalletConfig: {
|
|
@@ -493,8 +447,7 @@ describe('Actions SDK', () => {
|
|
|
493
447
|
{
|
|
494
448
|
chains: [{ chainId: unichain.id }],
|
|
495
449
|
lend: {
|
|
496
|
-
|
|
497
|
-
defaultSlippage: 50,
|
|
450
|
+
morpho: {},
|
|
498
451
|
},
|
|
499
452
|
wallet: {
|
|
500
453
|
hostedWalletConfig: {
|
|
@@ -546,10 +499,7 @@ describe('Actions SDK', () => {
|
|
|
546
499
|
chainId: unichain.id,
|
|
547
500
|
},
|
|
548
501
|
],
|
|
549
|
-
lend: {
|
|
550
|
-
provider: 'morpho',
|
|
551
|
-
defaultSlippage: 50,
|
|
552
|
-
},
|
|
502
|
+
lend: {},
|
|
553
503
|
wallet: {
|
|
554
504
|
hostedWalletConfig: {
|
|
555
505
|
provider: {
|
|
@@ -601,10 +551,7 @@ describe('Actions SDK', () => {
|
|
|
601
551
|
chainId: unichain.id,
|
|
602
552
|
},
|
|
603
553
|
],
|
|
604
|
-
lend: {
|
|
605
|
-
provider: 'morpho',
|
|
606
|
-
defaultSlippage: 50,
|
|
607
|
-
},
|
|
554
|
+
lend: {},
|
|
608
555
|
wallet: {
|
|
609
556
|
hostedWalletConfig: {
|
|
610
557
|
provider: {
|
|
@@ -689,10 +636,7 @@ describe('Actions SDK', () => {
|
|
|
689
636
|
chainId: unichain.id,
|
|
690
637
|
},
|
|
691
638
|
],
|
|
692
|
-
lend: {
|
|
693
|
-
provider: 'morpho',
|
|
694
|
-
defaultSlippage: 50,
|
|
695
|
-
},
|
|
639
|
+
lend: {},
|
|
696
640
|
wallet: {
|
|
697
641
|
hostedWalletConfig: {
|
|
698
642
|
provider: {
|
|
@@ -752,10 +696,7 @@ describe('Actions SDK', () => {
|
|
|
752
696
|
chainId: unichain.id,
|
|
753
697
|
},
|
|
754
698
|
],
|
|
755
|
-
lend: {
|
|
756
|
-
provider: 'morpho',
|
|
757
|
-
defaultSlippage: 50,
|
|
758
|
-
},
|
|
699
|
+
lend: {},
|
|
759
700
|
wallet: {
|
|
760
701
|
hostedWalletConfig: {
|
|
761
702
|
provider: {
|
|
@@ -807,8 +748,7 @@ describe('Actions SDK', () => {
|
|
|
807
748
|
},
|
|
808
749
|
],
|
|
809
750
|
lend: {
|
|
810
|
-
|
|
811
|
-
defaultSlippage: 50,
|
|
751
|
+
morpho: {},
|
|
812
752
|
},
|
|
813
753
|
wallet: {
|
|
814
754
|
hostedWalletConfig: {
|
|
@@ -859,8 +799,7 @@ describe('Actions SDK', () => {
|
|
|
859
799
|
},
|
|
860
800
|
],
|
|
861
801
|
lend: {
|
|
862
|
-
|
|
863
|
-
defaultSlippage: 50,
|
|
802
|
+
morpho: {},
|
|
864
803
|
},
|
|
865
804
|
wallet: {
|
|
866
805
|
hostedWalletConfig: {
|
package/src/actions.ts
CHANGED
|
@@ -1,9 +1,14 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { MorphoLendProvider } from '@/lend/index.js'
|
|
1
|
+
import type { LendProvider } from '@/lend/index.js'
|
|
2
|
+
import { AaveLendProvider, MorphoLendProvider } from '@/lend/index.js'
|
|
3
3
|
import { ActionsLendNamespace } from '@/lend/namespaces/ActionsLendNamespace.js'
|
|
4
4
|
import { ChainManager } from '@/services/ChainManager.js'
|
|
5
|
-
import
|
|
6
|
-
import type {
|
|
5
|
+
import { SUPPORTED_TOKENS } from '@/supported/tokens.js'
|
|
6
|
+
import type {
|
|
7
|
+
ActionsConfig,
|
|
8
|
+
AssetsConfig,
|
|
9
|
+
LendProviderConfig,
|
|
10
|
+
} from '@/types/actions.js'
|
|
11
|
+
import type { Asset } from '@/types/asset.js'
|
|
7
12
|
import { WalletNamespace } from '@/wallet/core/namespace/WalletNamespace.js'
|
|
8
13
|
import type { HostedWalletProvider } from '@/wallet/core/providers/hosted/abstract/HostedWalletProvider.js'
|
|
9
14
|
import type { HostedWalletProviderRegistry } from '@/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js'
|
|
@@ -38,8 +43,12 @@ export class Actions<
|
|
|
38
43
|
SmartWalletProvider
|
|
39
44
|
>
|
|
40
45
|
private chainManager: ChainManager
|
|
41
|
-
private _lend?: ActionsLendNamespace
|
|
42
|
-
private
|
|
46
|
+
private _lend?: ActionsLendNamespace
|
|
47
|
+
private _lendProviders: {
|
|
48
|
+
morpho?: LendProvider<LendProviderConfig>
|
|
49
|
+
aave?: LendProvider<LendProviderConfig>
|
|
50
|
+
} = {}
|
|
51
|
+
private _assetsConfig?: AssetsConfig
|
|
43
52
|
private hostedWalletProvider!: THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType]
|
|
44
53
|
private smartWalletProvider!: SmartWalletProvider
|
|
45
54
|
private hostedWalletProviderRegistry: HostedWalletProviderRegistry<
|
|
@@ -62,24 +71,27 @@ export class Actions<
|
|
|
62
71
|
) {
|
|
63
72
|
this.chainManager = new ChainManager(config.chains)
|
|
64
73
|
this.hostedWalletProviderRegistry = deps.hostedWalletProviderRegistry
|
|
74
|
+
this._assetsConfig = config.assets
|
|
65
75
|
|
|
66
|
-
// Create lending
|
|
76
|
+
// Create lending providers if configured
|
|
67
77
|
if (config.lend) {
|
|
68
|
-
if (config.lend.
|
|
69
|
-
this.
|
|
70
|
-
|
|
71
|
-
...config.lend,
|
|
72
|
-
defaultSlippage:
|
|
73
|
-
config.lend.defaultSlippage ??
|
|
74
|
-
DEFAULT_ACTIONS_CONFIG.lend.defaultSlippage,
|
|
75
|
-
},
|
|
78
|
+
if (config.lend.morpho) {
|
|
79
|
+
this._lendProviders.morpho = new MorphoLendProvider(
|
|
80
|
+
config.lend.morpho,
|
|
76
81
|
this.chainManager,
|
|
77
82
|
)
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
if (config.lend.aave) {
|
|
86
|
+
this._lendProviders.aave = new AaveLendProvider(
|
|
87
|
+
config.lend.aave,
|
|
88
|
+
this.chainManager,
|
|
89
|
+
)
|
|
90
|
+
}
|
|
78
91
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
throw new Error(`Unsupported lending provider: ${config.lend.provider}`)
|
|
92
|
+
// Create lend namespace if any providers are configured
|
|
93
|
+
if (this._lendProviders.morpho || this._lendProviders.aave) {
|
|
94
|
+
this._lend = new ActionsLendNamespace(this._lendProviders)
|
|
83
95
|
}
|
|
84
96
|
}
|
|
85
97
|
|
|
@@ -93,7 +105,7 @@ export class Actions<
|
|
|
93
105
|
* @returns ActionsLendNamespace for lending operations
|
|
94
106
|
* @throws Error if lend provider not configured
|
|
95
107
|
*/
|
|
96
|
-
get lend(): ActionsLendNamespace
|
|
108
|
+
get lend(): ActionsLendNamespace {
|
|
97
109
|
if (!this._lend) {
|
|
98
110
|
throw new Error(
|
|
99
111
|
'Lend provider not configured. Please add lend configuration to ActionsConfig.',
|
|
@@ -103,11 +115,50 @@ export class Actions<
|
|
|
103
115
|
}
|
|
104
116
|
|
|
105
117
|
/**
|
|
106
|
-
* Get the lend provider
|
|
107
|
-
* @returns
|
|
118
|
+
* Get the lend provider instances
|
|
119
|
+
* @returns Object containing configured lend providers
|
|
120
|
+
*/
|
|
121
|
+
get lendProviders(): {
|
|
122
|
+
morpho?: LendProvider<LendProviderConfig>
|
|
123
|
+
aave?: LendProvider<LendProviderConfig>
|
|
124
|
+
} {
|
|
125
|
+
return this._lendProviders
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* Get the list of supported assets based on configuration
|
|
130
|
+
* @description Returns filtered assets based on allow/block lists in assets config.
|
|
131
|
+
* If no config provided, returns all SUPPORTED_TOKENS.
|
|
132
|
+
* @returns Array of supported assets
|
|
108
133
|
*/
|
|
109
|
-
|
|
110
|
-
return
|
|
134
|
+
public getSupportedAssets(): Asset[] {
|
|
135
|
+
// If no assets config, return all supported tokens
|
|
136
|
+
if (!this._assetsConfig) {
|
|
137
|
+
return SUPPORTED_TOKENS
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
// If allow list provided, return only those
|
|
141
|
+
if (this._assetsConfig.allow && this._assetsConfig.allow.length > 0) {
|
|
142
|
+
return this._assetsConfig.allow
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
// If block list provided, filter out blocked assets
|
|
146
|
+
if (this._assetsConfig.block && this._assetsConfig.block.length > 0) {
|
|
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
|
+
})
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
// Default to all supported tokens
|
|
161
|
+
return SUPPORTED_TOKENS
|
|
111
162
|
}
|
|
112
163
|
|
|
113
164
|
/**
|
|
@@ -141,7 +192,11 @@ export class Actions<
|
|
|
141
192
|
)
|
|
142
193
|
}
|
|
143
194
|
this.hostedWalletProvider = factory.create(
|
|
144
|
-
{
|
|
195
|
+
{
|
|
196
|
+
chainManager: this.chainManager,
|
|
197
|
+
lendProviders: this._lendProviders,
|
|
198
|
+
supportedAssets: this.getSupportedAssets(),
|
|
199
|
+
},
|
|
145
200
|
options,
|
|
146
201
|
)
|
|
147
202
|
|
|
@@ -151,7 +206,8 @@ export class Actions<
|
|
|
151
206
|
) {
|
|
152
207
|
this.smartWalletProvider = new DefaultSmartWalletProvider(
|
|
153
208
|
this.chainManager,
|
|
154
|
-
this.
|
|
209
|
+
this._lendProviders,
|
|
210
|
+
this.getSupportedAssets(),
|
|
155
211
|
config.smartWalletConfig.provider.attributionSuffix,
|
|
156
212
|
)
|
|
157
213
|
} else {
|
package/src/constants/assets.ts
CHANGED
|
@@ -1,23 +1,28 @@
|
|
|
1
|
-
import type { Address } from 'viem'
|
|
2
1
|
import {
|
|
3
2
|
base,
|
|
4
3
|
baseSepolia,
|
|
5
4
|
mainnet,
|
|
5
|
+
optimism,
|
|
6
6
|
optimismSepolia,
|
|
7
|
+
sepolia,
|
|
7
8
|
unichain,
|
|
9
|
+
unichainSepolia,
|
|
10
|
+
worldchain,
|
|
8
11
|
} from 'viem/chains'
|
|
9
12
|
|
|
10
|
-
import type { SupportedChainId } from '@/constants/supportedChains.js'
|
|
11
13
|
import type { Asset } from '@/types/asset.js'
|
|
12
14
|
|
|
13
15
|
export const ETH: Asset = {
|
|
14
16
|
address: {
|
|
15
|
-
[mainnet.id]: '
|
|
16
|
-
[
|
|
17
|
-
[
|
|
18
|
-
[
|
|
19
|
-
[
|
|
20
|
-
|
|
17
|
+
[mainnet.id]: 'native',
|
|
18
|
+
[sepolia.id]: 'native',
|
|
19
|
+
[optimism.id]: 'native',
|
|
20
|
+
[optimismSepolia.id]: 'native',
|
|
21
|
+
[base.id]: 'native',
|
|
22
|
+
[baseSepolia.id]: 'native',
|
|
23
|
+
[unichain.id]: 'native',
|
|
24
|
+
[unichainSepolia.id]: 'native',
|
|
25
|
+
},
|
|
21
26
|
metadata: {
|
|
22
27
|
decimals: 18,
|
|
23
28
|
name: 'Ethereum',
|
|
@@ -25,3 +30,82 @@ export const ETH: Asset = {
|
|
|
25
30
|
},
|
|
26
31
|
type: 'native',
|
|
27
32
|
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Wrapped ETH token definition
|
|
36
|
+
* @description WETH is the ERC-20 wrapped version of native ETH
|
|
37
|
+
*/
|
|
38
|
+
export const WETH: Asset = {
|
|
39
|
+
address: {
|
|
40
|
+
[mainnet.id]: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
|
|
41
|
+
[sepolia.id]: '0x7b79995e5f793A07Bc00c21412e50Ecae098E7f9',
|
|
42
|
+
[optimism.id]: '0x4200000000000000000000000000000000000006',
|
|
43
|
+
[optimismSepolia.id]: '0x4200000000000000000000000000000000000006',
|
|
44
|
+
[base.id]: '0x4200000000000000000000000000000000000006',
|
|
45
|
+
[baseSepolia.id]: '0x4200000000000000000000000000000000000006',
|
|
46
|
+
[unichain.id]: '0x4200000000000000000000000000000000000006',
|
|
47
|
+
[unichainSepolia.id]: '0x4200000000000000000000000000000000000006',
|
|
48
|
+
},
|
|
49
|
+
metadata: {
|
|
50
|
+
symbol: 'WETH',
|
|
51
|
+
name: 'Wrapped Ether',
|
|
52
|
+
decimals: 18,
|
|
53
|
+
},
|
|
54
|
+
type: 'erc20',
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* USDC stablecoin definition
|
|
59
|
+
* @description Official Circle USDC addresses for Superchain networks
|
|
60
|
+
* @see https://developers.circle.com/stablecoins/usdc-contract-addresses
|
|
61
|
+
*/
|
|
62
|
+
export const USDC: Asset = {
|
|
63
|
+
address: {
|
|
64
|
+
[mainnet.id]: '0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48',
|
|
65
|
+
[sepolia.id]: '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238',
|
|
66
|
+
[optimism.id]: '0x0b2C639c533813f4Aa9D7837CAf62653d097Ff85',
|
|
67
|
+
[optimismSepolia.id]: '0x5fd84259d66Cd46123540766Be93DFE6D43130D7',
|
|
68
|
+
[base.id]: '0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913',
|
|
69
|
+
[baseSepolia.id]: '0x036CbD53842c5426634e7929541eC2318f3dCF7e',
|
|
70
|
+
[unichain.id]: '0x078D782b760474a361dDA0AF3839290b0EF57AD6',
|
|
71
|
+
[unichainSepolia.id]: '0x31d0220469e10c4E71834a79b1f276d740d3768F',
|
|
72
|
+
[worldchain.id]: '0x79A02482A880bCe3F13E09da970dC34dB4cD24D1',
|
|
73
|
+
},
|
|
74
|
+
metadata: {
|
|
75
|
+
symbol: 'USDC',
|
|
76
|
+
name: 'USD Coin',
|
|
77
|
+
decimals: 6,
|
|
78
|
+
},
|
|
79
|
+
type: 'erc20',
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Demo USDC token for testing
|
|
84
|
+
*/
|
|
85
|
+
export const USDC_DEMO: Asset = {
|
|
86
|
+
address: {
|
|
87
|
+
[baseSepolia.id]: '0xb1b0FE886cE376F28987Ad24b1759a8f0A7dd839',
|
|
88
|
+
},
|
|
89
|
+
metadata: {
|
|
90
|
+
symbol: 'USDC_DEMO',
|
|
91
|
+
name: 'USDC',
|
|
92
|
+
decimals: 6,
|
|
93
|
+
},
|
|
94
|
+
type: 'erc20',
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Morpho Token
|
|
99
|
+
*/
|
|
100
|
+
export const MORPHO: Asset = {
|
|
101
|
+
address: {
|
|
102
|
+
[mainnet.id]: '0x58D97B57BB95320F9a05dC918Aef65434969c2B2',
|
|
103
|
+
[base.id]: '0xBAa5CC21fd487B8Fcc2F632f3F4E8D37262a0842',
|
|
104
|
+
},
|
|
105
|
+
metadata: {
|
|
106
|
+
symbol: 'MORPHO',
|
|
107
|
+
name: 'Morpho Token',
|
|
108
|
+
decimals: 18,
|
|
109
|
+
},
|
|
110
|
+
type: 'erc20',
|
|
111
|
+
}
|
|
@@ -2,16 +2,24 @@ import {
|
|
|
2
2
|
base,
|
|
3
3
|
baseSepolia,
|
|
4
4
|
mainnet,
|
|
5
|
+
optimism,
|
|
5
6
|
optimismSepolia,
|
|
7
|
+
sepolia,
|
|
6
8
|
unichain,
|
|
9
|
+
unichainSepolia,
|
|
10
|
+
worldchain,
|
|
7
11
|
} from 'viem/chains'
|
|
8
12
|
|
|
9
13
|
export const SUPPORTED_CHAIN_IDS = [
|
|
10
14
|
mainnet.id,
|
|
11
|
-
|
|
15
|
+
sepolia.id,
|
|
16
|
+
optimism.id,
|
|
17
|
+
optimismSepolia.id,
|
|
12
18
|
base.id,
|
|
13
19
|
baseSepolia.id,
|
|
14
|
-
|
|
20
|
+
unichain.id,
|
|
21
|
+
unichainSepolia.id,
|
|
22
|
+
worldchain.id,
|
|
15
23
|
] as const
|
|
16
24
|
|
|
17
25
|
export type SupportedChainId = (typeof SUPPORTED_CHAIN_IDS)[number]
|