@eth-optimism/actions-sdk 0.4.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 (770) 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 +33 -18
  105. package/dist/actions/swap/core/SwapProvider.d.ts.map +1 -0
  106. package/dist/{swap → actions/swap}/core/SwapProvider.js +59 -44
  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 +27 -28
  120. package/dist/actions/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
  121. package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.js +73 -69
  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/actions/swap/namespaces/WalletSwapNamespace.js +109 -0
  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 +6 -6
  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 +9 -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 +10 -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 +40 -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 +12 -2
  219. package/dist/actions.d.ts.map +1 -1
  220. package/dist/actions.js +56 -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 -3
  231. package/dist/index.d.ts.map +1 -1
  232. package/dist/index.js +6 -2
  233. package/dist/index.js.map +1 -1
  234. package/dist/services/ChainManager.d.ts +7 -0
  235. package/dist/services/ChainManager.d.ts.map +1 -1
  236. package/dist/services/ChainManager.js +35 -7
  237. package/dist/services/ChainManager.js.map +1 -1
  238. package/dist/services/__mocks__/MockChainManager.d.ts +1 -0
  239. package/dist/services/__mocks__/MockChainManager.d.ts.map +1 -1
  240. package/dist/services/__mocks__/MockChainManager.js +5 -0
  241. package/dist/services/__mocks__/MockChainManager.js.map +1 -1
  242. package/dist/services/__tests__/ChainManager.spec.d.ts.map +1 -0
  243. package/dist/services/{ChainManager.spec.js → __tests__/ChainManager.spec.js} +7 -7
  244. package/dist/services/__tests__/ChainManager.spec.js.map +1 -0
  245. package/dist/services/__tests__/tokenBalance.spec.d.ts.map +1 -0
  246. package/dist/services/{tokenBalance.spec.js → __tests__/tokenBalance.spec.js} +42 -5
  247. package/dist/services/__tests__/tokenBalance.spec.js.map +1 -0
  248. package/dist/services/nameservices/ens/EnsNamespace.d.ts +57 -0
  249. package/dist/services/nameservices/ens/EnsNamespace.d.ts.map +1 -0
  250. package/dist/services/nameservices/ens/EnsNamespace.js +158 -0
  251. package/dist/services/nameservices/ens/EnsNamespace.js.map +1 -0
  252. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts +2 -0
  253. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts.map +1 -0
  254. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js +144 -0
  255. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js.map +1 -0
  256. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts +2 -0
  257. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts.map +1 -0
  258. package/dist/services/nameservices/ens/__tests__/utils.spec.js +75 -0
  259. package/dist/services/nameservices/ens/__tests__/utils.spec.js.map +1 -0
  260. package/dist/services/nameservices/ens/errors.d.ts +24 -0
  261. package/dist/services/nameservices/ens/errors.d.ts.map +1 -0
  262. package/dist/services/nameservices/ens/errors.js +35 -0
  263. package/dist/services/nameservices/ens/errors.js.map +1 -0
  264. package/dist/services/nameservices/ens/index.d.ts +5 -0
  265. package/dist/services/nameservices/ens/index.d.ts.map +1 -0
  266. package/dist/services/nameservices/ens/index.js +5 -0
  267. package/dist/services/nameservices/ens/index.js.map +1 -0
  268. package/dist/services/nameservices/ens/types.d.ts +63 -0
  269. package/dist/services/nameservices/ens/types.d.ts.map +1 -0
  270. package/dist/services/nameservices/ens/types.js +14 -0
  271. package/dist/services/nameservices/ens/types.js.map +1 -0
  272. package/dist/services/nameservices/ens/utils.d.ts +25 -0
  273. package/dist/services/nameservices/ens/utils.d.ts.map +1 -0
  274. package/dist/services/nameservices/ens/utils.js +53 -0
  275. package/dist/services/nameservices/ens/utils.js.map +1 -0
  276. package/dist/services/tokenBalance.d.ts +8 -5
  277. package/dist/services/tokenBalance.d.ts.map +1 -1
  278. package/dist/services/tokenBalance.js +15 -8
  279. package/dist/services/tokenBalance.js.map +1 -1
  280. package/dist/types/actions.d.ts +69 -7
  281. package/dist/types/actions.d.ts.map +1 -1
  282. package/dist/types/asset.d.ts +7 -0
  283. package/dist/types/asset.d.ts.map +1 -1
  284. package/dist/types/common/FilterAssetChain.d.ts +13 -0
  285. package/dist/types/common/FilterAssetChain.d.ts.map +1 -0
  286. package/dist/types/common/FilterAssetChain.js +2 -0
  287. package/dist/types/common/FilterAssetChain.js.map +1 -0
  288. package/dist/types/common/TransactionOptions.d.ts +13 -0
  289. package/dist/types/common/TransactionOptions.d.ts.map +1 -0
  290. package/dist/types/common/TransactionOptions.js +2 -0
  291. package/dist/types/common/TransactionOptions.js.map +1 -0
  292. package/dist/types/common/index.d.ts +3 -0
  293. package/dist/types/common/index.d.ts.map +1 -0
  294. package/dist/types/common/index.js +3 -0
  295. package/dist/types/common/index.js.map +1 -0
  296. package/dist/types/index.d.ts +1 -0
  297. package/dist/types/index.d.ts.map +1 -1
  298. package/dist/types/index.js +1 -0
  299. package/dist/types/index.js.map +1 -1
  300. package/dist/types/lend/base.d.ts +44 -34
  301. package/dist/types/lend/base.d.ts.map +1 -1
  302. package/dist/types/lend/base.js +3 -3
  303. package/dist/types/lend/base.js.map +1 -1
  304. package/dist/types/lend/index.d.ts +0 -1
  305. package/dist/types/lend/index.d.ts.map +1 -1
  306. package/dist/types/lend/index.js +0 -1
  307. package/dist/types/lend/index.js.map +1 -1
  308. package/dist/types/providers.d.ts +2 -2
  309. package/dist/types/providers.d.ts.map +1 -1
  310. package/dist/types/swap/base.d.ts +29 -16
  311. package/dist/types/swap/base.d.ts.map +1 -1
  312. package/dist/types/swap/base.js +3 -3
  313. package/dist/types/swap/base.js.map +1 -1
  314. package/dist/utils/__tests__/approve.test.d.ts.map +1 -0
  315. package/dist/utils/{approve.test.js → __tests__/approve.test.js} +40 -18
  316. package/dist/utils/__tests__/approve.test.js.map +1 -0
  317. package/dist/utils/__tests__/assets.test.d.ts.map +1 -0
  318. package/dist/utils/{assets.test.js → __tests__/assets.test.js} +2 -2
  319. package/dist/utils/__tests__/assets.test.js.map +1 -0
  320. package/dist/utils/__tests__/serializers.test.d.ts +2 -0
  321. package/dist/utils/__tests__/serializers.test.d.ts.map +1 -0
  322. package/dist/utils/__tests__/serializers.test.js +43 -0
  323. package/dist/utils/__tests__/serializers.test.js.map +1 -0
  324. package/dist/utils/__tests__/validateAddresses.test.d.ts.map +1 -0
  325. package/dist/utils/{validateAddresses.test.js → __tests__/validateAddresses.test.js} +10 -10
  326. package/dist/utils/__tests__/validateAddresses.test.js.map +1 -0
  327. package/dist/utils/abi/permit2.d.ts +48 -0
  328. package/dist/utils/abi/permit2.d.ts.map +1 -0
  329. package/dist/utils/abi/permit2.js +34 -0
  330. package/dist/utils/abi/permit2.js.map +1 -0
  331. package/dist/utils/approve.d.ts +26 -3
  332. package/dist/utils/approve.d.ts.map +1 -1
  333. package/dist/utils/approve.js +34 -37
  334. package/dist/utils/approve.js.map +1 -1
  335. package/dist/utils/assets.d.ts.map +1 -1
  336. package/dist/utils/assets.js +3 -2
  337. package/dist/utils/assets.js.map +1 -1
  338. package/dist/utils/serializers.d.ts +16 -0
  339. package/dist/utils/serializers.d.ts.map +1 -0
  340. package/dist/utils/serializers.js +18 -0
  341. package/dist/utils/serializers.js.map +1 -0
  342. package/dist/utils/validation.d.ts +13 -1
  343. package/dist/utils/validation.d.ts.map +1 -1
  344. package/dist/utils/validation.js +38 -8
  345. package/dist/utils/validation.js.map +1 -1
  346. package/dist/wallet/core/error/errors.d.ts +21 -0
  347. package/dist/wallet/core/error/errors.d.ts.map +1 -0
  348. package/dist/wallet/core/error/errors.js +24 -0
  349. package/dist/wallet/core/error/errors.js.map +1 -0
  350. package/dist/wallet/core/namespace/WalletNamespace.d.ts +24 -8
  351. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  352. package/dist/wallet/core/namespace/WalletNamespace.js +48 -17
  353. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  354. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +105 -10
  355. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  356. package/dist/wallet/core/providers/WalletProvider.d.ts +3 -2
  357. package/dist/wallet/core/providers/WalletProvider.d.ts.map +1 -1
  358. package/dist/wallet/core/providers/WalletProvider.js +8 -2
  359. package/dist/wallet/core/providers/WalletProvider.js.map +1 -1
  360. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +1 -1
  361. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
  362. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts.map +1 -1
  363. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js +2 -1
  364. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js.map +1 -1
  365. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +1 -1
  366. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
  367. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +1 -1
  368. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
  369. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts +2 -0
  370. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts.map +1 -0
  371. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js +31 -0
  372. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js.map +1 -0
  373. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +1 -0
  374. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.js.map +1 -0
  375. package/dist/wallet/core/utils/executeTransactionBatch.d.ts +22 -0
  376. package/dist/wallet/core/utils/executeTransactionBatch.d.ts.map +1 -0
  377. package/dist/wallet/core/utils/executeTransactionBatch.js +26 -0
  378. package/dist/wallet/core/utils/executeTransactionBatch.js.map +1 -0
  379. package/dist/wallet/core/utils/retryOnStaleRead.d.ts.map +1 -0
  380. package/dist/wallet/core/utils/retryOnStaleRead.js.map +1 -0
  381. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +8 -8
  382. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  383. package/dist/wallet/core/wallets/abstract/Wallet.js +15 -12
  384. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  385. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +3 -3
  386. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  387. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  388. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +28 -2
  389. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  390. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts +1 -1
  391. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts.map +1 -1
  392. package/dist/wallet/core/wallets/eoa/EOAWallet.js.map +1 -1
  393. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts +1 -1
  394. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts.map +1 -1
  395. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +1 -1
  396. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  397. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +2 -2
  398. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  399. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +1 -1
  400. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  401. package/dist/wallet/node/index.d.ts +1 -0
  402. package/dist/wallet/node/index.d.ts.map +1 -1
  403. package/dist/wallet/node/index.js +1 -0
  404. package/dist/wallet/node/index.js.map +1 -1
  405. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  406. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  407. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +1 -1
  408. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  409. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  410. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  411. package/dist/wallet/node/wallets/local/LocalWallet.d.ts +24 -0
  412. package/dist/wallet/node/wallets/local/LocalWallet.d.ts.map +1 -0
  413. package/dist/wallet/node/wallets/local/LocalWallet.js +21 -0
  414. package/dist/wallet/node/wallets/local/LocalWallet.js.map +1 -0
  415. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts +2 -0
  416. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts.map +1 -0
  417. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js +51 -0
  418. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js.map +1 -0
  419. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -1
  420. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
  421. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  422. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  423. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  424. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  425. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
  426. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  427. package/package.json +2 -2
  428. package/src/__tests__/actions.test.ts +3 -1
  429. package/src/{lend → actions/lend}/__mocks__/MockLendProvider.ts +24 -9
  430. package/src/{lend → actions/lend}/__mocks__/mockLendTransaction.ts +2 -2
  431. package/src/{lend → actions/lend}/core/LendProvider.ts +123 -39
  432. package/src/{lend → actions/lend}/core/__tests__/LendProvider.test.ts +82 -3
  433. package/src/actions/lend/index.ts +3 -0
  434. package/src/{lend → actions/lend}/namespaces/BaseLendNamespace.ts +20 -37
  435. package/src/{lend → actions/lend}/namespaces/WalletLendNamespace.ts +15 -22
  436. package/src/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.ts +3 -3
  437. package/src/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.ts +3 -3
  438. package/src/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.ts +6 -6
  439. package/src/{lend → actions/lend}/providers/aave/AaveLendProvider.ts +65 -73
  440. package/src/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.ts +7 -7
  441. package/src/{lend → actions/lend}/providers/aave/sdk.ts +15 -9
  442. package/src/{lend → actions/lend}/providers/morpho/MorphoLendProvider.ts +67 -53
  443. package/src/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.ts +79 -5
  444. package/src/{lend → actions/lend}/providers/morpho/__tests__/api.test.ts +3 -3
  445. package/src/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.ts +2 -2
  446. package/src/{lend → actions/lend}/providers/morpho/sdk.ts +23 -12
  447. package/src/actions/lend/utils/markets.ts +62 -0
  448. package/src/actions/shared/BaseNamespace.ts +46 -0
  449. package/src/actions/shared/__tests__/BaseNamespace.spec.ts +58 -0
  450. package/src/{lend/providers → actions/shared}/morpho/contracts.ts +2 -2
  451. package/src/{swap → actions/swap}/__mocks__/MockSwapProvider.ts +6 -2
  452. package/src/{swap → actions/swap}/core/SwapProvider.ts +99 -65
  453. package/src/{swap → actions/swap}/core/__tests__/SwapProvider.test.ts +51 -1
  454. package/src/{swap → actions/swap}/core/markets.ts +2 -1
  455. package/src/actions/swap/index.ts +19 -0
  456. package/src/{swap → actions/swap}/namespaces/ActionsSwapNamespace.ts +1 -1
  457. package/src/{swap → actions/swap}/namespaces/BaseSwapNamespace.ts +127 -109
  458. package/src/actions/swap/namespaces/WalletSwapNamespace.ts +154 -0
  459. package/src/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.ts +10 -6
  460. package/src/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.ts +110 -22
  461. package/src/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.ts +37 -15
  462. package/src/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +2 -2
  463. package/src/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.ts +65 -3
  464. package/src/{swap → actions/swap}/providers/uniswap/addresses.ts +5 -1
  465. package/src/{swap → actions/swap}/providers/uniswap/encoding.ts +3 -3
  466. package/src/{swap → actions/swap}/providers/uniswap/markets.ts +2 -2
  467. package/src/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.ts +74 -32
  468. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +2 -2
  469. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +8 -7
  470. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +47 -5
  471. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.ts +31 -2
  472. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.ts +34 -3
  473. package/src/{swap → actions/swap}/providers/velodrome/config.ts +5 -1
  474. package/src/{swap → actions/swap}/providers/velodrome/encoding/helpers.ts +3 -2
  475. package/src/{swap → actions/swap}/providers/velodrome/encoding/index.ts +0 -1
  476. package/src/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.ts +4 -3
  477. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.ts +31 -23
  478. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.ts +34 -27
  479. package/src/{swap → actions/swap}/providers/velodrome/markets.ts +4 -3
  480. package/src/actions.ts +82 -36
  481. package/src/core/error/__tests__/errors.test.ts +236 -0
  482. package/src/core/error/errors.ts +282 -22
  483. package/src/index.ts +25 -10
  484. package/src/services/ChainManager.ts +36 -9
  485. package/src/services/__mocks__/MockChainManager.ts +8 -0
  486. package/src/services/{ChainManager.spec.ts → __tests__/ChainManager.spec.ts} +6 -6
  487. package/src/services/{tokenBalance.spec.ts → __tests__/tokenBalance.spec.ts} +56 -1
  488. package/src/services/nameservices/ens/EnsNamespace.ts +210 -0
  489. package/src/services/nameservices/ens/__tests__/EnsNamespace.spec.ts +173 -0
  490. package/src/services/nameservices/ens/__tests__/utils.spec.ts +105 -0
  491. package/src/services/nameservices/ens/errors.ts +45 -0
  492. package/src/services/nameservices/ens/index.ts +17 -0
  493. package/src/services/nameservices/ens/types.ts +76 -0
  494. package/src/services/nameservices/ens/utils.ts +85 -0
  495. package/src/services/tokenBalance.ts +16 -7
  496. package/src/types/actions.ts +72 -7
  497. package/src/types/asset.ts +8 -0
  498. package/src/types/common/FilterAssetChain.ts +13 -0
  499. package/src/types/common/TransactionOptions.ts +12 -0
  500. package/src/types/common/index.ts +2 -0
  501. package/src/types/index.ts +1 -0
  502. package/src/types/lend/base.ts +48 -36
  503. package/src/types/lend/index.ts +0 -1
  504. package/src/types/providers.ts +2 -2
  505. package/src/types/swap/base.ts +29 -16
  506. package/src/utils/{approve.test.ts → __tests__/approve.test.ts} +51 -18
  507. package/src/utils/__tests__/serializers.test.ts +53 -0
  508. package/src/utils/{validateAddresses.test.ts → __tests__/validateAddresses.test.ts} +9 -9
  509. package/src/utils/abi/permit2.ts +33 -0
  510. package/src/utils/approve.ts +48 -37
  511. package/src/utils/assets.ts +6 -6
  512. package/src/utils/serializers.ts +21 -0
  513. package/src/utils/validation.ts +53 -15
  514. package/src/wallet/core/error/errors.ts +30 -0
  515. package/src/wallet/core/namespace/WalletNamespace.ts +82 -20
  516. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +141 -16
  517. package/src/wallet/core/providers/WalletProvider.ts +12 -3
  518. package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +1 -1
  519. package/src/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.ts +2 -1
  520. package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +1 -1
  521. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +1 -1
  522. package/src/wallet/core/utils/__tests__/executeTransactionBatch.spec.ts +42 -0
  523. package/src/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.ts +1 -1
  524. package/src/wallet/core/utils/executeTransactionBatch.ts +37 -0
  525. package/src/wallet/core/wallets/abstract/Wallet.ts +19 -14
  526. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +3 -3
  527. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +54 -3
  528. package/src/wallet/core/wallets/eoa/EOAWallet.ts +1 -1
  529. package/src/wallet/core/wallets/smart/abstract/SmartWallet.ts +1 -1
  530. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +3 -3
  531. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +1 -1
  532. package/src/wallet/node/index.ts +1 -0
  533. package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  534. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +1 -1
  535. package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  536. package/src/wallet/node/wallets/local/LocalWallet.ts +48 -0
  537. package/src/wallet/node/wallets/local/__tests__/LocalWallet.spec.ts +64 -0
  538. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -1
  539. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  540. package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  541. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +1 -1
  542. package/dist/core/asset/__mocks__/mockAsset.d.ts +0 -6
  543. package/dist/core/asset/__mocks__/mockAsset.d.ts.map +0 -1
  544. package/dist/core/asset/__mocks__/mockAsset.js +0 -12
  545. package/dist/core/asset/__mocks__/mockAsset.js.map +0 -1
  546. package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +0 -1
  547. package/dist/core/utils/__tests__/retryOnStaleRead.spec.js.map +0 -1
  548. package/dist/core/utils/retryOnStaleRead.d.ts.map +0 -1
  549. package/dist/core/utils/retryOnStaleRead.js.map +0 -1
  550. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +0 -1
  551. package/dist/lend/__mocks__/MockLendProvider.js.map +0 -1
  552. package/dist/lend/__mocks__/MockMarkets.d.ts.map +0 -1
  553. package/dist/lend/__mocks__/MockMarkets.js.map +0 -1
  554. package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +0 -1
  555. package/dist/lend/__mocks__/mockLendTransaction.js.map +0 -1
  556. package/dist/lend/core/LendProvider.d.ts.map +0 -1
  557. package/dist/lend/core/LendProvider.js.map +0 -1
  558. package/dist/lend/core/__tests__/LendProvider.test.d.ts.map +0 -1
  559. package/dist/lend/core/__tests__/LendProvider.test.js.map +0 -1
  560. package/dist/lend/index.d.ts.map +0 -1
  561. package/dist/lend/index.js.map +0 -1
  562. package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +0 -1
  563. package/dist/lend/namespaces/ActionsLendNamespace.js.map +0 -1
  564. package/dist/lend/namespaces/BaseLendNamespace.d.ts +0 -43
  565. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +0 -1
  566. package/dist/lend/namespaces/BaseLendNamespace.js.map +0 -1
  567. package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +0 -1
  568. package/dist/lend/namespaces/WalletLendNamespace.js.map +0 -1
  569. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +0 -1
  570. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +0 -1
  571. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +0 -1
  572. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +0 -1
  573. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +0 -1
  574. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +0 -1
  575. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +0 -1
  576. package/dist/lend/providers/aave/AaveLendProvider.js.map +0 -1
  577. package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +0 -1
  578. package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +0 -1
  579. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +0 -1
  580. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +0 -1
  581. package/dist/lend/providers/aave/abis/pool.d.ts.map +0 -1
  582. package/dist/lend/providers/aave/abis/pool.js.map +0 -1
  583. package/dist/lend/providers/aave/addresses.d.ts.map +0 -1
  584. package/dist/lend/providers/aave/addresses.js.map +0 -1
  585. package/dist/lend/providers/aave/sdk.d.ts.map +0 -1
  586. package/dist/lend/providers/aave/sdk.js.map +0 -1
  587. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +0 -1
  588. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +0 -1
  589. package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts.map +0 -1
  590. package/dist/lend/providers/morpho/__mocks__/mockVault.js.map +0 -1
  591. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +0 -1
  592. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +0 -1
  593. package/dist/lend/providers/morpho/__tests__/api.test.d.ts.map +0 -1
  594. package/dist/lend/providers/morpho/__tests__/api.test.js.map +0 -1
  595. package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts.map +0 -1
  596. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +0 -1
  597. package/dist/lend/providers/morpho/api.d.ts.map +0 -1
  598. package/dist/lend/providers/morpho/api.js.map +0 -1
  599. package/dist/lend/providers/morpho/contracts.d.ts.map +0 -1
  600. package/dist/lend/providers/morpho/sdk.d.ts.map +0 -1
  601. package/dist/lend/providers/morpho/sdk.js.map +0 -1
  602. package/dist/services/ChainManager.spec.d.ts.map +0 -1
  603. package/dist/services/ChainManager.spec.js.map +0 -1
  604. package/dist/services/tokenBalance.spec.d.ts.map +0 -1
  605. package/dist/services/tokenBalance.spec.js.map +0 -1
  606. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +0 -1
  607. package/dist/swap/__mocks__/MockSwapProvider.js.map +0 -1
  608. package/dist/swap/core/SwapProvider.d.ts.map +0 -1
  609. package/dist/swap/core/SwapProvider.js.map +0 -1
  610. package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +0 -1
  611. package/dist/swap/core/__tests__/SwapProvider.test.js.map +0 -1
  612. package/dist/swap/core/markets.d.ts.map +0 -1
  613. package/dist/swap/core/markets.js.map +0 -1
  614. package/dist/swap/index.d.ts.map +0 -1
  615. package/dist/swap/index.js.map +0 -1
  616. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +0 -1
  617. package/dist/swap/namespaces/ActionsSwapNamespace.js.map +0 -1
  618. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +0 -1
  619. package/dist/swap/namespaces/BaseSwapNamespace.js.map +0 -1
  620. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +0 -34
  621. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +0 -1
  622. package/dist/swap/namespaces/WalletSwapNamespace.js +0 -84
  623. package/dist/swap/namespaces/WalletSwapNamespace.js.map +0 -1
  624. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +0 -1
  625. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +0 -1
  626. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +0 -1
  627. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +0 -1
  628. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +0 -1
  629. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +0 -1
  630. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +0 -1
  631. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +0 -1
  632. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +0 -1
  633. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +0 -1
  634. package/dist/swap/providers/uniswap/abis.d.ts.map +0 -1
  635. package/dist/swap/providers/uniswap/abis.js.map +0 -1
  636. package/dist/swap/providers/uniswap/addresses.d.ts.map +0 -1
  637. package/dist/swap/providers/uniswap/addresses.js.map +0 -1
  638. package/dist/swap/providers/uniswap/encoding.d.ts.map +0 -1
  639. package/dist/swap/providers/uniswap/encoding.js.map +0 -1
  640. package/dist/swap/providers/uniswap/markets.d.ts.map +0 -1
  641. package/dist/swap/providers/uniswap/markets.js.map +0 -1
  642. package/dist/swap/providers/uniswap/types.d.ts.map +0 -1
  643. package/dist/swap/providers/uniswap/types.js.map +0 -1
  644. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +0 -1
  645. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +0 -1
  646. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +0 -1
  647. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +0 -1
  648. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +0 -1
  649. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +0 -1
  650. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +0 -1
  651. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +0 -1
  652. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +0 -1
  653. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +0 -1
  654. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +0 -1
  655. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +0 -1
  656. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +0 -1
  657. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +0 -1
  658. package/dist/swap/providers/velodrome/abis.d.ts.map +0 -1
  659. package/dist/swap/providers/velodrome/abis.js.map +0 -1
  660. package/dist/swap/providers/velodrome/addresses.d.ts.map +0 -1
  661. package/dist/swap/providers/velodrome/addresses.js.map +0 -1
  662. package/dist/swap/providers/velodrome/config.d.ts.map +0 -1
  663. package/dist/swap/providers/velodrome/config.js.map +0 -1
  664. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +0 -1
  665. package/dist/swap/providers/velodrome/encoding/helpers.js.map +0 -1
  666. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +0 -1
  667. package/dist/swap/providers/velodrome/encoding/index.js.map +0 -1
  668. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +0 -1
  669. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +0 -1
  670. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +0 -15
  671. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +0 -1
  672. package/dist/swap/providers/velodrome/encoding/routers/approval.js +0 -33
  673. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +0 -1
  674. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +0 -1
  675. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +0 -1
  676. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +0 -1
  677. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +0 -1
  678. package/dist/swap/providers/velodrome/markets.d.ts.map +0 -1
  679. package/dist/swap/providers/velodrome/markets.js.map +0 -1
  680. package/dist/swap/providers/velodrome/types.d.ts.map +0 -1
  681. package/dist/swap/providers/velodrome/types.js.map +0 -1
  682. package/dist/types/lend/contracts.d.ts.map +0 -1
  683. package/dist/types/lend/contracts.js +0 -2
  684. package/dist/types/lend/contracts.js.map +0 -1
  685. package/dist/utils/approve.test.d.ts.map +0 -1
  686. package/dist/utils/approve.test.js.map +0 -1
  687. package/dist/utils/assets.test.d.ts.map +0 -1
  688. package/dist/utils/assets.test.js.map +0 -1
  689. package/dist/utils/markets.d.ts +0 -17
  690. package/dist/utils/markets.d.ts.map +0 -1
  691. package/dist/utils/markets.js +0 -25
  692. package/dist/utils/markets.js.map +0 -1
  693. package/dist/utils/validateAddresses.test.d.ts.map +0 -1
  694. package/dist/utils/validateAddresses.test.js.map +0 -1
  695. package/src/core/asset/__mocks__/mockAsset.ts +0 -13
  696. package/src/lend/index.ts +0 -3
  697. package/src/swap/index.ts +0 -19
  698. package/src/swap/namespaces/WalletSwapNamespace.ts +0 -121
  699. package/src/swap/providers/velodrome/encoding/routers/approval.ts +0 -45
  700. package/src/utils/markets.ts +0 -35
  701. /package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.d.ts +0 -0
  702. /package/dist/{lend → actions/lend}/index.d.ts +0 -0
  703. /package/dist/{lend → actions/lend}/index.js +0 -0
  704. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.d.ts +0 -0
  705. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.js +0 -0
  706. /package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.d.ts +0 -0
  707. /package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.d.ts +0 -0
  708. /package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.d.ts +0 -0
  709. /package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.js +0 -0
  710. /package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.d.ts +0 -0
  711. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.d.ts +0 -0
  712. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.js +0 -0
  713. /package/dist/{lend → actions/lend}/providers/aave/addresses.d.ts +0 -0
  714. /package/dist/{lend → actions/lend}/providers/aave/addresses.js +0 -0
  715. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.d.ts +0 -0
  716. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.js +0 -0
  717. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.d.ts +0 -0
  718. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.d.ts +0 -0
  719. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.d.ts +0 -0
  720. /package/dist/{lend → actions/lend}/providers/morpho/api.d.ts +0 -0
  721. /package/dist/{lend → actions/lend}/providers/morpho/api.js +0 -0
  722. /package/dist/{lend/providers → actions/shared}/morpho/contracts.js +0 -0
  723. /package/dist/{swap/providers/uniswap → actions/shared/morpho}/types.js +0 -0
  724. /package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.d.ts +0 -0
  725. /package/dist/{swap → actions/swap}/index.d.ts +0 -0
  726. /package/dist/{swap → actions/swap}/index.js +0 -0
  727. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.d.ts +0 -0
  728. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.js +0 -0
  729. /package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +0 -0
  730. /package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +0 -0
  731. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +0 -0
  732. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.d.ts +0 -0
  733. /package/dist/{swap → actions/swap}/providers/uniswap/abis.d.ts +0 -0
  734. /package/dist/{swap → actions/swap}/providers/uniswap/abis.js +0 -0
  735. /package/dist/{swap/providers/velodrome → actions/swap/providers/uniswap}/types.js +0 -0
  736. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +0 -0
  737. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +0 -0
  738. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +0 -0
  739. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +0 -0
  740. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.d.ts +0 -0
  741. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.js +0 -0
  742. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.d.ts +0 -0
  743. /package/dist/{swap → actions/swap}/providers/velodrome/abis.d.ts +0 -0
  744. /package/dist/{swap → actions/swap}/providers/velodrome/abis.js +0 -0
  745. /package/dist/{swap → actions/swap}/providers/velodrome/addresses.js +0 -0
  746. /package/dist/services/{ChainManager.spec.d.ts → __tests__/ChainManager.spec.d.ts} +0 -0
  747. /package/dist/services/{tokenBalance.spec.d.ts → __tests__/tokenBalance.spec.d.ts} +0 -0
  748. /package/dist/utils/{approve.test.d.ts → __tests__/approve.test.d.ts} +0 -0
  749. /package/dist/utils/{assets.test.d.ts → __tests__/assets.test.d.ts} +0 -0
  750. /package/dist/utils/{validateAddresses.test.d.ts → __tests__/validateAddresses.test.d.ts} +0 -0
  751. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.d.ts +0 -0
  752. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.js +0 -0
  753. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.d.ts +0 -0
  754. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.js +0 -0
  755. /package/src/{lend → actions/lend}/__mocks__/MockMarkets.ts +0 -0
  756. /package/src/{lend → actions/lend}/namespaces/ActionsLendNamespace.ts +0 -0
  757. /package/src/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.ts +0 -0
  758. /package/src/{lend → actions/lend}/providers/aave/abis/pool.ts +0 -0
  759. /package/src/{lend → actions/lend}/providers/aave/addresses.ts +0 -0
  760. /package/src/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.ts +0 -0
  761. /package/src/{lend → actions/lend}/providers/morpho/api.ts +0 -0
  762. /package/src/{types/lend/contracts.ts → actions/shared/morpho/types.ts} +0 -0
  763. /package/src/{swap → actions/swap}/providers/uniswap/abis.ts +0 -0
  764. /package/src/{swap → actions/swap}/providers/uniswap/types.ts +0 -0
  765. /package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.ts +0 -0
  766. /package/src/{swap → actions/swap}/providers/velodrome/abis.ts +0 -0
  767. /package/src/{swap → actions/swap}/providers/velodrome/addresses.ts +0 -0
  768. /package/src/{swap → actions/swap}/providers/velodrome/types.ts +0 -0
  769. /package/src/utils/{assets.test.ts → __tests__/assets.test.ts} +0 -0
  770. /package/src/{core → wallet/core}/utils/retryOnStaleRead.ts +0 -0
