@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
@@ -0,0 +1,144 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import { EnsNamespace } from '../EnsNamespace.js';
3
+ import { EnsResolutionError, EnsRpcError, } from '../errors.js';
4
+ const REAL_ADDRESS = '0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045';
5
+ const ENS_NAME = 'vitalik.eth';
6
+ function mockChainManager(client) {
7
+ const tryGetPublicClient = client
8
+ ? vi.fn().mockReturnValue(client)
9
+ : vi.fn().mockReturnValue(undefined);
10
+ return { tryGetPublicClient };
11
+ }
12
+ function mockClient(overrides = {}) {
13
+ return {
14
+ getEnsAddress: vi.fn().mockResolvedValue(REAL_ADDRESS),
15
+ getEnsName: vi.fn().mockResolvedValue(ENS_NAME),
16
+ getEnsText: vi.fn().mockResolvedValue(null),
17
+ ...overrides,
18
+ };
19
+ }
20
+ describe('EnsNamespace', () => {
21
+ describe('getAddress', () => {
22
+ it('resolves a hex address directly', async () => {
23
+ const ens = new EnsNamespace(mockChainManager());
24
+ expect(await ens.getAddress(REAL_ADDRESS)).toBe(REAL_ADDRESS);
25
+ });
26
+ it('resolves an ENS name via mainnet client', async () => {
27
+ const client = mockClient();
28
+ const ens = new EnsNamespace(mockChainManager(client));
29
+ expect(await ens.getAddress(ENS_NAME)).toBe(REAL_ADDRESS);
30
+ expect(client.getEnsAddress).toHaveBeenCalledWith({ name: ENS_NAME });
31
+ });
32
+ it('caches resolved addresses on subsequent calls', async () => {
33
+ const client = mockClient();
34
+ const ens = new EnsNamespace(mockChainManager(client));
35
+ await ens.getAddress(ENS_NAME);
36
+ await ens.getAddress(ENS_NAME);
37
+ expect(client.getEnsAddress).toHaveBeenCalledTimes(1);
38
+ });
39
+ });
40
+ describe('getName', () => {
41
+ it('returns ENS name for a known address', async () => {
42
+ const client = mockClient();
43
+ const ens = new EnsNamespace(mockChainManager(client));
44
+ expect(await ens.getName(REAL_ADDRESS)).toBe(ENS_NAME);
45
+ expect(client.getEnsName).toHaveBeenCalledWith({ address: REAL_ADDRESS });
46
+ });
47
+ it('returns null when no primary name is set', async () => {
48
+ const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) });
49
+ const ens = new EnsNamespace(mockChainManager(client));
50
+ expect(await ens.getName(REAL_ADDRESS)).toBeNull();
51
+ });
52
+ it('throws EnsRpcError on RPC failure', async () => {
53
+ const client = mockClient({
54
+ getEnsName: vi.fn().mockRejectedValue(new Error('rpc down')),
55
+ });
56
+ const ens = new EnsNamespace(mockChainManager(client));
57
+ await expect(ens.getName(REAL_ADDRESS)).rejects.toThrow(EnsRpcError);
58
+ });
59
+ it('caches results on subsequent calls', async () => {
60
+ const client = mockClient();
61
+ const ens = new EnsNamespace(mockChainManager(client));
62
+ await ens.getName(REAL_ADDRESS);
63
+ await ens.getName(REAL_ADDRESS);
64
+ expect(client.getEnsName).toHaveBeenCalledTimes(1);
65
+ });
66
+ it('caches null results', async () => {
67
+ const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) });
68
+ const ens = new EnsNamespace(mockChainManager(client));
69
+ await ens.getName(REAL_ADDRESS);
70
+ await ens.getName(REAL_ADDRESS);
71
+ expect(client.getEnsName).toHaveBeenCalledTimes(1);
72
+ });
73
+ });
74
+ describe('getInfo', () => {
75
+ it('returns all-null EnsInfo when address has no primary name', async () => {
76
+ const client = mockClient({ getEnsName: vi.fn().mockResolvedValue(null) });
77
+ const ens = new EnsNamespace(mockChainManager(client));
78
+ const info = await ens.getInfo(REAL_ADDRESS);
79
+ expect(info).toEqual({
80
+ avatar: null,
81
+ display: null,
82
+ description: null,
83
+ url: null,
84
+ email: null,
85
+ keywords: null,
86
+ twitter: null,
87
+ github: null,
88
+ discord: null,
89
+ reddit: null,
90
+ });
91
+ });
92
+ it('returns all text record fields when name is given', async () => {
93
+ const client = mockClient({
94
+ getEnsText: vi.fn().mockResolvedValue('test-value'),
95
+ });
96
+ const ens = new EnsNamespace(mockChainManager(client));
97
+ const info = await ens.getInfo(ENS_NAME);
98
+ expect(info.avatar).toBe('test-value');
99
+ expect(info.twitter).toBe('test-value');
100
+ expect(info.github).toBe('test-value');
101
+ });
102
+ it('returns null fields when text records are not set', async () => {
103
+ const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) });
104
+ const ens = new EnsNamespace(mockChainManager(client));
105
+ const info = await ens.getInfo(ENS_NAME);
106
+ expect(info.avatar).toBeNull();
107
+ expect(info.twitter).toBeNull();
108
+ });
109
+ it('fetches all 10 standard keys in parallel', async () => {
110
+ const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) });
111
+ const ens = new EnsNamespace(mockChainManager(client));
112
+ await ens.getInfo(ENS_NAME);
113
+ expect(client.getEnsText).toHaveBeenCalledTimes(10);
114
+ });
115
+ it('throws EnsRpcError on text lookup RPC failure', async () => {
116
+ const client = mockClient({
117
+ getEnsText: vi.fn().mockRejectedValue(new Error('rpc down')),
118
+ });
119
+ const ens = new EnsNamespace(mockChainManager(client));
120
+ await expect(ens.getInfo(ENS_NAME)).rejects.toThrow(EnsRpcError);
121
+ });
122
+ it('throws EnsResolutionError when the resolved name fails normalization', async () => {
123
+ const client = mockClient({
124
+ getEnsName: vi.fn().mockResolvedValue('not!valid.eth'),
125
+ });
126
+ const ens = new EnsNamespace(mockChainManager(client));
127
+ await expect(ens.getInfo(REAL_ADDRESS)).rejects.toThrow(EnsResolutionError);
128
+ });
129
+ it('skips reverse resolution when input is already an EnsName', async () => {
130
+ const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) });
131
+ const ens = new EnsNamespace(mockChainManager(client));
132
+ await ens.getInfo(ENS_NAME);
133
+ expect(client.getEnsName).not.toHaveBeenCalled();
134
+ });
135
+ it('caches results on subsequent calls', async () => {
136
+ const client = mockClient({ getEnsText: vi.fn().mockResolvedValue(null) });
137
+ const ens = new EnsNamespace(mockChainManager(client));
138
+ await ens.getInfo(ENS_NAME);
139
+ await ens.getInfo(ENS_NAME);
140
+ expect(client.getEnsText).toHaveBeenCalledTimes(10);
141
+ });
142
+ });
143
+ });
144
+ //# sourceMappingURL=EnsNamespace.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EnsNamespace.spec.js","sourceRoot":"","sources":["../../../../../src/services/nameservices/ens/__tests__/EnsNamespace.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=utils.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.spec.d.ts","sourceRoot":"","sources":["../../../../../src/services/nameservices/ens/__tests__/utils.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,75 @@
1
+ import { zeroAddress } from 'viem';
2
+ import { describe, expect, it, vi } from 'vitest';
3
+ import { resolveAddress } from '../utils.js';
4
+ const REAL_ADDRESS = '0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045';
5
+ const ZERO_ADDRESS = zeroAddress;
6
+ function mockClient(returnValue, rejects = false) {
7
+ const getEnsAddress = rejects
8
+ ? vi.fn().mockRejectedValue(new Error('network error'))
9
+ : vi.fn().mockResolvedValue(returnValue);
10
+ return { getEnsAddress };
11
+ }
12
+ describe('resolveAddress', () => {
13
+ describe('hex address input', () => {
14
+ it('returns a valid hex address as-is', async () => {
15
+ expect(await resolveAddress(REAL_ADDRESS)).toBe(REAL_ADDRESS);
16
+ });
17
+ it('does not require a mainnet client for hex addresses', async () => {
18
+ await expect(resolveAddress(REAL_ADDRESS)).resolves.toBe(REAL_ADDRESS);
19
+ });
20
+ });
21
+ describe('ENS name input', () => {
22
+ it('resolves a valid ENS name', async () => {
23
+ const client = mockClient(REAL_ADDRESS);
24
+ const result = await resolveAddress('vitalik.eth', client);
25
+ expect(result).toBe(REAL_ADDRESS);
26
+ expect(client.getEnsAddress).toHaveBeenCalledWith({ name: 'vitalik.eth' });
27
+ });
28
+ it('normalises the ENS name before resolving', async () => {
29
+ const client = mockClient(REAL_ADDRESS);
30
+ await resolveAddress('Vitalik.ETH', client);
31
+ expect(client.getEnsAddress).toHaveBeenCalledWith({ name: 'vitalik.eth' });
32
+ });
33
+ it('throws EnsNotConfiguredError when no mainnet client is provided', async () => {
34
+ const { EnsNotConfiguredError } = await import('../errors.js');
35
+ await expect(resolveAddress('vitalik.eth')).rejects.toThrow(EnsNotConfiguredError);
36
+ });
37
+ it('includes chain ID 1 in the error when no mainnet client provided', async () => {
38
+ await expect(resolveAddress('vitalik.eth')).rejects.toThrow('1');
39
+ });
40
+ it('throws when ENS name cannot be resolved (returns null)', async () => {
41
+ const client = mockClient(null);
42
+ await expect(resolveAddress('unresolvable.eth', client)).rejects.toThrow('"unresolvable.eth" could not be resolved');
43
+ });
44
+ it('throws when ENS name resolves to zero address', async () => {
45
+ const client = mockClient(ZERO_ADDRESS);
46
+ await expect(resolveAddress('zero.eth', client)).rejects.toThrow('zero address');
47
+ });
48
+ it('throws with RPC error label on network failure', async () => {
49
+ const client = mockClient(null, true);
50
+ await expect(resolveAddress('vitalik.eth', client)).rejects.toThrow('RPC error');
51
+ });
52
+ it('preserves the original cause on RPC failure', async () => {
53
+ const client = mockClient(null, true);
54
+ let caught;
55
+ try {
56
+ await resolveAddress('vitalik.eth', client);
57
+ }
58
+ catch (e) {
59
+ caught = e;
60
+ }
61
+ expect(caught?.cause).toBeInstanceOf(Error);
62
+ expect((caught?.cause).message).toBe('network error');
63
+ });
64
+ });
65
+ describe('invalid input', () => {
66
+ it('throws for ENS-shaped strings that fail normalisation', async () => {
67
+ // Has a dot so satisfies EnsName, but contains invalid ENS characters
68
+ await expect(resolveAddress('not!valid.eth', {})).rejects.toThrow('Invalid address or ENS name');
69
+ });
70
+ it('includes the invalid input in the error message', async () => {
71
+ await expect(resolveAddress('!!bad!!.eth', {})).rejects.toThrow('"!!bad!!.eth"');
72
+ });
73
+ });
74
+ });
75
+ //# sourceMappingURL=utils.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.spec.js","sourceRoot":"","sources":["../../../../../src/services/nameservices/ens/__tests__/utils.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Thrown when an ENS operation is attempted but the required chain is not
3
+ * included in the Actions chain configuration.
4
+ */
5
+ export declare class EnsNotConfiguredError extends Error {
6
+ chainId: number;
7
+ constructor(chainId?: 1);
8
+ }
9
+ /**
10
+ * Thrown when an ENS name cannot be resolved to an address — e.g. the name
11
+ * is unregistered, resolves to the zero address, or fails normalization.
12
+ */
13
+ export declare class EnsResolutionError extends Error {
14
+ input: string;
15
+ constructor(message: string, input: string, options?: ErrorOptions);
16
+ }
17
+ /**
18
+ * Thrown when an ENS RPC call fails due to a network or provider error.
19
+ */
20
+ export declare class EnsRpcError extends Error {
21
+ input: string;
22
+ constructor(message: string, input: string, options?: ErrorOptions);
23
+ }
24
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/errors.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,KAAK;IAC9C,OAAO,EAAE,MAAM,CAAA;gBAEH,OAAO,IAAa;CAQjC;AAED;;;GAGG;AACH,qBAAa,kBAAmB,SAAQ,KAAK;IAC3C,KAAK,EAAE,MAAM,CAAA;gBAED,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY;CAKnE;AAED;;GAEG;AACH,qBAAa,WAAY,SAAQ,KAAK;IACpC,KAAK,EAAE,MAAM,CAAA;gBAED,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY;CAKnE"}
@@ -0,0 +1,35 @@
1
+ import { mainnet } from 'viem/chains';
2
+ /**
3
+ * Thrown when an ENS operation is attempted but the required chain is not
4
+ * included in the Actions chain configuration.
5
+ */
6
+ export class EnsNotConfiguredError extends Error {
7
+ constructor(chainId = mainnet.id) {
8
+ super(`ENS operations require Ethereum mainnet. ` +
9
+ `Add chain ID ${chainId} to your chain configuration.`);
10
+ this.name = 'EnsNotConfiguredError';
11
+ this.chainId = chainId;
12
+ }
13
+ }
14
+ /**
15
+ * Thrown when an ENS name cannot be resolved to an address — e.g. the name
16
+ * is unregistered, resolves to the zero address, or fails normalization.
17
+ */
18
+ export class EnsResolutionError extends Error {
19
+ constructor(message, input, options) {
20
+ super(message, options);
21
+ this.name = 'EnsResolutionError';
22
+ this.input = input;
23
+ }
24
+ }
25
+ /**
26
+ * Thrown when an ENS RPC call fails due to a network or provider error.
27
+ */
28
+ export class EnsRpcError extends Error {
29
+ constructor(message, input, options) {
30
+ super(message, options);
31
+ this.name = 'EnsRpcError';
32
+ this.input = input;
33
+ }
34
+ }
35
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAErC;;;GAGG;AACH,MAAM,OAAO,qBAAsB,SAAQ,KAAK;IAG9C,YAAY,OAAO,GAAG,OAAO,CAAC,EAAE;QAC9B,KAAK,CACH,2CAA2C;YACzC,gBAAgB,OAAO,+BAA+B,CACzD,CAAA;QACD,IAAI,CAAC,IAAI,GAAG,uBAAuB,CAAA;QACnC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,OAAO,kBAAmB,SAAQ,KAAK;IAG3C,YAAY,OAAe,EAAE,KAAa,EAAE,OAAsB;QAChE,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;QACvB,IAAI,CAAC,IAAI,GAAG,oBAAoB,CAAA;QAChC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,WAAY,SAAQ,KAAK;IAGpC,YAAY,OAAe,EAAE,KAAa,EAAE,OAAsB;QAChE,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;QACvB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAA;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;CACF"}
@@ -0,0 +1,5 @@
1
+ export { EnsNamespace } from './EnsNamespace.js';
2
+ export { EnsNotConfiguredError, EnsResolutionError, EnsRpcError, } from './errors.js';
3
+ export { type EnsInfo, type EnsName, isEnsName, type NameServiceProvider, } from './types.js';
4
+ export { passthroughResolver, type RecipientResolver, resolveAddress, } from './utils.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EACL,qBAAqB,EACrB,kBAAkB,EAClB,WAAW,GACZ,MAAM,aAAa,CAAA;AACpB,OAAO,EACL,KAAK,OAAO,EACZ,KAAK,OAAO,EACZ,SAAS,EACT,KAAK,mBAAmB,GACzB,MAAM,YAAY,CAAA;AACnB,OAAO,EACL,mBAAmB,EACnB,KAAK,iBAAiB,EACtB,cAAc,GACf,MAAM,YAAY,CAAA"}
@@ -0,0 +1,5 @@
1
+ export { EnsNamespace } from './EnsNamespace.js';
2
+ export { EnsNotConfiguredError, EnsResolutionError, EnsRpcError, } from './errors.js';
3
+ export { isEnsName, } from './types.js';
4
+ export { passthroughResolver, resolveAddress, } from './utils.js';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EACL,qBAAqB,EACrB,kBAAkB,EAClB,WAAW,GACZ,MAAM,aAAa,CAAA;AACpB,OAAO,EAGL,SAAS,GAEV,MAAM,YAAY,CAAA;AACnB,OAAO,EACL,mBAAmB,EAEnB,cAAc,GACf,MAAM,YAAY,CAAA"}
@@ -0,0 +1,63 @@
1
+ import type { Address } from 'viem';
2
+ import type { SwapExecuteParams, SwapQuoteParams } from '../../../types/swap/base.js';
3
+ /**
4
+ * A dot-separated ENS name (e.g. `vitalik.eth`, `sub.vitalik.eth`, `example.com`).
5
+ *
6
+ * ENS is not limited to `.eth` — it supports any DNSSEC-enabled DNS TLD as well
7
+ * as ENS-native TLDs (`.eth`, `.test`). Subdomains of arbitrary depth are valid.
8
+ *
9
+ * This type is a structural constraint (at least one dot) mirroring viem's Address type.
10
+ * True validity is determined at runtime by `normalize()` (ENSIP-15): a name is valid
11
+ * if and only if it does not throw during normalization.
12
+ */
13
+ export type EnsName = `${string}.${string}`;
14
+ /**
15
+ * Type guard for EnsName. Mirrors the pattern of viem's isAddress.
16
+ * Rejects obviously invalid forms (leading/trailing dots, consecutive dots)
17
+ * but does not run full ENSIP-15 normalization — use normalize() for that.
18
+ * @param value - String to check
19
+ * @returns True if the value satisfies the EnsName structural constraint
20
+ */
21
+ export declare function isEnsName(value: string): value is EnsName;
22
+ /**
23
+ * Standard ENS profile text record fields as defined by ENSIP-5 and ENSIP-18.
24
+ * All fields are null when not set on the resolver.
25
+ */
26
+ export interface EnsInfo {
27
+ avatar: string | null;
28
+ display: string | null;
29
+ description: string | null;
30
+ url: string | null;
31
+ email: string | null;
32
+ keywords: string | null;
33
+ /** com.twitter */
34
+ twitter: string | null;
35
+ /** com.github */
36
+ github: string | null;
37
+ /** com.discord */
38
+ discord: string | null;
39
+ /** org.reddit */
40
+ reddit: string | null;
41
+ }
42
+ /** SwapExecuteParams with recipient narrowed to Address after ENS resolution */
43
+ export type SwapExecuteParamsResolved = Omit<SwapExecuteParams, 'recipient'> & {
44
+ recipient?: Address;
45
+ };
46
+ /** SwapQuoteParams with recipient narrowed to Address after ENS resolution */
47
+ export type SwapQuoteParamsResolved = Omit<SwapQuoteParams, 'recipient'> & {
48
+ recipient?: Address;
49
+ };
50
+ /**
51
+ * Common interface for human-readable name service providers.
52
+ * Implemented by {@link EnsNamespace}; designed to support future providers
53
+ * such as Basename, Lens, Unstoppable Domains, etc.
54
+ */
55
+ export interface NameServiceProvider {
56
+ /** Resolve a name or address to a checksummed hex address. */
57
+ getAddress(input: Address | EnsName): Promise<Address>;
58
+ /** Reverse-resolve an address to its primary name, or null if not set. */
59
+ getName(address: Address): Promise<EnsName | null>;
60
+ /** Fetch all standard profile text record fields in a single batched call. */
61
+ getInfo(input: Address | EnsName): Promise<EnsInfo>;
62
+ }
63
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAEnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAE9E;;;;;;;;;GASG;AACH,MAAM,MAAM,OAAO,GAAG,GAAG,MAAM,IAAI,MAAM,EAAE,CAAA;AAE3C;;;;;;GAMG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,OAAO,CAOzD;AAED;;;GAGG;AACH,MAAM,WAAW,OAAO;IACtB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,kBAAkB;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,iBAAiB;IACjB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,kBAAkB;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,iBAAiB;IACjB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;CACtB;AAED,gFAAgF;AAChF,MAAM,MAAM,yBAAyB,GAAG,IAAI,CAAC,iBAAiB,EAAE,WAAW,CAAC,GAAG;IAC7E,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,8EAA8E;AAC9E,MAAM,MAAM,uBAAuB,GAAG,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,GAAG;IACzE,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED;;;;GAIG;AACH,MAAM,WAAW,mBAAmB;IAClC,8DAA8D;IAC9D,UAAU,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;IACtD,0EAA0E;IAC1E,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,CAAA;IAClD,8EAA8E;IAC9E,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;CACpD"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Type guard for EnsName. Mirrors the pattern of viem's isAddress.
3
+ * Rejects obviously invalid forms (leading/trailing dots, consecutive dots)
4
+ * but does not run full ENSIP-15 normalization — use normalize() for that.
5
+ * @param value - String to check
6
+ * @returns True if the value satisfies the EnsName structural constraint
7
+ */
8
+ export function isEnsName(value) {
9
+ return (value.includes('.') &&
10
+ !value.startsWith('.') &&
11
+ !value.endsWith('.') &&
12
+ !value.includes('..'));
13
+ }
14
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/types.ts"],"names":[],"mappings":"AAgBA;;;;;;GAMG;AACH,MAAM,UAAU,SAAS,CAAC,KAAa;IACrC,OAAO,CACL,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC;QACnB,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC;QACtB,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC;QACpB,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CACtB,CAAA;AACH,CAAC"}
@@ -0,0 +1,25 @@
1
+ import type { Address, PublicClient } from 'viem';
2
+ import type { EnsName } from './types.js';
3
+ export { type EnsName, isEnsName } from './types.js';
4
+ /** Resolves an ENS name or address to a checksummed hex Address, or returns undefined. */
5
+ export type RecipientResolver = (recipient: Address | EnsName | undefined) => Promise<Address | undefined>;
6
+ /** Pass-through resolver used when no ENS resolution is configured. Throws on ENS names. */
7
+ export declare const passthroughResolver: RecipientResolver;
8
+ /**
9
+ * Low-level utility to resolve an ENS name or hex address to a checksummed hex address.
10
+ * Use this when you manage your own viem PublicClient (e.g. inside providers or scripts).
11
+ *
12
+ * If you have an {@link Actions} instance, prefer `actions.ens.getAddress()` instead —
13
+ * it handles client lookup and fallback automatically from your chain configuration.
14
+ *
15
+ * Hex addresses (0x...) are returned as-is after format validation.
16
+ * ENS names require a mainnet public client for on-chain resolution.
17
+ * @param input - Hex address (0x...) or ENS name (e.g. "vitalik.eth")
18
+ * @param mainnetClient - Public client connected to Ethereum mainnet (required for ENS names)
19
+ * @returns Resolved hex address
20
+ * @throws {EnsNotConfiguredError} If mainnet client is not provided
21
+ * @throws {EnsResolutionError} If the name is invalid or cannot be resolved
22
+ * @throws {EnsRpcError} If the RPC call fails
23
+ */
24
+ export declare function resolveAddress(input: Address | EnsName, mainnetClient?: PublicClient): Promise<Address>;
25
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AASjD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sCAAsC,CAAA;AAEnE,OAAO,EAAE,KAAK,OAAO,EAAE,SAAS,EAAE,MAAM,sCAAsC,CAAA;AAE9E,0FAA0F;AAC1F,MAAM,MAAM,iBAAiB,GAAG,CAC9B,SAAS,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,KACrC,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,CAAA;AAEjC,4FAA4F;AAC5F,eAAO,MAAM,mBAAmB,EAAE,iBAKjC,CAAA;AAED;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,cAAc,CAClC,KAAK,EAAE,OAAO,GAAG,OAAO,EACxB,aAAa,CAAC,EAAE,YAAY,GAC3B,OAAO,CAAC,OAAO,CAAC,CAuClB"}
@@ -0,0 +1,53 @@
1
+ import { isAddress, isAddressEqual, zeroAddress } from 'viem';
2
+ import { normalize } from 'viem/ens';
3
+ import { EnsNotConfiguredError, EnsResolutionError, EnsRpcError, } from './errors.js';
4
+ export { isEnsName } from './types.js';
5
+ /** Pass-through resolver used when no ENS resolution is configured. Throws on ENS names. */
6
+ export const passthroughResolver = (r) => {
7
+ if (r !== undefined && !isAddress(r, { strict: false })) {
8
+ throw new Error(`ENS resolution is not configured; received "${r}"`);
9
+ }
10
+ return Promise.resolve(r);
11
+ };
12
+ /**
13
+ * Low-level utility to resolve an ENS name or hex address to a checksummed hex address.
14
+ * Use this when you manage your own viem PublicClient (e.g. inside providers or scripts).
15
+ *
16
+ * If you have an {@link Actions} instance, prefer `actions.ens.getAddress()` instead —
17
+ * it handles client lookup and fallback automatically from your chain configuration.
18
+ *
19
+ * Hex addresses (0x...) are returned as-is after format validation.
20
+ * ENS names require a mainnet public client for on-chain resolution.
21
+ * @param input - Hex address (0x...) or ENS name (e.g. "vitalik.eth")
22
+ * @param mainnetClient - Public client connected to Ethereum mainnet (required for ENS names)
23
+ * @returns Resolved hex address
24
+ * @throws {EnsNotConfiguredError} If mainnet client is not provided
25
+ * @throws {EnsResolutionError} If the name is invalid or cannot be resolved
26
+ * @throws {EnsRpcError} If the RPC call fails
27
+ */
28
+ export async function resolveAddress(input, mainnetClient) {
29
+ if (isAddress(input, { strict: false }))
30
+ return input;
31
+ if (!mainnetClient)
32
+ throw new EnsNotConfiguredError();
33
+ const normalized = (() => {
34
+ try {
35
+ return normalize(input);
36
+ }
37
+ catch (cause) {
38
+ throw new EnsResolutionError(`Invalid address or ENS name: "${input}"`, input, { cause });
39
+ }
40
+ })();
41
+ const resolved = await mainnetClient
42
+ .getEnsAddress({ name: normalized })
43
+ .catch((cause) => {
44
+ throw new EnsRpcError(`ENS resolution failed for "${input}": RPC error`, input, { cause });
45
+ });
46
+ if (!resolved)
47
+ throw new EnsResolutionError(`ENS name "${input}" could not be resolved`, input);
48
+ if (isAddressEqual(resolved, zeroAddress)) {
49
+ throw new EnsResolutionError(`ENS name "${input}" resolved to the zero address`, input);
50
+ }
51
+ return resolved;
52
+ }
53
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/services/nameservices/ens/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,MAAM,CAAA;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAEpC,OAAO,EACL,qBAAqB,EACrB,kBAAkB,EAClB,WAAW,GACZ,MAAM,uCAAuC,CAAA;AAG9C,OAAO,EAAgB,SAAS,EAAE,MAAM,sCAAsC,CAAA;AAO9E,4FAA4F;AAC5F,MAAM,CAAC,MAAM,mBAAmB,GAAsB,CAAC,CAAC,EAAE,EAAE;IAC1D,IAAI,CAAC,KAAK,SAAS,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;QACxD,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,GAAG,CAAC,CAAA;IACtE,CAAC;IACD,OAAO,OAAO,CAAC,OAAO,CAAC,CAAwB,CAAC,CAAA;AAClD,CAAC,CAAA;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAwB,EACxB,aAA4B;IAE5B,IAAI,SAAS,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;QAAE,OAAO,KAAK,CAAA;IAErD,IAAI,CAAC,aAAa;QAAE,MAAM,IAAI,qBAAqB,EAAE,CAAA;IAErD,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE;QACvB,IAAI,CAAC;YACH,OAAO,SAAS,CAAC,KAAK,CAAC,CAAA;QACzB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,kBAAkB,CAC1B,iCAAiC,KAAK,GAAG,EACzC,KAAK,EACL,EAAE,KAAK,EAAE,CACV,CAAA;QACH,CAAC;IACH,CAAC,CAAC,EAAE,CAAA;IAEJ,MAAM,QAAQ,GAAG,MAAM,aAAa;SACjC,aAAa,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;SACnC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE;QACxB,MAAM,IAAI,WAAW,CACnB,8BAA8B,KAAK,cAAc,EACjD,KAAK,EACL,EAAE,KAAK,EAAE,CACV,CAAA;IACH,CAAC,CAAC,CAAA;IAEJ,IAAI,CAAC,QAAQ;QACX,MAAM,IAAI,kBAAkB,CAC1B,aAAa,KAAK,yBAAyB,EAC3C,KAAK,CACN,CAAA;IACH,IAAI,cAAc,CAAC,QAAQ,EAAE,WAAW,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,kBAAkB,CAC1B,aAAa,KAAK,gCAAgC,EAClD,KAAK,CACN,CAAA;IACH,CAAC;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC"}
@@ -1,15 +1,18 @@
1
1
  import type { Address } from 'viem';
