@eth-optimism/actions-sdk 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (436) hide show
  1. package/dist/__mocks__/MockAssets.d.ts +17 -2
  2. package/dist/__mocks__/MockAssets.d.ts.map +1 -1
  3. package/dist/__mocks__/MockAssets.js +49 -6
  4. package/dist/__mocks__/MockAssets.js.map +1 -1
  5. package/dist/__tests__/actions.test.js +1 -1
  6. package/dist/__tests__/actions.test.js.map +1 -1
  7. package/dist/actions.d.ts +8 -13
  8. package/dist/actions.d.ts.map +1 -1
  9. package/dist/actions.js +35 -27
  10. package/dist/actions.js.map +1 -1
  11. package/dist/constants/assets.d.ts +215 -4
  12. package/dist/constants/assets.d.ts.map +1 -1
  13. package/dist/constants/assets.js +734 -11
  14. package/dist/constants/assets.js.map +1 -1
  15. package/dist/constants/providers.d.ts +6 -0
  16. package/dist/constants/providers.d.ts.map +1 -0
  17. package/dist/constants/providers.js +6 -0
  18. package/dist/constants/providers.js.map +1 -0
  19. package/dist/constants/supportedChains.d.ts +2 -2
  20. package/dist/constants/supportedChains.d.ts.map +1 -1
  21. package/dist/constants/supportedChains.js +12 -2
  22. package/dist/constants/supportedChains.js.map +1 -1
  23. package/dist/index.d.ts +4 -5
  24. package/dist/index.d.ts.map +1 -1
  25. package/dist/index.js +3 -4
  26. package/dist/index.js.map +1 -1
  27. package/dist/lend/__mocks__/MockLendProvider.d.ts +1 -1
  28. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -1
  29. package/dist/lend/__mocks__/MockLendProvider.js +7 -2
  30. package/dist/lend/__mocks__/MockLendProvider.js.map +1 -1
  31. package/dist/lend/core/LendProvider.d.ts +12 -8
  32. package/dist/lend/core/LendProvider.d.ts.map +1 -1
  33. package/dist/lend/core/LendProvider.js +15 -21
  34. package/dist/lend/core/LendProvider.js.map +1 -1
  35. package/dist/lend/namespaces/BaseLendNamespace.d.ts +2 -6
  36. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -1
  37. package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -1
  38. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +7 -4
  39. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -1
  40. package/dist/lend/providers/aave/AaveLendProvider.d.ts +1 -6
  41. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -1
  42. package/dist/lend/providers/aave/AaveLendProvider.js +3 -6
  43. package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -1
  44. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +14 -6
  45. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -1
  46. package/dist/lend/providers/aave/addresses.d.ts +13 -39
  47. package/dist/lend/providers/aave/addresses.d.ts.map +1 -1
  48. package/dist/lend/providers/aave/addresses.js +65 -60
  49. package/dist/lend/providers/aave/addresses.js.map +1 -1
  50. package/dist/lend/providers/aave/sdk.d.ts +2 -2
  51. package/dist/lend/providers/aave/sdk.d.ts.map +1 -1
  52. package/dist/lend/providers/aave/sdk.js +6 -28
  53. package/dist/lend/providers/aave/sdk.js.map +1 -1
  54. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +1 -6
  55. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
  56. package/dist/lend/providers/morpho/MorphoLendProvider.js +4 -13
  57. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
  58. package/dist/lend/providers/morpho/__tests__/api.test.js +52 -43
  59. package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
  60. package/dist/lend/providers/morpho/__tests__/sdk.test.js +41 -42
  61. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
  62. package/dist/lend/providers/morpho/api.d.ts +3 -7
  63. package/dist/lend/providers/morpho/api.d.ts.map +1 -1
  64. package/dist/lend/providers/morpho/api.js +2 -2
  65. package/dist/lend/providers/morpho/api.js.map +1 -1
  66. package/dist/lend/providers/morpho/contracts.d.ts +11 -10
  67. package/dist/lend/providers/morpho/contracts.d.ts.map +1 -1
  68. package/dist/lend/providers/morpho/contracts.js +43 -10
  69. package/dist/lend/providers/morpho/contracts.js.map +1 -1
  70. package/dist/lend/providers/morpho/sdk.d.ts +7 -2
  71. package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
  72. package/dist/lend/providers/morpho/sdk.js +67 -63
  73. package/dist/lend/providers/morpho/sdk.js.map +1 -1
  74. package/dist/nodeActionsFactory.d.ts +1 -1
  75. package/dist/reactActionsFactory.d.ts +1 -1
  76. package/dist/services/ChainManager.d.ts +8 -8
  77. package/dist/services/ChainManager.d.ts.map +1 -1
  78. package/dist/services/ChainManager.js.map +1 -1
  79. package/dist/services/__mocks__/MockChainManager.d.ts +4 -4
  80. package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
  81. package/dist/services/__mocks__/MockChainManager.js.map +1 -1
  82. package/dist/services/tokenBalance.d.ts +1 -1
  83. package/dist/services/tokenBalance.d.ts.map +1 -1
  84. package/dist/services/tokenBalance.js +31 -30
  85. package/dist/services/tokenBalance.js.map +1 -1
  86. package/dist/services/tokenBalance.spec.js +20 -24
  87. package/dist/services/tokenBalance.spec.js.map +1 -1
  88. package/dist/swap/__mocks__/MockSwapProvider.d.ts +20 -8
  89. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -1
  90. package/dist/swap/__mocks__/MockSwapProvider.js +52 -29
  91. package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -1
  92. package/dist/swap/core/SwapProvider.d.ts +105 -16
  93. package/dist/swap/core/SwapProvider.d.ts.map +1 -1
  94. package/dist/swap/core/SwapProvider.js +218 -36
  95. package/dist/swap/core/SwapProvider.js.map +1 -1
  96. package/dist/swap/core/__tests__/SwapProvider.test.js +115 -9
  97. package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -1
  98. package/dist/swap/core/markets.d.ts +47 -0
  99. package/dist/swap/core/markets.d.ts.map +1 -0
  100. package/dist/swap/core/markets.js +65 -0
  101. package/dist/swap/core/markets.js.map +1 -0
  102. package/dist/swap/index.d.ts +2 -0
  103. package/dist/swap/index.d.ts.map +1 -1
  104. package/dist/swap/index.js +1 -0
  105. package/dist/swap/index.js.map +1 -1
  106. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +2 -2
  107. package/dist/swap/namespaces/ActionsSwapNamespace.js +2 -2
  108. package/dist/swap/namespaces/BaseSwapNamespace.d.ts +48 -8
  109. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -1
  110. package/dist/swap/namespaces/BaseSwapNamespace.js +139 -16
  111. package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -1
  112. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +19 -7
  113. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -1
  114. package/dist/swap/namespaces/WalletSwapNamespace.js +39 -15
  115. package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -1
  116. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +150 -11
  117. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -1
  118. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +85 -8
  119. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -1
  120. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +9 -42
  121. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -1
  122. package/dist/swap/providers/uniswap/UniswapSwapProvider.js +81 -139
  123. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -1
  124. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +10 -9
  125. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -1
  126. package/dist/swap/providers/uniswap/__tests__/sdk.test.js +17 -17
  127. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -1
  128. package/dist/swap/providers/uniswap/addresses.d.ts +5 -0
  129. package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -1
  130. package/dist/swap/providers/uniswap/addresses.js +1 -1
  131. package/dist/swap/providers/uniswap/addresses.js.map +1 -1
  132. package/dist/swap/providers/uniswap/encoding.d.ts +4 -4
  133. package/dist/swap/providers/uniswap/encoding.js +17 -17
  134. package/dist/swap/providers/uniswap/markets.d.ts +19 -0
  135. package/dist/swap/providers/uniswap/markets.d.ts.map +1 -0
  136. package/dist/swap/providers/uniswap/markets.js +48 -0
  137. package/dist/swap/providers/uniswap/markets.js.map +1 -0
  138. package/dist/swap/providers/uniswap/types.d.ts +4 -3
  139. package/dist/swap/providers/uniswap/types.d.ts.map +1 -1
  140. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts +49 -0
  141. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
  142. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js +140 -0
  143. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
  144. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +2 -0
  145. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
  146. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +255 -0
  147. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
  148. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +2 -0
  149. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
  150. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +166 -0
  151. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
  152. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +2 -0
  153. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
  154. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +419 -0
  155. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
  156. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts +2 -0
  157. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
  158. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js +51 -0
  159. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
  160. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts +14 -0
  161. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
  162. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js +13 -0
  163. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
  164. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts +2 -0
  165. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
  166. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js +173 -0
  167. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
  168. package/dist/swap/providers/velodrome/abis.d.ts +396 -0
  169. package/dist/swap/providers/velodrome/abis.d.ts.map +1 -0
  170. package/dist/swap/providers/velodrome/abis.js +257 -0
  171. package/dist/swap/providers/velodrome/abis.js.map +1 -0
  172. package/dist/swap/providers/velodrome/addresses.d.ts +39 -0
  173. package/dist/swap/providers/velodrome/addresses.d.ts.map +1 -0
  174. package/dist/swap/providers/velodrome/addresses.js +57 -0
  175. package/dist/swap/providers/velodrome/addresses.js.map +1 -0
  176. package/dist/swap/providers/velodrome/config.d.ts +22 -0
  177. package/dist/swap/providers/velodrome/config.d.ts.map +1 -0
  178. package/dist/swap/providers/velodrome/config.js +29 -0
  179. package/dist/swap/providers/velodrome/config.js.map +1 -0
  180. package/dist/swap/providers/velodrome/encoding/helpers.d.ts +37 -0
  181. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
  182. package/dist/swap/providers/velodrome/encoding/helpers.js +60 -0
  183. package/dist/swap/providers/velodrome/encoding/helpers.js.map +1 -0
  184. package/dist/swap/providers/velodrome/encoding/index.d.ts +8 -0
  185. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
  186. package/dist/swap/providers/velodrome/encoding/index.js +5 -0
  187. package/dist/swap/providers/velodrome/encoding/index.js.map +1 -0
  188. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts +39 -0
  189. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
  190. package/dist/swap/providers/velodrome/encoding/poolRouter.js +83 -0
  191. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
  192. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +15 -0
  193. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +1 -0
  194. package/dist/swap/providers/velodrome/encoding/routers/approval.js +33 -0
  195. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +1 -0
  196. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts +40 -0
  197. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
  198. package/dist/swap/providers/velodrome/encoding/routers/cl.js +80 -0
  199. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
  200. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts +42 -0
  201. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
  202. package/dist/swap/providers/velodrome/encoding/routers/v2.js +166 -0
  203. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
  204. package/dist/swap/providers/velodrome/markets.d.ts +21 -0
  205. package/dist/swap/providers/velodrome/markets.d.ts.map +1 -0
  206. package/dist/swap/providers/velodrome/markets.js +69 -0
  207. package/dist/swap/providers/velodrome/markets.js.map +1 -0
  208. package/dist/swap/providers/velodrome/types.d.ts +31 -0
  209. package/dist/swap/providers/velodrome/types.d.ts.map +1 -0
  210. package/dist/swap/providers/velodrome/types.js +2 -0
  211. package/dist/swap/providers/velodrome/types.js.map +1 -0
  212. package/dist/types/actions.d.ts +44 -9
  213. package/dist/types/actions.d.ts.map +1 -1
  214. package/dist/types/asset.d.ts +7 -9
  215. package/dist/types/asset.d.ts.map +1 -1
  216. package/dist/types/chain.d.ts +2 -2
  217. package/dist/types/chain.d.ts.map +1 -1
  218. package/dist/types/lend/base.d.ts +6 -6
  219. package/dist/types/lend/base.d.ts.map +1 -1
  220. package/dist/types/lend/base.js.map +1 -1
  221. package/dist/types/lend/contracts.d.ts +2 -1
  222. package/dist/types/lend/contracts.d.ts.map +1 -1
  223. package/dist/types/providers.d.ts +21 -0
  224. package/dist/types/providers.d.ts.map +1 -0
  225. package/dist/types/providers.js +2 -0
  226. package/dist/types/providers.js.map +1 -0
  227. package/dist/types/swap/base.d.ts +133 -33
  228. package/dist/types/swap/base.d.ts.map +1 -1
  229. package/dist/utils/approve.d.ts +82 -0
  230. package/dist/utils/approve.d.ts.map +1 -0
  231. package/dist/utils/{permit2.js → approve.js} +48 -14
  232. package/dist/utils/approve.js.map +1 -0
  233. package/dist/utils/approve.test.d.ts +2 -0
  234. package/dist/utils/approve.test.d.ts.map +1 -0
  235. package/dist/utils/{permit2.test.js → approve.test.js} +95 -2
  236. package/dist/utils/approve.test.js.map +1 -0
  237. package/dist/utils/assets.d.ts +6 -0
  238. package/dist/utils/assets.d.ts.map +1 -1
  239. package/dist/utils/assets.js +10 -0
  240. package/dist/utils/assets.js.map +1 -1
  241. package/dist/utils/validateAddresses.d.ts +32 -0
  242. package/dist/utils/validateAddresses.d.ts.map +1 -0
  243. package/dist/utils/validateAddresses.js +103 -0
  244. package/dist/utils/validateAddresses.js.map +1 -0
  245. package/dist/utils/validateAddresses.test.d.ts +2 -0
  246. package/dist/utils/validateAddresses.test.d.ts.map +1 -0
  247. package/dist/utils/validateAddresses.test.js +314 -0
  248. package/dist/utils/validateAddresses.test.js.map +1 -0
  249. package/dist/wallet/core/namespace/WalletNamespace.d.ts +21 -9
  250. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  251. package/dist/wallet/core/namespace/WalletNamespace.js +44 -15
  252. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  253. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +4 -4
  254. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  255. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +4 -16
  256. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
  257. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
  258. package/dist/wallet/core/providers/hosted/types/index.d.ts +6 -11
  259. package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
  260. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +2 -9
  261. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
  262. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
  263. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +6 -17
  264. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  265. package/dist/wallet/core/wallets/abstract/Wallet.js +5 -6
  266. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  267. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +10 -1
  268. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  269. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js +2 -2
  270. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  271. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +12 -4
  272. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  273. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +3 -10
  274. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  275. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  276. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  277. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -10
  278. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  279. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  280. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts +2 -4
  281. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
  282. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +6 -8
  283. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
  284. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +4 -4
  285. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  286. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +2 -9
  287. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  288. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  289. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +3 -10
  290. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  291. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  292. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +3 -10
  293. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  294. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  295. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +3 -9
  296. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
  297. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +3 -2
  298. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
  299. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -9
  300. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  301. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -2
  302. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  303. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +3 -9
  304. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  305. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +3 -2
  306. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  307. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts +2 -4
  308. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -1
  309. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +11 -13
  310. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
  311. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +6 -6
  312. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  313. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +5 -10
  314. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
  315. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +3 -3
  316. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -1
  317. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts +2 -6
  318. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts.map +1 -1
  319. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js.map +1 -1
  320. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +5 -10
  321. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  322. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +3 -3
  323. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  324. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -10
  325. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  326. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  327. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  328. package/package.json +3 -2
  329. package/src/__mocks__/MockAssets.ts +54 -6
  330. package/src/__tests__/actions.test.ts +1 -1
  331. package/src/actions.ts +58 -61
  332. package/src/constants/assets.ts +781 -10
  333. package/src/constants/providers.ts +5 -0
  334. package/src/constants/supportedChains.ts +22 -2
  335. package/src/index.ts +50 -8
  336. package/src/lend/__mocks__/MockLendProvider.ts +8 -3
  337. package/src/lend/core/LendProvider.ts +27 -28
  338. package/src/lend/namespaces/BaseLendNamespace.ts +2 -6
  339. package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +12 -5
  340. package/src/lend/providers/aave/AaveLendProvider.ts +3 -7
  341. package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +16 -7
  342. package/src/lend/providers/aave/addresses.ts +82 -64
  343. package/src/lend/providers/aave/sdk.ts +11 -36
  344. package/src/lend/providers/morpho/MorphoLendProvider.ts +4 -16
  345. package/src/lend/providers/morpho/__tests__/api.test.ts +65 -44
  346. package/src/lend/providers/morpho/__tests__/sdk.test.ts +43 -43
  347. package/src/lend/providers/morpho/api.ts +7 -8
  348. package/src/lend/providers/morpho/contracts.ts +62 -13
  349. package/src/lend/providers/morpho/sdk.ts +85 -63
  350. package/src/services/ChainManager.ts +12 -21
  351. package/src/services/__mocks__/MockChainManager.ts +4 -7
  352. package/src/services/tokenBalance.spec.ts +20 -24
  353. package/src/services/tokenBalance.ts +39 -33
  354. package/src/swap/__mocks__/MockSwapProvider.ts +77 -42
  355. package/src/swap/core/SwapProvider.ts +307 -49
  356. package/src/swap/core/__tests__/SwapProvider.test.ts +151 -9
  357. package/src/swap/core/markets.ts +104 -0
  358. package/src/swap/index.ts +5 -0
  359. package/src/swap/namespaces/ActionsSwapNamespace.ts +2 -2
  360. package/src/swap/namespaces/BaseSwapNamespace.ts +199 -18
  361. package/src/swap/namespaces/WalletSwapNamespace.ts +53 -14
  362. package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +241 -14
  363. package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +103 -8
  364. package/src/swap/providers/uniswap/UniswapSwapProvider.ts +108 -195
  365. package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +12 -12
  366. package/src/swap/providers/uniswap/__tests__/sdk.test.ts +19 -20
  367. package/src/swap/providers/uniswap/addresses.ts +3 -1
  368. package/src/swap/providers/uniswap/encoding.ts +22 -22
  369. package/src/swap/providers/uniswap/markets.ts +84 -0
  370. package/src/swap/providers/uniswap/types.ts +4 -3
  371. package/src/swap/providers/velodrome/VelodromeSwapProvider.ts +224 -0
  372. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +341 -0
  373. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +202 -0
  374. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +506 -0
  375. package/src/swap/providers/velodrome/__tests__/encoding.cl.test.ts +69 -0
  376. package/src/swap/providers/velodrome/__tests__/encoding.helpers.ts +20 -0
  377. package/src/swap/providers/velodrome/__tests__/encoding.v2.test.ts +235 -0
  378. package/src/swap/providers/velodrome/abis.ts +264 -0
  379. package/src/swap/providers/velodrome/addresses.ts +107 -0
  380. package/src/swap/providers/velodrome/config.ts +46 -0
  381. package/src/swap/providers/velodrome/encoding/helpers.ts +82 -0
  382. package/src/swap/providers/velodrome/encoding/index.ts +7 -0
  383. package/src/swap/providers/velodrome/encoding/poolRouter.ts +124 -0
  384. package/src/swap/providers/velodrome/encoding/routers/approval.ts +45 -0
  385. package/src/swap/providers/velodrome/encoding/routers/cl.ts +156 -0
  386. package/src/swap/providers/velodrome/encoding/routers/v2.ts +267 -0
  387. package/src/swap/providers/velodrome/markets.ts +100 -0
  388. package/src/swap/providers/velodrome/types.ts +30 -0
  389. package/src/types/actions.ts +49 -9
  390. package/src/types/asset.ts +12 -9
  391. package/src/types/chain.ts +2 -2
  392. package/src/types/lend/base.ts +6 -6
  393. package/src/types/lend/contracts.ts +5 -1
  394. package/src/types/providers.ts +22 -0
  395. package/src/types/swap/base.ts +147 -34
  396. package/src/utils/{permit2.test.ts → approve.test.ts} +117 -1
  397. package/src/utils/{permit2.ts → approve.ts} +67 -14
  398. package/src/utils/assets.ts +14 -0
  399. package/src/utils/validateAddresses.test.ts +439 -0
  400. package/src/utils/validateAddresses.ts +153 -0
  401. package/src/wallet/core/namespace/WalletNamespace.ts +70 -16
  402. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +8 -4
  403. package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +5 -17
  404. package/src/wallet/core/providers/hosted/types/index.ts +9 -11
  405. package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +5 -17
  406. package/src/wallet/core/wallets/abstract/Wallet.ts +15 -22
  407. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +13 -1
  408. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +21 -5
  409. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +5 -17
  410. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +0 -1
  411. package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +3 -10
  412. package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +8 -8
  413. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +4 -4
  414. package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +3 -10
  415. package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +5 -17
  416. package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +5 -17
  417. package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +7 -11
  418. package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +7 -11
  419. package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +7 -11
  420. package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +23 -10
  421. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +6 -6
  422. package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +10 -18
  423. package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +2 -6
  424. package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +10 -18
  425. package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +10 -18
  426. package/dist/supported/tokens.d.ts +0 -25
  427. package/dist/supported/tokens.d.ts.map +0 -1
  428. package/dist/supported/tokens.js +0 -44
  429. package/dist/supported/tokens.js.map +0 -1
  430. package/dist/utils/permit2.d.ts +0 -46
  431. package/dist/utils/permit2.d.ts.map +0 -1
  432. package/dist/utils/permit2.js.map +0 -1
  433. package/dist/utils/permit2.test.d.ts +0 -2
  434. package/dist/utils/permit2.test.d.ts.map +0 -1
  435. package/dist/utils/permit2.test.js.map +0 -1
  436. package/src/supported/tokens.ts +0 -66
