@eth-optimism/actions-sdk 0.5.0 → 0.6.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 (778) hide show
  1. package/dist/__tests__/actions.test.js +1 -1
  2. package/dist/__tests__/actions.test.js.map +1 -1
  3. package/dist/{lend → actions/lend}/__mocks__/MockLendProvider.d.ts +6 -6
  4. package/dist/actions/lend/__mocks__/MockLendProvider.d.ts.map +1 -0
  5. package/dist/{lend → actions/lend}/__mocks__/MockLendProvider.js +20 -7
  6. package/dist/actions/lend/__mocks__/MockLendProvider.js.map +1 -0
  7. package/dist/{lend → actions/lend}/__mocks__/MockMarkets.d.ts +1 -1
  8. package/dist/actions/lend/__mocks__/MockMarkets.d.ts.map +1 -0
  9. package/dist/{lend → actions/lend}/__mocks__/MockMarkets.js +1 -1
  10. package/dist/actions/lend/__mocks__/MockMarkets.js.map +1 -0
  11. package/dist/{lend → actions/lend}/__mocks__/mockLendTransaction.d.ts +2 -2
  12. package/dist/actions/lend/__mocks__/mockLendTransaction.d.ts.map +1 -0
  13. package/dist/{lend → actions/lend}/__mocks__/mockLendTransaction.js +1 -1
  14. package/dist/actions/lend/__mocks__/mockLendTransaction.js.map +1 -0
  15. package/dist/{lend → actions/lend}/core/LendProvider.d.ts +38 -22
  16. package/dist/actions/lend/core/LendProvider.d.ts.map +1 -0
  17. package/dist/{lend → actions/lend}/core/LendProvider.js +61 -22
  18. package/dist/actions/lend/core/LendProvider.js.map +1 -0
  19. package/dist/actions/lend/core/__tests__/LendProvider.test.d.ts.map +1 -0
  20. package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.js +57 -3
  21. package/dist/actions/lend/core/__tests__/LendProvider.test.js.map +1 -0
  22. package/dist/actions/lend/index.d.ts.map +1 -0
  23. package/dist/actions/lend/index.js.map +1 -0
  24. package/dist/actions/lend/namespaces/ActionsLendNamespace.d.ts.map +1 -0
  25. package/dist/actions/lend/namespaces/ActionsLendNamespace.js.map +1 -0
  26. package/dist/actions/lend/namespaces/BaseLendNamespace.d.ts +33 -0
  27. package/dist/actions/lend/namespaces/BaseLendNamespace.d.ts.map +1 -0
  28. package/dist/{lend → actions/lend}/namespaces/BaseLendNamespace.js +11 -24
  29. package/dist/actions/lend/namespaces/BaseLendNamespace.js.map +1 -0
  30. package/dist/{lend → actions/lend}/namespaces/WalletLendNamespace.d.ts +8 -11
  31. package/dist/actions/lend/namespaces/WalletLendNamespace.d.ts.map +1 -0
  32. package/dist/{lend → actions/lend}/namespaces/WalletLendNamespace.js +13 -15
  33. package/dist/actions/lend/namespaces/WalletLendNamespace.js.map +1 -0
  34. package/dist/actions/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +1 -0
  35. package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.js +1 -1
  36. package/dist/actions/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +1 -0
  37. package/dist/actions/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +1 -0
  38. package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.js +2 -2
  39. package/dist/actions/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +1 -0
  40. package/dist/actions/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +1 -0
  41. package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.js +5 -5
  42. package/dist/actions/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +1 -0
  43. package/dist/{lend → actions/lend}/providers/aave/AaveLendProvider.d.ts +18 -20
  44. package/dist/actions/lend/providers/aave/AaveLendProvider.d.ts.map +1 -0
  45. package/dist/{lend → actions/lend}/providers/aave/AaveLendProvider.js +56 -54
  46. package/dist/actions/lend/providers/aave/AaveLendProvider.js.map +1 -0
  47. package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.d.ts +1 -1
  48. package/dist/actions/lend/providers/aave/__mocks__/mockReserve.d.ts.map +1 -0
  49. package/dist/actions/lend/providers/aave/__mocks__/mockReserve.js.map +1 -0
  50. package/dist/actions/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +1 -0
  51. package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.js +4 -4
  52. package/dist/actions/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +1 -0
  53. package/dist/actions/lend/providers/aave/abis/pool.d.ts.map +1 -0
  54. package/dist/actions/lend/providers/aave/abis/pool.js.map +1 -0
  55. package/dist/actions/lend/providers/aave/addresses.d.ts.map +1 -0
  56. package/dist/actions/lend/providers/aave/addresses.js.map +1 -0
  57. package/dist/{lend → actions/lend}/providers/aave/sdk.d.ts +4 -4
  58. package/dist/actions/lend/providers/aave/sdk.d.ts.map +1 -0
  59. package/dist/{lend → actions/lend}/providers/aave/sdk.js +10 -5
  60. package/dist/actions/lend/providers/aave/sdk.js.map +1 -0
  61. package/dist/{lend → actions/lend}/providers/morpho/MorphoLendProvider.d.ts +18 -14
  62. package/dist/actions/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -0
  63. package/dist/{lend → actions/lend}/providers/morpho/MorphoLendProvider.js +48 -44
  64. package/dist/actions/lend/providers/morpho/MorphoLendProvider.js.map +1 -0
  65. package/dist/actions/lend/providers/morpho/__mocks__/mockVault.d.ts.map +1 -0
  66. package/dist/actions/lend/providers/morpho/__mocks__/mockVault.js.map +1 -0
  67. package/dist/actions/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +1 -0
  68. package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.js +58 -3
  69. package/dist/actions/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +1 -0
  70. package/dist/actions/lend/providers/morpho/__tests__/api.test.d.ts.map +1 -0
  71. package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.js +2 -2
  72. package/dist/actions/lend/providers/morpho/__tests__/api.test.js.map +1 -0
  73. package/dist/actions/lend/providers/morpho/__tests__/sdk.test.d.ts.map +1 -0
  74. package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.js +1 -1
  75. package/dist/actions/lend/providers/morpho/__tests__/sdk.test.js.map +1 -0
  76. package/dist/actions/lend/providers/morpho/api.d.ts.map +1 -0
  77. package/dist/actions/lend/providers/morpho/api.js.map +1 -0
  78. package/dist/{lend → actions/lend}/providers/morpho/sdk.d.ts +4 -4
  79. package/dist/actions/lend/providers/morpho/sdk.d.ts.map +1 -0
  80. package/dist/{lend → actions/lend}/providers/morpho/sdk.js +18 -7
  81. package/dist/actions/lend/providers/morpho/sdk.js.map +1 -0
  82. package/dist/actions/lend/utils/markets.d.ts +26 -0
  83. package/dist/actions/lend/utils/markets.d.ts.map +1 -0
  84. package/dist/actions/lend/utils/markets.js +44 -0
  85. package/dist/actions/lend/utils/markets.js.map +1 -0
  86. package/dist/actions/shared/BaseNamespace.d.ts +29 -0
  87. package/dist/actions/shared/BaseNamespace.d.ts.map +1 -0
  88. package/dist/actions/shared/BaseNamespace.js +31 -0
  89. package/dist/actions/shared/BaseNamespace.js.map +1 -0
  90. package/dist/actions/shared/__tests__/BaseNamespace.spec.d.ts +2 -0
  91. package/dist/actions/shared/__tests__/BaseNamespace.spec.d.ts.map +1 -0
  92. package/dist/actions/shared/__tests__/BaseNamespace.spec.js +42 -0
  93. package/dist/actions/shared/__tests__/BaseNamespace.spec.js.map +1 -0
  94. package/dist/{lend/providers → actions/shared}/morpho/contracts.d.ts +1 -1
  95. package/dist/actions/shared/morpho/contracts.d.ts.map +1 -0
  96. package/dist/{lend/providers → actions/shared}/morpho/contracts.js.map +1 -1
  97. package/dist/{types/lend/contracts.d.ts → actions/shared/morpho/types.d.ts} +2 -2
  98. package/dist/actions/shared/morpho/types.d.ts.map +1 -0
  99. package/dist/actions/shared/morpho/types.js.map +1 -0
  100. package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.d.ts +7 -6
  101. package/dist/actions/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
  102. package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.js +5 -2
  103. package/dist/actions/swap/__mocks__/MockSwapProvider.js.map +1 -0
  104. package/dist/{swap → actions/swap}/core/SwapProvider.d.ts +29 -14
  105. package/dist/actions/swap/core/SwapProvider.d.ts.map +1 -0
  106. package/dist/{swap → actions/swap}/core/SwapProvider.js +57 -38
  107. package/dist/actions/swap/core/SwapProvider.js.map +1 -0
  108. package/dist/actions/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
  109. package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.js +39 -0
  110. package/dist/actions/swap/core/__tests__/SwapProvider.test.js.map +1 -0
  111. package/dist/{swap → actions/swap}/core/markets.d.ts +3 -3
  112. package/dist/actions/swap/core/markets.d.ts.map +1 -0
  113. package/dist/{swap → actions/swap}/core/markets.js +2 -1
  114. package/dist/actions/swap/core/markets.js.map +1 -0
  115. package/dist/actions/swap/index.d.ts.map +1 -0
  116. package/dist/actions/swap/index.js.map +1 -0
  117. package/dist/actions/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
  118. package/dist/actions/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
  119. package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.d.ts +25 -28
  120. package/dist/actions/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
  121. package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.js +58 -59
  122. package/dist/actions/swap/namespaces/BaseSwapNamespace.js.map +1 -0
  123. package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts +56 -0
  124. package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
  125. package/dist/{swap → actions/swap}/namespaces/WalletSwapNamespace.js +43 -23
  126. package/dist/actions/swap/namespaces/WalletSwapNamespace.js.map +1 -0
  127. package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
  128. package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.js +2 -2
  129. package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
  130. package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
  131. package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.js +83 -19
  132. package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
  133. package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.d.ts +8 -5
  134. package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
  135. package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.js +14 -5
  136. package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
  137. package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
  138. package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.js +1 -1
  139. package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
  140. package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
  141. package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.js +47 -1
  142. package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
  143. package/dist/actions/swap/providers/uniswap/abis.d.ts.map +1 -0
  144. package/dist/actions/swap/providers/uniswap/abis.js.map +1 -0
  145. package/dist/{swap → actions/swap}/providers/uniswap/addresses.d.ts +1 -1
  146. package/dist/actions/swap/providers/uniswap/addresses.d.ts.map +1 -0
  147. package/dist/{swap → actions/swap}/providers/uniswap/addresses.js +6 -2
  148. package/dist/actions/swap/providers/uniswap/addresses.js.map +1 -0
  149. package/dist/{swap → actions/swap}/providers/uniswap/encoding.d.ts +3 -3
  150. package/dist/actions/swap/providers/uniswap/encoding.d.ts.map +1 -0
  151. package/dist/{swap → actions/swap}/providers/uniswap/encoding.js +2 -2
  152. package/dist/actions/swap/providers/uniswap/encoding.js.map +1 -0
  153. package/dist/{swap → actions/swap}/providers/uniswap/markets.d.ts +3 -3
  154. package/dist/actions/swap/providers/uniswap/markets.d.ts.map +1 -0
  155. package/dist/{swap → actions/swap}/providers/uniswap/markets.js +1 -1
  156. package/dist/actions/swap/providers/uniswap/markets.js.map +1 -0
  157. package/dist/{swap → actions/swap}/providers/uniswap/types.d.ts +1 -1
  158. package/dist/actions/swap/providers/uniswap/types.d.ts.map +1 -0
  159. package/dist/actions/swap/providers/uniswap/types.js.map +1 -0
  160. package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.d.ts +9 -4
  161. package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
  162. package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.js +37 -11
  163. package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
  164. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
  165. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
  166. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
  167. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +7 -6
  168. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
  169. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
  170. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +39 -4
  171. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
  172. package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
  173. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.js +22 -1
  174. package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
  175. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.d.ts +1 -1
  176. package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
  177. package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
  178. package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
  179. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.js +25 -1
  180. package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
  181. package/dist/actions/swap/providers/velodrome/abis.d.ts.map +1 -0
  182. package/dist/actions/swap/providers/velodrome/abis.js.map +1 -0
  183. package/dist/{swap → actions/swap}/providers/velodrome/addresses.d.ts +1 -1
  184. package/dist/actions/swap/providers/velodrome/addresses.d.ts.map +1 -0
  185. package/dist/actions/swap/providers/velodrome/addresses.js.map +1 -0
  186. package/dist/{swap → actions/swap}/providers/velodrome/config.d.ts +1 -1
  187. package/dist/actions/swap/providers/velodrome/config.d.ts.map +1 -0
  188. package/dist/{swap → actions/swap}/providers/velodrome/config.js +5 -1
  189. package/dist/actions/swap/providers/velodrome/config.js.map +1 -0
  190. package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.d.ts +3 -3
  191. package/dist/actions/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
  192. package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.js +4 -3
  193. package/dist/actions/swap/providers/velodrome/encoding/helpers.js.map +1 -0
  194. package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.d.ts +0 -1
  195. package/dist/actions/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
  196. package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.js +0 -1
  197. package/dist/actions/swap/providers/velodrome/encoding/index.js.map +1 -0
  198. package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.d.ts +3 -3
  199. package/dist/actions/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
  200. package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.js +2 -1
  201. package/dist/actions/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
  202. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.d.ts +24 -3
  203. package/dist/actions/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
  204. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.js +22 -10
  205. package/dist/actions/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
  206. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.d.ts +23 -3
  207. package/dist/actions/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
  208. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.js +24 -13
  209. package/dist/actions/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
  210. package/dist/{swap → actions/swap}/providers/velodrome/markets.d.ts +3 -3
  211. package/dist/actions/swap/providers/velodrome/markets.d.ts.map +1 -0
  212. package/dist/{swap → actions/swap}/providers/velodrome/markets.js +4 -3
  213. package/dist/actions/swap/providers/velodrome/markets.js.map +1 -0
  214. package/dist/{swap → actions/swap}/providers/velodrome/types.d.ts +1 -1
  215. package/dist/actions/swap/providers/velodrome/types.d.ts.map +1 -0
  216. package/dist/actions/swap/providers/velodrome/types.js +2 -0
  217. package/dist/actions/swap/providers/velodrome/types.js.map +1 -0
  218. package/dist/actions.d.ts +4 -3
  219. package/dist/actions.d.ts.map +1 -1
  220. package/dist/actions.js +45 -22
  221. package/dist/actions.js.map +1 -1
  222. package/dist/core/error/__tests__/errors.test.d.ts +2 -0
  223. package/dist/core/error/__tests__/errors.test.d.ts.map +1 -0
  224. package/dist/core/error/__tests__/errors.test.js +195 -0
  225. package/dist/core/error/__tests__/errors.test.js.map +1 -0
  226. package/dist/core/error/errors.d.ts +131 -15
  227. package/dist/core/error/errors.d.ts.map +1 -1
  228. package/dist/core/error/errors.js +201 -17
  229. package/dist/core/error/errors.js.map +1 -1
  230. package/dist/index.d.ts +7 -5
  231. package/dist/index.d.ts.map +1 -1
  232. package/dist/index.js +6 -4
  233. package/dist/index.js.map +1 -1
  234. package/dist/services/ChainManager.d.ts.map +1 -1
  235. package/dist/services/ChainManager.js +26 -7
  236. package/dist/services/ChainManager.js.map +1 -1
  237. package/dist/services/__tests__/ChainManager.spec.d.ts.map +1 -0
  238. package/dist/services/{ChainManager.spec.js → __tests__/ChainManager.spec.js} +7 -7
  239. package/dist/services/__tests__/ChainManager.spec.js.map +1 -0
  240. package/dist/services/__tests__/tokenBalance.spec.d.ts.map +1 -0
  241. package/dist/services/{tokenBalance.spec.js → __tests__/tokenBalance.spec.js} +42 -5
  242. package/dist/services/__tests__/tokenBalance.spec.js.map +1 -0
  243. package/dist/{ens → services/nameservices/ens}/EnsNamespace.d.ts +1 -1
  244. package/dist/services/nameservices/ens/EnsNamespace.d.ts.map +1 -0
  245. package/dist/{ens → services/nameservices/ens}/EnsNamespace.js +1 -1
  246. package/dist/services/nameservices/ens/EnsNamespace.js.map +1 -0
  247. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts.map +1 -0
  248. package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.js +2 -2
  249. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js.map +1 -0
  250. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts +2 -0
  251. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts.map +1 -0
  252. package/dist/{utils/ens.test.js → services/nameservices/ens/__tests__/utils.spec.js} +3 -3
  253. package/dist/services/nameservices/ens/__tests__/utils.spec.js.map +1 -0
  254. package/dist/services/nameservices/ens/errors.d.ts.map +1 -0
  255. package/dist/services/nameservices/ens/errors.js.map +1 -0
  256. package/dist/{ens → services/nameservices/ens}/index.d.ts +1 -0
  257. package/dist/services/nameservices/ens/index.d.ts.map +1 -0
  258. package/dist/{ens → services/nameservices/ens}/index.js +1 -0
  259. package/dist/services/nameservices/ens/index.js.map +1 -0
  260. package/dist/{ens → services/nameservices/ens}/types.d.ts +1 -1
  261. package/dist/services/nameservices/ens/types.d.ts.map +1 -0
  262. package/dist/services/nameservices/ens/types.js.map +1 -0
  263. package/dist/{utils/ens.d.ts → services/nameservices/ens/utils.d.ts} +3 -3
  264. package/dist/services/nameservices/ens/utils.d.ts.map +1 -0
  265. package/dist/{utils/ens.js → services/nameservices/ens/utils.js} +3 -3
  266. package/dist/services/nameservices/ens/utils.js.map +1 -0
  267. package/dist/services/tokenBalance.d.ts +8 -5
  268. package/dist/services/tokenBalance.d.ts.map +1 -1
  269. package/dist/services/tokenBalance.js +15 -8
  270. package/dist/services/tokenBalance.js.map +1 -1
  271. package/dist/types/actions.d.ts +69 -7
  272. package/dist/types/actions.d.ts.map +1 -1
  273. package/dist/types/asset.d.ts +7 -0
  274. package/dist/types/asset.d.ts.map +1 -1
  275. package/dist/types/common/FilterAssetChain.d.ts +13 -0
  276. package/dist/types/common/FilterAssetChain.d.ts.map +1 -0
  277. package/dist/types/common/FilterAssetChain.js +2 -0
  278. package/dist/types/common/FilterAssetChain.js.map +1 -0
  279. package/dist/types/common/TransactionOptions.d.ts +13 -0
  280. package/dist/types/common/TransactionOptions.d.ts.map +1 -0
  281. package/dist/types/common/TransactionOptions.js +2 -0
  282. package/dist/types/common/TransactionOptions.js.map +1 -0
  283. package/dist/types/common/index.d.ts +3 -0
  284. package/dist/types/common/index.d.ts.map +1 -0
  285. package/dist/types/common/index.js +3 -0
  286. package/dist/types/common/index.js.map +1 -0
  287. package/dist/types/index.d.ts +1 -0
  288. package/dist/types/index.d.ts.map +1 -1
  289. package/dist/types/index.js +1 -0
  290. package/dist/types/index.js.map +1 -1
  291. package/dist/types/lend/base.d.ts +44 -34
  292. package/dist/types/lend/base.d.ts.map +1 -1
  293. package/dist/types/lend/base.js +3 -3
  294. package/dist/types/lend/base.js.map +1 -1
  295. package/dist/types/lend/index.d.ts +0 -1
  296. package/dist/types/lend/index.d.ts.map +1 -1
  297. package/dist/types/lend/index.js +0 -1
  298. package/dist/types/lend/index.js.map +1 -1
  299. package/dist/types/providers.d.ts +2 -2
  300. package/dist/types/providers.d.ts.map +1 -1
  301. package/dist/types/swap/base.d.ts +25 -13
  302. package/dist/types/swap/base.d.ts.map +1 -1
  303. package/dist/types/swap/base.js +3 -3
  304. package/dist/types/swap/base.js.map +1 -1
  305. package/dist/utils/__tests__/approve.test.d.ts.map +1 -0
  306. package/dist/utils/{approve.test.js → __tests__/approve.test.js} +40 -18
  307. package/dist/utils/__tests__/approve.test.js.map +1 -0
  308. package/dist/utils/__tests__/assets.test.d.ts.map +1 -0
  309. package/dist/utils/{assets.test.js → __tests__/assets.test.js} +2 -2
  310. package/dist/utils/__tests__/assets.test.js.map +1 -0
  311. package/dist/utils/__tests__/serializers.test.d.ts +2 -0
  312. package/dist/utils/__tests__/serializers.test.d.ts.map +1 -0
  313. package/dist/utils/__tests__/serializers.test.js +43 -0
  314. package/dist/utils/__tests__/serializers.test.js.map +1 -0
  315. package/dist/utils/__tests__/validateAddresses.test.d.ts.map +1 -0
  316. package/dist/utils/{validateAddresses.test.js → __tests__/validateAddresses.test.js} +10 -10
  317. package/dist/utils/__tests__/validateAddresses.test.js.map +1 -0
  318. package/dist/utils/abi/permit2.d.ts +48 -0
  319. package/dist/utils/abi/permit2.d.ts.map +1 -0
  320. package/dist/utils/abi/permit2.js +34 -0
  321. package/dist/utils/abi/permit2.js.map +1 -0
  322. package/dist/utils/approve.d.ts +26 -3
  323. package/dist/utils/approve.d.ts.map +1 -1
  324. package/dist/utils/approve.js +34 -37
  325. package/dist/utils/approve.js.map +1 -1
  326. package/dist/utils/assets.d.ts.map +1 -1
  327. package/dist/utils/assets.js +3 -2
  328. package/dist/utils/assets.js.map +1 -1
  329. package/dist/utils/serializers.d.ts +16 -0
  330. package/dist/utils/serializers.d.ts.map +1 -0
  331. package/dist/utils/serializers.js +18 -0
  332. package/dist/utils/serializers.js.map +1 -0
  333. package/dist/utils/validation.d.ts +8 -1
  334. package/dist/utils/validation.d.ts.map +1 -1
  335. package/dist/utils/validation.js +28 -8
  336. package/dist/utils/validation.js.map +1 -1
  337. package/dist/wallet/core/error/errors.d.ts +21 -0
  338. package/dist/wallet/core/error/errors.d.ts.map +1 -0
  339. package/dist/wallet/core/error/errors.js +24 -0
  340. package/dist/wallet/core/error/errors.js.map +1 -0
  341. package/dist/wallet/core/namespace/WalletNamespace.d.ts +24 -8
  342. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  343. package/dist/wallet/core/namespace/WalletNamespace.js +48 -17
  344. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  345. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +105 -10
  346. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  347. package/dist/wallet/core/providers/WalletProvider.d.ts +3 -2
  348. package/dist/wallet/core/providers/WalletProvider.d.ts.map +1 -1
  349. package/dist/wallet/core/providers/WalletProvider.js +8 -2
  350. package/dist/wallet/core/providers/WalletProvider.js.map +1 -1
  351. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +1 -1
  352. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
  353. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts.map +1 -1
  354. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js +2 -1
  355. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js.map +1 -1
  356. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +1 -1
  357. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
  358. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +1 -1
  359. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
  360. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts +2 -0
  361. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts.map +1 -0
  362. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js +31 -0
  363. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js.map +1 -0
  364. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +1 -0
  365. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.js.map +1 -0
  366. package/dist/wallet/core/utils/executeTransactionBatch.d.ts +22 -0
  367. package/dist/wallet/core/utils/executeTransactionBatch.d.ts.map +1 -0
  368. package/dist/wallet/core/utils/executeTransactionBatch.js +26 -0
  369. package/dist/wallet/core/utils/executeTransactionBatch.js.map +1 -0
  370. package/dist/wallet/core/utils/retryOnStaleRead.d.ts.map +1 -0
  371. package/dist/wallet/core/utils/retryOnStaleRead.js.map +1 -0
  372. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +8 -8
  373. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  374. package/dist/wallet/core/wallets/abstract/Wallet.js +13 -12
  375. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  376. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +3 -3
  377. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  378. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  379. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +28 -2
  380. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  381. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts +1 -1
  382. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts.map +1 -1
  383. package/dist/wallet/core/wallets/eoa/EOAWallet.js.map +1 -1
  384. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts +1 -1
  385. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts.map +1 -1
  386. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +1 -1
  387. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  388. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +2 -2
  389. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  390. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +1 -1
  391. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  392. package/dist/wallet/node/index.d.ts +1 -0
  393. package/dist/wallet/node/index.d.ts.map +1 -1
  394. package/dist/wallet/node/index.js +1 -0
  395. package/dist/wallet/node/index.js.map +1 -1
  396. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  397. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  398. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +1 -1
  399. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  400. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  401. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  402. package/dist/wallet/node/wallets/local/LocalWallet.d.ts +24 -0
  403. package/dist/wallet/node/wallets/local/LocalWallet.d.ts.map +1 -0
  404. package/dist/wallet/node/wallets/local/LocalWallet.js +21 -0
  405. package/dist/wallet/node/wallets/local/LocalWallet.js.map +1 -0
  406. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts +2 -0
  407. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts.map +1 -0
  408. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js +51 -0
  409. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js.map +1 -0
  410. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -1
  411. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
  412. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  413. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  414. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  415. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  416. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
  417. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  418. package/package.json +2 -2
  419. package/src/__tests__/actions.test.ts +3 -1
  420. package/src/{lend → actions/lend}/__mocks__/MockLendProvider.ts +24 -9
  421. package/src/{lend → actions/lend}/__mocks__/mockLendTransaction.ts +2 -2
  422. package/src/{lend → actions/lend}/core/LendProvider.ts +123 -39
  423. package/src/{lend → actions/lend}/core/__tests__/LendProvider.test.ts +82 -3
  424. package/src/actions/lend/index.ts +3 -0
  425. package/src/{lend → actions/lend}/namespaces/BaseLendNamespace.ts +20 -37
  426. package/src/{lend → actions/lend}/namespaces/WalletLendNamespace.ts +15 -22
  427. package/src/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.ts +3 -3
  428. package/src/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.ts +3 -3
  429. package/src/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.ts +6 -6
  430. package/src/{lend → actions/lend}/providers/aave/AaveLendProvider.ts +65 -73
  431. package/src/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.ts +7 -7
  432. package/src/{lend → actions/lend}/providers/aave/sdk.ts +15 -9
  433. package/src/{lend → actions/lend}/providers/morpho/MorphoLendProvider.ts +67 -53
  434. package/src/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.ts +79 -5
  435. package/src/{lend → actions/lend}/providers/morpho/__tests__/api.test.ts +3 -3
  436. package/src/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.ts +2 -2
  437. package/src/{lend → actions/lend}/providers/morpho/sdk.ts +23 -12
  438. package/src/actions/lend/utils/markets.ts +62 -0
  439. package/src/actions/shared/BaseNamespace.ts +46 -0
  440. package/src/actions/shared/__tests__/BaseNamespace.spec.ts +58 -0
  441. package/src/{lend/providers → actions/shared}/morpho/contracts.ts +2 -2
  442. package/src/{swap → actions/swap}/__mocks__/MockSwapProvider.ts +6 -2
  443. package/src/{swap → actions/swap}/core/SwapProvider.ts +88 -55
  444. package/src/{swap → actions/swap}/core/__tests__/SwapProvider.test.ts +51 -1
  445. package/src/{swap → actions/swap}/core/markets.ts +2 -1
  446. package/src/actions/swap/index.ts +19 -0
  447. package/src/{swap → actions/swap}/namespaces/ActionsSwapNamespace.ts +1 -1
  448. package/src/{swap → actions/swap}/namespaces/BaseSwapNamespace.ts +92 -90
  449. package/src/actions/swap/namespaces/WalletSwapNamespace.ts +154 -0
  450. package/src/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.ts +6 -6
  451. package/src/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.ts +110 -22
  452. package/src/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.ts +34 -14
  453. package/src/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +2 -2
  454. package/src/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.ts +65 -3
  455. package/src/{swap → actions/swap}/providers/uniswap/addresses.ts +5 -1
  456. package/src/{swap → actions/swap}/providers/uniswap/encoding.ts +3 -3
  457. package/src/{swap → actions/swap}/providers/uniswap/markets.ts +2 -2
  458. package/src/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.ts +71 -31
  459. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +2 -2
  460. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +8 -7
  461. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +46 -5
  462. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.ts +31 -2
  463. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.ts +34 -3
  464. package/src/{swap → actions/swap}/providers/velodrome/config.ts +5 -1
  465. package/src/{swap → actions/swap}/providers/velodrome/encoding/helpers.ts +3 -2
  466. package/src/{swap → actions/swap}/providers/velodrome/encoding/index.ts +0 -1
  467. package/src/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.ts +4 -3
  468. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.ts +31 -23
  469. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.ts +34 -27
  470. package/src/{swap → actions/swap}/providers/velodrome/markets.ts +4 -3
  471. package/src/actions.ts +68 -37
  472. package/src/core/error/__tests__/errors.test.ts +236 -0
  473. package/src/core/error/errors.ts +282 -22
  474. package/src/index.ts +18 -12
  475. package/src/services/ChainManager.ts +26 -9
  476. package/src/services/{ChainManager.spec.ts → __tests__/ChainManager.spec.ts} +6 -6
  477. package/src/services/{tokenBalance.spec.ts → __tests__/tokenBalance.spec.ts} +56 -1
  478. package/src/{ens → services/nameservices/ens}/EnsNamespace.ts +1 -1
  479. package/src/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.ts +6 -4
  480. package/src/{utils/ens.test.ts → services/nameservices/ens/__tests__/utils.spec.ts} +3 -2
  481. package/src/{ens → services/nameservices/ens}/index.ts +5 -0
  482. package/src/{utils/ens.ts → services/nameservices/ens/utils.ts} +3 -3
  483. package/src/services/tokenBalance.ts +16 -7
  484. package/src/types/actions.ts +72 -7
  485. package/src/types/asset.ts +8 -0
  486. package/src/types/common/FilterAssetChain.ts +13 -0
  487. package/src/types/common/TransactionOptions.ts +12 -0
  488. package/src/types/common/index.ts +2 -0
  489. package/src/types/index.ts +1 -0
  490. package/src/types/lend/base.ts +48 -36
  491. package/src/types/lend/index.ts +0 -1
  492. package/src/types/providers.ts +2 -2
  493. package/src/types/swap/base.ts +25 -13
  494. package/src/utils/{approve.test.ts → __tests__/approve.test.ts} +51 -18
  495. package/src/utils/__tests__/serializers.test.ts +53 -0
  496. package/src/utils/{validateAddresses.test.ts → __tests__/validateAddresses.test.ts} +9 -9
  497. package/src/utils/abi/permit2.ts +33 -0
  498. package/src/utils/approve.ts +48 -37
  499. package/src/utils/assets.ts +6 -6
  500. package/src/utils/serializers.ts +21 -0
  501. package/src/utils/validation.ts +42 -15
  502. package/src/wallet/core/error/errors.ts +30 -0
  503. package/src/wallet/core/namespace/WalletNamespace.ts +82 -20
  504. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +141 -16
  505. package/src/wallet/core/providers/WalletProvider.ts +12 -3
  506. package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +1 -1
  507. package/src/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.ts +2 -1
  508. package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +1 -1
  509. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +1 -1
  510. package/src/wallet/core/utils/__tests__/executeTransactionBatch.spec.ts +42 -0
  511. package/src/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.ts +1 -1
  512. package/src/wallet/core/utils/executeTransactionBatch.ts +37 -0
  513. package/src/wallet/core/wallets/abstract/Wallet.ts +17 -15
  514. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +3 -3
  515. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +54 -3
  516. package/src/wallet/core/wallets/eoa/EOAWallet.ts +1 -1
  517. package/src/wallet/core/wallets/smart/abstract/SmartWallet.ts +1 -1
  518. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +3 -3
  519. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +1 -1
  520. package/src/wallet/node/index.ts +1 -0
  521. package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  522. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +1 -1
  523. package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  524. package/src/wallet/node/wallets/local/LocalWallet.ts +48 -0
  525. package/src/wallet/node/wallets/local/__tests__/LocalWallet.spec.ts +64 -0
  526. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -1
  527. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  528. package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  529. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +1 -1
  530. package/dist/core/asset/__mocks__/mockAsset.d.ts +0 -6
  531. package/dist/core/asset/__mocks__/mockAsset.d.ts.map +0 -1
  532. package/dist/core/asset/__mocks__/mockAsset.js +0 -12
  533. package/dist/core/asset/__mocks__/mockAsset.js.map +0 -1
  534. package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +0 -1
  535. package/dist/core/utils/__tests__/retryOnStaleRead.spec.js.map +0 -1
  536. package/dist/core/utils/retryOnStaleRead.d.ts.map +0 -1
  537. package/dist/core/utils/retryOnStaleRead.js.map +0 -1
  538. package/dist/ens/EnsNamespace.d.ts.map +0 -1
  539. package/dist/ens/EnsNamespace.js.map +0 -1
  540. package/dist/ens/EnsNamespace.spec.d.ts.map +0 -1
  541. package/dist/ens/EnsNamespace.spec.js.map +0 -1
  542. package/dist/ens/errors.d.ts.map +0 -1
  543. package/dist/ens/errors.js.map +0 -1
  544. package/dist/ens/index.d.ts.map +0 -1
  545. package/dist/ens/index.js.map +0 -1
  546. package/dist/ens/types.d.ts.map +0 -1
  547. package/dist/ens/types.js.map +0 -1
  548. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +0 -1
  549. package/dist/lend/__mocks__/MockLendProvider.js.map +0 -1
  550. package/dist/lend/__mocks__/MockMarkets.d.ts.map +0 -1
  551. package/dist/lend/__mocks__/MockMarkets.js.map +0 -1
  552. package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +0 -1
  553. package/dist/lend/__mocks__/mockLendTransaction.js.map +0 -1
  554. package/dist/lend/core/LendProvider.d.ts.map +0 -1
  555. package/dist/lend/core/LendProvider.js.map +0 -1
  556. package/dist/lend/core/__tests__/LendProvider.test.d.ts.map +0 -1
  557. package/dist/lend/core/__tests__/LendProvider.test.js.map +0 -1
  558. package/dist/lend/index.d.ts.map +0 -1
  559. package/dist/lend/index.js.map +0 -1
  560. package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +0 -1
  561. package/dist/lend/namespaces/ActionsLendNamespace.js.map +0 -1
  562. package/dist/lend/namespaces/BaseLendNamespace.d.ts +0 -43
  563. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +0 -1
  564. package/dist/lend/namespaces/BaseLendNamespace.js.map +0 -1
  565. package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +0 -1
  566. package/dist/lend/namespaces/WalletLendNamespace.js.map +0 -1
  567. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +0 -1
  568. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +0 -1
  569. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +0 -1
  570. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +0 -1
  571. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +0 -1
  572. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +0 -1
  573. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +0 -1
  574. package/dist/lend/providers/aave/AaveLendProvider.js.map +0 -1
  575. package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +0 -1
  576. package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +0 -1
  577. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +0 -1
  578. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +0 -1
  579. package/dist/lend/providers/aave/abis/pool.d.ts.map +0 -1
  580. package/dist/lend/providers/aave/abis/pool.js.map +0 -1
  581. package/dist/lend/providers/aave/addresses.d.ts.map +0 -1
  582. package/dist/lend/providers/aave/addresses.js.map +0 -1
  583. package/dist/lend/providers/aave/sdk.d.ts.map +0 -1
  584. package/dist/lend/providers/aave/sdk.js.map +0 -1
  585. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +0 -1
  586. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +0 -1
  587. package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts.map +0 -1
  588. package/dist/lend/providers/morpho/__mocks__/mockVault.js.map +0 -1
  589. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +0 -1
  590. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +0 -1
  591. package/dist/lend/providers/morpho/__tests__/api.test.d.ts.map +0 -1
  592. package/dist/lend/providers/morpho/__tests__/api.test.js.map +0 -1
  593. package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts.map +0 -1
  594. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +0 -1
  595. package/dist/lend/providers/morpho/api.d.ts.map +0 -1
  596. package/dist/lend/providers/morpho/api.js.map +0 -1
  597. package/dist/lend/providers/morpho/contracts.d.ts.map +0 -1
  598. package/dist/lend/providers/morpho/sdk.d.ts.map +0 -1
  599. package/dist/lend/providers/morpho/sdk.js.map +0 -1
  600. package/dist/services/ChainManager.spec.d.ts.map +0 -1
  601. package/dist/services/ChainManager.spec.js.map +0 -1
  602. package/dist/services/tokenBalance.spec.d.ts.map +0 -1
  603. package/dist/services/tokenBalance.spec.js.map +0 -1
  604. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +0 -1
  605. package/dist/swap/__mocks__/MockSwapProvider.js.map +0 -1
  606. package/dist/swap/core/SwapProvider.d.ts.map +0 -1
  607. package/dist/swap/core/SwapProvider.js.map +0 -1
  608. package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +0 -1
  609. package/dist/swap/core/__tests__/SwapProvider.test.js.map +0 -1
  610. package/dist/swap/core/markets.d.ts.map +0 -1
  611. package/dist/swap/core/markets.js.map +0 -1
  612. package/dist/swap/index.d.ts.map +0 -1
  613. package/dist/swap/index.js.map +0 -1
  614. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +0 -1
  615. package/dist/swap/namespaces/ActionsSwapNamespace.js.map +0 -1
  616. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +0 -1
  617. package/dist/swap/namespaces/BaseSwapNamespace.js.map +0 -1
  618. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +0 -35
  619. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +0 -1
  620. package/dist/swap/namespaces/WalletSwapNamespace.js.map +0 -1
  621. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +0 -1
  622. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +0 -1
  623. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +0 -1
  624. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +0 -1
  625. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +0 -1
  626. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +0 -1
  627. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +0 -1
  628. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +0 -1
  629. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +0 -1
  630. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +0 -1
  631. package/dist/swap/providers/uniswap/abis.d.ts.map +0 -1
  632. package/dist/swap/providers/uniswap/abis.js.map +0 -1
  633. package/dist/swap/providers/uniswap/addresses.d.ts.map +0 -1
  634. package/dist/swap/providers/uniswap/addresses.js.map +0 -1
  635. package/dist/swap/providers/uniswap/encoding.d.ts.map +0 -1
  636. package/dist/swap/providers/uniswap/encoding.js.map +0 -1
  637. package/dist/swap/providers/uniswap/markets.d.ts.map +0 -1
  638. package/dist/swap/providers/uniswap/markets.js.map +0 -1
  639. package/dist/swap/providers/uniswap/types.d.ts.map +0 -1
  640. package/dist/swap/providers/uniswap/types.js.map +0 -1
  641. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +0 -1
  642. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +0 -1
  643. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +0 -1
  644. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +0 -1
  645. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +0 -1
  646. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +0 -1
  647. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +0 -1
  648. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +0 -1
  649. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +0 -1
  650. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +0 -1
  651. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +0 -1
  652. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +0 -1
  653. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +0 -1
  654. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +0 -1
  655. package/dist/swap/providers/velodrome/abis.d.ts.map +0 -1
  656. package/dist/swap/providers/velodrome/abis.js.map +0 -1
  657. package/dist/swap/providers/velodrome/addresses.d.ts.map +0 -1
  658. package/dist/swap/providers/velodrome/addresses.js.map +0 -1
  659. package/dist/swap/providers/velodrome/config.d.ts.map +0 -1
  660. package/dist/swap/providers/velodrome/config.js.map +0 -1
  661. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +0 -1
  662. package/dist/swap/providers/velodrome/encoding/helpers.js.map +0 -1
  663. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +0 -1
  664. package/dist/swap/providers/velodrome/encoding/index.js.map +0 -1
  665. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +0 -1
  666. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +0 -1
  667. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +0 -15
  668. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +0 -1
  669. package/dist/swap/providers/velodrome/encoding/routers/approval.js +0 -33
  670. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +0 -1
  671. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +0 -1
  672. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +0 -1
  673. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +0 -1
  674. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +0 -1
  675. package/dist/swap/providers/velodrome/markets.d.ts.map +0 -1
  676. package/dist/swap/providers/velodrome/markets.js.map +0 -1
  677. package/dist/swap/providers/velodrome/types.d.ts.map +0 -1
  678. package/dist/swap/providers/velodrome/types.js.map +0 -1
  679. package/dist/types/lend/contracts.d.ts.map +0 -1
  680. package/dist/types/lend/contracts.js +0 -2
  681. package/dist/types/lend/contracts.js.map +0 -1
  682. package/dist/utils/approve.test.d.ts.map +0 -1
  683. package/dist/utils/approve.test.js.map +0 -1
  684. package/dist/utils/assets.test.d.ts.map +0 -1
  685. package/dist/utils/assets.test.js.map +0 -1
  686. package/dist/utils/ens.d.ts.map +0 -1
  687. package/dist/utils/ens.js.map +0 -1
  688. package/dist/utils/ens.test.d.ts +0 -2
  689. package/dist/utils/ens.test.d.ts.map +0 -1
  690. package/dist/utils/ens.test.js.map +0 -1
  691. package/dist/utils/markets.d.ts +0 -17
  692. package/dist/utils/markets.d.ts.map +0 -1
  693. package/dist/utils/markets.js +0 -25
  694. package/dist/utils/markets.js.map +0 -1
  695. package/dist/utils/validateAddresses.test.d.ts.map +0 -1
  696. package/dist/utils/validateAddresses.test.js.map +0 -1
  697. package/src/core/asset/__mocks__/mockAsset.ts +0 -13
  698. package/src/lend/index.ts +0 -3
  699. package/src/swap/index.ts +0 -19
  700. package/src/swap/namespaces/WalletSwapNamespace.ts +0 -129
  701. package/src/swap/providers/velodrome/encoding/routers/approval.ts +0 -45
  702. package/src/utils/markets.ts +0 -35
  703. /package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.d.ts +0 -0
  704. /package/dist/{lend → actions/lend}/index.d.ts +0 -0
  705. /package/dist/{lend → actions/lend}/index.js +0 -0
  706. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.d.ts +0 -0
  707. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.js +0 -0
  708. /package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.d.ts +0 -0
  709. /package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.d.ts +0 -0
  710. /package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.d.ts +0 -0
  711. /package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.js +0 -0
  712. /package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.d.ts +0 -0
  713. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.d.ts +0 -0
  714. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.js +0 -0
  715. /package/dist/{lend → actions/lend}/providers/aave/addresses.d.ts +0 -0
  716. /package/dist/{lend → actions/lend}/providers/aave/addresses.js +0 -0
  717. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.d.ts +0 -0
  718. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.js +0 -0
  719. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.d.ts +0 -0
  720. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.d.ts +0 -0
  721. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.d.ts +0 -0
  722. /package/dist/{lend → actions/lend}/providers/morpho/api.d.ts +0 -0
  723. /package/dist/{lend → actions/lend}/providers/morpho/api.js +0 -0
  724. /package/dist/{lend/providers → actions/shared}/morpho/contracts.js +0 -0
  725. /package/dist/{swap/providers/uniswap → actions/shared/morpho}/types.js +0 -0
  726. /package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.d.ts +0 -0
  727. /package/dist/{swap → actions/swap}/index.d.ts +0 -0
  728. /package/dist/{swap → actions/swap}/index.js +0 -0
  729. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.d.ts +0 -0
  730. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.js +0 -0
  731. /package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +0 -0
  732. /package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +0 -0
  733. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +0 -0
  734. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.d.ts +0 -0
  735. /package/dist/{swap → actions/swap}/providers/uniswap/abis.d.ts +0 -0
  736. /package/dist/{swap → actions/swap}/providers/uniswap/abis.js +0 -0
  737. /package/dist/{swap/providers/velodrome → actions/swap/providers/uniswap}/types.js +0 -0
  738. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +0 -0
  739. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +0 -0
  740. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +0 -0
  741. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +0 -0
  742. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.d.ts +0 -0
  743. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.js +0 -0
  744. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.d.ts +0 -0
  745. /package/dist/{swap → actions/swap}/providers/velodrome/abis.d.ts +0 -0
  746. /package/dist/{swap → actions/swap}/providers/velodrome/abis.js +0 -0
  747. /package/dist/{swap → actions/swap}/providers/velodrome/addresses.js +0 -0
  748. /package/dist/services/{ChainManager.spec.d.ts → __tests__/ChainManager.spec.d.ts} +0 -0
  749. /package/dist/services/{tokenBalance.spec.d.ts → __tests__/tokenBalance.spec.d.ts} +0 -0
  750. /package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.d.ts +0 -0
  751. /package/dist/{ens → services/nameservices/ens}/errors.d.ts +0 -0
  752. /package/dist/{ens → services/nameservices/ens}/errors.js +0 -0
  753. /package/dist/{ens → services/nameservices/ens}/types.js +0 -0
  754. /package/dist/utils/{approve.test.d.ts → __tests__/approve.test.d.ts} +0 -0
  755. /package/dist/utils/{assets.test.d.ts → __tests__/assets.test.d.ts} +0 -0
  756. /package/dist/utils/{validateAddresses.test.d.ts → __tests__/validateAddresses.test.d.ts} +0 -0
  757. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.d.ts +0 -0
  758. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.js +0 -0
  759. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.d.ts +0 -0
  760. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.js +0 -0
  761. /package/src/{lend → actions/lend}/__mocks__/MockMarkets.ts +0 -0
  762. /package/src/{lend → actions/lend}/namespaces/ActionsLendNamespace.ts +0 -0
  763. /package/src/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.ts +0 -0
  764. /package/src/{lend → actions/lend}/providers/aave/abis/pool.ts +0 -0
  765. /package/src/{lend → actions/lend}/providers/aave/addresses.ts +0 -0
  766. /package/src/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.ts +0 -0
  767. /package/src/{lend → actions/lend}/providers/morpho/api.ts +0 -0
  768. /package/src/{types/lend/contracts.ts → actions/shared/morpho/types.ts} +0 -0
  769. /package/src/{swap → actions/swap}/providers/uniswap/abis.ts +0 -0
  770. /package/src/{swap → actions/swap}/providers/uniswap/types.ts +0 -0
  771. /package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.ts +0 -0
  772. /package/src/{swap → actions/swap}/providers/velodrome/abis.ts +0 -0
  773. /package/src/{swap → actions/swap}/providers/velodrome/addresses.ts +0 -0
  774. /package/src/{swap → actions/swap}/providers/velodrome/types.ts +0 -0
  775. /package/src/{ens → services/nameservices/ens}/errors.ts +0 -0
  776. /package/src/{ens → services/nameservices/ens}/types.ts +0 -0
  777. /package/src/utils/{assets.test.ts → __tests__/assets.test.ts} +0 -0
  778. /package/src/{core → wallet/core}/utils/retryOnStaleRead.ts +0 -0