2
2
  import type { ChainManager } from './ChainManager.js';
3
- import type { Asset, TokenBalance } from '../types/asset.js';
3
+ import type { Asset, BalanceFetchOptions, TokenBalance } from '../types/asset.js';
4
4
  /**
5
- * Fetch ETH balance across all supported chains
5
+ * Fetch ETH balance across the requested chains (or all supported chains).
6
6
  * @param chainManager - The chain manager
7
7
  * @param walletAddress - The wallet address
8
+ * @param options - Optional `chainIds` filter (caller-validated)
8
9
  * @returns Promise resolving to ETH balance
9
10
  */
10
- export declare function fetchETHBalance(chainManager: ChainManager, walletAddress: Address): Promise<TokenBalance>;
11
+ export declare function fetchETHBalance(chainManager: ChainManager, walletAddress: Address, options?: BalanceFetchOptions): Promise<TokenBalance>;
11
12
  /**
12
- * Fetch total balance for this asset across all supported chains
13
+ * Fetch total balance for this asset across the requested chains (or all
14
+ * supported chains). Chains where the asset has no configured address are
15
+ * silently skipped, matching the unfiltered behavior.
13
16
  */
14
- export declare function fetchERC20Balance(chainManager: ChainManager, walletAddress: Address, asset: Asset): Promise<TokenBalance>;
17
+ export declare function fetchERC20Balance(chainManager: ChainManager, walletAddress: Address, asset: Asset, options?: BalanceFetchOptions): Promise<TokenBalance>;
15
18
  //# sourceMappingURL=tokenBalance.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tokenBalance.d.ts","sourceRoot":"","sources":["../../src/services/tokenBalance.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAKnC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAE3D;;;;;GAKG;AACH,wBAAsB,eAAe,CACnC,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,YAAY,CAAC,CA8BvB;AAED;;GAEG;AACH,wBAAsB,iBAAiB,CACrC,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,OAAO,EACtB,KAAK,EAAE,KAAK,GACX,OAAO,CAAC,YAAY,CAAC,CAuCvB"}