@@ -1,8 +1,7 @@
1
1
  import { type Address, type LocalAccount } from 'viem';
2
- import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
3
2
  import type { ChainManager } from '../../../../../services/ChainManager.js';
4
- import type { SwapProvider } from '../../../../../swap/core/SwapProvider.js';
5
- import type { LendProviderConfig, SwapProviderConfig } from '../../../../../types/actions.js';
3
+ import type { Asset } from '../../../../../types/asset.js';
4
+ import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
6
5
  import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
7
6
  import type { DynamicHostedWalletToActionsWalletOptions } from '../../../providers/hosted/types/index.js';
8
7
  /**
@@ -24,13 +23,9 @@ export declare class DynamicWallet extends EOAWallet {
24
23
  static create(params: {
25
24
  dynamicWallet: DynamicHostedWalletToActionsWalletOptions['wallet'];
26
25
  chainManager: ChainManager;
27
- lendProviders?: {
28
- morpho?: LendProvider<LendProviderConfig>;
29
- aave?: LendProvider<LendProviderConfig>;
30
- };
31
- swapProviders?: {
32
- uniswap?: SwapProvider<SwapProviderConfig>;
33
- };
26
+ lendProviders?: LendProviders;
27
+ swapProviders?: SwapProviders;
28
+ supportedAssets?: Asset[];
34
29
  }): Promise<DynamicWallet>;
35
30
  /**
36
31
  * Initialize the DynamicWallet by creating the signer account
@@ -1 +1 @@
1
- {"version":3,"file":"DynamicWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,MAAM,CAAA;AAEtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAChF,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAG/G;;;GAGG;AACH,qBAAa,aAAc,SAAQ,SAAS;IACnC,MAAM,EAAG,YAAY,CAAA;IACrB,OAAO,EAAG,OAAO,CAAA;IACxB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqD;IAEnF;;;;;;OAMG;IACH,OAAO;WAeM,MAAM,CAAC,MAAM,EAAE;QAC1B,aAAa,EAAE,yCAAyC,CAAC,QAAQ,CAAC,CAAA;QAClE,YAAY,EAAE,YAAY,CAAA;QAC1B,aAAa,CAAC,EAAE;YACd,MAAM,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;YACzC,IAAI,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SACxC,CAAA;QACD,aAAa,CAAC,EAAE;YACd,OAAO,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SAC3C,CAAA;KACF,GAAG,OAAO,CAAC,aAAa,CAAC;IAW1B;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
1
+ {"version":3,"file":"DynamicWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,MAAM,CAAA;AAEtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAG/G;;;GAGG;AACH,qBAAa,aAAc,SAAQ,SAAS;IACnC,MAAM,EAAG,YAAY,CAAA;IACrB,OAAO,EAAG,OAAO,CAAA;IACxB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqD;IAEnF;;;;;;OAMG;IACH,OAAO;WAWM,MAAM,CAAC,MAAM,EAAE;QAC1B,aAAa,EAAE,yCAAyC,CAAC,QAAQ,CAAC,CAAA;QAClE,YAAY,EAAE,YAAY,CAAA;QAC1B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,aAAa,CAAC;IAY1B;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
@@ -12,12 +12,12 @@ export class DynamicWallet extends EOAWallet {
12
12
  * @param lendProviders - Optional lend providers for DeFi operations
13
13
  * @param swapProviders - Optional swap providers for trading operations
14
14
  */
