@eth-optimism/actions-sdk 0.1.0 → 0.3.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/LICENSE +1 -1
  2. package/dist/__mocks__/MockAssets.d.ts.map +1 -0
  3. package/dist/{test → __mocks__}/MockAssets.js +2 -0
  4. package/dist/__mocks__/MockAssets.js.map +1 -0
  5. package/dist/__mocks__/MockPrivyClient.d.ts.map +1 -0
  6. package/dist/__mocks__/MockPrivyClient.js.map +1 -0
  7. package/dist/__mocks__/utils.d.ts.map +1 -0
  8. package/dist/__mocks__/utils.js.map +1 -0
  9. package/dist/__tests__/actions.test.d.ts.map +1 -0
  10. package/dist/{actions.test.js → __tests__/actions.test.js} +5 -9
  11. package/dist/__tests__/actions.test.js.map +1 -0
  12. package/dist/actions.d.ts +20 -1
  13. package/dist/actions.d.ts.map +1 -1
  14. package/dist/actions.js +37 -13
  15. package/dist/actions.js.map +1 -1
  16. package/dist/constants/assets.d.ts +23 -0
  17. package/dist/constants/assets.d.ts.map +1 -1
  18. package/dist/constants/assets.js +99 -6
  19. package/dist/constants/assets.js.map +1 -1
  20. package/dist/constants/contracts.d.ts +4 -0
  21. package/dist/constants/contracts.d.ts.map +1 -0
  22. package/dist/constants/contracts.js +3 -0
  23. package/dist/constants/contracts.js.map +1 -0
  24. package/dist/constants/supportedChains.d.ts +1 -1
  25. package/dist/constants/supportedChains.d.ts.map +1 -1
  26. package/dist/constants/supportedChains.js +7 -3
  27. package/dist/constants/supportedChains.js.map +1 -1
  28. package/dist/core/asset/__mocks__/mockAsset.js +1 -1
  29. package/dist/core/asset/__mocks__/mockAsset.js.map +1 -1
  30. package/dist/index.d.ts +4 -3
  31. package/dist/index.d.ts.map +1 -1
  32. package/dist/index.js +3 -1
  33. package/dist/index.js.map +1 -1
  34. package/dist/{test → lend/__mocks__}/MockLendProvider.d.ts +7 -6
  35. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +1 -0
  36. package/dist/{test → lend/__mocks__}/MockLendProvider.js +20 -21
  37. package/dist/lend/__mocks__/MockLendProvider.js.map +1 -0
  38. package/dist/{test → lend/__mocks__}/MockMarkets.d.ts +1 -1
  39. package/dist/lend/__mocks__/MockMarkets.d.ts.map +1 -0
  40. package/dist/{test → lend/__mocks__}/MockMarkets.js +1 -1
  41. package/dist/lend/__mocks__/MockMarkets.js.map +1 -0
  42. package/dist/lend/__mocks__/mockLendTransaction.d.ts +3 -12
  43. package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +1 -1
  44. package/dist/lend/__mocks__/mockLendTransaction.js +3 -19
  45. package/dist/lend/__mocks__/mockLendTransaction.js.map +1 -1
  46. package/dist/lend/core/LendProvider.d.ts +14 -8
  47. package/dist/lend/core/LendProvider.d.ts.map +1 -1
  48. package/dist/lend/core/LendProvider.js +29 -17
  49. package/dist/lend/core/LendProvider.js.map +1 -1
  50. package/dist/lend/core/__tests__/LendProvider.test.js +4 -6
  51. package/dist/lend/core/__tests__/LendProvider.test.js.map +1 -1
  52. package/dist/lend/namespaces/ActionsLendNamespace.d.ts +2 -36
  53. package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +1 -1
  54. package/dist/lend/namespaces/ActionsLendNamespace.js +2 -48
  55. package/dist/lend/namespaces/ActionsLendNamespace.js.map +1 -1
  56. package/dist/lend/namespaces/BaseLendNamespace.d.ts +47 -0
  57. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +1 -0
  58. package/dist/lend/namespaces/BaseLendNamespace.js +58 -0
  59. package/dist/lend/namespaces/BaseLendNamespace.js.map +1 -0
  60. package/dist/lend/namespaces/WalletLendNamespace.d.ts +8 -36
  61. package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +1 -1
  62. package/dist/lend/namespaces/WalletLendNamespace.js +14 -69
  63. package/dist/lend/namespaces/WalletLendNamespace.js.map +1 -1
  64. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js +2 -2
  65. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +1 -1
  66. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts +2 -0
  67. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +1 -0
  68. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js +110 -0
  69. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -0
  70. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js +8 -10
  71. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +1 -1
  72. package/dist/lend/providers/aave/AaveLendProvider.d.ts +19 -27
  73. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +1 -1
  74. package/dist/lend/providers/aave/AaveLendProvider.js +124 -180
  75. package/dist/lend/providers/aave/AaveLendProvider.js.map +1 -1
  76. package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts +11 -0
  77. package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +1 -0
  78. package/dist/lend/providers/aave/__mocks__/mockReserve.js +80 -0
  79. package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +1 -0
  80. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts +2 -0
  81. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +1 -0
  82. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js +315 -0
  83. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -0
  84. package/dist/lend/providers/aave/abis/pool.d.ts +153 -0
  85. package/dist/lend/providers/aave/abis/pool.d.ts.map +1 -0
  86. package/dist/lend/providers/aave/abis/pool.js +79 -0
  87. package/dist/lend/providers/aave/abis/pool.js.map +1 -0
  88. package/dist/lend/providers/aave/sdk.d.ts.map +1 -1
  89. package/dist/lend/providers/aave/sdk.js +6 -65
  90. package/dist/lend/providers/aave/sdk.js.map +1 -1
  91. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +0 -1
  92. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -1
  93. package/dist/lend/providers/morpho/MorphoLendProvider.js +13 -28
  94. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -1
  95. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js +5 -24
  96. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +1 -1
  97. package/dist/lend/providers/morpho/__tests__/api.test.js +248 -54
  98. package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -1
  99. package/dist/lend/providers/morpho/__tests__/sdk.test.js +3 -2
  100. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -1
  101. package/dist/lend/providers/morpho/api.d.ts +4 -0
  102. package/dist/lend/providers/morpho/api.d.ts.map +1 -1
  103. package/dist/lend/providers/morpho/api.js.map +1 -1
  104. package/dist/lend/providers/morpho/contracts.d.ts +19 -0
  105. package/dist/lend/providers/morpho/contracts.d.ts.map +1 -0
  106. package/dist/lend/providers/morpho/contracts.js +32 -0
  107. package/dist/lend/providers/morpho/contracts.js.map +1 -0
  108. package/dist/lend/providers/morpho/sdk.d.ts.map +1 -1
  109. package/dist/lend/providers/morpho/sdk.js +177 -71
  110. package/dist/lend/providers/morpho/sdk.js.map +1 -1
  111. package/dist/services/ChainManager.d.ts +1 -1
  112. package/dist/{test → services/__mocks__}/MockChainManager.d.ts +1 -1
  113. package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -0
  114. package/dist/services/__mocks__/MockChainManager.js.map +1 -0
  115. package/dist/services/tokenBalance.d.ts.map +1 -1
  116. package/dist/services/tokenBalance.js +4 -5
  117. package/dist/services/tokenBalance.js.map +1 -1
  118. package/dist/services/tokenBalance.spec.js +2 -2
  119. package/dist/services/tokenBalance.spec.js.map +1 -1
  120. package/dist/supported/tokens.d.ts +4 -4
  121. package/dist/supported/tokens.d.ts.map +1 -1
  122. package/dist/supported/tokens.js +10 -70
  123. package/dist/supported/tokens.js.map +1 -1
  124. package/dist/swap/__mocks__/MockSwapProvider.d.ts +38 -0
  125. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
  126. package/dist/swap/__mocks__/MockSwapProvider.js +138 -0
  127. package/dist/swap/__mocks__/MockSwapProvider.js.map +1 -0
  128. package/dist/swap/core/SwapProvider.d.ts +56 -0
  129. package/dist/swap/core/SwapProvider.d.ts.map +1 -0
  130. package/dist/swap/core/SwapProvider.js +177 -0
  131. package/dist/swap/core/SwapProvider.js.map +1 -0
  132. package/dist/swap/core/__tests__/SwapProvider.test.d.ts +2 -0
  133. package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
  134. package/dist/swap/core/__tests__/SwapProvider.test.js +329 -0
  135. package/dist/swap/core/__tests__/SwapProvider.test.js.map +1 -0
  136. package/dist/swap/index.d.ts +7 -0
  137. package/dist/swap/index.d.ts.map +1 -0
  138. package/dist/swap/index.js +8 -0
  139. package/dist/swap/index.js.map +1 -0
  140. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts +8 -0
  141. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
  142. package/dist/swap/namespaces/ActionsSwapNamespace.js +8 -0
  143. package/dist/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
  144. package/dist/swap/namespaces/BaseSwapNamespace.d.ts +33 -0
  145. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
  146. package/dist/swap/namespaces/BaseSwapNamespace.js +58 -0
  147. package/dist/swap/namespaces/BaseSwapNamespace.js.map +1 -0
  148. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +22 -0
  149. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
  150. package/dist/swap/namespaces/WalletSwapNamespace.js +60 -0
  151. package/dist/swap/namespaces/WalletSwapNamespace.js.map +1 -0
  152. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +2 -0
  153. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
  154. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js +106 -0
  155. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
  156. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +2 -0
  157. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
  158. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js +132 -0
  159. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
  160. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts +68 -0
  161. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
  162. package/dist/swap/providers/uniswap/UniswapSwapProvider.js +206 -0
  163. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
  164. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +2 -0
  165. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
  166. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js +257 -0
  167. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
  168. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts +2 -0
  169. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
  170. package/dist/swap/providers/uniswap/__tests__/sdk.test.js +312 -0
  171. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
  172. package/dist/swap/providers/uniswap/abis.d.ts +227 -0
  173. package/dist/swap/providers/uniswap/abis.d.ts.map +1 -0
  174. package/dist/swap/providers/uniswap/abis.js +138 -0
  175. package/dist/swap/providers/uniswap/abis.js.map +1 -0
  176. package/dist/swap/providers/uniswap/addresses.d.ts +21 -0
  177. package/dist/swap/providers/uniswap/addresses.d.ts.map +1 -0
  178. package/dist/swap/providers/uniswap/addresses.js +81 -0
  179. package/dist/swap/providers/uniswap/addresses.js.map +1 -0
  180. package/dist/swap/providers/uniswap/encoding.d.ts +77 -0
  181. package/dist/swap/providers/uniswap/encoding.d.ts.map +1 -0
  182. package/dist/swap/providers/uniswap/encoding.js +233 -0
  183. package/dist/swap/providers/uniswap/encoding.js.map +1 -0
  184. package/dist/swap/providers/uniswap/types.d.ts +20 -0
  185. package/dist/swap/providers/uniswap/types.d.ts.map +1 -0
  186. package/dist/swap/providers/uniswap/types.js +2 -0
  187. package/dist/swap/providers/uniswap/types.js.map +1 -0
  188. package/dist/types/actions.d.ts +19 -5
  189. package/dist/types/actions.d.ts.map +1 -1
  190. package/dist/types/asset.d.ts +3 -3
  191. package/dist/types/asset.d.ts.map +1 -1
  192. package/dist/types/index.d.ts +2 -0
  193. package/dist/types/index.d.ts.map +1 -1
  194. package/dist/types/index.js +2 -0
  195. package/dist/types/index.js.map +1 -1
  196. package/dist/types/lend/base.d.ts +7 -22
  197. package/dist/types/lend/base.d.ts.map +1 -1
  198. package/dist/types/lend/base.js.map +1 -1
  199. package/dist/types/lend/contracts.d.ts +17 -0
  200. package/dist/types/lend/contracts.d.ts.map +1 -0
  201. package/dist/types/lend/contracts.js +2 -0
  202. package/dist/types/lend/contracts.js.map +1 -0
  203. package/dist/types/lend/index.d.ts +1 -0
  204. package/dist/types/lend/index.d.ts.map +1 -1
  205. package/dist/types/lend/index.js +1 -0
  206. package/dist/types/lend/index.js.map +1 -1
  207. package/dist/types/swap/base.d.ts +238 -0
  208. package/dist/types/swap/base.d.ts.map +1 -0
  209. package/dist/types/swap/base.js +4 -0
  210. package/dist/types/swap/base.js.map +1 -0
  211. package/dist/types/swap/index.d.ts +2 -0
  212. package/dist/types/swap/index.d.ts.map +1 -0
  213. package/dist/types/swap/index.js +2 -0
  214. package/dist/types/swap/index.js.map +1 -0
  215. package/dist/types/transaction.d.ts +14 -0
  216. package/dist/types/transaction.d.ts.map +1 -0
  217. package/dist/types/transaction.js +2 -0
  218. package/dist/types/transaction.js.map +1 -0
  219. package/dist/utils/assets.d.ts +11 -6
  220. package/dist/utils/assets.d.ts.map +1 -1
  221. package/dist/utils/assets.js +16 -12
  222. package/dist/utils/assets.js.map +1 -1
  223. package/dist/utils/assets.test.js +14 -2
  224. package/dist/utils/assets.test.js.map +1 -1
  225. package/dist/utils/constants.d.ts +5 -0
  226. package/dist/utils/constants.d.ts.map +1 -0
  227. package/dist/utils/constants.js +5 -0
  228. package/dist/utils/constants.js.map +1 -0
  229. package/dist/utils/permit2.d.ts +46 -0
  230. package/dist/utils/permit2.d.ts.map +1 -0
  231. package/dist/utils/permit2.js +100 -0
  232. package/dist/utils/permit2.js.map +1 -0
  233. package/dist/utils/permit2.test.d.ts +2 -0
  234. package/dist/utils/permit2.test.d.ts.map +1 -0
  235. package/dist/utils/permit2.test.js +110 -0
  236. package/dist/utils/permit2.test.js.map +1 -0
  237. package/dist/utils/validation.d.ts +12 -0
  238. package/dist/utils/validation.d.ts.map +1 -0
  239. package/dist/utils/validation.js +44 -0
  240. package/dist/utils/validation.js.map +1 -0
  241. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  242. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  243. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +4 -4
  244. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  245. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +4 -4
  246. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
  247. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +7 -1
  248. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -1
  249. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js +2 -1
  250. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -1
  251. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +2 -2
  252. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
  253. package/dist/wallet/core/providers/hosted/types/index.d.ts +5 -1
  254. package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -1
  255. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +7 -1
  256. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -1
  257. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js +5 -1
  258. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -1
  259. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +5 -5
  260. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
  261. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +13 -2
  262. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  263. package/dist/wallet/core/wallets/abstract/Wallet.js +7 -1
  264. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  265. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +2 -2
  266. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  267. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js +2 -2
  268. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js.map +1 -1
  269. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +7 -2
  270. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  271. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +6 -5
  272. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  273. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +3 -3
  274. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  275. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js +1 -1
  276. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js.map +1 -1
  277. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js +1 -1
  278. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js.map +1 -1
  279. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +6 -1
  280. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  281. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js +3 -1
  282. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  283. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +4 -4
  284. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  285. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -1
  286. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +4 -3
  287. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -1
  288. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +2 -2
  289. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  290. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +5 -1
  291. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  292. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +4 -2
  293. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  294. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +2 -2
  295. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  296. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +6 -1
  297. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  298. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js +4 -3
  299. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  300. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +3 -3
  301. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
  302. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +2 -2
  303. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -1
  304. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -1
  305. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  306. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  307. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  308. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -2
  309. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
  310. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +1 -1
  311. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -1
  312. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +7 -1
  313. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -1
  314. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +6 -2
  315. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -1
  316. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.d.ts.map +1 -1
  317. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js +1 -1
  318. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js.map +1 -1
  319. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +6 -2
  320. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
  321. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +6 -1
  322. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -1
  323. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +5 -2
  324. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -1
  325. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.d.ts.map +1 -1
  326. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js +1 -1
  327. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js.map +1 -1
  328. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +3 -2
  329. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  330. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +6 -3
  331. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -1
  332. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +5 -4
  333. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -1
  334. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +2 -2
  335. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  336. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -1
  337. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +6 -6
  338. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -1
  339. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
  340. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  341. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +7 -1
  342. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -1
  343. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +5 -3
  344. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -1
  345. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js +2 -2
  346. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js.map +1 -1
  347. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js +1 -1
  348. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js.map +1 -1
  349. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +5 -1
  350. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -1
  351. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +3 -3
  352. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -1
  353. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +2 -2
  354. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
  355. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +1 -1
  356. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -1
  357. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +5 -1
  358. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -1
  359. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +2 -2
  360. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -1
  361. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -2
  362. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
  363. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +1 -1
  364. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -1
  365. package/package.json +2 -2
  366. package/src/{test → __mocks__}/MockAssets.ts +2 -0
  367. package/src/{test → __mocks__}/MockPrivyClient.ts +1 -1
  368. package/src/{actions.test.ts → __tests__/actions.test.ts} +2 -6
  369. package/src/actions.ts +57 -19
  370. package/src/constants/assets.ts +108 -8
  371. package/src/constants/contracts.ts +5 -0
  372. package/src/constants/supportedChains.ts +10 -2
  373. package/src/core/asset/__mocks__/mockAsset.ts +1 -1
  374. package/src/index.ts +30 -2
  375. package/src/{test → lend/__mocks__}/MockLendProvider.ts +20 -23
  376. package/src/{test → lend/__mocks__}/MockMarkets.ts +1 -1
  377. package/src/lend/__mocks__/mockLendTransaction.ts +4 -26
  378. package/src/lend/core/LendProvider.ts +40 -20
  379. package/src/lend/core/__tests__/LendProvider.test.ts +4 -7
  380. package/src/lend/namespaces/ActionsLendNamespace.ts +2 -85
  381. package/src/lend/namespaces/BaseLendNamespace.ts +89 -0
  382. package/src/lend/namespaces/WalletLendNamespace.ts +25 -121
  383. package/src/lend/namespaces/__tests__/ActionsLendNamespace.spec.ts +10 -9
  384. package/src/lend/namespaces/__tests__/BaseLendNamespace.spec.ts +137 -0
  385. package/src/lend/namespaces/__tests__/WalletLendNamespace.spec.ts +19 -22
  386. package/src/lend/providers/aave/AaveLendProvider.ts +163 -231
  387. package/src/lend/providers/aave/__mocks__/mockReserve.ts +84 -0
  388. package/src/lend/providers/aave/__tests__/AaveLendProvider.test.ts +419 -0
  389. package/src/lend/providers/aave/abis/pool.ts +81 -0
  390. package/src/lend/providers/aave/sdk.ts +7 -69
  391. package/src/lend/providers/morpho/MorphoLendProvider.ts +20 -41
  392. package/src/lend/providers/morpho/__tests__/MorphoLendProvider.test.ts +8 -32
  393. package/src/lend/providers/morpho/__tests__/api.test.ts +277 -51
  394. package/src/lend/providers/morpho/__tests__/sdk.test.ts +3 -2
  395. package/src/lend/providers/morpho/api.ts +4 -0
  396. package/src/lend/providers/morpho/contracts.ts +37 -0
  397. package/src/lend/providers/morpho/sdk.ts +241 -84
  398. package/src/services/tokenBalance.spec.ts +2 -2
  399. package/src/services/tokenBalance.ts +6 -7
  400. package/src/supported/tokens.ts +18 -77
  401. package/src/swap/__mocks__/MockSwapProvider.ts +216 -0
  402. package/src/swap/core/SwapProvider.ts +319 -0
  403. package/src/swap/core/__tests__/SwapProvider.test.ts +478 -0
  404. package/src/swap/index.ts +14 -0
  405. package/src/swap/namespaces/ActionsSwapNamespace.ts +7 -0
  406. package/src/swap/namespaces/BaseSwapNamespace.ts +77 -0
  407. package/src/swap/namespaces/WalletSwapNamespace.ts +82 -0
  408. package/src/swap/namespaces/__tests__/BaseSwapNamespace.spec.ts +138 -0
  409. package/src/swap/namespaces/__tests__/WalletSwapNamespace.spec.ts +162 -0
  410. package/src/swap/providers/uniswap/UniswapSwapProvider.ts +304 -0
  411. package/src/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +299 -0
  412. package/src/swap/providers/uniswap/__tests__/sdk.test.ts +370 -0
  413. package/src/swap/providers/uniswap/abis.ts +144 -0
  414. package/src/swap/providers/uniswap/addresses.ts +108 -0
  415. package/src/swap/providers/uniswap/encoding.ts +406 -0
  416. package/src/swap/providers/uniswap/types.ts +24 -0
  417. package/src/types/actions.ts +22 -6
  418. package/src/types/asset.ts +3 -3
  419. package/src/types/index.ts +2 -0
  420. package/src/types/lend/base.ts +12 -25
  421. package/src/types/lend/contracts.ts +18 -0
  422. package/src/types/lend/index.ts +1 -0
  423. package/src/types/swap/base.ts +259 -0
  424. package/src/types/swap/index.ts +1 -0
  425. package/src/types/transaction.ts +14 -0
  426. package/src/utils/assets.test.ts +17 -2
  427. package/src/utils/assets.ts +28 -11
  428. package/src/utils/constants.ts +4 -0
  429. package/src/utils/permit2.test.ts +142 -0
  430. package/src/utils/permit2.ts +144 -0
  431. package/src/utils/validation.ts +76 -0
  432. package/src/wallet/core/namespace/WalletNamespace.ts +2 -4
  433. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +6 -6
  434. package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +6 -6
  435. package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +9 -1
  436. package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +3 -3
  437. package/src/wallet/core/providers/hosted/types/index.ts +5 -1
  438. package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +13 -1
  439. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +9 -9
  440. package/src/wallet/core/wallets/abstract/Wallet.ts +18 -2
  441. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +2 -2
  442. package/src/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.ts +2 -2
  443. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +14 -5
  444. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +3 -3
  445. package/src/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.ts +1 -1
  446. package/src/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.ts +1 -1
  447. package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +13 -2
  448. package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +5 -5
  449. package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +10 -2
  450. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +3 -3
  451. package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +8 -2
  452. package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +2 -2
  453. package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +11 -2
  454. package/src/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +4 -4
  455. package/src/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +2 -2
  456. package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +10 -2
  457. package/src/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -2
  458. package/src/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +1 -1
  459. package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +10 -2
  460. package/src/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.ts +1 -1
  461. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +9 -5
  462. package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +9 -2
  463. package/src/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.ts +1 -1
  464. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +5 -5
  465. package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +9 -4
  466. package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +2 -2
  467. package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +18 -6
  468. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +5 -7
  469. package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +12 -2
  470. package/src/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.ts +2 -2
  471. package/src/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.ts +1 -1
  472. package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +10 -2
  473. package/src/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +2 -2
  474. package/src/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +1 -1
  475. package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +10 -2
  476. package/src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -2
  477. package/src/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +1 -1
  478. package/dist/actions.test.d.ts.map +0 -1
  479. package/dist/actions.test.js.map +0 -1
  480. package/dist/test/MockAssets.d.ts.map +0 -1
  481. package/dist/test/MockAssets.js.map +0 -1
  482. package/dist/test/MockChainManager.d.ts.map +0 -1
  483. package/dist/test/MockChainManager.js.map +0 -1
  484. package/dist/test/MockLendProvider.d.ts.map +0 -1
  485. package/dist/test/MockLendProvider.js.map +0 -1
  486. package/dist/test/MockMarkets.d.ts.map +0 -1
  487. package/dist/test/MockMarkets.js.map +0 -1
  488. package/dist/test/MockPrivyClient.d.ts.map +0 -1
  489. package/dist/test/MockPrivyClient.js.map +0 -1
  490. package/dist/test/utils.d.ts.map +0 -1
  491. package/dist/test/utils.js.map +0 -1
  492. /package/dist/{test → __mocks__}/MockAssets.d.ts +0 -0
  493. /package/dist/{test → __mocks__}/MockPrivyClient.d.ts +0 -0
  494. /package/dist/{test → __mocks__}/MockPrivyClient.js +0 -0
  495. /package/dist/{test → __mocks__}/utils.d.ts +0 -0
  496. /package/dist/{test → __mocks__}/utils.js +0 -0
  497. /package/dist/{actions.test.d.ts → __tests__/actions.test.d.ts} +0 -0
  498. /package/dist/{test → services/__mocks__}/MockChainManager.js +0 -0
  499. /package/src/{test → __mocks__}/utils.ts +0 -0
  500. /package/src/{test → services/__mocks__}/MockChainManager.ts +0 -0