1
+ {"version":3,"file":"tokenBalance.d.ts","sourceRoot":"","sources":["../../src/services/tokenBalance.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAKnC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EAAE,KAAK,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAEhF;;;;;;GAMG;AACH,wBAAsB,eAAe,CACnC,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,OAAO,EACtB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO,CAAC,YAAY,CAAC,CAgCvB;AAED;;;;GAIG;AACH,wBAAsB,iBAAiB,CACrC,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,OAAO,EACtB,KAAK,EAAE,KAAK,EACZ,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO,CAAC,YAAY,CAAC,CAyCvB"}
@@ -1,14 +1,17 @@
1
1
  import { erc20Abi, formatEther, formatUnits } from 'viem';
2
2
  import { ETH } from '../constants/assets.js';
3
3
  /**
4
- * Fetch ETH balance across all supported chains
4
+ * Fetch ETH balance across the requested chains (or all supported chains).
5
5
  * @param chainManager - The chain manager
6
6
  * @param walletAddress - The wallet address
7
+ * @param options - Optional `chainIds` filter (caller-validated)
7
8
  * @returns Promise resolving to ETH balance
8
9
  */
9
- export async function fetchETHBalance(chainManager, walletAddress) {
10
- const supportedChains = chainManager.getSupportedChains();
11
- const chainBalancePromises = supportedChains.map(async (chainId) => {
10
+ export async function fetchETHBalance(chainManager, walletAddress, options) {
11
+ const targetChains = [
12
+ ...new Set(options?.chainIds ?? chainManager.getSupportedChains()),
13
+ ];
14
+ const chainBalancePromises = targetChains.map(async (chainId) => {
12
15
  const publicClient = chainManager.getPublicClient(chainId);
13
16
  const balanceRaw = await publicClient.getBalance({
14
17
  address: walletAddress,
@@ -33,11 +36,15 @@ export async function fetchETHBalance(chainManager, walletAddress) {
33
36
  };
34
37
  }
35
38
  /**
36
- * Fetch total balance for this asset across all supported chains
39
+ * Fetch total balance for this asset across the requested chains (or all
40
+ * supported chains). Chains where the asset has no configured address are
41
+ * silently skipped, matching the unfiltered behavior.
37
42
  */
38
- export async function fetchERC20Balance(chainManager, walletAddress, asset) {
39
- const supportedChains = chainManager.getSupportedChains();
40
- const chainsWithToken = supportedChains.filter((chainId) => asset.address[chainId]);
43
+ export async function fetchERC20Balance(chainManager, walletAddress, asset, options) {
44
+ const targetChains = [
45
+ ...new Set(options?.chainIds ?? chainManager.getSupportedChains()),
46
+ ];
47
+ const chainsWithToken = targetChains.filter((chainId) => asset.address[chainId]);
41
48
  const chainBalancePromises = chainsWithToken.map(async (chainId) => {
42
49
  const balanceRaw = await fetchBalanceForChain(asset, chainId, walletAddress, chainManager);
43
50
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"tokenBalance.js","sourceRoot":"","sources":["../../src/services/tokenBalance.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tokenBalance.js","sourceRoot":"","sources":["../../src/services/tokenBalance.ts"],"names":[],"mappings":"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"}