15
- constructor(chainManager, dynamicWallet, lendProviders, swapProviders) {
16
- super(chainManager, lendProviders, swapProviders);
15
+ constructor(chainManager, dynamicWallet, lendProviders, swapProviders, supportedAssets) {
16
+ super(chainManager, lendProviders, swapProviders, supportedAssets);
17
17
  this.dynamicWallet = dynamicWallet;
18
18
  }
19
19
  static async create(params) {
20
- const wallet = new DynamicWallet(params.chainManager, params.dynamicWallet, params.lendProviders, params.swapProviders);
20
+ const wallet = new DynamicWallet(params.chainManager, params.dynamicWallet, params.lendProviders, params.swapProviders, params.supportedAssets);
21
21
  await wallet.initialize();
22
22
  return wallet;
23
23
  }
@@ -1 +1 @@
1
- {"version":3,"file":"DynamicWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAElE,OAAO,EAAE,YAAY,EAAE,MAAM,6DAA6D,CAAA;AAE1F;;;GAGG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAK1C;;;;;;OAMG;IACH,YACE,YAA0B,EAC1B,aAAkE,EAClE,aAGC,EACD,aAEC;QAED,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,CAAC,CAAA;QACjD,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;IACpC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAUnB;QACC,MAAM,MAAM,GAAG,IAAI,aAAa,CAC9B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,CACrB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,MAAM,EAAE,IAAI,CAAC,aAAa;SAC3B,CAAC,CAAA;IACJ,CAAC;CACF"}
1
+ {"version":3,"file":"DynamicWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAElE,OAAO,EAAE,YAAY,EAAE,MAAM,6DAA6D,CAAA;AAE1F;;;GAGG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAK1C;;;;;;OAMG;IACH,YACE,YAA0B,EAC1B,aAAkE,EAClE,aAA6B,EAC7B,aAA6B,EAC7B,eAAyB;QAEzB,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,CAAC,CAAA;QAClE,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;IACpC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAMnB;QACC,MAAM,MAAM,GAAG,IAAI,aAAa,CAC9B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,CACvB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,MAAM,EAAE,IAAI,CAAC,aAAa;SAC3B,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -1,6 +1,5 @@
1
- import type { LendProvider } from '../../../../../../lend/core/LendProvider.js';
2
1
  import type { ChainManager } from '../../../../../../services/ChainManager.js';
3
- import type { LendProviderConfig } from '../../../../../../types/actions.js';
2
+ import type { LendProviders } from '../../../../../../types/providers.js';
4
3
  import type { Wallet } from '../../../../../core/wallets/abstract/Wallet.js';
5
4
  import type { DynamicHostedWalletToActionsWalletOptions } from '../../../../providers/hosted/types/index.js';
6
5
  /**
@@ -13,10 +12,7 @@ export declare class DynamicWalletMock {
13
12
  static readonly create: import("vitest").Mock<[_params: {
14
13
  chainManager: ChainManager;
15
14
  dynamicWallet: DynamicHostedWalletToActionsWalletOptions["wallet"];
16
- lendProviders?: {
17
- morpho?: LendProvider<LendProviderConfig>;
18
- aave?: LendProvider<LendProviderConfig>;
19
- };
15
+ lendProviders?: LendProviders;
20
16
  }], Promise<Wallet>>;
21
17
  }
22
18
  //# sourceMappingURL=DynamicWalletMock.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"DynamicWalletMock.d.ts","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAC5D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAA;AACtE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAE/G;;;;;GAKG;AACH,qBAAa,iBAAiB;IAC5B,MAAM,CAAC,QAAQ,CAAC,MAAM;sBAEJ,YAAY;uBACX,yCAAyC,CAAC,QAAQ,CAAC;wBAClD;YACd,MAAM,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;YACzC,IAAI,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SACxC;yBAIJ;CACF"}
1
+ {"version":3,"file":"DynamicWalletMock.d.ts","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACzD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAA;AACtE,OAAO,KAAK,EAAE,yCAAyC,EAAE,MAAM,gDAAgD,CAAA;AAE/G;;;;;GAKG;AACH,qBAAa,iBAAiB;IAC5B,MAAM,CAAC,QAAQ,CAAC,MAAM;sBAEJ,YAAY;uBACX,yCAAyC,CAAC,QAAQ,CAAC;wBAClD,aAAa;yBAIhC;CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"DynamicWalletMock.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAQ3B;;;;;GAKG;AACH,MAAM,OAAO,iBAAiB;;;AACZ,wBAAM,GAAG,EAAE,CAAC,EAAE,CAC5B,KAAK,EAAE,OAON,EAAmB,EAAE;IACpB,OAAO,EAAuB,CAAA;AAChC,CAAC,CACF,AAXqB,CAWrB"}
1
+ {"version":3,"file":"DynamicWalletMock.js","sourceRoot":"","sources":["../../../../../../../src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAO3B;;;;;GAKG;AACH,MAAM,OAAO,iBAAiB;;;AACZ,wBAAM,GAAG,EAAE,CAAC,EAAE,CAC5B,KAAK,EAAE,OAIN,EAAmB,EAAE;IACpB,OAAO,EAAuB,CAAA;AAChC,CAAC,CACF,AARqB,CAQrB"}
@@ -1,9 +1,8 @@
1
1
  import type { ConnectedWallet } from '@privy-io/react-auth';
2
2
  import type { Address, LocalAccount } from 'viem';
3
- import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
4
3
  import type { ChainManager } from '../../../../../services/ChainManager.js';
5
- import type { SwapProvider } from '../../../../../swap/core/SwapProvider.js';
6
- import type { LendProviderConfig, SwapProviderConfig } from '../../../../../types/actions.js';
4
+ import type { Asset } from '../../../../../types/asset.js';
5
+ import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
7
6
  import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
8
7
  /**
9
8
  * Privy wallet implementation
@@ -17,13 +16,9 @@ export declare class PrivyWallet extends EOAWallet {
17
16
  static create(params: {
18
17
  chainManager: ChainManager;
19
18
  connectedWallet: ConnectedWallet;
20
- lendProviders?: {
21
- morpho?: LendProvider<LendProviderConfig>;
22
- aave?: LendProvider<LendProviderConfig>;
23
- };
24
- swapProviders?: {
25
- uniswap?: SwapProvider<SwapProviderConfig>;
26
- };
19
+ lendProviders?: LendProviders;
20
+ swapProviders?: SwapProviders;
21
+ supportedAssets?: Asset[];
27
22
  }): Promise<PrivyWallet>;
28
23
  /**
29
24
  * Initialize the PrivyWallet by creating the signer account
@@ -1 +1 @@
1
- {"version":3,"file":"PrivyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAChF,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAGlE;;;GAGG;AACH,qBAAa,WAAY,SAAQ,SAAS;IACjC,OAAO,EAAG,OAAO,CAAA;IACjB,MAAM,EAAG,YAAY,CAAA;IAE5B,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAiB;IAEjD,OAAO;WAeM,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,YAAY,CAAA;QAC1B,eAAe,EAAE,eAAe,CAAA;QAChC,aAAa,CAAC,EAAE;YACd,MAAM,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;YACzC,IAAI,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SACxC,CAAA;QACD,aAAa,CAAC,EAAE;YACd,OAAO,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SAC3C,CAAA;KACF,GAAG,OAAO,CAAC,WAAW,CAAC;IAWxB;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
1
+ {"version":3,"file":"PrivyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAGlE;;;GAGG;AACH,qBAAa,WAAY,SAAQ,SAAS;IACjC,OAAO,EAAG,OAAO,CAAA;IACjB,MAAM,EAAG,YAAY,CAAA;IAE5B,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAiB;IAEjD,OAAO;WAWM,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,YAAY,CAAA;QAC1B,eAAe,EAAE,eAAe,CAAA;QAChC,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,WAAW,CAAC;IAYxB;;OAEG;cACa,qBAAqB;IAKrC;;;;;;;OAOG;YACW,YAAY;CAK3B"}
@@ -5,12 +5,12 @@ import { createSigner } from './utils/createSigner.js';
5
5
  * @description Wallet implementation using Privy service
6
6
  */
7
7
  export class PrivyWallet extends EOAWallet {
8
- constructor(chainManager, connectedWallet, lendProviders, swapProviders) {
9
- super(chainManager, lendProviders, swapProviders);
8
+ constructor(chainManager, connectedWallet, lendProviders, swapProviders, supportedAssets) {
9
+ super(chainManager, lendProviders, swapProviders, supportedAssets);
10
10
  this.connectedWallet = connectedWallet;
11
11
  }
12
12
  static async create(params) {
13
- const wallet = new PrivyWallet(params.chainManager, params.connectedWallet, params.lendProviders, params.swapProviders);
13
+ const wallet = new PrivyWallet(params.chainManager, params.connectedWallet, params.lendProviders, params.swapProviders, params.supportedAssets);
14
14
  await wallet.initialize();
15
15
  return wallet;
16
16
  }
@@ -1 +1 @@
1
- {"version":3,"file":"PrivyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAA;AAExF;;;GAGG;AACH,MAAM,OAAO,WAAY,SAAQ,SAAS;IAMxC,YACE,YAA0B,EAC1B,eAAgC,EAChC,aAGC,EACD,aAEC;QAED,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,CAAC,CAAA;QACjD,IAAI,CAAC,eAAe,GAAG,eAAe,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAUnB;QACC,MAAM,MAAM,GAAG,IAAI,WAAW,CAC5B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,CACrB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAA;IACJ,CAAC;CACF"}
1
+ {"version":3,"file":"PrivyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/privy/PrivyWallet.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,2DAA2D,CAAA;AAExF;;;GAGG;AACH,MAAM,OAAO,WAAY,SAAQ,SAAS;IAMxC,YACE,YAA0B,EAC1B,eAAgC,EAChC,aAA6B,EAC7B,aAA6B,EAC7B,eAAyB;QAEzB,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,CAAC,CAAA;QAClE,IAAI,CAAC,eAAe,GAAG,eAAe,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAMnB;QACC,MAAM,MAAM,GAAG,IAAI,WAAW,CAC5B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,CACvB,CAAA;QACD,MAAM,MAAM,CAAC,UAAU,EAAE,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,qBAAqB;QACnC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IACpC,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,YAAY;QACxB,OAAO,YAAY,CAAC;YAClB,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -1,9 +1,8 @@
1
1
  import type { TurnkeySDKClientBase } from '@turnkey/react-wallet-kit';
2
2
  import type { Address, LocalAccount } from 'viem';
3
- import type { LendProvider } from '../../../../../lend/core/LendProvider.js';
4
3
  import type { ChainManager } from '../../../../../services/ChainManager.js';
5
- import type { SwapProvider } from '../../../../../swap/core/SwapProvider.js';
6
- import type { LendProviderConfig, SwapProviderConfig } from '../../../../../types/actions.js';
4
+ import type { Asset } from '../../../../../types/asset.js';
5
+ import type { LendProviders, SwapProviders } from '../../../../../types/providers.js';
7
6
  import { EOAWallet } from '../../../../core/wallets/eoa/EOAWallet.js';
8
7
  /**
9
8
  * Turnkey wallet implementation
@@ -38,13 +37,9 @@ export declare class TurnkeyWallet extends EOAWallet {
38
37
  organizationId: string;
39
38
  signWith: string;
40
39
  ethereumAddress?: string;
41
- lendProviders?: {
42
- morpho?: LendProvider<LendProviderConfig>;
43
- aave?: LendProvider<LendProviderConfig>;
44
- };
45
- swapProviders?: {
46
- uniswap?: SwapProvider<SwapProviderConfig>;
47
- };
40
+ lendProviders?: LendProviders;
41
+ swapProviders?: SwapProviders;
42
+ supportedAssets?: Asset[];
48
43
  }): Promise<TurnkeyWallet>;
49
44
  protected performInitialization(): Promise<void>;
50
45
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"TurnkeyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AACrE,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,KAAK,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAChF,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;WA8BM,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;YACd,MAAM,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;YACzC,IAAI,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SACxC,CAAA;QACD,aAAa,CAAC,EAAE;YACd,OAAO,CAAC,EAAE,YAAY,CAAC,kBAAkB,CAAC,CAAA;SAC3C,CAAA;KACF,GAAG,OAAO,CAAC,aAAa,CAAC;cAMV,qBAAqB;IAKrC;;;;;;;;OAQG;YACW,YAAY;CAQ3B"}
1
+ {"version":3,"file":"TurnkeyWallet.d.ts","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AACrE,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AAEjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAA;AAGlE;;;GAGG;AACH,qBAAa,aAAc,SAAQ,SAAS;IACnC,OAAO,EAAG,OAAO,CAAA;IACjB,MAAM,EAAG,YAAY,CAAA;IAC5B;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;IAC7C;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAQ;IACvC;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAQ;IACjC;;;;;OAKG;IACH,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAQ;IAEzC,OAAO;WA2BM,MAAM,CAAC,MAAM,EAAE;QAC1B,YAAY,EAAE,YAAY,CAAA;QAC1B,MAAM,EAAE,oBAAoB,CAAA;QAC5B,cAAc,EAAE,MAAM,CAAA;QACtB,QAAQ,EAAE,MAAM,CAAA;QAChB,eAAe,CAAC,EAAE,MAAM,CAAA;QACxB,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,aAAa,CAAC,EAAE,aAAa,CAAA;QAC7B,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;KAC1B,GAAG,OAAO,CAAC,aAAa,CAAC;cAMV,qBAAqB;IAKrC;;;;;;;;OAQG;YACW,YAAY;CAQ3B"}
@@ -6,8 +6,8 @@ import { createSigner } from './utils/createSigner.js';
6
6
  */
7
7
  export class TurnkeyWallet extends EOAWallet {
8
8
  constructor(params) {
9
- const { chainManager, client, organizationId, signWith, ethereumAddress, lendProviders, swapProviders, } = params;
10
- super(chainManager, lendProviders, swapProviders);
9
+ const { chainManager, client, organizationId, signWith, ethereumAddress, lendProviders, swapProviders, supportedAssets, } = params;
10
+ super(chainManager, lendProviders, swapProviders, supportedAssets);
11
11
  this.client = client;
12
12
  this.organizationId = organizationId;
13
13
  this.signWith = signWith;
@@ -1 +1 @@
1
- {"version":3,"file":"TurnkeyWallet.js","sourceRoot":"","sources":["../../../../../../src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts"],"names":[],"mappings":"AAOA,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,MAanB;QACC,MAAM,EACJ,YAAY,EACZ,MAAM,EACN,cAAc,EACd,QAAQ,EACR,eAAe,EACf,aAAa,EACb,aAAa,GACd,GAAG,MAAM,CAAA;QACV,KAAK,CAAC,YAAY,EAAE,aAAa,EAAE,aAAa,CAAC,CAAA;QACjD,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,MAanB;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"}
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
- "version": "0.3.0",
13
+ "sideEffects": false,
14
+ "version": "0.4.0",
14
15
  "description": "TypeScript SDK for Actions",
15
16
  "main": "dist/index.js",
16
17
  "types": "dist/index.d.ts",
@@ -83,7 +84,7 @@
83
84
  "lint": "eslint \"**/*.{ts,tsx}\" && prettier --check \"**/*.{ts,tsx}\"",
84
85
  "lint:fix": "eslint \"**/*.{ts,tsx}\" --fix && prettier \"**/*.{ts,tsx}\" --write --log-level=warn",
85
86
  "test": "vitest --run --project unit",
86
- "test:supersim": "vitest --run --project supersim",
87
+ "test:network": "vitest --run --project network",
87
88
  "typecheck": "tsc --noEmit --emitDeclarationOnly false"
88
89
  }
89
90
  }
@@ -1,14 +1,19 @@
1
1
  import type { Address } from 'viem'
2
+ import { base, baseSepolia, mode, optimism, unichain } from 'viem/chains'
2
3
 
3
4
  import type { Asset } from '@/types/asset.js'
4
5
 
5
6
  /**
6
- * Mock USDC asset for testing
7
+ * Mock USDC asset for testing.
8
+ * Includes addresses for all commonly tested chains.
7
9
  */
8
10
  export const MockUSDCAsset: Asset = {
9
11
  address: {
10
- 130: '0xA0b86991c431c924C2407E4C573C686cc8C6c5b7' as Address,
11
- 84532: '0xA0b86991c431c924C2407E4C573C686cc8C6c5b7' as Address,
12
+ [optimism.id]: '0x1111111111111111111111111111111111111111' as Address,
13
+ [base.id]: '0x2222222222222222222222222222222222222222' as Address,
14
+ [baseSepolia.id]: '0x3333333333333333333333333333333333333333' as Address,
15
+ [unichain.id]: '0xA0b86991c431c924C2407E4C573C686cc8C6c5b7' as Address,
16
+ [mode.id]: '0x5555555555555555555555555555555555555555' as Address,
12
17
  },
13
18
  metadata: {
14
19
  decimals: 6,
@@ -19,12 +24,16 @@ export const MockUSDCAsset: Asset = {
19
24
  }
20
25
 
21
26
  /**
22
- * Mock WETH asset for testing
27
+ * Mock WETH asset for testing.
28
+ * Uses the standard OP Stack WETH predeploy address on all chains.
23
29
  */
24
30
  export const MockWETHAsset: Asset = {
25
31
  address: {
26
- 130: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2' as Address,
27
- 84532: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2' as Address,
32
+ [optimism.id]: '0x4200000000000000000000000000000000000006' as Address,
33
+ [base.id]: '0x4200000000000000000000000000000000000006' as Address,
34
+ [baseSepolia.id]: '0x4200000000000000000000000000000000000006' as Address,
35
+ [unichain.id]: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2' as Address,
36
+ [mode.id]: '0x4200000000000000000000000000000000000006' as Address,
28
37
  },
29
38
  metadata: {
30
39
  decimals: 18,
@@ -33,3 +42,42 @@ export const MockWETHAsset: Asset = {
33
42
  },
34
43
  type: 'erc20',
35
44
  }
45
+
46
+ /**
47
+ * Mock OP token for testing.
48
+ */
49
+ export const MockOPAsset: Asset = {
50
+ address: {
51
+ [optimism.id]: '0x4200000000000000000000000000000000000042' as Address,
52
+ },
53
+ metadata: {
54
+ decimals: 18,
55
+ name: 'Optimism',
56
+ symbol: 'OP',
57
+ },
58
+ type: 'erc20',
59
+ }
60
+
61
+ /**
62
+ * Mock native ETH asset for testing.
63
+ */
64
+ export const MockETHAsset: Asset = {
65
+ address: {
66
+ [optimism.id]: 'native',
67
+ [base.id]: 'native',
68
+ [baseSepolia.id]: 'native',
69
+ },
70
+ metadata: {
71
+ decimals: 18,
72
+ name: 'Ether',
73
+ symbol: 'ETH',
74
+ },
75
+ type: 'native',
76
+ }
77
+
78
+ /** Standard test wallet address */
79
+ export const MOCK_WALLET =
80
+ '0x000000000000000000000000000000000000dEaD' as Address
81
+
82
+ /** Standard mock pool address */
83
+ export const MOCK_POOL = '0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA' as Address
@@ -433,7 +433,7 @@ describe('Actions SDK', () => {
433
433
  expect(actions.lend).toBeDefined()
434
434
  const supportedIds = actions.lend.supportedChainIds()
435
435
  expect(supportedIds).toContain(130) // Unichain
436
- expect(supportedIds).toContain(8453) // Base
436
+ expect(supportedIds).toContain(84532) // Base Sepolia
437
437
  })
438
438
  })
439
439
 
package/src/actions.ts CHANGED
@@ -1,18 +1,18 @@
1
- import type { LendProvider } from '@/lend/index.js'
2
1
  import { AaveLendProvider, MorphoLendProvider } from '@/lend/index.js'
3
2
  import { ActionsLendNamespace } from '@/lend/namespaces/ActionsLendNamespace.js'
4
3
  import { ChainManager } from '@/services/ChainManager.js'
5
- import { SUPPORTED_TOKENS } from '@/supported/tokens.js'
6
- import type { SwapProvider } from '@/swap/index.js'
7
- import { UniswapSwapProvider } from '@/swap/index.js'
4
+ import { UniswapSwapProvider, VelodromeSwapProvider } from '@/swap/index.js'
8
5
  import { ActionsSwapNamespace } from '@/swap/namespaces/ActionsSwapNamespace.js'
9
6
  import type {
10
7
  ActionsConfig,
11
8
  AssetsConfig,
12
- LendProviderConfig,
13
- SwapProviderConfig,
9
+ LendProviders,
10
+ SwapProviders,
11
+ SwapSettings,
14
12
  } from '@/types/actions.js'
15
13
  import type { Asset } from '@/types/asset.js'
14
+ import { getAllAssetAddresses } from '@/utils/assets.js'
15
+ import { validateConfigAddresses } from '@/utils/validateAddresses.js'
16
16
  import { WalletNamespace } from '@/wallet/core/namespace/WalletNamespace.js'
17
17
  import type { HostedWalletProvider } from '@/wallet/core/providers/hosted/abstract/HostedWalletProvider.js'
18
18
  import type { HostedWalletProviderRegistry } from '@/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js'
@@ -48,17 +48,11 @@ export class Actions<
48
48
  >
49
49
  private chainManager: ChainManager
50
50
  private _lend?: ActionsLendNamespace
51
- private _lendProviders: {
52
- morpho?: LendProvider<LendProviderConfig>
53
- aave?: LendProvider<LendProviderConfig>
54
- } = {}
51
+ private _lendProviders: LendProviders = {}
55
52
  private _swap?: ActionsSwapNamespace
56
- private _swapProviders: {
57
- uniswap?: SwapProvider<SwapProviderConfig>
58
- } = {}
53
+ private _swapProviders: SwapProviders = {}
54
+ private _swapSettings?: SwapSettings
59
55
  private _assetsConfig?: AssetsConfig
60
- private hostedWalletProvider!: THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType]
61
- private smartWalletProvider!: SmartWalletProvider
62
56
  private hostedWalletProviderRegistry: HostedWalletProviderRegistry<
63
57
  THostedWalletProvidersSchema['providerInstances'],
64
58
  THostedWalletProvidersSchema['providerConfigs'],
@@ -80,6 +74,7 @@ export class Actions<
80
74
  this.chainManager = new ChainManager(config.chains)
81
75
  this.hostedWalletProviderRegistry = deps.hostedWalletProviderRegistry
82
76
  this._assetsConfig = config.assets
77
+ validateConfigAddresses(config)
83
78
 
84
79
  if (config.lend?.morpho) {
85
80
  this._lendProviders.morpho = new MorphoLendProvider(
@@ -97,12 +92,27 @@ export class Actions<
97
92
  this._lend = new ActionsLendNamespace(this._lendProviders)
98
93
  }
99
94
 
95
+ const swapSettings = config.swap?.settings
100
96
  if (config.swap?.uniswap) {
101
97
  this._swapProviders.uniswap = new UniswapSwapProvider(
102
98
  config.swap.uniswap,
103
99
  this.chainManager,
100
+ swapSettings,
101
+ )
102
+ }
103
+ if (config.swap?.velodrome) {
104
+ this._swapProviders.velodrome = new VelodromeSwapProvider(
105
+ config.swap.velodrome,
106
+ this.chainManager,
107
+ swapSettings,
108
+ )
109
+ }
110
+ this._swapSettings = swapSettings
111
+ if (Object.values(this._swapProviders).some(Boolean)) {
112
+ this._swap = new ActionsSwapNamespace(
113
+ this._swapProviders,
114
+ this._swapSettings,
104
115
  )
105
- this._swap = new ActionsSwapNamespace(this._swapProviders)
106
116
  }
107
117
 
108
118
  this.wallet = this.createWalletNamespace(config.wallet)
@@ -128,10 +138,7 @@ export class Actions<
128
138
  * Get the lend provider instances
129
139
  * @returns Object containing configured lend providers
130
140
  */
131
- get lendProviders(): {
132
- morpho?: LendProvider<LendProviderConfig>
133
- aave?: LendProvider<LendProviderConfig>
134
- } {
141
+ get lendProviders(): LendProviders {
135
142
  return this._lendProviders
136
143
  }
137
144
 
@@ -155,46 +162,35 @@ export class Actions<
155
162
  * Get the swap provider instances
156
163
  * @returns Object containing configured swap providers
157
164
  */
158
- get swapProviders(): {
159
- uniswap?: SwapProvider<SwapProviderConfig>
160
- } {
165
+ get swapProviders(): SwapProviders {
161
166
  return this._swapProviders
162
167
  }
163
168
 
164
169
  /**
165
170
  * Get the list of supported assets based on configuration
166
171
  * @description Returns filtered assets based on allow/block lists in assets config.
167
- * If no config provided, returns all SUPPORTED_TOKENS.
172
+ * If no config provided, returns empty array. Developers must explicitly configure
173
+ * their supported assets via ActionsConfig.assets.allow.
168
174
  * @returns Array of supported assets
169
175
  */
170
176
  public getSupportedAssets(): Asset[] {
171
- // If no assets config, return all supported tokens
172
177
  if (!this._assetsConfig) {
173
- return SUPPORTED_TOKENS
178
+ return []
174
179
  }
175
180
 
176
- // If allow list provided, return only those
177
- if (this._assetsConfig.allow && this._assetsConfig.allow.length > 0) {
178
- return this._assetsConfig.allow
179
- }
181
+ const allow = this._assetsConfig.allow ?? []
182
+ const block = this._assetsConfig.block
180
183
 
181
- // If block list provided, filter out blocked assets
182
- if (this._assetsConfig.block && this._assetsConfig.block.length > 0) {
183
- const blockedAddresses = new Set(
184
- this._assetsConfig.block.flatMap((asset) =>
185
- Object.values(asset.address).map((addr) => addr.toLowerCase()),
186
- ),
187
- )
188
- return SUPPORTED_TOKENS.filter((token) => {
189
- const tokenAddresses = Object.values(token.address).map((addr) =>
190
- addr.toLowerCase(),
191
- )
192
- return !tokenAddresses.some((addr) => blockedAddresses.has(addr))
193
- })
184
+ if (!block?.length) {
185
+ return allow
194
186
  }
195
187
 
196
- // Default to all supported tokens
197
- return SUPPORTED_TOKENS
188
+ const blockedAddresses = new Set(block.flatMap(getAllAssetAddresses))
189
+
190
+ return allow.filter((asset) => {
191
+ const addresses = getAllAssetAddresses(asset)
192
+ return !addresses.some((addr) => blockedAddresses.has(addr))
193
+ })
198
194
  }
199
195
 
200
196
  /**
@@ -202,16 +198,18 @@ export class Actions<
202
198
  * @param config - Wallet configuration
203
199
  * @returns WalletProvider instance
204
200
  */
205
- private createWalletProvider(
201
+ private async createWalletProvider(
206
202
  config: ActionsConfig<
207
203
  THostedWalletProviderType,
208
204
  THostedWalletProvidersSchema['providerConfigs']
209
205
  >['wallet'],
210
- ): WalletProvider<
211
- THostedWalletProviderType,
212
- THostedWalletProvidersSchema['providerToActionsOptions'],
213
- THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
214
- SmartWalletProvider
206
+ ): Promise<
207
+ WalletProvider<
208
+ THostedWalletProviderType,
209
+ THostedWalletProvidersSchema['providerToActionsOptions'],
210
+ THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
211
+ SmartWalletProvider
212
+ >
215
213
  > {
216
214
  const hostedWalletProviderConfig = config.hostedWalletConfig.provider
217
215
  const factory = this.hostedWalletProviderRegistry.getFactory(
@@ -227,21 +225,23 @@ export class Actions<
227
225
  `Invalid options for hosted wallet provider: ${hostedWalletProviderConfig.type}`,
228
226
  )
229
227
  }
230
- this.hostedWalletProvider = factory.create(
228
+ const hostedWalletProvider = await factory.create(
231
229
  {
232
230
  chainManager: this.chainManager,
233
231
  lendProviders: this._lendProviders,
234
232
  swapProviders: this._swapProviders,
235
233
  supportedAssets: this.getSupportedAssets(),
234
+ swapSettings: this._swapSettings,
236
235
  },
237
236
  options,
238
237
  )
239
238
 
239
+ let smartWalletProvider: SmartWalletProvider
240
240
  if (
241
241
  !config.smartWalletConfig ||
242
242
  config.smartWalletConfig.provider.type === 'default'
243
243
  ) {
244
- this.smartWalletProvider = new DefaultSmartWalletProvider(
244
+ smartWalletProvider = new DefaultSmartWalletProvider(
245
245
  this.chainManager,
246
246
  this._lendProviders,
247
247
  this._swapProviders,
@@ -254,16 +254,13 @@ export class Actions<
254
254
  )
255
255
  }
256
256
 
257
- const walletProvider = new WalletProvider(
258
- this.hostedWalletProvider,
259
- this.smartWalletProvider,
260
- )
261
-
262
- return walletProvider
257
+ return new WalletProvider(hostedWalletProvider, smartWalletProvider)
263
258
  }
264
259
 
265
260
  /**
266
261
  * Create the wallet namespace instance
262
+ * @description Creates a WalletNamespace with lazy provider initialization.
263
+ * The wallet provider is not created until the first wallet method is called.
267
264
  * @param config - Wallet configuration
268
265
  * @returns WalletNamespace instance
269
266
  */
@@ -273,12 +270,12 @@ export class Actions<
273
270
  THostedWalletProvidersSchema['providerConfigs']
274
271
  >['wallet'],
275
272
  ) {
276
- const walletProvider = this.createWalletProvider(config)
273
+ const providerFactory = () => this.createWalletProvider(config)
277
274
  return new WalletNamespace<
278
275
  THostedWalletProviderType,
279
276
  THostedWalletProvidersSchema['providerToActionsOptions'],
280
277
  THostedWalletProvidersSchema['providerInstances'][THostedWalletProviderType],
281
278
  SmartWalletProvider
282
- >(walletProvider)
279
+ >(providerFactory)
283
280
  }
284
281
  }