@eth-optimism/actions-sdk 0.2.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (500) 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 -4
  4. package/dist/__mocks__/MockAssets.js.map +1 -1
  5. package/dist/__tests__/actions.test.js +1 -5
  6. package/dist/__tests__/actions.test.js.map +1 -1
  7. package/dist/actions.d.ts +23 -9
  8. package/dist/actions.d.ts.map +1 -1
  9. package/dist/actions.js +68 -36
  10. package/dist/actions.js.map +1 -1
  11. package/dist/constants/assets.d.ts +217 -2
  12. package/dist/constants/assets.d.ts.map +1 -1
  13. package/dist/constants/assets.js +744 -6
  14. package/dist/constants/assets.js.map +1 -1
  15. package/dist/constants/contracts.d.ts +4 -0
  16. package/dist/constants/contracts.d.ts.map +1 -0
  17. package/dist/constants/contracts.js +3 -0
  18. package/dist/constants/contracts.js.map +1 -0
  19. package/dist/constants/providers.d.ts +6 -0
  20. package/dist/constants/providers.d.ts.map +1 -0
  21. package/dist/constants/providers.js +6 -0
  22. package/dist/constants/providers.js.map +1 -0
  23. package/dist/constants/supportedChains.d.ts +2 -2
  24. package/dist/constants/supportedChains.d.ts.map +1 -1
  25. package/dist/constants/supportedChains.js +12 -2
  26. package/dist/constants/supportedChains.js.map +1 -1
  27. package/dist/index.d.ts +4 -4
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +3 -2
  30. package/dist/index.js.map +1 -1
  31. package/dist/lend/__mocks__/MockLendProvider.d.ts +1 -1
  32. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -1
  33. package/dist/lend/__mocks__/MockLendProvider.js +7 -2
  34. package/dist/lend/__mocks__/MockLendProvider.js.map +1 -1
  35. package/dist/lend/core/LendProvider.d.ts +12 -14
  36. package/dist/lend/core/LendProvider.d.ts.map +1 -1
  37. package/dist/lend/core/LendProvider.js +16 -31
  38. package/dist/lend/core/LendProvider.js.map +1 -1
  39. package/dist/lend/core/__tests__/LendProvider.test.js +2 -4
  40. package/dist/lend/core/__tests__/LendProvider.test.js.map +1 -1
  41. package/dist/lend/namespaces/BaseLendNamespace.d.ts +2 -6
  42. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -1
  43. package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -1
  44. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +7 -4
  45. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -1
  46. package/dist/lend/providers/aave/AaveLendProvider.d.ts +1 -6
  47. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -1
  48. package/dist/lend/providers/aave/AaveLendProvider.js +3 -6
  49. package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -1
  50. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +14 -6
  51. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -1
  52. package/dist/lend/providers/aave/addresses.d.ts +13 -39
  53. package/dist/lend/providers/aave/addresses.d.ts.map +1 -1
  54. package/dist/lend/providers/aave/addresses.js +65 -60
  55. package/dist/lend/providers/aave/addresses.js.map +1 -1
  56. package/dist/lend/providers/aave/sdk.d.ts +2 -2
  57. package/dist/lend/providers/aave/sdk.d.ts.map +1 -1
  58. package/dist/lend/providers/aave/sdk.js +6 -28
  59. package/dist/lend/providers/aave/sdk.js.map +1 -1
  60. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +1 -6
  61. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
  62. package/dist/lend/providers/morpho/MorphoLendProvider.js +4 -13
  63. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
  64. package/dist/lend/providers/morpho/__tests__/api.test.js +52 -43
  65. package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
  66. package/dist/lend/providers/morpho/__tests__/sdk.test.js +41 -41
  67. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
  68. package/dist/lend/providers/morpho/api.d.ts +3 -3
  69. package/dist/lend/providers/morpho/api.d.ts.map +1 -1
  70. package/dist/lend/providers/morpho/api.js +2 -2
  71. package/dist/lend/providers/morpho/api.js.map +1 -1
  72. package/dist/lend/providers/morpho/contracts.d.ts +11 -10
  73. package/dist/lend/providers/morpho/contracts.d.ts.map +1 -1
  74. package/dist/lend/providers/morpho/contracts.js +43 -10
  75. package/dist/lend/providers/morpho/contracts.js.map +1 -1
  76. package/dist/lend/providers/morpho/sdk.d.ts +7 -2
  77. package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
  78. package/dist/lend/providers/morpho/sdk.js +67 -54
  79. package/dist/lend/providers/morpho/sdk.js.map +1 -1
  80. package/dist/nodeActionsFactory.d.ts +1 -1
  81. package/dist/reactActionsFactory.d.ts +1 -1
  82. package/dist/services/ChainManager.d.ts +8 -8
  83. package/dist/services/ChainManager.d.ts.map +1 -1
  84. package/dist/services/ChainManager.js.map +1 -1
  85. package/dist/services/__mocks__/MockChainManager.d.ts +4 -4
  86. package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
  87. package/dist/services/__mocks__/MockChainManager.js.map +1 -1
  88. package/dist/services/tokenBalance.d.ts +1 -1
  89. package/dist/services/tokenBalance.d.ts.map +1 -1
  90. package/dist/services/tokenBalance.js +31 -30
  91. package/dist/services/tokenBalance.js.map +1 -1
  92. package/dist/services/tokenBalance.spec.js +20 -24
  93. package/dist/services/tokenBalance.spec.js.map +1 -1
  94. package/dist/swap/__mocks__/MockSwapProvider.d.ts +50 -0
  95. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
  96. package/dist/swap/__mocks__/MockSwapProvider.js +161 -0
  97. package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -0
  98. package/dist/swap/core/SwapProvider.d.ts +145 -0
  99. package/dist/swap/core/SwapProvider.d.ts.map +1 -0
  100. package/dist/swap/core/SwapProvider.js +359 -0
  101. package/dist/swap/core/SwapProvider.js.map +1 -0
  102. package/dist/swap/core/__tests__/SwapProvider.test.d.ts +2 -0
  103. package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
  104. package/dist/swap/core/__tests__/SwapProvider.test.js +435 -0
  105. package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -0
  106. package/dist/swap/core/markets.d.ts +47 -0
  107. package/dist/swap/core/markets.d.ts.map +1 -0
  108. package/dist/swap/core/markets.js +65 -0
  109. package/dist/swap/core/markets.js.map +1 -0
  110. package/dist/swap/index.d.ts +9 -0
  111. package/dist/swap/index.d.ts.map +1 -0
  112. package/dist/swap/index.js +9 -0
  113. package/dist/swap/index.js.map +1 -0
  114. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +8 -0
  115. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
  116. package/dist/swap/namespaces/ActionsSwapNamespace.js +8 -0
  117. package/dist/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
  118. package/dist/swap/namespaces/BaseSwapNamespace.d.ts +73 -0
  119. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
  120. package/dist/swap/namespaces/BaseSwapNamespace.js +181 -0
  121. package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -0
  122. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +34 -0
  123. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
  124. package/dist/swap/namespaces/WalletSwapNamespace.js +84 -0
  125. package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -0
  126. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +2 -0
  127. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
  128. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +245 -0
  129. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
  130. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +2 -0
  131. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
  132. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +209 -0
  133. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
  134. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +35 -0
  135. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
  136. package/dist/swap/providers/uniswap/UniswapSwapProvider.js +148 -0
  137. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
  138. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +2 -0
  139. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
  140. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +258 -0
  141. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
  142. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts +2 -0
  143. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
  144. package/dist/swap/providers/uniswap/__tests__/sdk.test.js +312 -0
  145. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
  146. package/dist/swap/providers/uniswap/abis.d.ts +227 -0
  147. package/dist/swap/providers/uniswap/abis.d.ts.map +1 -0
  148. package/dist/swap/providers/uniswap/abis.js +138 -0
  149. package/dist/swap/providers/uniswap/abis.js.map +1 -0
  150. package/dist/swap/providers/uniswap/addresses.d.ts +26 -0
  151. package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -0
  152. package/dist/swap/providers/uniswap/addresses.js +81 -0
  153. package/dist/swap/providers/uniswap/addresses.js.map +1 -0
  154. package/dist/swap/providers/uniswap/encoding.d.ts +77 -0
  155. package/dist/swap/providers/uniswap/encoding.d.ts.map +1 -0
  156. package/dist/swap/providers/uniswap/encoding.js +233 -0
  157. package/dist/swap/providers/uniswap/encoding.js.map +1 -0
  158. package/dist/swap/providers/uniswap/markets.d.ts +19 -0
  159. package/dist/swap/providers/uniswap/markets.d.ts.map +1 -0
  160. package/dist/swap/providers/uniswap/markets.js +48 -0
  161. package/dist/swap/providers/uniswap/markets.js.map +1 -0
  162. package/dist/swap/providers/uniswap/types.d.ts +21 -0
  163. package/dist/swap/providers/uniswap/types.d.ts.map +1 -0
  164. package/dist/swap/providers/uniswap/types.js +2 -0
  165. package/dist/swap/providers/uniswap/types.js.map +1 -0
  166. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts +49 -0
  167. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
  168. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js +140 -0
  169. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
  170. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +2 -0
  171. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
  172. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +255 -0
  173. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
  174. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +2 -0
  175. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
  176. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +166 -0
  177. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
  178. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +2 -0
  179. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
  180. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +419 -0
  181. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
  182. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts +2 -0
  183. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
  184. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js +51 -0
  185. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
  186. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts +14 -0
  187. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
  188. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js +13 -0
  189. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
  190. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts +2 -0
  191. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
  192. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js +173 -0
  193. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
  194. package/dist/swap/providers/velodrome/abis.d.ts +396 -0
  195. package/dist/swap/providers/velodrome/abis.d.ts.map +1 -0
  196. package/dist/swap/providers/velodrome/abis.js +257 -0
  197. package/dist/swap/providers/velodrome/abis.js.map +1 -0
  198. package/dist/swap/providers/velodrome/addresses.d.ts +39 -0
  199. package/dist/swap/providers/velodrome/addresses.d.ts.map +1 -0
  200. package/dist/swap/providers/velodrome/addresses.js +57 -0
  201. package/dist/swap/providers/velodrome/addresses.js.map +1 -0
  202. package/dist/swap/providers/velodrome/config.d.ts +22 -0
  203. package/dist/swap/providers/velodrome/config.d.ts.map +1 -0
  204. package/dist/swap/providers/velodrome/config.js +29 -0
  205. package/dist/swap/providers/velodrome/config.js.map +1 -0
  206. package/dist/swap/providers/velodrome/encoding/helpers.d.ts +37 -0
  207. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
  208. package/dist/swap/providers/velodrome/encoding/helpers.js +60 -0
  209. package/dist/swap/providers/velodrome/encoding/helpers.js.map +1 -0
  210. package/dist/swap/providers/velodrome/encoding/index.d.ts +8 -0
  211. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
  212. package/dist/swap/providers/velodrome/encoding/index.js +5 -0
  213. package/dist/swap/providers/velodrome/encoding/index.js.map +1 -0
  214. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts +39 -0
  215. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
  216. package/dist/swap/providers/velodrome/encoding/poolRouter.js +83 -0
  217. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
  218. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +15 -0
  219. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +1 -0
  220. package/dist/swap/providers/velodrome/encoding/routers/approval.js +33 -0
  221. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +1 -0
  222. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts +40 -0
  223. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
  224. package/dist/swap/providers/velodrome/encoding/routers/cl.js +80 -0
  225. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
  226. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts +42 -0
  227. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
  228. package/dist/swap/providers/velodrome/encoding/routers/v2.js +166 -0
  229. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
  230. package/dist/swap/providers/velodrome/markets.d.ts +21 -0
  231. package/dist/swap/providers/velodrome/markets.d.ts.map +1 -0
  232. package/dist/swap/providers/velodrome/markets.js +69 -0
  233. package/dist/swap/providers/velodrome/markets.js.map +1 -0
  234. package/dist/swap/providers/velodrome/types.d.ts +31 -0
  235. package/dist/swap/providers/velodrome/types.d.ts.map +1 -0
  236. package/dist/swap/providers/velodrome/types.js +2 -0
  237. package/dist/swap/providers/velodrome/types.js.map +1 -0
  238. package/dist/types/actions.d.ts +60 -11
  239. package/dist/types/actions.d.ts.map +1 -1
  240. package/dist/types/asset.d.ts +7 -9
  241. package/dist/types/asset.d.ts.map +1 -1
  242. package/dist/types/chain.d.ts +2 -2
  243. package/dist/types/chain.d.ts.map +1 -1
  244. package/dist/types/index.d.ts +2 -0
  245. package/dist/types/index.d.ts.map +1 -1
  246. package/dist/types/index.js +2 -0
  247. package/dist/types/index.js.map +1 -1
  248. package/dist/types/lend/base.d.ts +9 -19
  249. package/dist/types/lend/base.d.ts.map +1 -1
  250. package/dist/types/lend/base.js.map +1 -1
  251. package/dist/types/lend/contracts.d.ts +2 -1
  252. package/dist/types/lend/contracts.d.ts.map +1 -1
  253. package/dist/types/providers.d.ts +21 -0
  254. package/dist/types/providers.d.ts.map +1 -0
  255. package/dist/types/providers.js +2 -0
  256. package/dist/types/providers.js.map +1 -0
  257. package/dist/types/swap/base.d.ts +338 -0
  258. package/dist/types/swap/base.d.ts.map +1 -0
  259. package/dist/types/swap/base.js +4 -0
  260. package/dist/types/swap/base.js.map +1 -0
  261. package/dist/types/swap/index.d.ts +2 -0
  262. package/dist/types/swap/index.d.ts.map +1 -0
  263. package/dist/types/swap/index.js +2 -0
  264. package/dist/types/swap/index.js.map +1 -0
  265. package/dist/types/transaction.d.ts +14 -0
  266. package/dist/types/transaction.d.ts.map +1 -0
  267. package/dist/types/transaction.js +2 -0
  268. package/dist/types/transaction.js.map +1 -0
  269. package/dist/utils/approve.d.ts +82 -0
  270. package/dist/utils/approve.d.ts.map +1 -0
  271. package/dist/utils/approve.js +134 -0
  272. package/dist/utils/approve.js.map +1 -0
  273. package/dist/utils/approve.test.d.ts +2 -0
  274. package/dist/utils/approve.test.d.ts.map +1 -0
  275. package/dist/utils/approve.test.js +203 -0
  276. package/dist/utils/approve.test.js.map +1 -0
  277. package/dist/utils/assets.d.ts +10 -5
  278. package/dist/utils/assets.d.ts.map +1 -1
  279. package/dist/utils/assets.js +14 -11
  280. package/dist/utils/assets.js.map +1 -1
  281. package/dist/utils/assets.test.js +13 -1
  282. package/dist/utils/assets.test.js.map +1 -1
  283. package/dist/utils/validateAddresses.d.ts +32 -0
  284. package/dist/utils/validateAddresses.d.ts.map +1 -0
  285. package/dist/utils/validateAddresses.js +103 -0
  286. package/dist/utils/validateAddresses.js.map +1 -0
  287. package/dist/utils/validateAddresses.test.d.ts +2 -0
  288. package/dist/utils/validateAddresses.test.d.ts.map +1 -0
  289. package/dist/utils/validateAddresses.test.js +314 -0
  290. package/dist/utils/validateAddresses.test.js.map +1 -0
  291. package/dist/utils/validation.d.ts +12 -0
  292. package/dist/utils/validation.d.ts.map +1 -0
  293. package/dist/utils/validation.js +44 -0
  294. package/dist/utils/validation.js.map +1 -0
  295. package/dist/wallet/core/namespace/WalletNamespace.d.ts +21 -9
  296. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  297. package/dist/wallet/core/namespace/WalletNamespace.js +44 -15
  298. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  299. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +4 -4
  300. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  301. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +4 -10
  302. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
  303. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js +2 -1
  304. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
  305. package/dist/wallet/core/providers/hosted/types/index.d.ts +6 -7
  306. package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
  307. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +5 -6
  308. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
  309. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js +5 -1
  310. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
  311. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +2 -2
  312. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
  313. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +12 -12
  314. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  315. package/dist/wallet/core/wallets/abstract/Wallet.js +9 -4
  316. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  317. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +10 -1
  318. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  319. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js +2 -2
  320. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  321. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +12 -4
  322. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  323. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +5 -7
  324. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  325. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +6 -5
  326. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  327. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  328. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +4 -6
  329. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  330. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -1
  331. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  332. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts +2 -4
  333. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
  334. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +8 -9
  335. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
  336. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +4 -4
  337. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  338. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +3 -6
  339. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  340. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +4 -2
  341. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  342. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +4 -6
  343. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  344. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js +4 -3
  345. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  346. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +3 -6
  347. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  348. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  349. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  350. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +6 -6
  351. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
  352. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +7 -2
  353. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
  354. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -0
  355. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
  356. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +5 -6
  357. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  358. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +6 -2
  359. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  360. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -0
  361. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  362. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +5 -8
  363. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  364. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +6 -4
  365. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  366. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts +2 -4
  367. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -1
  368. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +11 -13
  369. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
  370. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +6 -6
  371. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  372. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +7 -6
  373. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
  374. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +5 -3
  375. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -1
  376. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts +2 -6
  377. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts.map +1 -1
  378. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js.map +1 -1
  379. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +5 -6
  380. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  381. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +3 -3
  382. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  383. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -6
  384. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  385. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  386. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  387. package/package.json +4 -3
  388. package/src/__mocks__/MockAssets.ts +54 -4
  389. package/src/__tests__/actions.test.ts +1 -5
  390. package/src/actions.ts +106 -71
  391. package/src/constants/assets.ts +792 -5
  392. package/src/constants/contracts.ts +5 -0
  393. package/src/constants/providers.ts +5 -0
  394. package/src/constants/supportedChains.ts +22 -2
  395. package/src/index.ts +76 -6
  396. package/src/lend/__mocks__/MockLendProvider.ts +8 -3
  397. package/src/lend/core/LendProvider.ts +28 -41
  398. package/src/lend/core/__tests__/LendProvider.test.ts +2 -5
  399. package/src/lend/namespaces/BaseLendNamespace.ts +2 -6
  400. package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +12 -5
  401. package/src/lend/providers/aave/AaveLendProvider.ts +3 -7
  402. package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +16 -7
  403. package/src/lend/providers/aave/addresses.ts +82 -64
  404. package/src/lend/providers/aave/sdk.ts +11 -36
  405. package/src/lend/providers/morpho/MorphoLendProvider.ts +4 -16
  406. package/src/lend/providers/morpho/__tests__/api.test.ts +65 -44
  407. package/src/lend/providers/morpho/__tests__/sdk.test.ts +43 -42
  408. package/src/lend/providers/morpho/api.ts +7 -4
  409. package/src/lend/providers/morpho/contracts.ts +62 -13
  410. package/src/lend/providers/morpho/sdk.ts +85 -54
  411. package/src/services/ChainManager.ts +12 -21
  412. package/src/services/__mocks__/MockChainManager.ts +4 -7
  413. package/src/services/tokenBalance.spec.ts +20 -24
  414. package/src/services/tokenBalance.ts +39 -33
  415. package/src/swap/__mocks__/MockSwapProvider.ts +251 -0
  416. package/src/swap/core/SwapProvider.ts +577 -0
  417. package/src/swap/core/__tests__/SwapProvider.test.ts +620 -0
  418. package/src/swap/core/markets.ts +104 -0
  419. package/src/swap/index.ts +19 -0
  420. package/src/swap/namespaces/ActionsSwapNamespace.ts +7 -0
  421. package/src/swap/namespaces/BaseSwapNamespace.ts +258 -0
  422. package/src/swap/namespaces/WalletSwapNamespace.ts +121 -0
  423. package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +365 -0
  424. package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +257 -0
  425. package/src/swap/providers/uniswap/UniswapSwapProvider.ts +217 -0
  426. package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +299 -0
  427. package/src/swap/providers/uniswap/__tests__/sdk.test.ts +369 -0
  428. package/src/swap/providers/uniswap/abis.ts +144 -0
  429. package/src/swap/providers/uniswap/addresses.ts +110 -0
  430. package/src/swap/providers/uniswap/encoding.ts +406 -0
  431. package/src/swap/providers/uniswap/markets.ts +84 -0
  432. package/src/swap/providers/uniswap/types.ts +25 -0
  433. package/src/swap/providers/velodrome/VelodromeSwapProvider.ts +224 -0
  434. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +341 -0
  435. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +202 -0
  436. package/src/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +506 -0
  437. package/src/swap/providers/velodrome/__tests__/encoding.cl.test.ts +69 -0
  438. package/src/swap/providers/velodrome/__tests__/encoding.helpers.ts +20 -0
  439. package/src/swap/providers/velodrome/__tests__/encoding.v2.test.ts +235 -0
  440. package/src/swap/providers/velodrome/abis.ts +264 -0
  441. package/src/swap/providers/velodrome/addresses.ts +107 -0
  442. package/src/swap/providers/velodrome/config.ts +46 -0
  443. package/src/swap/providers/velodrome/encoding/helpers.ts +82 -0
  444. package/src/swap/providers/velodrome/encoding/index.ts +7 -0
  445. package/src/swap/providers/velodrome/encoding/poolRouter.ts +124 -0
  446. package/src/swap/providers/velodrome/encoding/routers/approval.ts +45 -0
  447. package/src/swap/providers/velodrome/encoding/routers/cl.ts +156 -0
  448. package/src/swap/providers/velodrome/encoding/routers/v2.ts +267 -0
  449. package/src/swap/providers/velodrome/markets.ts +100 -0
  450. package/src/swap/providers/velodrome/types.ts +30 -0
  451. package/src/types/actions.ts +68 -12
  452. package/src/types/asset.ts +12 -9
  453. package/src/types/chain.ts +2 -2
  454. package/src/types/index.ts +2 -0
  455. package/src/types/lend/base.ts +10 -20
  456. package/src/types/lend/contracts.ts +5 -1
  457. package/src/types/providers.ts +22 -0
  458. package/src/types/swap/base.ts +372 -0
  459. package/src/types/swap/index.ts +1 -0
  460. package/src/types/transaction.ts +14 -0
  461. package/src/utils/approve.test.ts +258 -0
  462. package/src/utils/approve.ts +197 -0
  463. package/src/utils/assets.test.ts +16 -1
  464. package/src/utils/assets.ts +27 -10
  465. package/src/utils/validateAddresses.test.ts +439 -0
  466. package/src/utils/validateAddresses.ts +153 -0
  467. package/src/utils/validation.ts +76 -0
  468. package/src/wallet/core/namespace/WalletNamespace.ts +70 -16
  469. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +8 -4
  470. package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +6 -10
  471. package/src/wallet/core/providers/hosted/types/index.ts +9 -7
  472. package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +10 -10
  473. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +2 -0
  474. package/src/wallet/core/wallets/abstract/Wallet.ts +23 -14
  475. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +13 -1
  476. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +21 -5
  477. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +11 -14
  478. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +0 -1
  479. package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +11 -7
  480. package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +16 -8
  481. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +4 -4
  482. package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +6 -7
  483. package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +8 -11
  484. package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +7 -11
  485. package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +11 -7
  486. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -0
  487. package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +10 -7
  488. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -0
  489. package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +10 -9
  490. package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +38 -13
  491. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +6 -6
  492. package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +13 -11
  493. package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +2 -6
  494. package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +11 -11
  495. package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +11 -11
  496. package/dist/supported/tokens.d.ts +0 -25
  497. package/dist/supported/tokens.d.ts.map +0 -1
  498. package/dist/supported/tokens.js +0 -37
  499. package/dist/supported/tokens.js.map +0 -1
  500. package/src/supported/tokens.ts +0 -52
