@eth-optimism/actions-sdk 0.3.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (479) 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 +17 -13
  8. package/dist/actions.d.ts.map +1 -1
  9. package/dist/actions.js +46 -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/ens/EnsNamespace.d.ts +57 -0
  24. package/dist/ens/EnsNamespace.d.ts.map +1 -0
  25. package/dist/ens/EnsNamespace.js +158 -0
  26. package/dist/ens/EnsNamespace.js.map +1 -0
  27. package/dist/ens/EnsNamespace.spec.d.ts +2 -0
  28. package/dist/ens/EnsNamespace.spec.d.ts.map +1 -0
  29. package/dist/ens/EnsNamespace.spec.js +144 -0
  30. package/dist/ens/EnsNamespace.spec.js.map +1 -0
  31. package/dist/ens/errors.d.ts +24 -0
  32. package/dist/ens/errors.d.ts.map +1 -0
  33. package/dist/ens/errors.js +35 -0
  34. package/dist/ens/errors.js.map +1 -0
  35. package/dist/ens/index.d.ts +4 -0
  36. package/dist/ens/index.d.ts.map +1 -0
  37. package/dist/ens/index.js +4 -0
  38. package/dist/ens/index.js.map +1 -0
  39. package/dist/ens/types.d.ts +63 -0
  40. package/dist/ens/types.d.ts.map +1 -0
  41. package/dist/ens/types.js +14 -0
  42. package/dist/ens/types.js.map +1 -0
  43. package/dist/index.d.ts +6 -5
  44. package/dist/index.d.ts.map +1 -1
  45. package/dist/index.js +5 -4
  46. package/dist/index.js.map +1 -1
  47. package/dist/lend/__mocks__/MockLendProvider.d.ts +1 -1
  48. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -1
  49. package/dist/lend/__mocks__/MockLendProvider.js +7 -2
  50. package/dist/lend/__mocks__/MockLendProvider.js.map +1 -1
  51. package/dist/lend/core/LendProvider.d.ts +12 -8
  52. package/dist/lend/core/LendProvider.d.ts.map +1 -1
  53. package/dist/lend/core/LendProvider.js +15 -21
  54. package/dist/lend/core/LendProvider.js.map +1 -1
  55. package/dist/lend/namespaces/BaseLendNamespace.d.ts +2 -6
  56. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -1
  57. package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -1
  58. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +7 -4
  59. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -1
  60. package/dist/lend/providers/aave/AaveLendProvider.d.ts +1 -6
  61. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -1
  62. package/dist/lend/providers/aave/AaveLendProvider.js +3 -6
  63. package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -1
  64. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +14 -6
  65. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -1
  66. package/dist/lend/providers/aave/addresses.d.ts +13 -39
  67. package/dist/lend/providers/aave/addresses.d.ts.map +1 -1
  68. package/dist/lend/providers/aave/addresses.js +65 -60
  69. package/dist/lend/providers/aave/addresses.js.map +1 -1
  70. package/dist/lend/providers/aave/sdk.d.ts +2 -2
  71. package/dist/lend/providers/aave/sdk.d.ts.map +1 -1
  72. package/dist/lend/providers/aave/sdk.js +6 -28
  73. package/dist/lend/providers/aave/sdk.js.map +1 -1
  74. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +1 -6
  75. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
  76. package/dist/lend/providers/morpho/MorphoLendProvider.js +4 -13
  77. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
  78. package/dist/lend/providers/morpho/__tests__/api.test.js +52 -43
  79. package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
  80. package/dist/lend/providers/morpho/__tests__/sdk.test.js +41 -42
  81. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
  82. package/dist/lend/providers/morpho/api.d.ts +3 -7
  83. package/dist/lend/providers/morpho/api.d.ts.map +1 -1
  84. package/dist/lend/providers/morpho/api.js +2 -2
  85. package/dist/lend/providers/morpho/api.js.map +1 -1
  86. package/dist/lend/providers/morpho/contracts.d.ts +11 -10
  87. package/dist/lend/providers/morpho/contracts.d.ts.map +1 -1
  88. package/dist/lend/providers/morpho/contracts.js +43 -10
  89. package/dist/lend/providers/morpho/contracts.js.map +1 -1
  90. package/dist/lend/providers/morpho/sdk.d.ts +7 -2
  91. package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
  92. package/dist/lend/providers/morpho/sdk.js +67 -63
  93. package/dist/lend/providers/morpho/sdk.js.map +1 -1
  94. package/dist/nodeActionsFactory.d.ts +1 -1
  95. package/dist/reactActionsFactory.d.ts +1 -1
  96. package/dist/services/ChainManager.d.ts +15 -8
  97. package/dist/services/ChainManager.d.ts.map +1 -1
  98. package/dist/services/ChainManager.js +9 -0
  99. package/dist/services/ChainManager.js.map +1 -1
  100. package/dist/services/__mocks__/MockChainManager.d.ts +5 -4
  101. package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
  102. package/dist/services/__mocks__/MockChainManager.js +5 -0
  103. package/dist/services/__mocks__/MockChainManager.js.map +1 -1
  104. package/dist/services/tokenBalance.d.ts +1 -1
  105. package/dist/services/tokenBalance.d.ts.map +1 -1
  106. package/dist/services/tokenBalance.js +31 -30
  107. package/dist/services/tokenBalance.js.map +1 -1
  108. package/dist/services/tokenBalance.spec.js +20 -24
  109. package/dist/services/tokenBalance.spec.js.map +1 -1
  110. package/dist/swap/__mocks__/MockSwapProvider.d.ts +20 -8
  111. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -1
  112. package/dist/swap/__mocks__/MockSwapProvider.js +52 -29
  113. package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -1
  114. package/dist/swap/core/SwapProvider.d.ts +105 -16
  115. package/dist/swap/core/SwapProvider.d.ts.map +1 -1
  116. package/dist/swap/core/SwapProvider.js +215 -37
  117. package/dist/swap/core/SwapProvider.js.map +1 -1
  118. package/dist/swap/core/__tests__/SwapProvider.test.js +115 -9
  119. package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -1
  120. package/dist/swap/core/markets.d.ts +47 -0
  121. package/dist/swap/core/markets.d.ts.map +1 -0
  122. package/dist/swap/core/markets.js +65 -0
  123. package/dist/swap/core/markets.js.map +1 -0
  124. package/dist/swap/index.d.ts +2 -0
  125. package/dist/swap/index.d.ts.map +1 -1
  126. package/dist/swap/index.js +1 -0
  127. package/dist/swap/index.js.map +1 -1
  128. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +2 -2
  129. package/dist/swap/namespaces/ActionsSwapNamespace.js +2 -2
  130. package/dist/swap/namespaces/BaseSwapNamespace.d.ts +50 -8
  131. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -1
  132. package/dist/swap/namespaces/BaseSwapNamespace.js +144 -16
  133. package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -1
  134. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +20 -7
  135. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -1
  136. package/dist/swap/namespaces/WalletSwapNamespace.js +44 -15
  137. package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -1
  138. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +150 -11
  139. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -1
  140. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +85 -8
  141. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -1
  142. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +10 -42
  143. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -1
  144. package/dist/swap/providers/uniswap/UniswapSwapProvider.js +81 -139
  145. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -1
  146. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +10 -9
  147. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -1
  148. package/dist/swap/providers/uniswap/__tests__/sdk.test.js +17 -17
  149. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -1
  150. package/dist/swap/providers/uniswap/addresses.d.ts +5 -0
  151. package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -1
  152. package/dist/swap/providers/uniswap/addresses.js +1 -1
  153. package/dist/swap/providers/uniswap/addresses.js.map +1 -1
  154. package/dist/swap/providers/uniswap/encoding.d.ts +4 -4
  155. package/dist/swap/providers/uniswap/encoding.js +17 -17
  156. package/dist/swap/providers/uniswap/markets.d.ts +19 -0
  157. package/dist/swap/providers/uniswap/markets.d.ts.map +1 -0
  158. package/dist/swap/providers/uniswap/markets.js +48 -0
  159. package/dist/swap/providers/uniswap/markets.js.map +1 -0
  160. package/dist/swap/providers/uniswap/types.d.ts +4 -3
  161. package/dist/swap/providers/uniswap/types.d.ts.map +1 -1
  162. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts +50 -0
  163. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
  164. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js +140 -0
  165. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
  166. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +2 -0
  167. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
  168. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +255 -0
  169. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
  170. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +2 -0
  171. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
  172. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +166 -0
  173. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
  174. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +2 -0
  175. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
  176. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +420 -0
  177. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
  178. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts +2 -0
  179. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
  180. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js +51 -0
  181. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
  182. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts +14 -0
  183. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
  184. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js +13 -0
  185. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
  186. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts +2 -0
  187. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
  188. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js +173 -0
  189. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
  190. package/dist/swap/providers/velodrome/abis.d.ts +396 -0
  191. package/dist/swap/providers/velodrome/abis.d.ts.map +1 -0
  192. package/dist/swap/providers/velodrome/abis.js +257 -0
  193. package/dist/swap/providers/velodrome/abis.js.map +1 -0
  194. package/dist/swap/providers/velodrome/addresses.d.ts +39 -0
  195. package/dist/swap/providers/velodrome/addresses.d.ts.map +1 -0
  196. package/dist/swap/providers/velodrome/addresses.js +57 -0
  197. package/dist/swap/providers/velodrome/addresses.js.map +1 -0
  198. package/dist/swap/providers/velodrome/config.d.ts +22 -0
  199. package/dist/swap/providers/velodrome/config.d.ts.map +1 -0
  200. package/dist/swap/providers/velodrome/config.js +29 -0
  201. package/dist/swap/providers/velodrome/config.js.map +1 -0
  202. package/dist/swap/providers/velodrome/encoding/helpers.d.ts +37 -0
  203. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
  204. package/dist/swap/providers/velodrome/encoding/helpers.js +60 -0
  205. package/dist/swap/providers/velodrome/encoding/helpers.js.map +1 -0
  206. package/dist/swap/providers/velodrome/encoding/index.d.ts +8 -0
  207. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
  208. package/dist/swap/providers/velodrome/encoding/index.js +5 -0
  209. package/dist/swap/providers/velodrome/encoding/index.js.map +1 -0
  210. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts +39 -0
  211. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
  212. package/dist/swap/providers/velodrome/encoding/poolRouter.js +83 -0
  213. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
  214. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +15 -0
  215. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +1 -0
  216. package/dist/swap/providers/velodrome/encoding/routers/approval.js +33 -0
  217. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +1 -0
  218. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts +40 -0
  219. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
  220. package/dist/swap/providers/velodrome/encoding/routers/cl.js +80 -0
  221. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
  222. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts +42 -0
  223. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
  224. package/dist/swap/providers/velodrome/encoding/routers/v2.js +166 -0
  225. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
  226. package/dist/swap/providers/velodrome/markets.d.ts +21 -0
  227. package/dist/swap/providers/velodrome/markets.d.ts.map +1 -0
  228. package/dist/swap/providers/velodrome/markets.js +69 -0
  229. package/dist/swap/providers/velodrome/markets.js.map +1 -0
  230. package/dist/swap/providers/velodrome/types.d.ts +31 -0
  231. package/dist/swap/providers/velodrome/types.d.ts.map +1 -0
  232. package/dist/swap/providers/velodrome/types.js +2 -0
  233. package/dist/swap/providers/velodrome/types.js.map +1 -0
  234. package/dist/types/actions.d.ts +44 -9
  235. package/dist/types/actions.d.ts.map +1 -1
  236. package/dist/types/asset.d.ts +7 -9
  237. package/dist/types/asset.d.ts.map +1 -1
  238. package/dist/types/chain.d.ts +2 -2
  239. package/dist/types/chain.d.ts.map +1 -1
  240. package/dist/types/lend/base.d.ts +6 -6
  241. package/dist/types/lend/base.d.ts.map +1 -1
  242. package/dist/types/lend/base.js.map +1 -1
  243. package/dist/types/lend/contracts.d.ts +2 -1
  244. package/dist/types/lend/contracts.d.ts.map +1 -1
  245. package/dist/types/providers.d.ts +21 -0
  246. package/dist/types/providers.d.ts.map +1 -0
  247. package/dist/types/providers.js +2 -0
  248. package/dist/types/providers.js.map +1 -0
  249. package/dist/types/swap/base.d.ts +136 -35
  250. package/dist/types/swap/base.d.ts.map +1 -1
  251. package/dist/types/swap/base.js.map +1 -1
  252. package/dist/utils/approve.d.ts +82 -0
  253. package/dist/utils/approve.d.ts.map +1 -0
  254. package/dist/utils/{permit2.js → approve.js} +48 -14
  255. package/dist/utils/approve.js.map +1 -0
  256. package/dist/utils/approve.test.d.ts +2 -0
  257. package/dist/utils/approve.test.d.ts.map +1 -0
  258. package/dist/utils/{permit2.test.js → approve.test.js} +95 -2
  259. package/dist/utils/approve.test.js.map +1 -0
  260. package/dist/utils/assets.d.ts +6 -0
  261. package/dist/utils/assets.d.ts.map +1 -1
  262. package/dist/utils/assets.js +10 -0
  263. package/dist/utils/assets.js.map +1 -1
  264. package/dist/utils/ens.d.ts +25 -0
  265. package/dist/utils/ens.d.ts.map +1 -0
  266. package/dist/utils/ens.js +53 -0
  267. package/dist/utils/ens.js.map +1 -0
  268. package/dist/utils/ens.test.d.ts +2 -0
  269. package/dist/utils/ens.test.d.ts.map +1 -0
  270. package/dist/utils/ens.test.js +75 -0
  271. package/dist/utils/ens.test.js.map +1 -0
  272. package/dist/utils/validateAddresses.d.ts +32 -0
  273. package/dist/utils/validateAddresses.d.ts.map +1 -0
  274. package/dist/utils/validateAddresses.js +103 -0
  275. package/dist/utils/validateAddresses.js.map +1 -0
  276. package/dist/utils/validateAddresses.test.d.ts +2 -0
  277. package/dist/utils/validateAddresses.test.d.ts.map +1 -0
  278. package/dist/utils/validateAddresses.test.js +314 -0
  279. package/dist/utils/validateAddresses.test.js.map +1 -0
  280. package/dist/utils/validation.d.ts +5 -0
  281. package/dist/utils/validation.d.ts.map +1 -1
  282. package/dist/utils/validation.js +10 -0
  283. package/dist/utils/validation.js.map +1 -1
  284. package/dist/wallet/core/namespace/WalletNamespace.d.ts +21 -9
  285. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  286. package/dist/wallet/core/namespace/WalletNamespace.js +44 -15
  287. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  288. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +4 -4
  289. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  290. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +4 -16
  291. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
  292. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
  293. package/dist/wallet/core/providers/hosted/types/index.d.ts +6 -11
  294. package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
  295. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +2 -9
  296. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
  297. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
  298. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +6 -17
  299. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  300. package/dist/wallet/core/wallets/abstract/Wallet.js +7 -6
  301. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  302. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +10 -1
  303. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  304. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js +2 -2
  305. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  306. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +12 -4
  307. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  308. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +3 -10
  309. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  310. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  311. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  312. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -10
  313. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  314. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  315. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts +2 -4
  316. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
  317. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +6 -8
  318. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
  319. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +4 -4
  320. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  321. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +2 -9
  322. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  323. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  324. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +3 -10
  325. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  326. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  327. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +3 -10
  328. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  329. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  330. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +3 -9
  331. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
  332. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +3 -2
  333. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
  334. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +3 -9
  335. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  336. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -2
  337. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  338. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +3 -9
  339. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  340. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +3 -2
  341. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  342. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts +2 -4
  343. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -1
  344. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +11 -13
  345. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
  346. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +6 -6
  347. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  348. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +5 -10
  349. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
  350. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +3 -3
  351. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -1
  352. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts +2 -6
  353. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts.map +1 -1
  354. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js.map +1 -1
  355. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +5 -10
  356. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  357. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +3 -3
  358. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  359. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -10
  360. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  361. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  362. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  363. package/package.json +3 -2
  364. package/src/__mocks__/MockAssets.ts +54 -6
  365. package/src/__tests__/actions.test.ts +1 -1
  366. package/src/actions.ts +73 -61
  367. package/src/constants/assets.ts +781 -10
  368. package/src/constants/providers.ts +5 -0
  369. package/src/constants/supportedChains.ts +22 -2
  370. package/src/ens/EnsNamespace.spec.ts +171 -0
  371. package/src/ens/EnsNamespace.ts +210 -0
  372. package/src/ens/errors.ts +45 -0
  373. package/src/ens/index.ts +12 -0
  374. package/src/ens/types.ts +76 -0
  375. package/src/index.ts +59 -8
  376. package/src/lend/__mocks__/MockLendProvider.ts +8 -3
  377. package/src/lend/core/LendProvider.ts +27 -28
  378. package/src/lend/namespaces/BaseLendNamespace.ts +2 -6
  379. package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +12 -5
  380. package/src/lend/providers/aave/AaveLendProvider.ts +3 -7
  381. package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +16 -7
  382. package/src/lend/providers/aave/addresses.ts +82 -64
  383. package/src/lend/providers/aave/sdk.ts +11 -36
  384. package/src/lend/providers/morpho/MorphoLendProvider.ts +4 -16
  385. package/src/lend/providers/morpho/__tests__/api.test.ts +65 -44
  386. package/src/lend/providers/morpho/__tests__/sdk.test.ts +43 -43
  387. package/src/lend/providers/morpho/api.ts +7 -8
  388. package/src/lend/providers/morpho/contracts.ts +62 -13
  389. package/src/lend/providers/morpho/sdk.ts +85 -63
  390. package/src/services/ChainManager.ts +22 -21
  391. package/src/services/__mocks__/MockChainManager.ts +12 -7
  392. package/src/services/tokenBalance.spec.ts +20 -24
  393. package/src/services/tokenBalance.ts +39 -33
  394. package/src/swap/__mocks__/MockSwapProvider.ts +77 -42
  395. package/src/swap/core/SwapProvider.ts +309 -50
  396. package/src/swap/core/__tests__/SwapProvider.test.ts +151 -9
  397. package/src/swap/core/markets.ts +104 -0
  398. package/src/swap/index.ts +5 -0
  399. package/src/swap/namespaces/ActionsSwapNamespace.ts +2 -2
  400. package/src/swap/namespaces/BaseSwapNamespace.ts +215 -18
  401. package/src/swap/namespaces/WalletSwapNamespace.ts +61 -14
  402. package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +245 -14
  403. package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +103 -8
  404. package/src/swap/providers/uniswap/UniswapSwapProvider.ts +110 -195
  405. package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +12 -12
  406. package/src/swap/providers/uniswap/__tests__/sdk.test.ts +19 -20
  407. package/src/swap/providers/uniswap/addresses.ts +3 -1
  408. package/src/swap/providers/uniswap/encoding.ts +22 -22
  409. package/src/swap/providers/uniswap/markets.ts +84 -0
  410. package/src/swap/providers/uniswap/types.ts +4 -3
  411. package/src/swap/providers/velodrome/VelodromeSwapProvider.ts +226 -0
  412. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +341 -0
  413. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +202 -0
  414. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +507 -0
  415. package/src/swap/providers/velodrome/__tests__/encoding.cl.test.ts +69 -0
  416. package/src/swap/providers/velodrome/__tests__/encoding.helpers.ts +20 -0
  417. package/src/swap/providers/velodrome/__tests__/encoding.v2.test.ts +235 -0
  418. package/src/swap/providers/velodrome/abis.ts +264 -0
  419. package/src/swap/providers/velodrome/addresses.ts +107 -0
  420. package/src/swap/providers/velodrome/config.ts +46 -0
  421. package/src/swap/providers/velodrome/encoding/helpers.ts +82 -0
  422. package/src/swap/providers/velodrome/encoding/index.ts +7 -0
  423. package/src/swap/providers/velodrome/encoding/poolRouter.ts +124 -0
  424. package/src/swap/providers/velodrome/encoding/routers/approval.ts +45 -0
  425. package/src/swap/providers/velodrome/encoding/routers/cl.ts +156 -0
  426. package/src/swap/providers/velodrome/encoding/routers/v2.ts +267 -0
  427. package/src/swap/providers/velodrome/markets.ts +100 -0
  428. package/src/swap/providers/velodrome/types.ts +30 -0
  429. package/src/types/actions.ts +49 -9
  430. package/src/types/asset.ts +12 -9
  431. package/src/types/chain.ts +2 -2
  432. package/src/types/lend/base.ts +6 -6
  433. package/src/types/lend/contracts.ts +5 -1
  434. package/src/types/providers.ts +22 -0
  435. package/src/types/swap/base.ts +150 -36
  436. package/src/utils/{permit2.test.ts → approve.test.ts} +117 -1
  437. package/src/utils/{permit2.ts → approve.ts} +67 -14
  438. package/src/utils/assets.ts +14 -0
  439. package/src/utils/ens.test.ts +104 -0
  440. package/src/utils/ens.ts +85 -0
  441. package/src/utils/validateAddresses.test.ts +439 -0
  442. package/src/utils/validateAddresses.ts +153 -0
  443. package/src/utils/validation.ts +11 -0
  444. package/src/wallet/core/namespace/WalletNamespace.ts +70 -16
  445. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +8 -4
  446. package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +5 -17
  447. package/src/wallet/core/providers/hosted/types/index.ts +9 -11
  448. package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +5 -17
  449. package/src/wallet/core/wallets/abstract/Wallet.ts +18 -22
  450. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +13 -1
  451. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +21 -5
  452. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +5 -17
  453. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +0 -1
  454. package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +3 -10
  455. package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +8 -8
  456. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +4 -4
  457. package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +3 -10
  458. package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +5 -17
  459. package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +5 -17
  460. package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +7 -11
  461. package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +7 -11
  462. package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +7 -11
  463. package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +23 -10
  464. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +6 -6
  465. package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +10 -18
  466. package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +2 -6
  467. package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +10 -18
  468. package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +10 -18
  469. package/dist/supported/tokens.d.ts +0 -25
  470. package/dist/supported/tokens.d.ts.map +0 -1
  471. package/dist/supported/tokens.js +0 -44
  472. package/dist/supported/tokens.js.map +0 -1
  473. package/dist/utils/permit2.d.ts +0 -46
  474. package/dist/utils/permit2.d.ts.map +0 -1
  475. package/dist/utils/permit2.js.map +0 -1
  476. package/dist/utils/permit2.test.d.ts +0 -2
  477. package/dist/utils/permit2.test.d.ts.map +0 -1
  478. package/dist/utils/permit2.test.js.map +0 -1
  479. package/src/supported/tokens.ts +0 -66