@@ -1,27 +1,287 @@
1
- import type { TransactionReceipt } from 'viem'
1
+ import { BaseError } from 'viem'
2
2
 
3
3
  /**
4
- * Error for a transaction that was included on-chain but reverted
5
- * @description Thrown when a transaction makes it into a block (i.e. has a
6
- * confirmed receipt) yet the EVM execution failed. The full
7
- * {@link TransactionReceipt | transaction receipt} is attached for
8
- * post-mortem analysis (status, logs, gas usage, etc.).
4
+ * Abstract base class for all Actions SDK errors.
5
+ * Extends viem's BaseError so callers can use instanceof narrowing
6
+ * and structured metaMessages alongside the shortMessage.
9
7
  */
10
- export class TransactionConfirmedButRevertedError extends Error {
11
- /** Full receipt returned by the node for the reverted transaction */
12
- receipt: TransactionReceipt
13
-
14
- /**
15
- * Create an instance of TransactionConfirmedButRevertedError
16
- * @param message - Human-readable description of the failure
17
- * @param receipt - Confirmed transaction receipt indicating a revert
18
- */
19
- constructor(message: string, receipt: TransactionReceipt) {
20
- if (!message || typeof message !== 'string') {
21
- throw new Error('"message" must be a nonempty string.')
22
- }
23
-
24
- super(message)
25
- this.receipt = receipt
8
+ export abstract class ActionsError extends BaseError {}
9
+
10
+ // ─────────────────────────────────────────────────────────────────────────────
11
+ // Chain / Network
12
+ // ─────────────────────────────────────────────────────────────────────────────
13
+
14
+ export class ChainNotSupportedError extends ActionsError {
15
+ override name = 'ChainNotSupportedError' as const
16
+ chainId: number
17
+ supportedChainIds: readonly number[]
18
+
19
+ constructor(params: {
20
+ chainId: number
21
+ supportedChainIds?: readonly number[]
22
+ }) {
23
+ super(`Chain ${params.chainId} is not supported`, {
24
+ metaMessages: params.supportedChainIds?.length
25
+ ? [`Supported chains: ${params.supportedChainIds.join(', ')}`]
26
+ : undefined,
27
+ })
28
+ this.chainId = params.chainId
29
+ this.supportedChainIds = params.supportedChainIds ?? []
30
+ }
31
+ }
32
+
33
+ // ─────────────────────────────────────────────────────────────────────────────
34
+ // Market / Provider
35
+ // ─────────────────────────────────────────────────────────────────────────────
36
+
37
+ export class MarketNotAllowedError extends ActionsError {
38
+ override name = 'MarketNotAllowedError' as const
39
+ chainId: number
40
+ assetInSymbol?: string
41
+ assetOutSymbol?: string
42
+ address?: string
43
+
44
+ constructor(params: {
45
+ chainId: number
46
+ assetInSymbol?: string
47
+ assetOutSymbol?: string
48
+ address?: string
49
+ reason?: string
50
+ }) {
51
+ const pair =
52
+ params.assetInSymbol && params.assetOutSymbol
53
+ ? `${params.assetInSymbol}/${params.assetOutSymbol}`
54
+ : (params.address ?? 'unknown')
55
+ super(`Market ${pair} not allowed on chain ${params.chainId}`, {
56
+ metaMessages: params.reason ? [params.reason] : undefined,
57
+ })
58
+ this.chainId = params.chainId
59
+ this.assetInSymbol = params.assetInSymbol
60
+ this.assetOutSymbol = params.assetOutSymbol
61
+ this.address = params.address
62
+ }
63
+ }
64
+
65
+ export class MarketNotFoundError extends ActionsError {
66
+ override name = 'MarketNotFoundError' as const
67
+ chainId: number
68
+ poolId?: string
69
+
70
+ constructor(params: { chainId: number; poolId?: string; reason?: string }) {
71
+ super(
72
+ params.poolId
73
+ ? `Market with poolId ${params.poolId} not found on chain ${params.chainId}`
74
+ : `Market not found on chain ${params.chainId}`,
75
+ { metaMessages: params.reason ? [params.reason] : undefined },
76
+ )
77
+ this.chainId = params.chainId
78
+ this.poolId = params.poolId
79
+ }
80
+ }
81
+
82
+ export class ProviderNotConfiguredError extends ActionsError {
83
+ override name = 'ProviderNotConfiguredError' as const
84
+ provider: string
85
+
86
+ constructor(params: { provider: string; details?: string }) {
87
+ super(`A '${params.provider}' provider is not configured`, {
88
+ metaMessages: params.details ? [params.details] : undefined,
89
+ })
90
+ this.provider = params.provider
91
+ }
92
+ }
93
+
94
+ export class MarketIdRequiredError extends ActionsError {
95
+ override name = 'MarketIdRequiredError' as const
96
+
97
+ constructor(details?: string) {
98
+ super('marketId is required', {
99
+ metaMessages: details ? [details] : undefined,
100
+ })
101
+ }
102
+ }
103
+
104
+ // ─────────────────────────────────────────────────────────────────────────────
105
+ // Amount / Swap Parameters
106
+ // ─────────────────────────────────────────────────────────────────────────────
107
+
108
+ export class AmountRequiredError extends ActionsError {
109
+ override name = 'AmountRequiredError' as const
110
+
111
+ constructor() {
112
+ super('Either amountIn or amountOut must be provided')
113
+ }
114
+ }
115
+
116
+ export class InvalidAmountError extends ActionsError {
117
+ override name = 'InvalidAmountError' as const
118
+ amount: number
119
+
120
+ constructor(amount: number) {
121
+ super('Amount must be positive', {
122
+ metaMessages: [`Received: ${amount}`],
123
+ })
124
+ this.amount = amount
125
+ }
126
+ }
127
+
128
+ export class ConflictingAmountsError extends ActionsError {
129
+ override name = 'ConflictingAmountsError' as const
130
+
131
+ constructor() {
132
+ super('Provide either amountIn or amountOut, not both')
133
+ }
134
+ }
135
+
136
+ export class SameAssetError extends ActionsError {
137
+ override name = 'SameAssetError' as const
138
+ symbol: string
139
+
140
+ constructor(symbol: string) {
141
+ super('Cannot swap an asset for itself', {
142
+ metaMessages: [`Asset: ${symbol}`],
143
+ })
144
+ this.symbol = symbol
145
+ }
146
+ }
147
+
148
+ export class QuoteExpiredError extends ActionsError {
149
+ override name = 'QuoteExpiredError' as const
150
+ expiresAt: number
151
+ currentTime: number
152
+
153
+ constructor(params: { expiresAt: number; currentTime: number }) {
154
+ super('Quote expired', {
155
+ metaMessages: [
156
+ `Expired at: ${params.expiresAt}`,
157
+ `Current time: ${params.currentTime}`,
158
+ ],
159
+ })
160
+ this.expiresAt = params.expiresAt
161
+ this.currentTime = params.currentTime
162
+ }
163
+ }
164
+
165
+ export class ExactOutputNotSupportedError extends ActionsError {
166
+ override name = 'ExactOutputNotSupportedError' as const
167
+ provider: string
168
+
169
+ constructor(provider: string) {
170
+ super(`${provider} does not support exact-output swaps`, {
171
+ metaMessages: ['Provide amountIn instead of amountOut'],
172
+ })
173
+ this.provider = provider
174
+ }
175
+ }
176
+
177
+ // ─────────────────────────────────────────────────────────────────────────────
178
+ // Address
179
+ // ─────────────────────────────────────────────────────────────────────────────
180
+
181
+ export class AddressRequiredError extends ActionsError {
182
+ override name = 'AddressRequiredError' as const
183
+ label: string
184
+
185
+ constructor(label: string) {
186
+ super(`${label} is required`)
187
+ this.label = label
188
+ }
189
+ }
190
+
191
+ export class ZeroAddressError extends ActionsError {
192
+ override name = 'ZeroAddressError' as const
193
+ label: string
194
+ address?: string
195
+
196
+ constructor(label: string, address?: string) {
197
+ super(`${label} cannot be the zero address`, {
198
+ metaMessages: address ? [`Address: ${address}`] : undefined,
199
+ })
200
+ this.label = label
201
+ this.address = address
202
+ }
203
+ }
204
+
205
+ // ─────────────────────────────────────────────────────────────────────────────
206
+ // Slippage
207
+ // ─────────────────────────────────────────────────────────────────────────────
208
+
209
+ export class SlippageOutOfRangeError extends ActionsError {
210
+ override name = 'SlippageOutOfRangeError' as const
211
+ slippage: number
212
+ maxSlippage: number
213
+
214
+ constructor(slippage: number, maxSlippage: number) {
215
+ super(`Slippage ${slippage} is out of range`, {
216
+ metaMessages: [`Allowed range: [0, ${maxSlippage * 100}%]`],
217
+ })
218
+ this.slippage = slippage
219
+ this.maxSlippage = maxSlippage
220
+ }
221
+ }
222
+
223
+ // ─────────────────────────────────────────────────────────────────────────────
224
+ // Asset
225
+ // ─────────────────────────────────────────────────────────────────────────────
226
+
227
+ export class AssetNotSupportedOnChainError extends ActionsError {
228
+ override name = 'AssetNotSupportedOnChainError' as const
229
+ symbol: string
230
+ chainId: number
231
+
232
+ constructor(symbol: string, chainId: number) {
233
+ super(`Asset ${symbol} is not supported on chain ${chainId}`)
234
+ this.symbol = symbol
235
+ this.chainId = chainId
236
+ }
237
+ }
238
+
239
+ export class NativeAssetAddressError extends ActionsError {
240
+ override name = 'NativeAssetAddressError' as const
241
+ symbol: string
242
+
243
+ constructor(symbol: string) {
244
+ super(`${symbol} is a native asset and has no contract address`)
245
+ this.symbol = symbol
246
+ }
247
+ }
248
+
249
+ export class AssetMetadataRequiredError extends ActionsError {
250
+ override name = 'AssetMetadataRequiredError' as const
251
+ context?: string
252
+
253
+ constructor(context?: string) {
254
+ super('Asset metadata is required', {
255
+ metaMessages: context ? [context] : undefined,
256
+ })
257
+ this.context = context
258
+ }
259
+ }
260
+
261
+ // ─────────────────────────────────────────────────────────────────────────────
262
+ // Generic input validation
263
+ // ─────────────────────────────────────────────────────────────────────────────
264
+
265
+ /**
266
+ * Thrown when a caller-supplied parameter does not match the expected shape
267
+ * (wrong type, empty when non-empty is required, etc.). The `expected` string
268
+ * documents the type signature the caller should have produced.
269
+ */
270
+ export class InvalidParamsError extends ActionsError {
271
+ override name = 'InvalidParamsError' as const
272
+ param: string
273
+ expected: string
274
+ received?: string
275
+
276
+ constructor(params: { param: string; expected: string; received?: string }) {
277
+ super(`Invalid params: ${params.param}`, {
278
+ metaMessages: [
279
+ `Expected: ${params.expected}`,
280
+ ...(params.received ? [`Received: ${params.received}`] : []),
281
+ ],
282
+ })
283
+ this.param = params.param
284
+ this.expected = params.expected
285
+ this.received = params.received
26
286
  }
27
287
  }
package/src/index.ts CHANGED
@@ -1,4 +1,14 @@
1
1
  export type { Actions } from '@/actions.js'
2
+ export { LendProvider, MorphoLendProvider } from '@/actions/lend/index.js'
3
+ export {
4
+ SwapProvider,
5
+ type UniswapMarketConfig,
6
+ UniswapSwapProvider,
7
+ type UniswapSwapProviderConfig,
8
+ type VelodromeMarketConfig,
9
+ VelodromeSwapProvider,
10
+ type VelodromeSwapProviderConfig,
11
+ } from '@/actions/swap/index.js'
2
12
  export {
3
13
  AAVE,
4
14
  ARB,
@@ -52,16 +62,19 @@ export {
52
62
  type SupportedChainId,
53
63
  } from '@/constants/supportedChains.js'
54
64
  export * from '@/core/error/errors.js'
55
- export { LendProvider, MorphoLendProvider } from '@/lend/index.js'
56
65
  export {
57
- SwapProvider,
58
- type UniswapMarketConfig,
59
- UniswapSwapProvider,
60
- type UniswapSwapProviderConfig,
61
- type VelodromeMarketConfig,
62
- VelodromeSwapProvider,
63
- type VelodromeSwapProviderConfig,
64
- } from '@/swap/index.js'
66
+ type EnsInfo,
67
+ EnsNamespace,
68
+ EnsNotConfiguredError,
69
+ EnsResolutionError,
70
+ EnsRpcError,
71
+ type NameServiceProvider,
72
+ } from '@/services/nameservices/ens/index.js'
73
+ export {
74
+ type EnsName,
75
+ isEnsName,
76
+ resolveAddress,
77
+ } from '@/services/nameservices/ens/utils.js'
65
78
  export type {
66
79
  ActionsConfig,
67
80
  ApyBreakdown,
@@ -74,7 +87,6 @@ export type {
74
87
  LendMarketMetadata,
75
88
  LendMarketPosition,
76
89
  LendMarketSupply,
77
- LendOptions,
78
90
  LendProviderConfig,
79
91
  LendTransaction,
80
92
  LendTransactionReceipt,
@@ -95,10 +107,13 @@ export type {
95
107
  SwapTransaction,
96
108
  TokenBalance,
97
109
  TransactionData,
110
+ TransactionOptions,
98
111
  UserOperationTransactionReceipt,
99
112
  WalletConfig,
100
113
  WalletSwapParams,
101
114
  } from '@/types/index.js'
102
115
  export { getAssetAddress, isAssetSupportedOnChain } from '@/utils/assets.js'
116
+ export { serializeBigInt } from '@/utils/serializers.js'
117
+ export * from '@/wallet/core/error/errors.js'
103
118
  export { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
104
119
  export { SmartWallet } from '@/wallet/core/wallets/smart/abstract/SmartWallet.js'
@@ -13,6 +13,7 @@ import type { BundlerClient, SmartAccount } from 'viem/account-abstraction'
13
13
  import { createBundlerClient } from 'viem/account-abstraction'
14
14
 
15
15
  import type { SupportedChainId } from '@/constants/supportedChains.js'
16
+ import { ChainNotSupportedError } from '@/core/error/errors.js'
16
17
  import type { ChainConfig } from '@/types/chain.js'
17
18
 
18
19
  /**
@@ -44,11 +45,24 @@ export class ChainManager {
44
45
  getPublicClient(chainId: SupportedChainId): PublicClient {
45
46
  const client = this.publicClients.get(chainId)
46
47
  if (!client) {
47
- throw new Error(`No public client configured for chain ID: ${chainId}`)
48
+ throw new ChainNotSupportedError({
49
+ chainId,
50
+ supportedChainIds: this.getSupportedChains(),
51
+ })
48
52
  }
49
53
  return client
50
54
  }
51
55
 
56
+ /**
57
+ * Get public client for a specific chain, or undefined if not configured.
58
+ * Use this when the chain is optional (e.g. mainnet for ENS resolution).
59
+ * @param chainId - The chain ID to retrieve the public client for
60
+ * @returns PublicClient instance, or undefined if not configured
61
+ */
62
+ tryGetPublicClient(chainId: SupportedChainId): PublicClient | undefined {
63
+ return this.publicClients.get(chainId)
64
+ }
65
+
52
66
  /**
53
67
  * Get bundler client for a specific chain
54
68
  * @param chainId - The chain ID to retrieve the bundler client for
@@ -63,7 +77,10 @@ export class ChainManager {
63
77
  const chainConfig = this.getChainConfig(chainId)
64
78
  const bundlerConfig = chainConfig.bundler
65
79
  if (!bundlerConfig) {
66
- throw new Error(`No bundler configured for chain ID: ${chainId}`)
80
+ throw new ChainNotSupportedError({
81
+ chainId,
82
+ supportedChainIds: this.getSupportedChains(),
83
+ })
67
84
  }
68
85
  if (bundlerConfig.type === 'pimlico') {
69
86
  return this.getPimlicoBundlerClient(
@@ -74,7 +91,10 @@ export class ChainManager {
74
91
  }
75
92
  const bundlerUrl = this.getBundlerUrl(chainId)
76
93
  if (!bundlerUrl) {
77
- throw new Error(`No bundler URL configured for chain ID: ${chainId}`)
94
+ throw new ChainNotSupportedError({
95
+ chainId,
96
+ supportedChainIds: this.getSupportedChains(),
97
+ })
78
98
  }
79
99
  const client = createPublicClient({
80
100
  chain: this.getChain(chainId),
@@ -108,7 +128,10 @@ export class ChainManager {
108
128
  getBundlerUrl(chainId: SupportedChainId): string | undefined {
109
129
  const chainConfig = this.getChainConfig(chainId)
110
130
  if (!chainConfig.bundler) {
111
- throw new Error(`No bundler configured for chain ID: ${chainId}`)
131
+ throw new ChainNotSupportedError({
132
+ chainId,
133
+ supportedChainIds: this.getSupportedChains(),
134
+ })
112
135
  }
113
136
  return chainConfig.bundler.url
114
137
  }
@@ -157,12 +180,13 @@ export class ChainManager {
157
180
  for (const chainConfig of chains) {
158
181
  const chain = chainById[chainConfig.chainId]
159
182
  if (!chain) {
160
- throw new Error(`Chain not found for ID: ${chainConfig.chainId}`)
183
+ throw new ChainNotSupportedError({ chainId: chainConfig.chainId })
161
184
  }
162
185
  if (clients.has(chainConfig.chainId)) {
163
- throw new Error(
164
- `Public client already configured for chain ID: ${chainConfig.chainId}`,
165
- )
186
+ throw new ChainNotSupportedError({
187
+ chainId: chainConfig.chainId,
188
+ supportedChainIds: Array.from(clients.keys()),
189
+ })
166
190
  }
167
191
  const client = createPublicClient({
168
192
  chain,
@@ -183,7 +207,10 @@ export class ChainManager {
183
207
  private getChainConfig(chainId: SupportedChainId): ChainConfig {
184
208
  const chainConfig = this.chainConfigs.find((c) => c.chainId === chainId)
185
209
  if (!chainConfig) {
186
- throw new Error(`No chain config found for chain ID: ${chainId}`)
210
+ throw new ChainNotSupportedError({
211
+ chainId,
212
+ supportedChainIds: this.getSupportedChains(),
213
+ })
187
214
  }
188
215
  return chainConfig
189
216
  }
@@ -21,6 +21,9 @@ export class MockChainManager {
21
21
  public getPublicClient: MockedFunction<
22
22
  (chainId: SupportedChainId) => PublicClient
23
23
  >
24
+ public tryGetPublicClient: MockedFunction<
25
+ (chainId: SupportedChainId) => PublicClient | undefined
26
+ >
24
27
  public getBundlerClient: MockedFunction<
25
28
  (chainId: SupportedChainId, account: SmartAccount) => BundlerClient
26
29
  >
@@ -54,6 +57,11 @@ export class MockChainManager {
54
57
  }
55
58
  return client
56
59
  })
60
+ this.tryGetPublicClient = vi
61
+ .fn()
62
+ .mockImplementation((chainId: SupportedChainId) => {
63
+ return this.publicClients.get(chainId)
64
+ })
57
65
  this.getBundlerClient = vi
58
66
  .fn()
59
67
  .mockImplementation((chainId: SupportedChainId) => {
@@ -90,7 +90,7 @@ describe('ChainManager', () => {
90
90
  ]
91
91
 
92
92
  expect(() => new ChainManager(invalidChainConfigs)).toThrow(
93
- 'Chain not found for ID: 99999',
93
+ 'Chain 99999 is not supported',
94
94
  )
95
95
  })
96
96
 
@@ -100,7 +100,7 @@ describe('ChainManager', () => {
100
100
  { chainId: unichain.id, rpcUrls: ['https://another.rpc'] },
101
101
  ]
102
102
  expect(() => new ChainManager(multiChainConfigs)).toThrow(
103
- `Public client already configured for chain ID: ${unichain.id}`,
103
+ `Chain ${unichain.id} is not supported`,
104
104
  )
105
105
  })
106
106
  })
@@ -117,7 +117,7 @@ describe('ChainManager', () => {
117
117
  const unsupportedChainId = 999 as unknown as SupportedChainId
118
118
 
119
119
  expect(() => chainManager.getPublicClient(unsupportedChainId)).toThrow(
120
- 'No public client configured for chain ID: 999',
120
+ 'Chain 999 is not supported',
121
121
  )
122
122
  })
123
123
  })
@@ -183,7 +183,7 @@ describe('ChainManager', () => {
183
183
 
184
184
  expect(() =>
185
185
  chainManager.getTransportForChain(unsupportedChainId),
186
- ).toThrow('No chain config found for chain ID: 999')
186
+ ).toThrow('Chain 999 is not supported')
187
187
  })
188
188
  })
189
189
 
@@ -306,7 +306,7 @@ describe('ChainManager', () => {
306
306
  const mgr = new ChainManager(configs)
307
307
 
308
308
  expect(() => mgr.getBundlerClient(unichain.id, mockAccount)).toThrow(
309
- `No bundler configured for chain ID: ${unichain.id}`,
309
+ `Chain ${unichain.id} is not supported`,
310
310
  )
311
311
  })
312
312
 
@@ -325,7 +325,7 @@ describe('ChainManager', () => {
325
325
  const mgr = new ChainManager(configs)
326
326
 
327
327
  expect(() => mgr.getBundlerClient(unichain.id, mockAccount)).toThrow(
328
- `No bundler URL configured for chain ID: ${unichain.id}`,
328
+ `Chain ${unichain.id} is not supported`,
329
329
  )
330
330
  })
331
331
  })
@@ -1,5 +1,5 @@
1
1
  import type { Address } from 'viem'
2
- import { unichain } from 'viem/chains'
2
+ import { base, optimism, unichain } from 'viem/chains'
3
3
  import { beforeEach, describe, expect, it } from 'vitest'
4
4
 
5
5
  import { MockUSDCAsset } from '@/__mocks__/MockAssets.js'
@@ -20,6 +20,12 @@ describe('TokenBalance', () => {
20
20
  }) as any
21
21
  })
22
22
 
23
+ const multiChainManager = (): ChainManager =>
24
+ new MockChainManager({
25
+ supportedChains: [optimism.id, base.id, unichain.id],
26
+ defaultBalance: 1000000n,
27
+ }) as unknown as ChainManager
28
+
23
29
  describe('fetchBalance', () => {
24
30
  it('should fetch token balance across supported chains', async () => {
25
31
  const balance = await fetchERC20Balance(
@@ -85,5 +91,54 @@ describe('TokenBalance', () => {
85
91
  },
86
92
  })
87
93
  })
94
+
95
+ it('queries only the requested chains when chainIds is provided', async () => {
96
+ const cm = multiChainManager()
97
+
98
+ const balance = await fetchETHBalance(cm, walletAddress, {
99
+ chainIds: [base.id],
100
+ })
101
+
102
+ expect(balance.chains).toEqual({
103
+ [base.id]: { balance: 0.000000000001, balanceRaw: 1000000n },
104
+ })
105
+ expect(balance.totalBalanceRaw).toBe(1000000n)
106
+ expect(cm.getPublicClient).toHaveBeenCalledTimes(1)
107
+ expect(cm.getPublicClient).toHaveBeenCalledWith(base.id)
108
+ })
109
+ })
110
+
111
+ describe('fetchERC20Balance with chainIds filter', () => {
112
+ it('queries only the requested chains', async () => {
113
+ const cm = multiChainManager()
114
+
115
+ const balance = await fetchERC20Balance(
116
+ cm,
117
+ walletAddress,
118
+ MockUSDCAsset,
119
+ { chainIds: [optimism.id, base.id] },
120
+ )
121
+
122
+ expect(Object.keys(balance.chains).map(Number).sort()).toEqual(
123
+ [optimism.id, base.id].sort(),
124
+ )
125
+ expect(balance.totalBalanceRaw).toBe(2000000n)
126
+ })
127
+
128
+ it('silently skips requested chains where the asset has no address', async () => {
129
+ const cm = multiChainManager()
130
+ const opOnly: Asset = {
131
+ ...MockUSDCAsset,
132
+ address: { [optimism.id]: MockUSDCAsset.address[optimism.id] } as any,
133
+ }
134
+
135
+ const balance = await fetchERC20Balance(cm, walletAddress, opOnly, {
136
+ chainIds: [optimism.id, base.id],
137
+ })
138
+
139
+ expect(balance.chains).toEqual({
140
+ [optimism.id]: { balance: 1, balanceRaw: 1000000n },
141
+ })
142
+ })
88
143
  })
89
144
  })