@@ -0,0 +1,216 @@
1
+ import type { Address } from 'viem'
2
+ import { type MockedFunction, vi } from 'vitest'
3
+
4
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
5
+ import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
6
+ import type { ChainManager } from '@/services/ChainManager.js'
7
+ import { SwapProvider } from '@/swap/core/SwapProvider.js'
8
+ import type {
9
+ GetSwapMarketParams,
10
+ GetSwapMarketsParams,
11
+ ResolvedSwapParams,
12
+ SwapMarket,
13
+ SwapPrice,
14
+ SwapPriceParams,
15
+ SwapProviderConfig,
16
+ SwapTransaction,
17
+ } from '@/types/swap/index.js'
18
+
19
+ export interface MockSwapProviderConfig {
20
+ supportedChains: SupportedChainId[]
21
+ defaultPrice: string
22
+ defaultPriceImpact: number
23
+ }
24
+
25
+ /**
26
+ * Mock Swap Provider for testing
27
+ */
28
+ export class MockSwapProvider extends SwapProvider<SwapProviderConfig> {
29
+ public mockExecute: MockedFunction<
30
+ (params: ResolvedSwapParams) => Promise<SwapTransaction>
31
+ >
32
+ public mockGetPrice: MockedFunction<
33
+ (params: SwapPriceParams) => Promise<SwapPrice>
34
+ >
35
+ public mockGetMarket: MockedFunction<
36
+ (params: GetSwapMarketParams) => Promise<SwapMarket>
37
+ >
38
+ public mockGetMarkets: MockedFunction<
39
+ (params: GetSwapMarketsParams) => Promise<SwapMarket[]>
40
+ >
41
+
42
+ private _supportedChains: SupportedChainId[]
43
+ private mockProviderConfig: MockSwapProviderConfig
44
+
45
+ constructor(
46
+ config?: SwapProviderConfig,
47
+ mockConfig?: Partial<MockSwapProviderConfig>,
48
+ chainManager?: ChainManager,
49
+ ) {
50
+ super(
51
+ config || {},
52
+ chainManager || (new MockChainManager() as unknown as ChainManager),
53
+ )
54
+
55
+ this._supportedChains = mockConfig?.supportedChains ?? [
56
+ 84532 as SupportedChainId,
57
+ ]
58
+ this.mockProviderConfig = {
59
+ supportedChains: this._supportedChains,
60
+ defaultPrice: mockConfig?.defaultPrice ?? '1.5',
61
+ defaultPriceImpact: mockConfig?.defaultPriceImpact ?? 0.001,
62
+ }
63
+
64
+ // Create mocked functions
65
+ this.mockExecute = vi
66
+ .fn()
67
+ .mockImplementation(this.createMockSwapTransaction.bind(this))
68
+ this.mockGetPrice = vi
69
+ .fn()
70
+ .mockImplementation(this.createMockPrice.bind(this))
71
+ this.mockGetMarket = vi
72
+ .fn()
73
+ .mockImplementation(this.createMockMarket.bind(this))
74
+ this.mockGetMarkets = vi
75
+ .fn()
76
+ .mockImplementation(this.createMockMarkets.bind(this))
77
+ }
78
+
79
+ supportedChainIds(): SupportedChainId[] {
80
+ return this._supportedChains
81
+ }
82
+
83
+ reset(): void {
84
+ vi.clearAllMocks()
85
+ }
86
+
87
+ // Expose protected methods for testing
88
+ public testValidateMarketAllowed(
89
+ assetIn: any,
90
+ assetOut: any,
91
+ chainId: SupportedChainId,
92
+ ): void {
93
+ return this.validateMarketAllowed(assetIn, assetOut, chainId)
94
+ }
95
+
96
+ protected async _execute(
97
+ params: ResolvedSwapParams,
98
+ ): Promise<SwapTransaction> {
99
+ return this.mockExecute(params)
100
+ }
101
+
102
+ protected async _getPrice(params: SwapPriceParams): Promise<SwapPrice> {
103
+ return this.mockGetPrice(params)
104
+ }
105
+
106
+ protected async _getMarket(params: GetSwapMarketParams): Promise<SwapMarket> {
107
+ return this.mockGetMarket(params)
108
+ }
109
+
110
+ protected async _getMarkets(
111
+ params: GetSwapMarketsParams,
112
+ ): Promise<SwapMarket[]> {
113
+ return this.mockGetMarkets(params)
114
+ }
115
+
116
+ private createMockSwapTransaction(
117
+ params: ResolvedSwapParams,
118
+ ): SwapTransaction {
119
+ const amountIn = params.amountInWei ?? 1000000n
120
+ const amountOut = 1500000000000000000n
121
+
122
+ return {
123
+ amountIn: 1.0,
124
+ amountOut: 1.5,
125
+ amountInWei: amountIn,
126
+ amountOutWei: amountOut,
127
+ assetIn: params.assetIn,
128
+ assetOut: params.assetOut,
129
+ price: this.mockProviderConfig.defaultPrice,
130
+ priceImpact: this.mockProviderConfig.defaultPriceImpact,
131
+ transactionData: {
132
+ swap: {
133
+ to: '0x492e6456d9528771018deb9e87ef7750ef184104' as Address,
134
+ data: '0x1234' as `0x${string}`,
135
+ value: 0n,
136
+ },
137
+ },
138
+ }
139
+ }
140
+
141
+ private createMockPrice(params: SwapPriceParams): SwapPrice {
142
+ const amountIn =
143
+ params.amountIn !== undefined
144
+ ? BigInt(
145
+ Math.floor(
146
+ params.amountIn * 10 ** params.assetIn.metadata.decimals,
147
+ ),
148
+ )
149
+ : BigInt(10 ** params.assetIn.metadata.decimals)
150
+
151
+ const amountOut = (amountIn * 15n) / 10n
152
+
153
+ return {
154
+ price: this.mockProviderConfig.defaultPrice,
155
+ priceInverse: '0.666666',
156
+ amountIn: 1.0,
157
+ amountOut: 1.5,
158
+ amountInWei: amountIn,
159
+ amountOutWei: amountOut,
160
+ priceImpact: this.mockProviderConfig.defaultPriceImpact,
161
+ route: {
162
+ path: [params.assetIn, params.assetOut!],
163
+ pools: [
164
+ {
165
+ address: '0x1234' as Address,
166
+ fee: 500,
167
+ version: 'v4',
168
+ },
169
+ ],
170
+ },
171
+ gasEstimate: 150000n,
172
+ }
173
+ }
174
+
175
+ private createMockMarket(params: GetSwapMarketParams): SwapMarket {
176
+ return {
177
+ marketId: {
178
+ poolId: params.poolId,
179
+ chainId: params.chainId,
180
+ },
181
+ assets: [
182
+ {
183
+ type: 'erc20',
184
+ address: { [params.chainId]: '0x1111' as Address },
185
+ metadata: { name: 'USDC', symbol: 'USDC', decimals: 6 },
186
+ },
187
+ {
188
+ type: 'erc20',
189
+ address: { [params.chainId]: '0x2222' as Address },
190
+ metadata: { name: 'WETH', symbol: 'WETH', decimals: 18 },
191
+ },
192
+ ],
193
+ fee: 500,
194
+ provider: 'uniswap',
195
+ }
196
+ }
197
+
198
+ private createMockMarkets(_params: GetSwapMarketsParams): SwapMarket[] {
199
+ return [
200
+ this.createMockMarket({
201
+ poolId: '0xpool1',
202
+ chainId: 84532 as SupportedChainId,
203
+ }),
204
+ ]
205
+ }
206
+ }
207
+
208
+ /**
209
+ * Create a mock swap provider
210
+ */
211
+ export function createMockSwapProvider(
212
+ config?: SwapProviderConfig,
213
+ mockConfig?: Partial<MockSwapProviderConfig>,
214
+ ): MockSwapProvider {
215
+ return new MockSwapProvider(config, mockConfig)
216
+ }
@@ -0,0 +1,319 @@
1
+ import type { Address } from 'viem'
2
+
3
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
4
+ import type { ChainManager } from '@/services/ChainManager.js'
5
+ import type { Asset } from '@/types/asset.js'
6
+ import type {
7
+ GetSwapMarketParams,
8
+ GetSwapMarketsParams,
9
+ ResolvedSwapParams,
10
+ SwapExecuteParams,
11
+ SwapMarket,
12
+ SwapMarketConfig,
13
+ SwapPrice,
14
+ SwapPriceParams,
15
+ SwapProviderConfig,
16
+ SwapTransaction,
17
+ } from '@/types/swap/index.js'
18
+ import type { TransactionData } from '@/types/transaction.js'
19
+ import {
20
+ getAssetAddress,
21
+ isNativeAsset,
22
+ parseAssetAmount,
23
+ } from '@/utils/assets.js'
24
+ import {
25
+ buildPermit2ApprovalTx,
26
+ buildTokenApprovalTx,
27
+ checkPermit2Allowance,
28
+ checkTokenAllowance,
29
+ } from '@/utils/permit2.js'
30
+ import {
31
+ validateAmountPositiveIfExists,
32
+ validateAmountProvided,
33
+ validateAssetOnChain,
34
+ validateChainSupported,
35
+ validateNotBothAmounts,
36
+ validateNotSameAsset,
37
+ validateNotZeroAddress,
38
+ validateSlippage,
39
+ } from '@/utils/validation.js'
40
+
41
+ const DEFAULT_SLIPPAGE = 0.005
42
+ const DEFAULT_DEADLINE_OFFSET = 60
43
+ const DEFAULT_MAX_SLIPPAGE = 0.5
44
+
45
+ /**
46
+ * Abstract base class for swap providers.
47
+ * Public methods handle validation and conversion,
48
+ * protected abstract methods implement provider-specific logic.
49
+ */
50
+ export abstract class SwapProvider<
51
+ TConfig extends SwapProviderConfig = SwapProviderConfig,
52
+ > {
53
+ protected readonly _config: TConfig
54
+ protected readonly chainManager: ChainManager
55
+
56
+ constructor(config: TConfig, chainManager: ChainManager) {
57
+ this._config = config
58
+ this.chainManager = chainManager
59
+ }
60
+
61
+ get config(): TConfig {
62
+ return this._config
63
+ }
64
+
65
+ get defaultSlippage(): number {
66
+ return this._config.defaultSlippage ?? DEFAULT_SLIPPAGE
67
+ }
68
+
69
+ /**
70
+ * Execute a token swap
71
+ * @param params - Swap parameters including assets, amounts, and chain
72
+ * @returns Swap transaction data ready for execution
73
+ */
74
+ async execute(params: SwapExecuteParams): Promise<SwapTransaction> {
75
+ this.executeValidations(params)
76
+ const resolvedParams = this.resolveParams(params)
77
+ validateSlippage(
78
+ resolvedParams.slippage,
79
+ this._config.maxSlippage ?? DEFAULT_MAX_SLIPPAGE,
80
+ )
81
+ return this._execute(resolvedParams)
82
+ }
83
+
84
+ /** Get price quote for a swap */
85
+ async getPrice(params: SwapPriceParams): Promise<SwapPrice> {
86
+ validateChainSupported(params.chainId, this.supportedChainIds())
87
+ return this._getPrice(params)
88
+ }
89
+
90
+ /** Get a specific swap market by ID */
91
+ async getMarket(params: GetSwapMarketParams): Promise<SwapMarket> {
92
+ validateChainSupported(params.chainId, this.supportedChainIds())
93
+ return this._getMarket(params)
94
+ }
95
+
96
+ /** Get available swap markets, optionally filtered by chainId or asset */
97
+ async getMarkets(params: GetSwapMarketsParams = {}): Promise<SwapMarket[]> {
98
+ if (params.chainId) {
99
+ validateChainSupported(params.chainId, this.supportedChainIds())
100
+ }
101
+ return this._getMarkets(params)
102
+ }
103
+
104
+ isChainSupported(chainId: SupportedChainId): boolean {
105
+ return this.supportedChainIds().includes(chainId)
106
+ }
107
+
108
+ // ─────────────────────────────────────────────────────────────────────────────
109
+ // Protected helpers
110
+ // ─────────────────────────────────────────────────────────────────────────────
111
+
112
+ protected validateMarketAllowed(
113
+ assetIn: Asset,
114
+ assetOut: Asset,
115
+ chainId: SupportedChainId,
116
+ ): void {
117
+ const { marketBlocklist, marketAllowlist } = this._config
118
+
119
+ if (marketBlocklist?.length) {
120
+ const isBlocked = this.findMatchingConfig(
121
+ assetIn,
122
+ assetOut,
123
+ chainId,
124
+ marketBlocklist,
125
+ )
126
+ if (isBlocked) {
127
+ throw new Error(
128
+ `Pair ${assetIn.metadata.symbol}/${assetOut.metadata.symbol} is blocked on chain ${chainId}`,
129
+ )
130
+ }
131
+ }
132
+
133
+ if (marketAllowlist?.length) {
134
+ const isAllowed = this.findMatchingConfig(
135
+ assetIn,
136
+ assetOut,
137
+ chainId,
138
+ marketAllowlist,
139
+ )
140
+ if (!isAllowed) {
141
+ throw new Error(
142
+ `Pair ${assetIn.metadata.symbol}/${assetOut.metadata.symbol} is not in the allowlist for chain ${chainId}`,
143
+ )
144
+ }
145
+ }
146
+ }
147
+
148
+ protected resolveMarketConfig(
149
+ assetIn: Asset,
150
+ assetOut: Asset,
151
+ chainId: SupportedChainId,
152
+ ): SwapMarketConfig | undefined {
153
+ const { marketAllowlist } = this._config
154
+ if (!marketAllowlist?.length) {
155
+ throw new Error(
156
+ 'No markets configured. Provide a marketAllowlist in swap provider config.',
157
+ )
158
+ }
159
+ return this.findMatchingConfig(assetIn, assetOut, chainId, marketAllowlist)
160
+ }
161
+
162
+ /**
163
+ * Build Permit2 approval transactions for an ERC20 swap input.
164
+ * Skipped for native assets. Checks both ERC20→Permit2 and Permit2→spender allowances in parallel.
165
+ * @param params - Resolved swap params (wallet address, asset info, chain)
166
+ * @param requiredAmount - Amount in wei that must be approved
167
+ * @param permit2Address - Permit2 contract address
168
+ * @param permit2Spender - The router/contract that Permit2 should approve (e.g. Universal Router)
169
+ * @param permit2ExpirySeconds - Optional custom expiry for the Permit2 approval
170
+ */
171
+ protected async buildPermit2Approvals(
172
+ params: ResolvedSwapParams,
173
+ requiredAmount: bigint,
174
+ permit2Address: Address,
175
+ permit2Spender: Address,
176
+ permit2ExpirySeconds?: number,
177
+ ): Promise<{
178
+ tokenApproval: TransactionData | undefined
179
+ permit2Approval: TransactionData | undefined
180
+ }> {
181
+ if (isNativeAsset(params.assetIn)) {
182
+ return { tokenApproval: undefined, permit2Approval: undefined }
183
+ }
184
+
185
+ const publicClient = this.chainManager.getPublicClient(params.chainId)
186
+ const token = getAssetAddress(params.assetIn, params.chainId)
187
+
188
+ const [tokenAllowance, permit2Allowance] = await Promise.all([
189
+ checkTokenAllowance({
190
+ publicClient,
191
+ token,
192
+ owner: params.walletAddress,
193
+ spender: permit2Address,
194
+ }),
195
+ checkPermit2Allowance({
196
+ publicClient,
197
+ permit2Address,
198
+ owner: params.walletAddress,
199
+ token,
200
+ spender: permit2Spender,
201
+ }),
202
+ ])
203
+
204
+ const tokenApproval =
205
+ tokenAllowance < requiredAmount
206
+ ? buildTokenApprovalTx(token, permit2Address)
207
+ : undefined
208
+
209
+ // Permit2 expiration is in Unix seconds (matching EVM block.timestamp)
210
+ const permit2Expired =
211
+ permit2Allowance.expiration < Math.floor(Date.now() / 1000)
212
+ const permit2Approval =
213
+ permit2Allowance.amount < requiredAmount || permit2Expired
214
+ ? buildPermit2ApprovalTx({
215
+ permit2Address,
216
+ token,
217
+ spender: permit2Spender,
218
+ amount: requiredAmount,
219
+ expirySeconds: permit2ExpirySeconds,
220
+ })
221
+ : undefined
222
+
223
+ return { tokenApproval, permit2Approval }
224
+ }
225
+
226
+ // ─────────────────────────────────────────────────────────────────────────────
227
+ // Private helpers
228
+ // ─────────────────────────────────────────────────────────────────────────────
229
+
230
+ private executeValidations(params: SwapExecuteParams): void {
231
+ validateAmountProvided(params.amountIn, params.amountOut)
232
+ validateAmountPositiveIfExists(params.amountIn)
233
+ validateAmountPositiveIfExists(params.amountOut)
234
+ validateNotBothAmounts(params.amountIn, params.amountOut)
235
+ validateNotSameAsset(params.assetIn, params.assetOut)
236
+ validateNotZeroAddress(params.walletAddress, 'walletAddress')
237
+ if (params.recipient) {
238
+ validateNotZeroAddress(params.recipient, 'recipient')
239
+ }
240
+ validateChainSupported(params.chainId, this.supportedChainIds())
241
+ this.validateMarketAllowed(params.assetIn, params.assetOut, params.chainId)
242
+ validateAssetOnChain(params.assetIn, params.chainId)
243
+ validateAssetOnChain(params.assetOut, params.chainId)
244
+ }
245
+
246
+ private resolveParams(params: SwapExecuteParams): ResolvedSwapParams {
247
+ return {
248
+ amountInWei: parseAssetAmount(params.assetIn, params.amountIn),
249
+ amountOutWei: parseAssetAmount(params.assetOut, params.amountOut),
250
+ assetIn: params.assetIn,
251
+ assetOut: params.assetOut,
252
+ slippage: params.slippage ?? this.defaultSlippage,
253
+ deadline:
254
+ params.deadline ??
255
+ Math.floor(Date.now() / 1000) + DEFAULT_DEADLINE_OFFSET,
256
+ // Send output tokens to specified recipient, or back to the initiating wallet
257
+ recipient: params.recipient ?? params.walletAddress,
258
+ walletAddress: params.walletAddress,
259
+ chainId: params.chainId,
260
+ }
261
+ }
262
+
263
+ private findMatchingConfig(
264
+ assetIn: Asset,
265
+ assetOut: Asset,
266
+ chainId: SupportedChainId,
267
+ list: SwapMarketConfig[],
268
+ ): SwapMarketConfig | undefined {
269
+ const addressIn = assetIn.address[chainId]
270
+ const addressOut = assetOut.address[chainId]
271
+ if (!addressIn || !addressOut) return undefined
272
+
273
+ return list.find((config) => {
274
+ if (config.chainId !== undefined && config.chainId !== chainId)
275
+ return false
276
+ return this.containsPairByAddress(
277
+ addressIn,
278
+ addressOut,
279
+ chainId,
280
+ config.assets,
281
+ )
282
+ })
283
+ }
284
+
285
+ private containsPairByAddress(
286
+ addressIn: string,
287
+ addressOut: string,
288
+ chainId: SupportedChainId,
289
+ assets: Asset[],
290
+ ): boolean {
291
+ const addresses = assets
292
+ .map((a) => a.address[chainId]?.toLowerCase())
293
+ .filter(Boolean)
294
+ return (
295
+ addresses.includes(addressIn.toLowerCase()) &&
296
+ addresses.includes(addressOut.toLowerCase())
297
+ )
298
+ }
299
+
300
+ // ─────────────────────────────────────────────────────────────────────────────
301
+ // Abstract methods (implement in provider)
302
+ // ─────────────────────────────────────────────────────────────────────────────
303
+
304
+ abstract supportedChainIds(): SupportedChainId[]
305
+
306
+ protected abstract _execute(
307
+ params: ResolvedSwapParams,
308
+ ): Promise<SwapTransaction>
309
+
310
+ protected abstract _getPrice(params: SwapPriceParams): Promise<SwapPrice>
311
+
312
+ protected abstract _getMarket(
313
+ params: GetSwapMarketParams,
314
+ ): Promise<SwapMarket>
315
+
316
+ protected abstract _getMarkets(
317
+ params: GetSwapMarketsParams,
318
+ ): Promise<SwapMarket[]>
319
+ }