@@ -0,0 +1,104 @@
1
+ import type { Address } from 'viem'
2
+
3
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
4
+ import type { Asset } from '@/types/asset.js'
5
+ import type {
6
+ GetSwapMarketsParams,
7
+ SwapMarket,
8
+ SwapMarketConfig,
9
+ } from '@/types/swap/index.js'
10
+
11
+ /**
12
+ * Sentinel address meaning "send output to msg.sender" in Universal Router commands.
13
+ * The Universal Router maps address(1) to msg.sender and address(2) to the router itself.
14
+ * Only valid in Universal Router calldata encoding — do not use as a general-purpose address.
15
+ * Both Uniswap and Velodrome/Aerodrome Universal Router forks use this convention.
16
+ * @see https://github.com/Uniswap/universal-router/blob/main/contracts/libraries/Constants.sol
17
+ */
18
+ export const UNIVERSAL_ROUTER_MSG_SENDER =
19
+ '0x0000000000000000000000000000000000000001' as Address
20
+
21
+ /**
22
+ * Generate unique asset pairs, optionally filtered to pairs containing a required asset.
23
+ * @param assets - Full list of assets from a market config
24
+ * @param requiredAsset - If set, only pairs including this asset are returned
25
+ */
26
+ export function assetPairs(
27
+ assets: Asset[],
28
+ requiredAsset?: Asset,
29
+ ): Array<[Asset, Asset]> {
30
+ return assets
31
+ .flatMap((a, i) => assets.slice(i + 1).map((b): [Asset, Asset] => [a, b]))
32
+ .filter(
33
+ ([a, b]) => !requiredAsset || a === requiredAsset || b === requiredAsset,
34
+ )
35
+ }
36
+
37
+ /**
38
+ * Sort two addresses for deterministic pool ID computation.
39
+ * @returns [lower, higher] addresses
40
+ */
41
+ export function sortAddressPair(
42
+ addrA: string,
43
+ addrB: string,
44
+ ): [string, string] {
45
+ return addrA.toLowerCase() < addrB.toLowerCase()
46
+ ? [addrA, addrB]
47
+ : [addrB, addrA]
48
+ }
49
+
50
+ /**
51
+ * Find a specific market by poolId across a set of configs.
52
+ * @param configs - Valid market configs to search
53
+ * @param chainId - Target chain
54
+ * @param poolId - Pool ID to match
55
+ * @param toMarkets - Provider-specific function that expands a config into SwapMarket[]
56
+ * @returns Matching market
57
+ * @throws If no matching market found
58
+ */
59
+ export function findMarket<T extends SwapMarketConfig>(
60
+ configs: T[],
61
+ chainId: SupportedChainId,
62
+ poolId: string,
63
+ toMarkets: (config: T, chainId: SupportedChainId) => SwapMarket[],
64
+ ): SwapMarket {
65
+ for (const config of configs) {
66
+ if (config.chainId !== undefined && config.chainId !== chainId) continue
67
+ const match = toMarkets(config, chainId).find(
68
+ (m) => m.marketId.poolId === poolId,
69
+ )
70
+ if (match) return match
71
+ }
72
+ throw new Error(`Market with poolId ${poolId} not found on chain ${chainId}`)
73
+ }
74
+
75
+ /**
76
+ * Expand market configs into concrete SwapMarket objects with optional filters.
77
+ * @param options.configs - Valid market configs
78
+ * @param options.filters - Optional chainId and asset filters
79
+ * @param options.supportedChainIds - All chain IDs this provider supports
80
+ * @param options.toMarkets - Provider-specific function that expands a config into SwapMarket[]
81
+ */
82
+ export function expandMarkets<T extends SwapMarketConfig>(options: {
83
+ configs: T[]
84
+ filters: GetSwapMarketsParams
85
+ supportedChainIds: SupportedChainId[]
86
+ toMarkets: (
87
+ config: T,
88
+ chainId: SupportedChainId,
89
+ asset?: Asset,
90
+ ) => SwapMarket[]
91
+ }): SwapMarket[] {
92
+ const { configs, filters, supportedChainIds, toMarkets } = options
93
+ return configs.flatMap((config) => {
94
+ const chainIds = filters.chainId
95
+ ? [filters.chainId]
96
+ : config.chainId
97
+ ? [config.chainId]
98
+ : supportedChainIds
99
+
100
+ return chainIds.flatMap((chainId) =>
101
+ toMarkets(config, chainId, filters.asset),
102
+ )
103
+ })
104
+ }
@@ -0,0 +1,19 @@
1
+ // Core
2
+ export { SwapProvider } from '@/swap/core/SwapProvider.js'
3
+
4
+ // Namespaces
5
+ export { ActionsSwapNamespace } from '@/swap/namespaces/ActionsSwapNamespace.js'
6
+ export { BaseSwapNamespace } from '@/swap/namespaces/BaseSwapNamespace.js'
7
+ export { WalletSwapNamespace } from '@/swap/namespaces/WalletSwapNamespace.js'
8
+
9
+ // Providers
10
+ export type {
11
+ UniswapMarketConfig,
12
+ UniswapSwapProviderConfig,
13
+ } from '@/swap/providers/uniswap/types.js'
14
+ export { UniswapSwapProvider } from '@/swap/providers/uniswap/UniswapSwapProvider.js'
15
+ export type {
16
+ VelodromeMarketConfig,
17
+ VelodromeSwapProviderConfig,
18
+ } from '@/swap/providers/velodrome/types.js'
19
+ export { VelodromeSwapProvider } from '@/swap/providers/velodrome/VelodromeSwapProvider.js'
@@ -0,0 +1,7 @@
1
+ import { BaseSwapNamespace } from '@/swap/namespaces/BaseSwapNamespace.js'
2
+
3
+ /**
4
+ * Actions swap namespace (read-only, no wallet required).
5
+ * Provides getQuote(), getMarket(), and getMarkets() for read-only access without a wallet.
6
+ */
7
+ export class ActionsSwapNamespace extends BaseSwapNamespace {}
@@ -0,0 +1,258 @@
1
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
2
+ import type { SwapProvider } from '@/swap/core/SwapProvider.js'
3
+ import type { SwapProviderName, SwapSettings } from '@/types/actions.js'
4
+ import type { Asset } from '@/types/asset.js'
5
+ import type {
6
+ GetSwapMarketParams,
7
+ GetSwapMarketsParams,
8
+ SwapMarket,
9
+ SwapProviderConfig,
10
+ SwapProviders,
11
+ SwapQuote,
12
+ SwapQuoteParams,
13
+ } from '@/types/swap/index.js'
14
+
15
+ /**
16
+ * Base swap namespace with shared read-only operations
17
+ */
18
+ export abstract class BaseSwapNamespace {
19
+ constructor(
20
+ protected readonly providers: SwapProviders,
21
+ protected readonly settings?: SwapSettings,
22
+ ) {}
23
+
24
+ /**
25
+ * Get a swap quote with pre-built execution data.
26
+ * When `routing: 'price'` is set in settings and no explicit provider is requested,
27
+ * fetches quotes from all eligible providers in parallel and returns the best price.
28
+ * @param params - Quote parameters (assets, amounts, chain, optional provider)
29
+ * @returns The best available SwapQuote
30
+ */
31
+ async getQuote(params: SwapQuoteParams): Promise<SwapQuote> {
32
+ // Explicit provider — skip routing
33
+ if (params.provider) {
34
+ const provider = this.resolveProvider(
35
+ params.provider,
36
+ params.assetIn,
37
+ params.assetOut,
38
+ params.chainId,
39
+ )
40
+ return provider.getQuote(params)
41
+ }
42
+
43
+ // Price routing — quote all eligible providers, return best
44
+ if (this.settings?.routing === 'price') {
45
+ return this.getBestQuote(params)
46
+ }
47
+
48
+ // No routing — resolve single provider via fallback logic
49
+ const provider = this.resolveProvider(
50
+ undefined,
51
+ params.assetIn,
52
+ params.assetOut,
53
+ params.chainId,
54
+ )
55
+ return provider.getQuote(params)
56
+ }
57
+
58
+ /**
59
+ * Fetch quotes from all eligible providers in parallel and return the best.
60
+ * @param params - Quote parameters
61
+ * @returns The quote with the highest amountOut
62
+ * @throws If no provider returns a valid quote
63
+ */
64
+ private async getBestQuote(params: SwapQuoteParams): Promise<SwapQuote> {
65
+ const quotes = await this.fetchAllQuotes(params)
66
+
67
+ let best: SwapQuote | null = null
68
+ for (const quote of quotes) {
69
+ if (!best || quote.amountOutRaw > best.amountOutRaw) {
70
+ best = quote
71
+ }
72
+ }
73
+
74
+ if (!best) {
75
+ throw new Error(
76
+ `All providers failed to quote ${params.assetIn.metadata.symbol}/${params.assetOut.metadata.symbol}`,
77
+ )
78
+ }
79
+
80
+ return best
81
+ }
82
+
83
+ /**
84
+ * Fetch quotes from all eligible providers in parallel.
85
+ * Providers that don't support the pair or fail to quote are silently skipped.
86
+ * @param params - Quote parameters
87
+ * @returns Array of successful quotes (may be empty if all providers fail)
88
+ */
89
+ private async fetchAllQuotes(params: SwapQuoteParams): Promise<SwapQuote[]> {
90
+ const eligible = this.getAllProviders().filter((p) =>
91
+ p.isMarketSupported(params.assetIn, params.assetOut, params.chainId),
92
+ )
93
+
94
+ if (eligible.length === 0) {
95
+ throw new Error(
96
+ `No provider supports ${params.assetIn.metadata.symbol}/${params.assetOut.metadata.symbol} on chain ${params.chainId}`,
97
+ )
98
+ }
99
+
100
+ const results = await Promise.allSettled(
101
+ eligible.map((p) => p.getQuote(params)),
102
+ )
103
+
104
+ return results
105
+ .filter(
106
+ (r): r is PromiseFulfilledResult<SwapQuote> => r.status === 'fulfilled',
107
+ )
108
+ .map((r) => r.value)
109
+ }
110
+
111
+ /**
112
+ * Fetch quotes from all eligible providers in parallel.
113
+ * Unlike getQuote(), returns all successful quotes instead of just the best.
114
+ * If an explicit provider is specified, returns a single-element array from that provider.
115
+ * @param params - Quote parameters (assets, amounts, chain, optional provider)
116
+ * @returns Array of SwapQuotes sorted by amountOut descending (best first)
117
+ */
118
+ async getQuotes(params: SwapQuoteParams): Promise<SwapQuote[]> {
119
+ if (params.provider) {
120
+ const provider = this.resolveProvider(
121
+ params.provider,
122
+ params.assetIn,
123
+ params.assetOut,
124
+ params.chainId,
125
+ )
126
+ return [await provider.getQuote(params)]
127
+ }
128
+
129
+ const quotes = await this.fetchAllQuotes(params)
130
+ return quotes.sort((a, b) =>
131
+ a.amountOutRaw > b.amountOutRaw
132
+ ? -1
133
+ : a.amountOutRaw < b.amountOutRaw
134
+ ? 1
135
+ : 0,
136
+ )
137
+ }
138
+
139
+ /**
140
+ * Get a specific swap market by ID.
141
+ * @param params - Market identifier (poolId + chainId)
142
+ * @param provider - Optional provider name to query directly instead of searching all
143
+ * @returns Market information
144
+ */
145
+ async getMarket(
146
+ params: GetSwapMarketParams,
147
+ provider?: SwapProviderName,
148
+ ): Promise<SwapMarket> {
149
+ if (provider) {
150
+ const named = this.providers[provider]
151
+ if (!named) {
152
+ throw new Error(`Swap provider "${provider}" not configured`)
153
+ }
154
+ return named.getMarket(params)
155
+ }
156
+
157
+ for (const p of this.getAllProviders()) {
158
+ try {
159
+ return await p.getMarket(params)
160
+ } catch {
161
+ continue
162
+ }
163
+ }
164
+ throw new Error(
165
+ `Market with poolId ${params.poolId} not found on chain ${params.chainId}`,
166
+ )
167
+ }
168
+
169
+ /**
170
+ * Get available swap markets across all providers
171
+ * @param params - Optional filtering by chainId or asset
172
+ * @returns Promise resolving to array of markets from all providers
173
+ */
174
+ async getMarkets(params: GetSwapMarketsParams = {}): Promise<SwapMarket[]> {
175
+ const results = await Promise.all(
176
+ this.getAllProviders().map((p) => p.getMarkets(params)),
177
+ )
178
+ return results.flat()
179
+ }
180
+
181
+ /**
182
+ * Get all supported chain IDs across all providers
183
+ */
184
+ supportedChainIds(): SupportedChainId[] {
185
+ const chainIds = new Set<SupportedChainId>()
186
+ for (const provider of this.getAllProviders()) {
187
+ for (const chainId of provider.supportedChainIds()) {
188
+ chainIds.add(chainId)
189
+ }
190
+ }
191
+ return Array.from(chainIds)
192
+ }
193
+
194
+ // SwapProviders keys are optional (uniswap?, velodrome?, etc.) so filter out unconfigured ones
195
+ protected getAllProviders(): Array<SwapProvider<SwapProviderConfig>> {
196
+ return Object.values(this.providers).filter(
197
+ (p): p is SwapProvider<SwapProviderConfig> => p !== undefined,
198
+ )
199
+ }
200
+
201
+ /**
202
+ * Resolve which provider handles a request.
203
+ *
204
+ * Precedence:
205
+ * 1. Explicit `provider` param on the call
206
+ * 2. routing.defaultProvider (when no strategy set)
207
+ * 3. routing.strategy match (market-aware, defaultProvider as tiebreaker)
208
+ * 4. First provider whose allowlist matches
209
+ * 5. First configured provider
210
+ */
211
+ protected resolveProvider(
212
+ provider: SwapProviderName | undefined,
213
+ assetIn: Asset,
214
+ assetOut: Asset,
215
+ chainId: SupportedChainId,
216
+ ): SwapProvider<SwapProviderConfig> {
217
+ const allProviders = this.getAllProviders()
218
+ if (allProviders.length === 0) {
219
+ throw new Error('No swap provider configured')
220
+ }
221
+
222
+ // 1. Explicit provider param
223
+ if (provider) {
224
+ const named = this.providers[provider]
225
+ if (!named) {
226
+ throw new Error(`Swap provider "${provider}" not configured`)
227
+ }
228
+ return named
229
+ }
230
+
231
+ // Single provider — no routing needed
232
+ if (allProviders.length === 1) {
233
+ return allProviders[0]
234
+ }
235
+
236
+ // 2. defaultProvider with no routing strategy — always use it
237
+ if (this.settings?.defaultProvider && !this.settings.routing) {
238
+ const provider = this.providers[this.settings.defaultProvider]
239
+ if (provider) return provider
240
+ }
241
+
242
+ // 3. Match by market allowlist
243
+ for (const p of allProviders) {
244
+ if (p.isMarketSupported(assetIn, assetOut, chainId)) {
245
+ return p
246
+ }
247
+ }
248
+
249
+ // 4. Match by chain support
250
+ for (const p of allProviders) {
251
+ if (p.isChainSupported(chainId)) {
252
+ return p
253
+ }
254
+ }
255
+
256
+ return allProviders[0]
257
+ }
258
+ }
@@ -0,0 +1,121 @@
1
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
2
+ import { QUOTE_DISCRIMINATOR } from '@/swap/core/SwapProvider.js'
3
+ import { BaseSwapNamespace } from '@/swap/namespaces/BaseSwapNamespace.js'
4
+ import type { SwapSettings } from '@/types/actions.js'
5
+ import type {
6
+ SwapProviders,
7
+ SwapQuote,
8
+ SwapQuoteParams,
9
+ SwapReceipt,
10
+ SwapTransaction,
11
+ WalletSwapParams,
12
+ } from '@/types/swap/index.js'
13
+ import type { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
14
+
15
+ /**
16
+ * Wallet swap namespace with full operations including signing.
17
+ * Provides getQuote() for pricing and execute() for swapping tokens.
18
+ */
19
+ export class WalletSwapNamespace extends BaseSwapNamespace {
20
+ constructor(
21
+ providers: SwapProviders,
22
+ private readonly wallet: Wallet,
23
+ settings?: SwapSettings,
24
+ ) {
25
+ super(providers, settings)
26
+ }
27
+
28
+ /**
29
+ * Get a swap quote with the wallet address as recipient.
30
+ * Ensures calldata is encoded for the real wallet, not a placeholder.
31
+ */
32
+ override async getQuote(params: SwapQuoteParams): Promise<SwapQuote> {
33
+ return super.getQuote({
34
+ ...params,
35
+ recipient: params.recipient ?? this.wallet.address,
36
+ })
37
+ }
38
+
39
+ /**
40
+ * Get quotes from all providers with the wallet address as recipient.
41
+ */
42
+ override async getQuotes(params: SwapQuoteParams): Promise<SwapQuote[]> {
43
+ return super.getQuotes({
44
+ ...params,
45
+ recipient: params.recipient ?? this.wallet.address,
46
+ })
47
+ }
48
+
49
+ /**
50
+ * Execute a token swap.
51
+ * Accepts either raw params (re-quotes internally) or a pre-built SwapQuote (skips re-quoting).
52
+ * @param params - Swap parameters or a pre-built SwapQuote from getQuote()
53
+ * @returns Swap receipt with transaction details
54
+ */
55
+ async execute(params: WalletSwapParams | SwapQuote): Promise<SwapReceipt> {
56
+ // Inject walletAddress — raw params need it for validation,
57
+ // quotes need it for on-chain allowance checks during approval building
58
+ const executeParams =
59
+ QUOTE_DISCRIMINATOR in params
60
+ ? { ...params, recipient: this.wallet.address }
61
+ : { ...params, walletAddress: this.wallet.address }
62
+
63
+ const provider = this.resolveProvider(
64
+ params.provider,
65
+ params.assetIn,
66
+ params.assetOut,
67
+ params.chainId,
68
+ )
69
+
70
+ const swapTx = await provider.execute(executeParams)
71
+ const receipt = await this.executeTransaction(swapTx, params.chainId)
72
+ return this.buildReceipt(swapTx, receipt)
73
+ }
74
+
75
+ private buildReceipt(
76
+ swapTx: SwapTransaction,
77
+ receipt: SwapReceipt['receipt'],
78
+ ): SwapReceipt {
79
+ return {
80
+ receipt,
81
+ amountIn: swapTx.amountIn,
82
+ amountOut: swapTx.amountOut,
83
+ amountInRaw: swapTx.amountInRaw,
84
+ amountOutRaw: swapTx.amountOutRaw,
85
+ assetIn: swapTx.assetIn,
86
+ assetOut: swapTx.assetOut,
87
+ price: swapTx.price,
88
+ priceImpact: swapTx.priceImpact,
89
+ }
90
+ }
91
+
92
+ /**
93
+ * Execute swap transaction with approval batching
94
+ */
95
+ private async executeTransaction(
96
+ swapTx: SwapTransaction,
97
+ chainId: SupportedChainId,
98
+ ): Promise<SwapReceipt['receipt']> {
99
+ const { transactionData } = swapTx
100
+ const txs = []
101
+
102
+ // Add token approval if needed
103
+ if (transactionData.tokenApproval) {
104
+ txs.push(transactionData.tokenApproval)
105
+ }
106
+
107
+ // Add Permit2 approval if needed
108
+ if (transactionData.permit2Approval) {
109
+ txs.push(transactionData.permit2Approval)
110
+ }
111
+
112
+ // Add main swap transaction
113
+ txs.push(transactionData.swap)
114
+
115
+ // Execute as batch if multiple transactions, otherwise single
116
+ if (txs.length > 1) {
117
+ return this.wallet.sendBatch(txs, chainId)
118
+ }
119
+ return this.wallet.send(transactionData.swap, chainId)
120
+ }
121
+ }