@@ -0,0 +1,507 @@
1
+ import type { Address, PublicClient } from 'viem'
2
+ import { mode, optimism } from 'viem/chains'
3
+ import { describe, expect, it, vi } from 'vitest'
4
+
5
+ import {
6
+ MOCK_WALLET,
7
+ MockOPAsset as OP,
8
+ MockUSDCAsset as USDC,
9
+ MockWETHAsset as WETH,
10
+ } from '@/__mocks__/MockAssets.js'
11
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
12
+ import type { ChainManager } from '@/services/ChainManager.js'
13
+ import type { VelodromeSwapProviderConfig } from '@/swap/providers/velodrome/types.js'
14
+ import { VelodromeSwapProvider } from '@/swap/providers/velodrome/VelodromeSwapProvider.js'
15
+ import type { Asset } from '@/types/asset.js'
16
+
17
+ const CHAIN_ID = optimism.id as SupportedChainId
18
+
19
+ function createMockChainManager(): ChainManager {
20
+ const mockPublicClient = {
21
+ readContract: vi
22
+ .fn()
23
+ .mockImplementation(({ functionName }: { functionName: string }) => {
24
+ if (functionName === 'getAmountsOut')
25
+ return Promise.resolve([100000000n, 500000000000000000n])
26
+ if (functionName === 'allowance') return Promise.resolve(0n)
27
+ if (functionName === 'getPool')
28
+ return Promise.resolve('0xAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA')
29
+ if (functionName === 'quoteExactInputSingle')
30
+ return Promise.resolve([500000000000000000n, 0n, 0, 0n])
31
+ return Promise.resolve(0n)
32
+ }),
33
+ } as unknown as PublicClient
34
+
35
+ return {
36
+ getPublicClient: vi.fn().mockReturnValue(mockPublicClient),
37
+ tryGetPublicClient: vi.fn().mockReturnValue(undefined),
38
+ getSupportedChains: vi.fn().mockReturnValue([CHAIN_ID]),
39
+ } as unknown as ChainManager
40
+ }
41
+
42
+ function createProvider(
43
+ configOverrides?: Partial<VelodromeSwapProviderConfig>,
44
+ ): VelodromeSwapProvider {
45
+ const config: VelodromeSwapProviderConfig = {
46
+ defaultSlippage: 0.005,
47
+ marketAllowlist: [{ assets: [USDC, OP], stable: false, chainId: CHAIN_ID }],
48
+ ...configOverrides,
49
+ }
50
+ return new VelodromeSwapProvider(config, createMockChainManager())
51
+ }
52
+
53
+ describe('VelodromeSwapProvider', () => {
54
+ describe('supportedChainIds', () => {
55
+ it('returns Optimism and Base', () => {
56
+ const provider = createProvider()
57
+ const chainIds = provider.protocolSupportedChainIds()
58
+ expect(chainIds).toContain(10) // Optimism
59
+ expect(chainIds).toContain(8453) // Base
60
+ })
61
+ })
62
+
63
+ describe('execute', () => {
64
+ it('returns swap transaction with approval data', async () => {
65
+ const provider = createProvider()
66
+ const result = await provider.execute({
67
+ amountIn: 100,
68
+ assetIn: USDC,
69
+ assetOut: OP,
70
+ chainId: CHAIN_ID,
71
+ walletAddress: MOCK_WALLET,
72
+ })
73
+
74
+ expect(result.transactionData.swap).toBeDefined()
75
+ expect(result.transactionData.swap.to).toBeDefined()
76
+ expect(result.transactionData.swap.data).toMatch(/^0x/)
77
+ expect(result.amountIn).toBeDefined()
78
+ expect(result.amountOut).toBeDefined()
79
+ expect(result.price).toBeDefined()
80
+ })
81
+
82
+ it('includes token approval to router when allowance insufficient', async () => {
83
+ const provider = createProvider()
84
+ const result = await provider.execute({
85
+ amountIn: 100,
86
+ assetIn: USDC,
87
+ assetOut: OP,
88
+ chainId: CHAIN_ID,
89
+ walletAddress: MOCK_WALLET,
90
+ })
91
+
92
+ // Mock returns 0n allowance, so approval to Router should be needed
93
+ expect(result.transactionData.tokenApproval).toBeDefined()
94
+ // No Permit2 for Velodrome
95
+ expect(result.transactionData.permit2Approval).toBeUndefined()
96
+ })
97
+
98
+ it('throws for exact-output swaps', async () => {
99
+ const provider = createProvider()
100
+
101
+ await expect(
102
+ provider.execute({
103
+ amountOut: 1,
104
+ assetIn: USDC,
105
+ assetOut: OP,
106
+ chainId: CHAIN_ID,
107
+ walletAddress: MOCK_WALLET,
108
+ }),
109
+ ).rejects.toThrow('does not support exact-output swaps')
110
+ })
111
+
112
+ it('throws without stable flag in market config', async () => {
113
+ const provider = createProvider({
114
+ // Intentionally omit stable to test runtime validation
115
+ marketAllowlist: [{ assets: [USDC, OP], chainId: CHAIN_ID }],
116
+ })
117
+
118
+ await expect(
119
+ provider.execute({
120
+ amountIn: 100,
121
+ assetIn: USDC,
122
+ assetOut: OP,
123
+ chainId: CHAIN_ID,
124
+ walletAddress: MOCK_WALLET,
125
+ }),
126
+ ).rejects.toThrow(
127
+ 'Either stable (v2 AMM) or tickSpacing (CL) must be configured',
128
+ )
129
+ })
130
+ })
131
+
132
+ describe('getQuote', () => {
133
+ it('returns SwapQuote with execution data', async () => {
134
+ const provider = createProvider()
135
+ const quote = await provider.getQuote({
136
+ assetIn: USDC,
137
+ assetOut: OP,
138
+ amountIn: 100,
139
+ chainId: CHAIN_ID,
140
+ })
141
+
142
+ expect(quote.price).toBeTypeOf('number')
143
+ expect(quote.amountIn).toBeDefined()
144
+ expect(quote.amountOut).toBeDefined()
145
+ expect(quote.amountInRaw).toBeGreaterThan(0n)
146
+ expect(quote.route.path).toEqual([USDC, OP])
147
+ expect(quote.execution).toBeDefined()
148
+ expect(quote.execution.swapCalldata).toMatch(/^0x/)
149
+ expect(quote.execution.routerAddress).toBeDefined()
150
+ expect(quote.provider).toBe('velodrome')
151
+ expect(quote.quotedAt).toBeGreaterThan(0)
152
+ expect(quote.expiresAt).toBeGreaterThan(quote.quotedAt)
153
+ })
154
+
155
+ it('defaults to 1 unit when no amount specified', async () => {
156
+ const provider = createProvider()
157
+ const quote = await provider.getQuote({
158
+ assetIn: USDC,
159
+ assetOut: OP,
160
+ chainId: CHAIN_ID,
161
+ })
162
+
163
+ // 1 USDC = 1000000 (6 decimals)
164
+ expect(quote.amountInRaw).toBe(1000000n)
165
+ })
166
+
167
+ it('throws for exact-output quotes', async () => {
168
+ const provider = createProvider()
169
+
170
+ await expect(
171
+ provider.getQuote({
172
+ assetIn: USDC,
173
+ assetOut: OP,
174
+ amountOut: 1,
175
+ chainId: CHAIN_ID,
176
+ }),
177
+ ).rejects.toThrow('does not support exact-output swaps')
178
+ })
179
+
180
+ it('execute with quote skips re-quoting', async () => {
181
+ const provider = createProvider()
182
+ const quote = await provider.getQuote({
183
+ assetIn: USDC,
184
+ assetOut: OP,
185
+ amountIn: 100,
186
+ chainId: CHAIN_ID,
187
+ recipient: MOCK_WALLET,
188
+ })
189
+
190
+ const result = await provider.execute({
191
+ ...quote,
192
+ recipient: MOCK_WALLET,
193
+ })
194
+
195
+ expect(result.transactionData.swap).toBeDefined()
196
+ expect(result.transactionData.swap.data).toBe(
197
+ quote.execution.swapCalldata,
198
+ )
199
+ expect(result.price).toBe(quote.price)
200
+ })
201
+ })
202
+
203
+ describe('getMarkets', () => {
204
+ it('returns markets from allowlist config', async () => {
205
+ const provider = createProvider()
206
+ const markets = await provider.getMarkets({})
207
+ expect(markets).toHaveLength(1)
208
+ expect(markets[0].assets).toEqual([USDC, OP])
209
+ expect(markets[0].fee).toBe(0)
210
+ expect(markets[0].provider).toBe('velodrome')
211
+ expect(markets[0].marketId.poolId).toMatch(/^0x/)
212
+ expect(markets[0].marketId.chainId).toBe(CHAIN_ID)
213
+ })
214
+
215
+ it('returns empty when no allowlist configured', async () => {
216
+ const provider = createProvider({ marketAllowlist: [] })
217
+ const markets = await provider.getMarkets({})
218
+ expect(markets).toEqual([])
219
+ })
220
+
221
+ it('expands multi-asset filter into all pairs', async () => {
222
+ const provider = createProvider({
223
+ marketAllowlist: [
224
+ {
225
+ assets: [USDC, OP, WETH],
226
+ stable: false,
227
+ chainId: CHAIN_ID,
228
+ },
229
+ ],
230
+ })
231
+ const markets = await provider.getMarkets({})
232
+ // 3 assets → 3 pairs: USDC/OP, USDC/WETH, OP/WETH
233
+ expect(markets).toHaveLength(3)
234
+ })
235
+
236
+ it('filters by asset', async () => {
237
+ const provider = createProvider({
238
+ marketAllowlist: [
239
+ {
240
+ assets: [USDC, OP, WETH],
241
+ stable: false,
242
+ chainId: CHAIN_ID,
243
+ },
244
+ ],
245
+ })
246
+ const markets = await provider.getMarkets({ asset: USDC })
247
+ expect(markets).toHaveLength(2)
248
+ for (const market of markets) {
249
+ expect(market.assets).toContain(USDC)
250
+ }
251
+ })
252
+
253
+ it('skips configs without stable or tickSpacing defined', async () => {
254
+ const provider = createProvider({
255
+ marketAllowlist: [
256
+ // Intentionally omit both to test filtering
257
+ { assets: [USDC, OP], chainId: CHAIN_ID },
258
+ {
259
+ assets: [USDC, WETH],
260
+ stable: true,
261
+ chainId: CHAIN_ID,
262
+ },
263
+ ],
264
+ })
265
+ const markets = await provider.getMarkets({})
266
+ expect(markets).toHaveLength(1)
267
+ expect(markets[0].assets).toEqual([USDC, WETH])
268
+ })
269
+
270
+ it('includes CL configs with tickSpacing', async () => {
271
+ const provider = createProvider({
272
+ marketAllowlist: [
273
+ {
274
+ assets: [USDC, WETH],
275
+ tickSpacing: 100,
276
+ chainId: CHAIN_ID,
277
+ },
278
+ ],
279
+ })
280
+ const markets = await provider.getMarkets({})
281
+ expect(markets).toHaveLength(1)
282
+ expect(markets[0].marketId.poolId).toMatch(/^0x/)
283
+ })
284
+
285
+ it('CL pool has different poolId than v2 pool for same pair', async () => {
286
+ const v2Provider = createProvider({
287
+ marketAllowlist: [
288
+ { assets: [USDC, WETH], stable: false, chainId: CHAIN_ID },
289
+ ],
290
+ })
291
+ const clProvider = createProvider({
292
+ marketAllowlist: [
293
+ { assets: [USDC, WETH], tickSpacing: 100, chainId: CHAIN_ID },
294
+ ],
295
+ })
296
+ const v2Markets = await v2Provider.getMarkets({})
297
+ const clMarkets = await clProvider.getMarkets({})
298
+ expect(v2Markets[0].marketId.poolId).not.toBe(
299
+ clMarkets[0].marketId.poolId,
300
+ )
301
+ })
302
+
303
+ it('throws when both stable and tickSpacing are set', async () => {
304
+ const provider = createProvider({
305
+ marketAllowlist: [
306
+ {
307
+ assets: [USDC, OP],
308
+ stable: false,
309
+ tickSpacing: 100,
310
+ chainId: CHAIN_ID,
311
+ },
312
+ ],
313
+ })
314
+ await expect(provider.getMarkets({})).rejects.toThrow(
315
+ 'mutually exclusive',
316
+ )
317
+ })
318
+
319
+ it('skips assets without address on target chain', async () => {
320
+ const noChainAsset: Asset = {
321
+ type: 'erc20',
322
+ address: { 1: '0x5555555555555555555555555555555555555555' as Address },
323
+ metadata: { name: 'No Chain', symbol: 'NC', decimals: 18 },
324
+ }
325
+ const provider = createProvider({
326
+ marketAllowlist: [
327
+ { assets: [USDC, noChainAsset], stable: false, chainId: CHAIN_ID },
328
+ ],
329
+ })
330
+ const markets = await provider.getMarkets({})
331
+ expect(markets).toEqual([])
332
+ })
333
+
334
+ it('produces deterministic poolIds', async () => {
335
+ const provider = createProvider()
336
+ const first = await provider.getMarkets({})
337
+ const second = await provider.getMarkets({})
338
+ expect(first[0].marketId.poolId).toBe(second[0].marketId.poolId)
339
+ })
340
+ })
341
+
342
+ describe('getMarket', () => {
343
+ it('finds market by poolId', async () => {
344
+ const provider = createProvider()
345
+ const markets = await provider.getMarkets({})
346
+ const market = await provider.getMarket({
347
+ poolId: markets[0].marketId.poolId,
348
+ chainId: CHAIN_ID,
349
+ })
350
+ expect(market.fee).toBe(0)
351
+ expect(market.assets).toEqual([USDC, OP])
352
+ })
353
+
354
+ it('throws for unknown poolId', async () => {
355
+ const provider = createProvider()
356
+ await expect(
357
+ provider.getMarket({ poolId: '0xunknown', chainId: CHAIN_ID }),
358
+ ).rejects.toThrow('not found')
359
+ })
360
+
361
+ it('finds correct market in multi-asset filter', async () => {
362
+ const provider = createProvider({
363
+ marketAllowlist: [
364
+ {
365
+ assets: [USDC, OP, WETH],
366
+ stable: false,
367
+ chainId: CHAIN_ID,
368
+ },
369
+ ],
370
+ })
371
+ const markets = await provider.getMarkets({})
372
+ for (const expected of markets) {
373
+ const found = await provider.getMarket({
374
+ poolId: expected.marketId.poolId,
375
+ chainId: CHAIN_ID,
376
+ })
377
+ expect(found.marketId.poolId).toBe(expected.marketId.poolId)
378
+ }
379
+ })
380
+ })
381
+
382
+ describe('CL/Slipstream pools', () => {
383
+ it('getQuote returns quote with CL-specific providerContext', async () => {
384
+ const provider = createProvider({
385
+ marketAllowlist: [
386
+ { assets: [USDC, WETH], tickSpacing: 100, chainId: CHAIN_ID },
387
+ ],
388
+ })
389
+
390
+ const quote = await provider.getQuote({
391
+ assetIn: USDC,
392
+ assetOut: WETH,
393
+ amountIn: 100,
394
+ chainId: CHAIN_ID,
395
+ })
396
+
397
+ expect(quote.provider).toBe('velodrome')
398
+ expect(quote.amountOut).toBeGreaterThan(0)
399
+ expect(quote.execution.swapCalldata).toMatch(/^0x/)
400
+ expect(
401
+ (quote.execution.providerContext as Record<string, unknown>)
402
+ .tickSpacing,
403
+ ).toBe(100)
404
+ })
405
+
406
+ it('execute with CL quote uses pre-built calldata', async () => {
407
+ const provider = createProvider({
408
+ marketAllowlist: [
409
+ { assets: [USDC, WETH], tickSpacing: 100, chainId: CHAIN_ID },
410
+ ],
411
+ })
412
+
413
+ const quote = await provider.getQuote({
414
+ assetIn: USDC,
415
+ assetOut: WETH,
416
+ amountIn: 100,
417
+ chainId: CHAIN_ID,
418
+ recipient: MOCK_WALLET,
419
+ })
420
+
421
+ const result = await provider.execute({
422
+ ...quote,
423
+ recipient: MOCK_WALLET,
424
+ })
425
+ expect(result.transactionData.swap.data).toBe(
426
+ quote.execution.swapCalldata,
427
+ )
428
+ })
429
+
430
+ it('execute works for CL pool via raw params', async () => {
431
+ const provider = createProvider({
432
+ marketAllowlist: [
433
+ { assets: [USDC, WETH], tickSpacing: 100, chainId: CHAIN_ID },
434
+ ],
435
+ })
436
+
437
+ const result = await provider.execute({
438
+ amountIn: 100,
439
+ assetIn: USDC,
440
+ assetOut: WETH,
441
+ chainId: CHAIN_ID,
442
+ walletAddress: MOCK_WALLET,
443
+ })
444
+
445
+ expect(result.transactionData.swap).toBeDefined()
446
+ expect(result.amountOut).toBeGreaterThan(0)
447
+ })
448
+
449
+ it('throws for CL on unsupported chain (no clPoolFactory)', async () => {
450
+ const MODE_CHAIN_ID = mode.id as SupportedChainId
451
+
452
+ const mockChainManager = {
453
+ getPublicClient: vi.fn().mockReturnValue({
454
+ readContract: vi.fn(),
455
+ }),
456
+ getSupportedChains: vi.fn().mockReturnValue([MODE_CHAIN_ID]),
457
+ } as unknown as ChainManager
458
+
459
+ const provider = new VelodromeSwapProvider(
460
+ {
461
+ defaultSlippage: 0.005,
462
+ marketAllowlist: [
463
+ {
464
+ assets: [USDC, WETH],
465
+ tickSpacing: 100,
466
+ chainId: MODE_CHAIN_ID,
467
+ },
468
+ ],
469
+ },
470
+ mockChainManager,
471
+ )
472
+
473
+ await expect(
474
+ provider.getQuote({
475
+ assetIn: USDC,
476
+ assetOut: WETH,
477
+ amountIn: 100,
478
+ chainId: MODE_CHAIN_ID,
479
+ }),
480
+ ).rejects.toThrow('CL pools not supported on chain')
481
+ })
482
+ })
483
+
484
+ describe('protocolSupportedChainIds', () => {
485
+ it('includes all configured chains', () => {
486
+ const provider = createProvider()
487
+ const chainIds = provider.protocolSupportedChainIds()
488
+
489
+ expect(chainIds).toContain(10) // Optimism
490
+ expect(chainIds).toContain(8453) // Base
491
+ expect(chainIds).toContain(84532) // Base Sepolia
492
+ expect(chainIds).toContain(60808) // Bob
493
+ expect(chainIds).toContain(42220) // Celo
494
+ expect(chainIds).toContain(252) // Fraxtal
495
+ expect(chainIds).toContain(57073) // Ink
496
+ expect(chainIds).toContain(1135) // Lisk
497
+ expect(chainIds).toContain(1750) // Metal
498
+ expect(chainIds).toContain(34443) // Mode
499
+ expect(chainIds).toContain(1868) // Soneium
500
+ expect(chainIds).toContain(5330) // Superseed
501
+ expect(chainIds).toContain(1923) // Swell
502
+ expect(chainIds).toContain(130) // Unichain
503
+
504
+ expect(chainIds).toHaveLength(14)
505
+ })
506
+ })
507
+ })
@@ -0,0 +1,69 @@
1
+ import { describe, expect, it } from 'vitest'
2
+
3
+ import { MockUSDCAsset, MockWETHAsset } from '@/__mocks__/MockAssets.js'
4
+ import { UNIVERSAL_ROUTER_ABI } from '@/swap/providers/velodrome/abis.js'
5
+ import {
6
+ encodeCLSwap,
7
+ encodeSwap,
8
+ } from '@/swap/providers/velodrome/encoding/index.js'
9
+
10
+ import {
11
+ BASE_CHAIN_ID,
12
+ DEADLINE,
13
+ decode,
14
+ FACTORY,
15
+ RECIPIENT,
16
+ } from './encoding.helpers.js'
17
+
18
+ describe('encodeCLSwap', () => {
19
+ it('encodes V3_SWAP_EXACT_IN command (0x00)', () => {
20
+ const data = encodeCLSwap({
21
+ assetIn: MockUSDCAsset,
22
+ assetOut: MockWETHAsset,
23
+ amountInRaw: 1000000n,
24
+ amountOutMin: 400000000000000000n,
25
+ tickSpacing: 100,
26
+ recipient: RECIPIENT,
27
+ deadline: DEADLINE,
28
+ chainId: BASE_CHAIN_ID,
29
+ })
30
+
31
+ const { functionName, args } = decode<[string, string[], bigint]>(
32
+ UNIVERSAL_ROUTER_ABI,
33
+ data,
34
+ )
35
+ expect(functionName).toBe('execute')
36
+ const [commands, inputs, deadline] = args
37
+ expect(commands).toBe('0x00')
38
+ expect(inputs).toHaveLength(1)
39
+ expect(deadline).toBe(BigInt(DEADLINE))
40
+ })
41
+
42
+ it('produces different calldata than V2 universal router swap', () => {
43
+ const clData = encodeCLSwap({
44
+ assetIn: MockUSDCAsset,
45
+ assetOut: MockWETHAsset,
46
+ amountInRaw: 1000000n,
47
+ amountOutMin: 400000000000000000n,
48
+ tickSpacing: 100,
49
+ recipient: RECIPIENT,
50
+ deadline: DEADLINE,
51
+ chainId: BASE_CHAIN_ID,
52
+ })
53
+
54
+ const v2Data = encodeSwap({
55
+ assetIn: MockUSDCAsset,
56
+ assetOut: MockWETHAsset,
57
+ amountInRaw: 1000000n,
58
+ amountOutMin: 400000000000000000n,
59
+ routerType: 'universal',
60
+ stable: false,
61
+ factoryAddress: FACTORY,
62
+ recipient: RECIPIENT,
63
+ deadline: DEADLINE,
64
+ chainId: BASE_CHAIN_ID,
65
+ })
66
+
67
+ expect(clData).not.toBe(v2Data)
68
+ })
69
+ })
@@ -0,0 +1,20 @@
1
+ import type { Address } from 'viem'
2
+ import { decodeFunctionData } from 'viem'
3
+ import { base, optimism } from 'viem/chains'
4
+
5
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
6
+
7
+ export const OP_CHAIN_ID = optimism.id as SupportedChainId
8
+ export const BASE_CHAIN_ID = base.id as SupportedChainId
9
+ export const RECIPIENT = '0x000000000000000000000000000000000000dEaD' as Address
10
+ export const FACTORY = '0xF1046053aa5682b4F9a81b5481394DA16BE5FF5a' as Address
11
+ export const DEADLINE = Math.floor(Date.now() / 1000) + 60
12
+
13
+ /** Decode calldata and extract args without readonly tuple noise */
14
+ export function decode<T extends readonly unknown[]>(
15
+ abi: Parameters<typeof decodeFunctionData>[0]['abi'],
16
+ data: `0x${string}`,
17
+ ) {
18
+ const result = decodeFunctionData({ abi, data })
19
+ return { functionName: result.functionName, args: result.args as T }
20
+ }