@@ -1,10 +1,11 @@
1
1
  import type { Address } from 'viem'
2
2
  import { encodeFunctionData, erc20Abi, formatUnits } from 'viem'
3
3
 
4
+ import { LendProvider } from '@/actions/lend/core/LendProvider.js'
4
5
  import { WETH } from '@/constants/assets.js'
5
- import { LendProvider } from '@/lend/core/LendProvider.js'
6
+ import { ChainNotSupportedError } from '@/core/error/errors.js'
6
7
  import type { ChainManager } from '@/services/ChainManager.js'
7
- import type { LendProviderConfig } from '@/types/actions.js'
8
+ import type { LendProviderConfig, LendSettings } from '@/types/actions.js'
8
9
  import type {
9
10
  GetLendMarketsParams,
10
11
  GetMarketBalanceParams,
@@ -12,6 +13,7 @@ import type {
12
13
  LendMarket,
13
14
  LendMarketId,
14
15
  LendMarketPosition,
16
+ LendOpenPosition,
15
17
  LendOpenPositionInternalParams,
16
18
  LendTransaction,
17
19
  } from '@/types/lend/index.js'
@@ -30,35 +32,38 @@ import { getATokenAddress, getReserve, getReserves } from './sdk.js'
30
32
  * @description Lending provider implementation using Aave V3 protocol
31
33
  */
32
34
  export class AaveLendProvider extends LendProvider<LendProviderConfig> {
33
- protocolSupportedChainIds(): number[] {
34
- return getSupportedChainIds()
35
+ constructor(
36
+ config: LendProviderConfig,
37
+ chainManager: ChainManager,
38
+ settings?: LendSettings,
39
+ ) {
40
+ super(config, chainManager, settings)
35
41
  }
36
42
 
37
- /**
38
- * Create a new Aave lending provider
39
- * @param config - Aave lending configuration
40
- * @param chainManager - Chain manager for blockchain interactions
41
- */
42
- constructor(config: LendProviderConfig, chainManager: ChainManager) {
43
- super(config, chainManager)
43
+ protocolSupportedChainIds(): number[] {
44
+ return getSupportedChainIds()
44
45
  }
45
46
 
46
47
  /**
47
- * Open a lending position in an Aave market
48
- * @description Opens a lending position by supplying assets to an Aave reserve
49
- * @param params - Position opening parameters
50
- * @returns Promise resolving to lending transaction details
48
+ * Describe an Aave deposit. The base class wraps this into a
49
+ * `LendTransaction` with the appropriate ERC-20 approval based on
50
+ * `params.approvalMode`. Native-ETH paths return `spender: undefined` since
51
+ * deposits via the WETHGateway send value as `msg.value` rather than via
52
+ * `transferFrom`.
53
+ * @param params - Position opening parameters (amount in wei, walletAddress, approvalMode)
54
+ * @returns Spender + deposit calldata + APY snapshot
51
55
  */
52
56
  protected async _openPosition(
53
57
  params: LendOpenPositionInternalParams,
54
- ): Promise<LendTransaction> {
58
+ ): Promise<LendOpenPosition> {
55
59
  try {
56
60
  // Get Pool address for this chain
57
61
  const poolAddress = getPoolAddress(params.marketId.chainId)
58
62
  if (!poolAddress) {
59
- throw new Error(
60
- `Aave V3 not deployed on chain ${params.marketId.chainId}`,
61
- )
63
+ throw new ChainNotSupportedError({
64
+ chainId: params.marketId.chainId,
65
+ supportedChainIds: this.supportedChainIds(),
66
+ })
62
67
  }
63
68
 
64
69
  // Get market information for APY
@@ -67,13 +72,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
67
72
  chainId: params.marketId.chainId,
68
73
  })
69
74
 
70
- // Check if this is a native ETH market
71
75
  if (isNativeAsset(params.asset)) {
72
- return this._openETHPosition(params, poolAddress, marketInfo)
76
+ return this._buildETHOpenPosition(params, poolAddress, marketInfo)
73
77
  }
74
-
75
- // Standard ERC-20 flow
76
- return this._openERC20Position(params, poolAddress, marketInfo)
78
+ return this._buildERC20OpenPosition(params, poolAddress, marketInfo)
77
79
  } catch {
78
80
  throw new Error(
79
81
  `Failed to open position with ${params.amountWei} of ${params.asset.metadata.symbol}`,
@@ -94,9 +96,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
94
96
  // Get Pool address for this chain
95
97
  const poolAddress = getPoolAddress(params.marketId.chainId)
96
98
  if (!poolAddress) {
97
- throw new Error(
98
- `Aave V3 not deployed on chain ${params.marketId.chainId}`,
99
- )
99
+ throw new ChainNotSupportedError({
100
+ chainId: params.marketId.chainId,
101
+ supportedChainIds: this.supportedChainIds(),
102
+ })
100
103
  }
101
104
 
102
105
  const marketInfo = await this.getMarket({
@@ -162,9 +165,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
162
165
  const poolAddress = getPoolAddress(params.marketId.chainId)
163
166
 
164
167
  if (!poolAddress) {
165
- throw new Error(
166
- `Aave V3 not deployed on chain ${params.marketId.chainId}`,
167
- )
168
+ throw new ChainNotSupportedError({
169
+ chainId: params.marketId.chainId,
170
+ supportedChainIds: this.supportedChainIds(),
171
+ })
168
172
  }
169
173
 
170
174
  // Get the aToken address from Pool.getReserveData
@@ -206,22 +210,22 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
206
210
  }
207
211
 
208
212
  /**
209
- * Open position for native ETH using WETHGateway
210
- * @description Deposits native ETH via WETHGateway which wraps and deposits in one tx
213
+ * Describe a native-ETH deposit via Aave's WETHGateway. ETH is sent as
214
+ * `msg.value` and wrapped to aWETH inline no ERC-20 approval needed.
211
215
  */
212
- private async _openETHPosition(
216
+ private async _buildETHOpenPosition(
213
217
  params: LendOpenPositionInternalParams,
214
218
  poolAddress: Address,
215
219
  marketInfo: LendMarket,
216
- ): Promise<LendTransaction> {
220
+ ): Promise<LendOpenPosition> {
217
221
  const gatewayAddress = getWETHGatewayAddress(params.marketId.chainId)
218
222
  if (!gatewayAddress) {
219
- throw new Error(
220
- `WETHGateway not available on chain ${params.marketId.chainId}`,
221
- )
223
+ throw new ChainNotSupportedError({
224
+ chainId: params.marketId.chainId,
225
+ supportedChainIds: this.supportedChainIds(),
226
+ })
222
227
  }
223
228
 
224
- // Generate depositETH transaction
225
229
  const depositCallData = encodeFunctionData({
226
230
  abi: WETH_GATEWAY_ABI,
227
231
  functionName: 'depositETH',
@@ -235,33 +239,28 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
235
239
  const wethAddress = getAssetAddress(WETH, params.marketId.chainId)
236
240
 
237
241
  return {
238
- amount: params.amountWei,
239
- asset: wethAddress,
240
- marketId: params.marketId.address,
241
- apy: marketInfo.apy.total,
242
- transactionData: {
243
- position: {
244
- to: gatewayAddress,
245
- data: depositCallData,
246
- value: params.amountWei, // Send ETH as msg.value
247
- },
242
+ assetAddress: wethAddress,
243
+ transaction: {
244
+ to: gatewayAddress,
245
+ data: depositCallData,
246
+ value: params.amountWei, // Send ETH as msg.value
248
247
  },
248
+ apy: marketInfo.apy.total,
249
249
  }
250
250
  }
251
251
 
252
252
  /**
253
- * Open position for standard ERC-20 tokens
254
- * @description Standard approve + supply flow for non-WETH assets
253
+ * Describe a standard ERC-20 deposit. The base class builds the approval to
254
+ * `poolAddress` based on `params.approvalMode`.
255
255
  */
256
- private async _openERC20Position(
256
+ private async _buildERC20OpenPosition(
257
257
  params: LendOpenPositionInternalParams,
258
258
  poolAddress: Address,
259
259
  marketInfo: LendMarket,
260
- ): Promise<LendTransaction> {
260
+ ): Promise<LendOpenPosition> {
261
261
  // Get asset address for the chain (throws for native assets)
262
262
  const assetAddress = getAssetAddress(params.asset, params.marketId.chainId)
263
263
 
264
- // Generate supply transaction
265
264
  const supplyCallData = encodeFunctionData({
266
265
  abi: POOL_ABI,
267
266
  functionName: 'supply',
@@ -274,22 +273,14 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
274
273
  })
275
274
 
276
275
  return {
277
- amount: params.amountWei,
278
- asset: assetAddress,
279
- marketId: params.marketId.address,
280
- apy: marketInfo.apy.total,
281
- transactionData: {
282
- approval: this.buildApprovalTx(
283
- assetAddress,
284
- poolAddress,
285
- params.amountWei,
286
- ),
287
- position: {
288
- to: poolAddress,
289
- data: supplyCallData,
290
- value: 0n,
291
- },
276
+ spender: poolAddress,
277
+ assetAddress,
278
+ transaction: {
279
+ to: poolAddress,
280
+ data: supplyCallData,
281
+ value: 0n,
292
282
  },
283
+ apy: marketInfo.apy.total,
293
284
  }
294
285
  }
295
286
 
@@ -304,9 +295,10 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
304
295
  ): Promise<LendTransaction> {
305
296
  const gatewayAddress = getWETHGatewayAddress(params.marketId.chainId)
306
297
  if (!gatewayAddress) {
307
- throw new Error(
308
- `WETHGateway not available on chain ${params.marketId.chainId}`,
309
- )
298
+ throw new ChainNotSupportedError({
299
+ chainId: params.marketId.chainId,
300
+ supportedChainIds: this.supportedChainIds(),
301
+ })
310
302
  }
311
303
 
312
304
  const wethAddress = getAssetAddress(WETH, params.marketId.chainId)
@@ -331,7 +323,7 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
331
323
 
332
324
  return {
333
325
  amount: params.amount,
334
- asset: wethAddress,
326
+ assetAddress: wethAddress,
335
327
  marketId: params.marketId.address,
336
328
  apy: marketInfo.apy.total,
337
329
  transactionData: {
@@ -376,7 +368,7 @@ export class AaveLendProvider extends LendProvider<LendProviderConfig> {
376
368
 
377
369
  return {
378
370
  amount: params.amount,
379
- asset: assetAddress,
371
+ assetAddress,
380
372
  marketId: params.marketId.address,
381
373
  apy: marketInfo.apy.total,
382
374
  transactionData: {
@@ -1,19 +1,19 @@
1
1
  import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest'
2
2
 
3
- import { MockReceiverAddress } from '@/lend/__mocks__/MockMarkets.js'
3
+ import { MockReceiverAddress } from '@/actions/lend/__mocks__/MockMarkets.js'
4
4
  import {
5
5
  createMockAaveReserve,
6
6
  createMockWETHReserve,
7
- } from '@/lend/providers/aave/__mocks__/mockReserve.js'
8
- import { AaveLendProvider } from '@/lend/providers/aave/AaveLendProvider.js'
9
- import * as aaveSdk from '@/lend/providers/aave/sdk.js'
7
+ } from '@/actions/lend/providers/aave/__mocks__/mockReserve.js'
8
+ import { AaveLendProvider } from '@/actions/lend/providers/aave/AaveLendProvider.js'
9
+ import * as aaveSdk from '@/actions/lend/providers/aave/sdk.js'
10
10
  import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
11
11
  import type { ChainManager } from '@/services/ChainManager.js'
12
12
  import type { LendProviderConfig } from '@/types/actions.js'
13
13
  import type { Asset, LendMarketConfig } from '@/types/index.js'
14
14
 
15
15
  // Mock the Aave SDK modules
16
- vi.mock('@/lend/providers/aave/sdk.js', () => ({
16
+ vi.mock('@/actions/lend/providers/aave/sdk.js', () => ({
17
17
  getReserve: vi.fn(),
18
18
  getReserves: vi.fn(),
19
19
  getATokenAddress: vi.fn(),
@@ -139,7 +139,7 @@ describe('AaveLendProvider', () => {
139
139
 
140
140
  expect(lendTransaction).toHaveProperty('amount', BigInt('1000000000'))
141
141
  expect(lendTransaction).toHaveProperty(
142
- 'asset',
142
+ 'assetAddress',
143
143
  asset.address[marketId.chainId],
144
144
  )
145
145
  expect(lendTransaction).toHaveProperty('marketId', marketId.address)
@@ -228,7 +228,7 @@ describe('AaveLendProvider', () => {
228
228
 
229
229
  expect(withdrawTransaction).toHaveProperty('amount', BigInt('500000000'))
230
230
  expect(withdrawTransaction).toHaveProperty(
231
- 'asset',
231
+ 'assetAddress',
232
232
  asset.address[marketId.chainId],
233
233
  )
234
234
  expect(withdrawTransaction).toHaveProperty('marketId', marketId.address)
@@ -3,13 +3,17 @@ import { formatReserves } from '@aave/math-utils'
3
3
  import { providers } from 'ethers'
4
4
  import type { Address } from 'viem'
5
5
 
6
- import { WETH } from '@/constants/assets.js'
7
- import type { SupportedChainId } from '@/constants/supportedChains.js'
8
- import { POOL_GET_RESERVE_DATA_ABI } from '@/lend/providers/aave/abis/pool.js'
6
+ import { POOL_GET_RESERVE_DATA_ABI } from '@/actions/lend/providers/aave/abis/pool.js'
9
7
  import {
10
8
  getAaveAddresses,
11
9
  getPoolAddress,
12
- } from '@/lend/providers/aave/addresses.js'
10
+ } from '@/actions/lend/providers/aave/addresses.js'
11
+ import { WETH } from '@/constants/assets.js'
12
+ import type { SupportedChainId } from '@/constants/supportedChains.js'
13
+ import {
14
+ ChainNotSupportedError,
15
+ MarketNotAllowedError,
16
+ } from '@/core/error/errors.js'
13
17
  import type { ChainManager } from '@/services/ChainManager.js'
14
18
  import type { LendProviderConfig } from '@/types/actions.js'
15
19
  import type {
@@ -95,14 +99,16 @@ export async function getReserve(
95
99
  : undefined
96
100
 
97
101
  if (!marketConfig) {
98
- throw new Error(
99
- `Market ${params.marketId.address} on chain ${params.marketId.chainId} not found in allowlist`,
100
- )
102
+ throw new MarketNotAllowedError({
103
+ address: params.marketId.address,
104
+ chainId: params.marketId.chainId,
105
+ reason: 'Market not found in allowlist',
106
+ })
101
107
  }
102
108
 
103
109
  const addresses = getAaveAddresses(params.marketId.chainId)
104
110
  if (!addresses) {
105
- throw new Error(`Aave V3 not deployed on chain ${params.marketId.chainId}`)
111
+ throw new ChainNotSupportedError({ chainId: params.marketId.chainId })
106
112
  }
107
113
 
108
114
  const poolAddress = addresses.pool
@@ -244,7 +250,7 @@ export async function getATokenAddress(params: {
244
250
  }): Promise<Address> {
245
251
  const poolAddress = getPoolAddress(params.chainId)
246
252
  if (!poolAddress) {
247
- throw new Error(`Aave V3 not deployed on chain ${params.chainId}`)
253
+ throw new ChainNotSupportedError({ chainId: params.chainId })
248
254
  }
249
255
 
250
256
  try {
@@ -1,11 +1,12 @@
1
1
  import { MetaMorphoAction } from '@morpho-org/blue-sdk-viem'
2
- import { erc20Abi, formatUnits } from 'viem'
2
+ import { erc20Abi, erc4626Abi, formatUnits, type PublicClient } from 'viem'
3
3
 
4
- import { LendProvider } from '@/lend/core/LendProvider.js'
5
- import { getSupportedChainIds as getMorphoSupportedChainIds } from '@/lend/providers/morpho/contracts.js'
6
- import { getVault, getVaults } from '@/lend/providers/morpho/sdk.js'
4
+ import { LendProvider } from '@/actions/lend/core/LendProvider.js'
5
+ import { getVault, getVaults } from '@/actions/lend/providers/morpho/sdk.js'
6
+ import { findMarketInAllowlist } from '@/actions/lend/utils/markets.js'
7
+ import { getSupportedChainIds as getMorphoSupportedChainIds } from '@/actions/shared/morpho/contracts.js'
7
8
  import type { ChainManager } from '@/services/ChainManager.js'
8
- import type { LendProviderConfig } from '@/types/actions.js'
9
+ import type { LendProviderConfig, LendSettings } from '@/types/actions.js'
9
10
  import type {
10
11
  GetLendMarketsParams,
11
12
  GetMarketBalanceParams,
@@ -13,6 +14,7 @@ import type {
13
14
  LendMarket,
14
15
  LendMarketId,
15
16
  LendMarketPosition,
17
+ LendOpenPosition,
16
18
  LendOpenPositionInternalParams,
17
19
  LendTransaction,
18
20
  } from '@/types/lend/index.js'
@@ -23,28 +25,28 @@ import { getAssetAddress } from '@/utils/assets.js'
23
25
  * @description Lending provider implementation using Morpho protocol
24
26
  */
25
27
  export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
26
- protocolSupportedChainIds(): number[] {
27
- return getMorphoSupportedChainIds()
28
+ constructor(
29
+ config: LendProviderConfig,
30
+ chainManager: ChainManager,
31
+ settings?: LendSettings,
32
+ ) {
33
+ super(config, chainManager, settings)
28
34
  }
29
35
 
30
- /**
31
- * Create a new Morpho lending provider
32
- * @param config - Morpho lending configuration
33
- * @param chainManager - Chain manager for blockchain interactions
34
- */
35
- constructor(config: LendProviderConfig, chainManager: ChainManager) {
36
- super(config, chainManager)
36
+ protocolSupportedChainIds(): number[] {
37
+ return getMorphoSupportedChainIds()
37
38
  }
38
39
 
39
40
  /**
40
- * Open a lending position in a Morpho market
41
- * @description Opens a lending position by supplying assets to a Morpho market
42
- * @param params - Position opening parameters
43
- * @returns Promise resolving to lending transaction details
41
+ * Describe a Morpho deposit. The base class wraps this into a
42
+ * `LendTransaction` with the appropriate ERC-20 approval based on
43
+ * `params.approvalMode`.
44
+ * @param params - Position opening parameters (amount in wei, walletAddress, approvalMode)
45
+ * @returns Spender + deposit calldata + APY snapshot
44
46
  */
45
47
  protected async _openPosition(
46
48
  params: LendOpenPositionInternalParams,
47
- ): Promise<LendTransaction> {
49
+ ): Promise<LendOpenPosition> {
48
50
  try {
49
51
  // Get asset address for the chain (throws for native assets)
50
52
  const assetAddress = getAssetAddress(
@@ -58,27 +60,20 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
58
60
  chainId: params.marketId.chainId,
59
61
  })
60
62
 
61
- const assets = params.amountWei
62
- const receiver = params.walletAddress
63
- const depositCallData = MetaMorphoAction.deposit(assets, receiver)
63
+ const depositCallData = MetaMorphoAction.deposit(
64
+ params.amountWei,
65
+ params.walletAddress,
66
+ )
64
67
 
65
68
  return {
66
- amount: params.amountWei,
67
- asset: assetAddress,
68
- marketId: params.marketId.address,
69
- apy: vaultInfo.apy.total,
70
- transactionData: {
71
- approval: this.buildApprovalTx(
72
- assetAddress,
73
- params.marketId.address,
74
- params.amountWei,
75
- ),
76
- position: {
77
- to: params.marketId.address,
78
- data: depositCallData,
79
- value: 0n,
80
- },
69
+ spender: params.marketId.address,
70
+ assetAddress,
71
+ transaction: {
72
+ to: params.marketId.address,
73
+ data: depositCallData,
74
+ value: 0n,
81
75
  },
76
+ apy: vaultInfo.apy.total,
82
77
  }
83
78
  } catch {
84
79
  throw new Error(
@@ -119,7 +114,7 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
119
114
 
120
115
  return {
121
116
  amount: params.amount,
122
- asset: assetAddress,
117
+ assetAddress,
123
118
  marketId: params.marketId.address,
124
119
  apy: vaultInfo.apy.total,
125
120
  transactionData: {
@@ -180,6 +175,10 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
180
175
  const publicClient = this.chainManager.getPublicClient(
181
176
  params.marketId.chainId,
182
177
  )
178
+ const underlyingDecimals = await this.resolveUnderlyingDecimals(
179
+ publicClient,
180
+ params.marketId,
181
+ )
183
182
 
184
183
  // Get user's market token balance (shares in the vault)
185
184
  const shares = await publicClient.readContract({
@@ -192,28 +191,17 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
192
191
  // Convert shares to underlying asset balance using convertToAssets
193
192
  const balance = await publicClient.readContract({
194
193
  address: params.marketId.address,
195
- abi: [
196
- {
197
- name: 'convertToAssets',
198
- type: 'function',
199
- stateMutability: 'view',
200
- inputs: [{ name: 'shares', type: 'uint256' }],
201
- outputs: [{ name: '', type: 'uint256' }],
202
- },
203
- ],
194
+ abi: erc4626Abi,
204
195
  functionName: 'convertToAssets',
205
196
  args: [shares],
206
197
  })
207
198
 
208
- // Format the balances (USDC has 6 decimals)
209
- const balanceFormatted = formatUnits(balance, 6)
210
- const sharesFormatted = formatUnits(shares, 18) // Vault shares typically have 18 decimals
211
-
212
199
  return {
213
200
  balance,
214
- balanceFormatted,
201
+ balanceFormatted: formatUnits(balance, underlyingDecimals),
215
202
  shares,
216
- sharesFormatted,
203
+ // MetaMorpho vault shares are 18 decimals by contract invariant
204
+ sharesFormatted: formatUnits(shares, 18),
217
205
  marketId: params.marketId,
218
206
  }
219
207
  } catch {
@@ -222,4 +210,30 @@ export class MorphoLendProvider extends LendProvider<LendProviderConfig> {
222
210
  )
223
211
  }
224
212
  }
213
+
214
+ /**
215
+ * Resolve the underlying asset decimals for a market.
216
+ * @description Prefers the allowlisted market config (free, no RPC).
217
+ * Falls back to an on-chain read of the vault's ERC-4626 `asset()` +
218
+ * ERC-20 `decimals()` when the allowlist is empty or doesn't contain the
219
+ * market (e.g. a provider configured without an allowlist).
220
+ */
221
+ private async resolveUnderlyingDecimals(
222
+ publicClient: PublicClient,
223
+ marketId: LendMarketId,
224
+ ): Promise<number> {
225
+ const match = findMarketInAllowlist(this._config.marketAllowlist, marketId)
226
+ if (match) return match.asset.metadata.decimals
227
+
228
+ const underlying = await publicClient.readContract({
229
+ address: marketId.address,
230
+ abi: erc4626Abi,
231
+ functionName: 'asset',
232
+ })
233
+ return publicClient.readContract({
234
+ address: underlying,
235
+ abi: erc20Abi,
236
+ functionName: 'decimals',
237
+ })
238
+ }
225
239
  }
@@ -5,9 +5,9 @@ import {
5
5
  MockGauntletUSDCMarket,
6
6
  MockReceiverAddress,
7
7
  MockWETHMarket,
8
- } from '@/lend/__mocks__/MockMarkets.js'
9
- import { createMockMorphoVault } from '@/lend/providers/morpho/__mocks__/mockVault.js'
10
- import { MorphoLendProvider } from '@/lend/providers/morpho/MorphoLendProvider.js'
8
+ } from '@/actions/lend/__mocks__/MockMarkets.js'
9
+ import { createMockMorphoVault } from '@/actions/lend/providers/morpho/__mocks__/mockVault.js'
10
+ import { MorphoLendProvider } from '@/actions/lend/providers/morpho/MorphoLendProvider.js'
11
11
  import { MockChainManager } from '@/services/__mocks__/MockChainManager.js'
12
12
  import type { ChainManager } from '@/services/ChainManager.js'
13
13
  import type { LendProviderConfig } from '@/types/actions.js'
@@ -101,7 +101,7 @@ describe('MorphoLendProvider', () => {
101
101
 
102
102
  expect(withdrawTransaction).toHaveProperty('amount', BigInt('500000000'))
103
103
  expect(withdrawTransaction).toHaveProperty(
104
- 'asset',
104
+ 'assetAddress',
105
105
  asset.address[marketId.chainId],
106
106
  )
107
107
  expect(withdrawTransaction).toHaveProperty('marketId', marketId.address)
@@ -200,7 +200,7 @@ describe('MorphoLendProvider', () => {
200
200
 
201
201
  expect(lendTransaction).toHaveProperty('amount', BigInt('1000000000'))
202
202
  expect(lendTransaction).toHaveProperty(
203
- 'asset',
203
+ 'assetAddress',
204
204
  asset.address[marketId.chainId],
205
205
  )
206
206
  expect(lendTransaction).toHaveProperty('marketId', marketId.address)
@@ -235,6 +235,80 @@ describe('MorphoLendProvider', () => {
235
235
  })
236
236
  })
237
237
 
238
+ describe('getPosition', () => {
239
+ it('formats balance using the allowlist asset decimals (USDC, 6)', async () => {
240
+ const client = mockChainManager.getPublicClient(
241
+ MockGauntletUSDCMarket.chainId,
242
+ )
243
+ const shares = 10n ** 18n // 1 share
244
+ const underlyingBalance = 10n ** 6n // 1 USDC
245
+ vi.mocked(client.readContract)
246
+ .mockResolvedValueOnce(shares)
247
+ .mockResolvedValueOnce(underlyingBalance)
248
+
249
+ const position = await provider.getPosition(MockReceiverAddress, {
250
+ address: MockGauntletUSDCMarket.address,
251
+ chainId: MockGauntletUSDCMarket.chainId,
252
+ })
253
+
254
+ expect(position.balance).toBe(underlyingBalance)
255
+ expect(position.balanceFormatted).toBe('1')
256
+ expect(position.shares).toBe(shares)
257
+ expect(position.sharesFormatted).toBe('1')
258
+ })
259
+
260
+ it('formats balance using the allowlist asset decimals (WETH, 18)', async () => {
261
+ const client = mockChainManager.getPublicClient(MockWETHMarket.chainId)
262
+ const shares = 10n ** 18n
263
+ const underlyingBalance = 10n ** 18n // 1 WETH
264
+ vi.mocked(client.readContract)
265
+ .mockResolvedValueOnce(shares)
266
+ .mockResolvedValueOnce(underlyingBalance)
267
+
268
+ const position = await provider.getPosition(MockReceiverAddress, {
269
+ address: MockWETHMarket.address,
270
+ chainId: MockWETHMarket.chainId,
271
+ })
272
+
273
+ expect(position.balance).toBe(underlyingBalance)
274
+ expect(position.balanceFormatted).toBe('1')
275
+ })
276
+
277
+ it('falls back to on-chain asset() + decimals() when no allowlist match', async () => {
278
+ const providerWithoutAllowlist = new MorphoLendProvider(
279
+ {},
280
+ mockChainManager,
281
+ )
282
+ const client = mockChainManager.getPublicClient(
283
+ MockGauntletUSDCMarket.chainId,
284
+ )
285
+ const underlyingAddr = '0xabcdefabcdefabcdefabcdefabcdefabcdefabcd'
286
+ const onchainDecimals = 8 // simulate a non-USDC underlying
287
+ const shares = 10n ** 18n
288
+ const underlyingBalance = 10n ** 8n
289
+ vi.mocked(client.readContract)
290
+ // resolveUnderlyingDecimals: asset()
291
+ .mockResolvedValueOnce(underlyingAddr)
292
+ // resolveUnderlyingDecimals: decimals()
293
+ .mockResolvedValueOnce(onchainDecimals)
294
+ // balanceOf
295
+ .mockResolvedValueOnce(shares)
296
+ // convertToAssets
297
+ .mockResolvedValueOnce(underlyingBalance)
298
+
299
+ const position = await providerWithoutAllowlist.getPosition(
300
+ MockReceiverAddress,
301
+ {
302
+ address: MockGauntletUSDCMarket.address,
303
+ chainId: MockGauntletUSDCMarket.chainId,
304
+ },
305
+ )
306
+
307
+ expect(position.balanceFormatted).toBe('1')
308
+ expect(position.sharesFormatted).toBe('1')
309
+ })
310
+ })
311
+
238
312
  describe('market allowlist configuration', () => {
239
313
  it('should work without market allowlist', () => {
240
314
  const configWithoutAllowlist: LendProviderConfig = {}
@@ -2,12 +2,12 @@ import type { Address } from 'viem'
2
2
  import { mainnet } from 'viem/chains'
3
3
  import { afterEach, describe, expect, it, vi } from 'vitest'
4
4
 
5
- import { MORPHO, USDC } from '@/constants/assets.js'
6
- import { fetchRewards } from '@/lend/providers/morpho/api.js'
5
+ import { fetchRewards } from '@/actions/lend/providers/morpho/api.js'
7
6
  import {
8
7
  calculateRewardsBreakdown,
9
8
  fetchAndCalculateRewards,
10
- } from '@/lend/providers/morpho/sdk.js'
9
+ } from '@/actions/lend/providers/morpho/sdk.js'
10
+ import { MORPHO, USDC } from '@/constants/assets.js'
11
11
  import { externalTest } from '@/utils/test.js'
12
12
 
13
13
  const CHAIN_ID = mainnet.id