@eth-optimism/actions-sdk 0.5.0 → 0.7.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 (815) 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 +62 -23
  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 +2 -2
  95. package/dist/actions/shared/morpho/contracts.d.ts.map +1 -0
  96. package/dist/{lend/providers → actions/shared}/morpho/contracts.js +1 -1
  97. package/dist/{lend/providers → actions/shared}/morpho/contracts.js.map +1 -1
  98. package/dist/{types/lend/contracts.d.ts → actions/shared/morpho/types.d.ts} +2 -2
  99. package/dist/actions/shared/morpho/types.d.ts.map +1 -0
  100. package/dist/actions/shared/morpho/types.js.map +1 -0
  101. package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.d.ts +7 -6
  102. package/dist/actions/swap/__mocks__/MockSwapProvider.d.ts.map +1 -0
  103. package/dist/{swap → actions/swap}/__mocks__/MockSwapProvider.js +5 -2
  104. package/dist/actions/swap/__mocks__/MockSwapProvider.js.map +1 -0
  105. package/dist/{swap → actions/swap}/core/SwapProvider.d.ts +29 -14
  106. package/dist/actions/swap/core/SwapProvider.d.ts.map +1 -0
  107. package/dist/{swap → actions/swap}/core/SwapProvider.js +58 -39
  108. package/dist/actions/swap/core/SwapProvider.js.map +1 -0
  109. package/dist/actions/swap/core/__tests__/SwapProvider.test.d.ts.map +1 -0
  110. package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.js +39 -0
  111. package/dist/actions/swap/core/__tests__/SwapProvider.test.js.map +1 -0
  112. package/dist/{swap → actions/swap}/core/markets.d.ts +3 -3
  113. package/dist/actions/swap/core/markets.d.ts.map +1 -0
  114. package/dist/{swap → actions/swap}/core/markets.js +2 -1
  115. package/dist/actions/swap/core/markets.js.map +1 -0
  116. package/dist/actions/swap/index.d.ts.map +1 -0
  117. package/dist/actions/swap/index.js.map +1 -0
  118. package/dist/actions/swap/namespaces/ActionsSwapNamespace.d.ts.map +1 -0
  119. package/dist/actions/swap/namespaces/ActionsSwapNamespace.js.map +1 -0
  120. package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.d.ts +25 -28
  121. package/dist/actions/swap/namespaces/BaseSwapNamespace.d.ts.map +1 -0
  122. package/dist/{swap → actions/swap}/namespaces/BaseSwapNamespace.js +58 -59
  123. package/dist/actions/swap/namespaces/BaseSwapNamespace.js.map +1 -0
  124. package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts +56 -0
  125. package/dist/actions/swap/namespaces/WalletSwapNamespace.d.ts.map +1 -0
  126. package/dist/{swap → actions/swap}/namespaces/WalletSwapNamespace.js +46 -23
  127. package/dist/actions/swap/namespaces/WalletSwapNamespace.js.map +1 -0
  128. package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +1 -0
  129. package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.js +2 -2
  130. package/dist/actions/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +1 -0
  131. package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +1 -0
  132. package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.js +83 -19
  133. package/dist/actions/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +1 -0
  134. package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.d.ts +8 -5
  135. package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +1 -0
  136. package/dist/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.js +14 -5
  137. package/dist/actions/swap/providers/uniswap/UniswapSwapProvider.js.map +1 -0
  138. package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +1 -0
  139. package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.js +1 -1
  140. package/dist/actions/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +1 -0
  141. package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +1 -0
  142. package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.js +47 -1
  143. package/dist/actions/swap/providers/uniswap/__tests__/sdk.test.js.map +1 -0
  144. package/dist/actions/swap/providers/uniswap/abis.d.ts.map +1 -0
  145. package/dist/actions/swap/providers/uniswap/abis.js.map +1 -0
  146. package/dist/{swap → actions/swap}/providers/uniswap/addresses.d.ts +1 -1
  147. package/dist/actions/swap/providers/uniswap/addresses.d.ts.map +1 -0
  148. package/dist/{swap → actions/swap}/providers/uniswap/addresses.js +6 -2
  149. package/dist/actions/swap/providers/uniswap/addresses.js.map +1 -0
  150. package/dist/{swap → actions/swap}/providers/uniswap/encoding.d.ts +3 -3
  151. package/dist/actions/swap/providers/uniswap/encoding.d.ts.map +1 -0
  152. package/dist/{swap → actions/swap}/providers/uniswap/encoding.js +2 -2
  153. package/dist/actions/swap/providers/uniswap/encoding.js.map +1 -0
  154. package/dist/{swap → actions/swap}/providers/uniswap/markets.d.ts +3 -3
  155. package/dist/actions/swap/providers/uniswap/markets.d.ts.map +1 -0
  156. package/dist/{swap → actions/swap}/providers/uniswap/markets.js +1 -1
  157. package/dist/actions/swap/providers/uniswap/markets.js.map +1 -0
  158. package/dist/{swap → actions/swap}/providers/uniswap/types.d.ts +1 -1
  159. package/dist/actions/swap/providers/uniswap/types.d.ts.map +1 -0
  160. package/dist/actions/swap/providers/uniswap/types.js.map +1 -0
  161. package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.d.ts +9 -4
  162. package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +1 -0
  163. package/dist/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.js +37 -11
  164. package/dist/actions/swap/providers/velodrome/VelodromeSwapProvider.js.map +1 -0
  165. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +1 -0
  166. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +1 -0
  167. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +1 -0
  168. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js +7 -6
  169. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +1 -0
  170. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +1 -0
  171. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.js +39 -4
  172. package/dist/actions/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +1 -0
  173. package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +1 -0
  174. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.js +22 -1
  175. package/dist/actions/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +1 -0
  176. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.d.ts +1 -1
  177. package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +1 -0
  178. package/dist/actions/swap/providers/velodrome/__tests__/encoding.helpers.js.map +1 -0
  179. package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +1 -0
  180. package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.js +25 -1
  181. package/dist/actions/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +1 -0
  182. package/dist/actions/swap/providers/velodrome/abis.d.ts.map +1 -0
  183. package/dist/actions/swap/providers/velodrome/abis.js.map +1 -0
  184. package/dist/{swap → actions/swap}/providers/velodrome/addresses.d.ts +1 -1
  185. package/dist/actions/swap/providers/velodrome/addresses.d.ts.map +1 -0
  186. package/dist/actions/swap/providers/velodrome/addresses.js.map +1 -0
  187. package/dist/{swap → actions/swap}/providers/velodrome/config.d.ts +1 -1
  188. package/dist/actions/swap/providers/velodrome/config.d.ts.map +1 -0
  189. package/dist/{swap → actions/swap}/providers/velodrome/config.js +5 -1
  190. package/dist/actions/swap/providers/velodrome/config.js.map +1 -0
  191. package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.d.ts +3 -3
  192. package/dist/actions/swap/providers/velodrome/encoding/helpers.d.ts.map +1 -0
  193. package/dist/{swap → actions/swap}/providers/velodrome/encoding/helpers.js +4 -3
  194. package/dist/actions/swap/providers/velodrome/encoding/helpers.js.map +1 -0
  195. package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.d.ts +0 -1
  196. package/dist/actions/swap/providers/velodrome/encoding/index.d.ts.map +1 -0
  197. package/dist/{swap → actions/swap}/providers/velodrome/encoding/index.js +0 -1
  198. package/dist/actions/swap/providers/velodrome/encoding/index.js.map +1 -0
  199. package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.d.ts +3 -3
  200. package/dist/actions/swap/providers/velodrome/encoding/poolRouter.d.ts.map +1 -0
  201. package/dist/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.js +2 -1
  202. package/dist/actions/swap/providers/velodrome/encoding/poolRouter.js.map +1 -0
  203. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.d.ts +24 -3
  204. package/dist/actions/swap/providers/velodrome/encoding/routers/cl.d.ts.map +1 -0
  205. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.js +22 -10
  206. package/dist/actions/swap/providers/velodrome/encoding/routers/cl.js.map +1 -0
  207. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.d.ts +23 -3
  208. package/dist/actions/swap/providers/velodrome/encoding/routers/v2.d.ts.map +1 -0
  209. package/dist/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.js +24 -13
  210. package/dist/actions/swap/providers/velodrome/encoding/routers/v2.js.map +1 -0
  211. package/dist/{swap → actions/swap}/providers/velodrome/markets.d.ts +3 -3
  212. package/dist/actions/swap/providers/velodrome/markets.d.ts.map +1 -0
  213. package/dist/{swap → actions/swap}/providers/velodrome/markets.js +4 -3
  214. package/dist/actions/swap/providers/velodrome/markets.js.map +1 -0
  215. package/dist/{swap → actions/swap}/providers/velodrome/types.d.ts +1 -1
  216. package/dist/actions/swap/providers/velodrome/types.d.ts.map +1 -0
  217. package/dist/actions/swap/providers/velodrome/types.js +2 -0
  218. package/dist/actions/swap/providers/velodrome/types.js.map +1 -0
  219. package/dist/actions.d.ts +4 -3
  220. package/dist/actions.d.ts.map +1 -1
  221. package/dist/actions.js +45 -22
  222. package/dist/actions.js.map +1 -1
  223. package/dist/constants/supportedChains.d.ts +5790 -2
  224. package/dist/constants/supportedChains.d.ts.map +1 -1
  225. package/dist/constants/supportedChains.js +66 -20
  226. package/dist/constants/supportedChains.js.map +1 -1
  227. package/dist/core/error/__tests__/errors.test.d.ts +2 -0
  228. package/dist/core/error/__tests__/errors.test.d.ts.map +1 -0
  229. package/dist/core/error/__tests__/errors.test.js +195 -0
  230. package/dist/core/error/__tests__/errors.test.js.map +1 -0
  231. package/dist/core/error/errors.d.ts +155 -15
  232. package/dist/core/error/errors.d.ts.map +1 -1
  233. package/dist/core/error/errors.js +229 -17
  234. package/dist/core/error/errors.js.map +1 -1
  235. package/dist/index.d.ts +10 -6
  236. package/dist/index.d.ts.map +1 -1
  237. package/dist/index.js +9 -5
  238. package/dist/index.js.map +1 -1
  239. package/dist/services/ChainManager.d.ts.map +1 -1
  240. package/dist/services/ChainManager.js +42 -7
  241. package/dist/services/ChainManager.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/{ens → services/nameservices/ens}/EnsNamespace.d.ts +1 -1
  249. package/dist/services/nameservices/ens/EnsNamespace.d.ts.map +1 -0
  250. package/dist/{ens → services/nameservices/ens}/EnsNamespace.js +1 -1
  251. package/dist/services/nameservices/ens/EnsNamespace.js.map +1 -0
  252. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.d.ts.map +1 -0
  253. package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.js +2 -2
  254. package/dist/services/nameservices/ens/__tests__/EnsNamespace.spec.js.map +1 -0
  255. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts +2 -0
  256. package/dist/services/nameservices/ens/__tests__/utils.spec.d.ts.map +1 -0
  257. package/dist/{utils/ens.test.js → services/nameservices/ens/__tests__/utils.spec.js} +3 -3
  258. package/dist/services/nameservices/ens/__tests__/utils.spec.js.map +1 -0
  259. package/dist/services/nameservices/ens/errors.d.ts.map +1 -0
  260. package/dist/services/nameservices/ens/errors.js.map +1 -0
  261. package/dist/{ens → services/nameservices/ens}/index.d.ts +1 -0
  262. package/dist/services/nameservices/ens/index.d.ts.map +1 -0
  263. package/dist/{ens → services/nameservices/ens}/index.js +1 -0
  264. package/dist/services/nameservices/ens/index.js.map +1 -0
  265. package/dist/{ens → services/nameservices/ens}/types.d.ts +1 -1
  266. package/dist/services/nameservices/ens/types.d.ts.map +1 -0
  267. package/dist/services/nameservices/ens/types.js.map +1 -0
  268. package/dist/{utils/ens.d.ts → services/nameservices/ens/utils.d.ts} +3 -3
  269. package/dist/services/nameservices/ens/utils.d.ts.map +1 -0
  270. package/dist/{utils/ens.js → services/nameservices/ens/utils.js} +3 -3
  271. package/dist/services/nameservices/ens/utils.js.map +1 -0
  272. package/dist/services/tokenBalance.d.ts +8 -5
  273. package/dist/services/tokenBalance.d.ts.map +1 -1
  274. package/dist/services/tokenBalance.js +15 -8
  275. package/dist/services/tokenBalance.js.map +1 -1
  276. package/dist/types/actions.d.ts +80 -13
  277. package/dist/types/actions.d.ts.map +1 -1
  278. package/dist/types/actions.js +22 -1
  279. package/dist/types/actions.js.map +1 -1
  280. package/dist/types/asset.d.ts +7 -0
  281. package/dist/types/asset.d.ts.map +1 -1
  282. package/dist/types/common/FilterAssetChain.d.ts +13 -0
  283. package/dist/types/common/FilterAssetChain.d.ts.map +1 -0
  284. package/dist/types/common/FilterAssetChain.js +2 -0
  285. package/dist/types/common/FilterAssetChain.js.map +1 -0
  286. package/dist/types/common/TransactionOptions.d.ts +13 -0
  287. package/dist/types/common/TransactionOptions.d.ts.map +1 -0
  288. package/dist/types/common/TransactionOptions.js +2 -0
  289. package/dist/types/common/TransactionOptions.js.map +1 -0
  290. package/dist/types/common/index.d.ts +3 -0
  291. package/dist/types/common/index.d.ts.map +1 -0
  292. package/dist/types/common/index.js +3 -0
  293. package/dist/types/common/index.js.map +1 -0
  294. package/dist/types/index.d.ts +1 -0
  295. package/dist/types/index.d.ts.map +1 -1
  296. package/dist/types/index.js +1 -0
  297. package/dist/types/index.js.map +1 -1
  298. package/dist/types/lend/base.d.ts +44 -34
  299. package/dist/types/lend/base.d.ts.map +1 -1
  300. package/dist/types/lend/base.js +3 -3
  301. package/dist/types/lend/base.js.map +1 -1
  302. package/dist/types/lend/index.d.ts +0 -1
  303. package/dist/types/lend/index.d.ts.map +1 -1
  304. package/dist/types/lend/index.js +0 -1
  305. package/dist/types/lend/index.js.map +1 -1
  306. package/dist/types/providers.d.ts +22 -8
  307. package/dist/types/providers.d.ts.map +1 -1
  308. package/dist/types/providers.js +12 -1
  309. package/dist/types/providers.js.map +1 -1
  310. package/dist/types/swap/base.d.ts +25 -13
  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__/lendConfig.test.d.ts +2 -0
  321. package/dist/utils/__tests__/lendConfig.test.d.ts.map +1 -0
  322. package/dist/utils/__tests__/lendConfig.test.js +44 -0
  323. package/dist/utils/__tests__/lendConfig.test.js.map +1 -0
  324. package/dist/utils/__tests__/serializers.test.d.ts +2 -0
  325. package/dist/utils/__tests__/serializers.test.d.ts.map +1 -0
  326. package/dist/utils/__tests__/serializers.test.js +43 -0
  327. package/dist/utils/__tests__/serializers.test.js.map +1 -0
  328. package/dist/utils/__tests__/validateAddresses.test.d.ts.map +1 -0
  329. package/dist/utils/{validateAddresses.test.js → __tests__/validateAddresses.test.js} +10 -10
  330. package/dist/utils/__tests__/validateAddresses.test.js.map +1 -0
  331. package/dist/utils/abi/permit2.d.ts +48 -0
  332. package/dist/utils/abi/permit2.d.ts.map +1 -0
  333. package/dist/utils/abi/permit2.js +34 -0
  334. package/dist/utils/abi/permit2.js.map +1 -0
  335. package/dist/utils/approve.d.ts +26 -3
  336. package/dist/utils/approve.d.ts.map +1 -1
  337. package/dist/utils/approve.js +34 -37
  338. package/dist/utils/approve.js.map +1 -1
  339. package/dist/utils/assets.d.ts.map +1 -1
  340. package/dist/utils/assets.js +3 -2
  341. package/dist/utils/assets.js.map +1 -1
  342. package/dist/utils/lendConfig.d.ts +9 -0
  343. package/dist/utils/lendConfig.d.ts.map +1 -0
  344. package/dist/utils/lendConfig.js +12 -0
  345. package/dist/utils/lendConfig.js.map +1 -0
  346. package/dist/utils/serializers.d.ts +16 -0
  347. package/dist/utils/serializers.d.ts.map +1 -0
  348. package/dist/utils/serializers.js +18 -0
  349. package/dist/utils/serializers.js.map +1 -0
  350. package/dist/utils/validation.d.ts +8 -1
  351. package/dist/utils/validation.d.ts.map +1 -1
  352. package/dist/utils/validation.js +28 -8
  353. package/dist/utils/validation.js.map +1 -1
  354. package/dist/wallet/core/error/errors.d.ts +21 -0
  355. package/dist/wallet/core/error/errors.d.ts.map +1 -0
  356. package/dist/wallet/core/error/errors.js +24 -0
  357. package/dist/wallet/core/error/errors.js.map +1 -0
  358. package/dist/wallet/core/namespace/WalletNamespace.d.ts +24 -8
  359. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -1
  360. package/dist/wallet/core/namespace/WalletNamespace.js +48 -17
  361. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -1
  362. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +105 -10
  363. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -1
  364. package/dist/wallet/core/providers/WalletProvider.d.ts +3 -2
  365. package/dist/wallet/core/providers/WalletProvider.d.ts.map +1 -1
  366. package/dist/wallet/core/providers/WalletProvider.js +8 -2
  367. package/dist/wallet/core/providers/WalletProvider.js.map +1 -1
  368. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +1 -1
  369. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -1
  370. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts.map +1 -1
  371. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js +2 -1
  372. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js.map +1 -1
  373. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +1 -1
  374. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -1
  375. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +1 -1
  376. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -1
  377. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts +2 -0
  378. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.d.ts.map +1 -0
  379. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js +31 -0
  380. package/dist/wallet/core/utils/__tests__/executeTransactionBatch.spec.js.map +1 -0
  381. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +1 -0
  382. package/dist/wallet/core/utils/__tests__/retryOnStaleRead.spec.js.map +1 -0
  383. package/dist/wallet/core/utils/executeTransactionBatch.d.ts +22 -0
  384. package/dist/wallet/core/utils/executeTransactionBatch.d.ts.map +1 -0
  385. package/dist/wallet/core/utils/executeTransactionBatch.js +26 -0
  386. package/dist/wallet/core/utils/executeTransactionBatch.js.map +1 -0
  387. package/dist/wallet/core/utils/retryOnStaleRead.d.ts.map +1 -0
  388. package/dist/wallet/core/utils/retryOnStaleRead.js.map +1 -0
  389. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +17 -8
  390. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -1
  391. package/dist/wallet/core/wallets/abstract/Wallet.js +24 -12
  392. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -1
  393. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +3 -3
  394. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -1
  395. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -1
  396. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +41 -2
  397. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -1
  398. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts +13 -5
  399. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts.map +1 -1
  400. package/dist/wallet/core/wallets/eoa/EOAWallet.js +17 -12
  401. package/dist/wallet/core/wallets/eoa/EOAWallet.js.map +1 -1
  402. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js +37 -20
  403. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js.map +1 -1
  404. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts +1 -1
  405. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts.map +1 -1
  406. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +1 -1
  407. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -1
  408. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +2 -2
  409. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -1
  410. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +1 -1
  411. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -1
  412. package/dist/wallet/node/index.d.ts +1 -0
  413. package/dist/wallet/node/index.d.ts.map +1 -1
  414. package/dist/wallet/node/index.js +1 -0
  415. package/dist/wallet/node/index.js.map +1 -1
  416. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  417. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  418. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +1 -1
  419. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -1
  420. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  421. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  422. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +4 -1
  423. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
  424. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -1
  425. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
  426. package/dist/wallet/node/wallets/local/LocalWallet.d.ts +24 -0
  427. package/dist/wallet/node/wallets/local/LocalWallet.d.ts.map +1 -0
  428. package/dist/wallet/node/wallets/local/LocalWallet.js +21 -0
  429. package/dist/wallet/node/wallets/local/LocalWallet.js.map +1 -0
  430. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts +2 -0
  431. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.d.ts.map +1 -0
  432. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js +52 -0
  433. package/dist/wallet/node/wallets/local/__tests__/LocalWallet.spec.js.map +1 -0
  434. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +1 -1
  435. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -1
  436. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +1 -1
  437. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -1
  438. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +1 -1
  439. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -1
  440. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +1 -1
  441. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -1
  442. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js +2 -1
  443. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js.map +1 -1
  444. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +2 -1
  445. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -1
  446. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +2 -1
  447. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -1
  448. package/package.json +2 -2
  449. package/src/__tests__/actions.test.ts +3 -1
  450. package/src/{lend → actions/lend}/__mocks__/MockLendProvider.ts +24 -9
  451. package/src/{lend → actions/lend}/__mocks__/mockLendTransaction.ts +2 -2
  452. package/src/{lend → actions/lend}/core/LendProvider.ts +125 -41
  453. package/src/{lend → actions/lend}/core/__tests__/LendProvider.test.ts +82 -3
  454. package/src/actions/lend/index.ts +3 -0
  455. package/src/{lend → actions/lend}/namespaces/BaseLendNamespace.ts +20 -37
  456. package/src/{lend → actions/lend}/namespaces/WalletLendNamespace.ts +15 -22
  457. package/src/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.ts +3 -3
  458. package/src/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.ts +3 -3
  459. package/src/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.ts +6 -6
  460. package/src/{lend → actions/lend}/providers/aave/AaveLendProvider.ts +65 -73
  461. package/src/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.ts +7 -7
  462. package/src/{lend → actions/lend}/providers/aave/sdk.ts +15 -9
  463. package/src/{lend → actions/lend}/providers/morpho/MorphoLendProvider.ts +67 -53
  464. package/src/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.ts +79 -5
  465. package/src/{lend → actions/lend}/providers/morpho/__tests__/api.test.ts +3 -3
  466. package/src/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.ts +2 -2
  467. package/src/{lend → actions/lend}/providers/morpho/sdk.ts +23 -12
  468. package/src/actions/lend/utils/markets.ts +62 -0
  469. package/src/actions/shared/BaseNamespace.ts +46 -0
  470. package/src/actions/shared/__tests__/BaseNamespace.spec.ts +58 -0
  471. package/src/{lend/providers → actions/shared}/morpho/contracts.ts +3 -3
  472. package/src/{swap → actions/swap}/__mocks__/MockSwapProvider.ts +6 -2
  473. package/src/{swap → actions/swap}/core/SwapProvider.ts +89 -57
  474. package/src/{swap → actions/swap}/core/__tests__/SwapProvider.test.ts +51 -1
  475. package/src/{swap → actions/swap}/core/markets.ts +2 -1
  476. package/src/actions/swap/index.ts +19 -0
  477. package/src/{swap → actions/swap}/namespaces/ActionsSwapNamespace.ts +1 -1
  478. package/src/{swap → actions/swap}/namespaces/BaseSwapNamespace.ts +92 -90
  479. package/src/{swap → actions/swap}/namespaces/WalletSwapNamespace.ts +60 -34
  480. package/src/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.ts +6 -6
  481. package/src/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.ts +110 -22
  482. package/src/{swap → actions/swap}/providers/uniswap/UniswapSwapProvider.ts +34 -14
  483. package/src/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.ts +2 -2
  484. package/src/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.ts +65 -3
  485. package/src/{swap → actions/swap}/providers/uniswap/addresses.ts +5 -1
  486. package/src/{swap → actions/swap}/providers/uniswap/encoding.ts +3 -3
  487. package/src/{swap → actions/swap}/providers/uniswap/markets.ts +2 -2
  488. package/src/{swap → actions/swap}/providers/velodrome/VelodromeSwapProvider.ts +71 -31
  489. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.ts +2 -2
  490. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.ts +8 -7
  491. package/src/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.ts +46 -5
  492. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.ts +31 -2
  493. package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.ts +34 -3
  494. package/src/{swap → actions/swap}/providers/velodrome/config.ts +5 -1
  495. package/src/{swap → actions/swap}/providers/velodrome/encoding/helpers.ts +3 -2
  496. package/src/{swap → actions/swap}/providers/velodrome/encoding/index.ts +0 -1
  497. package/src/{swap → actions/swap}/providers/velodrome/encoding/poolRouter.ts +4 -3
  498. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/cl.ts +31 -23
  499. package/src/{swap → actions/swap}/providers/velodrome/encoding/routers/v2.ts +34 -27
  500. package/src/{swap → actions/swap}/providers/velodrome/markets.ts +4 -3
  501. package/src/actions.ts +68 -37
  502. package/src/constants/supportedChains.ts +81 -21
  503. package/src/core/error/__tests__/errors.test.ts +236 -0
  504. package/src/core/error/errors.ts +319 -22
  505. package/src/index.ts +31 -13
  506. package/src/services/ChainManager.ts +45 -9
  507. package/src/services/{ChainManager.spec.ts → __tests__/ChainManager.spec.ts} +6 -6
  508. package/src/services/{tokenBalance.spec.ts → __tests__/tokenBalance.spec.ts} +56 -1
  509. package/src/{ens → services/nameservices/ens}/EnsNamespace.ts +1 -1
  510. package/src/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.ts +6 -4
  511. package/src/{utils/ens.test.ts → services/nameservices/ens/__tests__/utils.spec.ts} +3 -2
  512. package/src/{ens → services/nameservices/ens}/index.ts +5 -0
  513. package/src/{utils/ens.ts → services/nameservices/ens/utils.ts} +3 -3
  514. package/src/services/tokenBalance.ts +16 -7
  515. package/src/types/actions.ts +96 -16
  516. package/src/types/asset.ts +8 -0
  517. package/src/types/common/FilterAssetChain.ts +13 -0
  518. package/src/types/common/TransactionOptions.ts +12 -0
  519. package/src/types/common/index.ts +2 -0
  520. package/src/types/index.ts +1 -0
  521. package/src/types/lend/base.ts +48 -36
  522. package/src/types/lend/index.ts +0 -1
  523. package/src/types/providers.ts +26 -8
  524. package/src/types/swap/base.ts +25 -13
  525. package/src/utils/{approve.test.ts → __tests__/approve.test.ts} +51 -18
  526. package/src/utils/__tests__/lendConfig.test.ts +52 -0
  527. package/src/utils/__tests__/serializers.test.ts +53 -0
  528. package/src/utils/{validateAddresses.test.ts → __tests__/validateAddresses.test.ts} +9 -9
  529. package/src/utils/abi/permit2.ts +33 -0
  530. package/src/utils/approve.ts +48 -37
  531. package/src/utils/assets.ts +6 -6
  532. package/src/utils/lendConfig.ts +17 -0
  533. package/src/utils/serializers.ts +21 -0
  534. package/src/utils/validation.ts +42 -15
  535. package/src/wallet/core/error/errors.ts +30 -0
  536. package/src/wallet/core/namespace/WalletNamespace.ts +82 -20
  537. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +141 -16
  538. package/src/wallet/core/providers/WalletProvider.ts +12 -3
  539. package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +1 -1
  540. package/src/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.ts +2 -1
  541. package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +1 -1
  542. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +1 -1
  543. package/src/wallet/core/utils/__tests__/executeTransactionBatch.spec.ts +42 -0
  544. package/src/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.ts +1 -1
  545. package/src/wallet/core/utils/executeTransactionBatch.ts +37 -0
  546. package/src/wallet/core/wallets/abstract/Wallet.ts +29 -15
  547. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +3 -3
  548. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +69 -3
  549. package/src/wallet/core/wallets/eoa/EOAWallet.ts +18 -13
  550. package/src/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.ts +43 -24
  551. package/src/wallet/core/wallets/smart/abstract/SmartWallet.ts +1 -1
  552. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +3 -3
  553. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +1 -1
  554. package/src/wallet/node/index.ts +1 -0
  555. package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  556. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +1 -1
  557. package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  558. package/src/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +4 -1
  559. package/src/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -1
  560. package/src/wallet/node/wallets/local/LocalWallet.ts +48 -0
  561. package/src/wallet/node/wallets/local/__tests__/LocalWallet.spec.ts +65 -0
  562. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +1 -1
  563. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +1 -1
  564. package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +1 -1
  565. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +1 -1
  566. package/src/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.ts +2 -1
  567. package/src/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +2 -1
  568. package/src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +2 -1
  569. package/dist/core/asset/__mocks__/mockAsset.d.ts +0 -6
  570. package/dist/core/asset/__mocks__/mockAsset.d.ts.map +0 -1
  571. package/dist/core/asset/__mocks__/mockAsset.js +0 -12
  572. package/dist/core/asset/__mocks__/mockAsset.js.map +0 -1
  573. package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +0 -1
  574. package/dist/core/utils/__tests__/retryOnStaleRead.spec.js.map +0 -1
  575. package/dist/core/utils/retryOnStaleRead.d.ts.map +0 -1
  576. package/dist/core/utils/retryOnStaleRead.js.map +0 -1
  577. package/dist/ens/EnsNamespace.d.ts.map +0 -1
  578. package/dist/ens/EnsNamespace.js.map +0 -1
  579. package/dist/ens/EnsNamespace.spec.d.ts.map +0 -1
  580. package/dist/ens/EnsNamespace.spec.js.map +0 -1
  581. package/dist/ens/errors.d.ts.map +0 -1
  582. package/dist/ens/errors.js.map +0 -1
  583. package/dist/ens/index.d.ts.map +0 -1
  584. package/dist/ens/index.js.map +0 -1
  585. package/dist/ens/types.d.ts.map +0 -1
  586. package/dist/ens/types.js.map +0 -1
  587. package/dist/lend/__mocks__/MockLendProvider.d.ts.map +0 -1
  588. package/dist/lend/__mocks__/MockLendProvider.js.map +0 -1
  589. package/dist/lend/__mocks__/MockMarkets.d.ts.map +0 -1
  590. package/dist/lend/__mocks__/MockMarkets.js.map +0 -1
  591. package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +0 -1
  592. package/dist/lend/__mocks__/mockLendTransaction.js.map +0 -1
  593. package/dist/lend/core/LendProvider.d.ts.map +0 -1
  594. package/dist/lend/core/LendProvider.js.map +0 -1
  595. package/dist/lend/core/__tests__/LendProvider.test.d.ts.map +0 -1
  596. package/dist/lend/core/__tests__/LendProvider.test.js.map +0 -1
  597. package/dist/lend/index.d.ts.map +0 -1
  598. package/dist/lend/index.js.map +0 -1
  599. package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +0 -1
  600. package/dist/lend/namespaces/ActionsLendNamespace.js.map +0 -1
  601. package/dist/lend/namespaces/BaseLendNamespace.d.ts +0 -43
  602. package/dist/lend/namespaces/BaseLendNamespace.d.ts.map +0 -1
  603. package/dist/lend/namespaces/BaseLendNamespace.js.map +0 -1
  604. package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +0 -1
  605. package/dist/lend/namespaces/WalletLendNamespace.js.map +0 -1
  606. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +0 -1
  607. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +0 -1
  608. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.d.ts.map +0 -1
  609. package/dist/lend/namespaces/__tests__/BaseLendNamespace.spec.js.map +0 -1
  610. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +0 -1
  611. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +0 -1
  612. package/dist/lend/providers/aave/AaveLendProvider.d.ts.map +0 -1
  613. package/dist/lend/providers/aave/AaveLendProvider.js.map +0 -1
  614. package/dist/lend/providers/aave/__mocks__/mockReserve.d.ts.map +0 -1
  615. package/dist/lend/providers/aave/__mocks__/mockReserve.js.map +0 -1
  616. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.d.ts.map +0 -1
  617. package/dist/lend/providers/aave/__tests__/AaveLendProvider.test.js.map +0 -1
  618. package/dist/lend/providers/aave/abis/pool.d.ts.map +0 -1
  619. package/dist/lend/providers/aave/abis/pool.js.map +0 -1
  620. package/dist/lend/providers/aave/addresses.d.ts.map +0 -1
  621. package/dist/lend/providers/aave/addresses.js.map +0 -1
  622. package/dist/lend/providers/aave/sdk.d.ts.map +0 -1
  623. package/dist/lend/providers/aave/sdk.js.map +0 -1
  624. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +0 -1
  625. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +0 -1
  626. package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts.map +0 -1
  627. package/dist/lend/providers/morpho/__mocks__/mockVault.js.map +0 -1
  628. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +0 -1
  629. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +0 -1
  630. package/dist/lend/providers/morpho/__tests__/api.test.d.ts.map +0 -1
  631. package/dist/lend/providers/morpho/__tests__/api.test.js.map +0 -1
  632. package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts.map +0 -1
  633. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +0 -1
  634. package/dist/lend/providers/morpho/api.d.ts.map +0 -1
  635. package/dist/lend/providers/morpho/api.js.map +0 -1
  636. package/dist/lend/providers/morpho/contracts.d.ts.map +0 -1
  637. package/dist/lend/providers/morpho/sdk.d.ts.map +0 -1
  638. package/dist/lend/providers/morpho/sdk.js.map +0 -1
  639. package/dist/services/ChainManager.spec.d.ts.map +0 -1
  640. package/dist/services/ChainManager.spec.js.map +0 -1
  641. package/dist/services/tokenBalance.spec.d.ts.map +0 -1
  642. package/dist/services/tokenBalance.spec.js.map +0 -1
  643. package/dist/swap/__mocks__/MockSwapProvider.d.ts.map +0 -1
  644. package/dist/swap/__mocks__/MockSwapProvider.js.map +0 -1
  645. package/dist/swap/core/SwapProvider.d.ts.map +0 -1
  646. package/dist/swap/core/SwapProvider.js.map +0 -1
  647. package/dist/swap/core/__tests__/SwapProvider.test.d.ts.map +0 -1
  648. package/dist/swap/core/__tests__/SwapProvider.test.js.map +0 -1
  649. package/dist/swap/core/markets.d.ts.map +0 -1
  650. package/dist/swap/core/markets.js.map +0 -1
  651. package/dist/swap/index.d.ts.map +0 -1
  652. package/dist/swap/index.js.map +0 -1
  653. package/dist/swap/namespaces/ActionsSwapNamespace.d.ts.map +0 -1
  654. package/dist/swap/namespaces/ActionsSwapNamespace.js.map +0 -1
  655. package/dist/swap/namespaces/BaseSwapNamespace.d.ts.map +0 -1
  656. package/dist/swap/namespaces/BaseSwapNamespace.js.map +0 -1
  657. package/dist/swap/namespaces/WalletSwapNamespace.d.ts +0 -35
  658. package/dist/swap/namespaces/WalletSwapNamespace.d.ts.map +0 -1
  659. package/dist/swap/namespaces/WalletSwapNamespace.js.map +0 -1
  660. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.d.ts.map +0 -1
  661. package/dist/swap/namespaces/__tests__/BaseSwapNamespace.spec.js.map +0 -1
  662. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.d.ts.map +0 -1
  663. package/dist/swap/namespaces/__tests__/WalletSwapNamespace.spec.js.map +0 -1
  664. package/dist/swap/providers/uniswap/UniswapSwapProvider.d.ts.map +0 -1
  665. package/dist/swap/providers/uniswap/UniswapSwapProvider.js.map +0 -1
  666. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts.map +0 -1
  667. package/dist/swap/providers/uniswap/__tests__/UniswapSwapProvider.test.js.map +0 -1
  668. package/dist/swap/providers/uniswap/__tests__/sdk.test.d.ts.map +0 -1
  669. package/dist/swap/providers/uniswap/__tests__/sdk.test.js.map +0 -1
  670. package/dist/swap/providers/uniswap/abis.d.ts.map +0 -1
  671. package/dist/swap/providers/uniswap/abis.js.map +0 -1
  672. package/dist/swap/providers/uniswap/addresses.d.ts.map +0 -1
  673. package/dist/swap/providers/uniswap/addresses.js.map +0 -1
  674. package/dist/swap/providers/uniswap/encoding.d.ts.map +0 -1
  675. package/dist/swap/providers/uniswap/encoding.js.map +0 -1
  676. package/dist/swap/providers/uniswap/markets.d.ts.map +0 -1
  677. package/dist/swap/providers/uniswap/markets.js.map +0 -1
  678. package/dist/swap/providers/uniswap/types.d.ts.map +0 -1
  679. package/dist/swap/providers/uniswap/types.js.map +0 -1
  680. package/dist/swap/providers/velodrome/VelodromeSwapProvider.d.ts.map +0 -1
  681. package/dist/swap/providers/velodrome/VelodromeSwapProvider.js.map +0 -1
  682. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts.map +0 -1
  683. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js.map +0 -1
  684. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts.map +0 -1
  685. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.js.map +0 -1
  686. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts.map +0 -1
  687. package/dist/swap/providers/velodrome/__tests__/VelodromeSwapProvider.test.js.map +0 -1
  688. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.d.ts.map +0 -1
  689. package/dist/swap/providers/velodrome/__tests__/encoding.cl.test.js.map +0 -1
  690. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.d.ts.map +0 -1
  691. package/dist/swap/providers/velodrome/__tests__/encoding.helpers.js.map +0 -1
  692. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.d.ts.map +0 -1
  693. package/dist/swap/providers/velodrome/__tests__/encoding.v2.test.js.map +0 -1
  694. package/dist/swap/providers/velodrome/abis.d.ts.map +0 -1
  695. package/dist/swap/providers/velodrome/abis.js.map +0 -1
  696. package/dist/swap/providers/velodrome/addresses.d.ts.map +0 -1
  697. package/dist/swap/providers/velodrome/addresses.js.map +0 -1
  698. package/dist/swap/providers/velodrome/config.d.ts.map +0 -1
  699. package/dist/swap/providers/velodrome/config.js.map +0 -1
  700. package/dist/swap/providers/velodrome/encoding/helpers.d.ts.map +0 -1
  701. package/dist/swap/providers/velodrome/encoding/helpers.js.map +0 -1
  702. package/dist/swap/providers/velodrome/encoding/index.d.ts.map +0 -1
  703. package/dist/swap/providers/velodrome/encoding/index.js.map +0 -1
  704. package/dist/swap/providers/velodrome/encoding/poolRouter.d.ts.map +0 -1
  705. package/dist/swap/providers/velodrome/encoding/poolRouter.js.map +0 -1
  706. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts +0 -15
  707. package/dist/swap/providers/velodrome/encoding/routers/approval.d.ts.map +0 -1
  708. package/dist/swap/providers/velodrome/encoding/routers/approval.js +0 -33
  709. package/dist/swap/providers/velodrome/encoding/routers/approval.js.map +0 -1
  710. package/dist/swap/providers/velodrome/encoding/routers/cl.d.ts.map +0 -1
  711. package/dist/swap/providers/velodrome/encoding/routers/cl.js.map +0 -1
  712. package/dist/swap/providers/velodrome/encoding/routers/v2.d.ts.map +0 -1
  713. package/dist/swap/providers/velodrome/encoding/routers/v2.js.map +0 -1
  714. package/dist/swap/providers/velodrome/markets.d.ts.map +0 -1
  715. package/dist/swap/providers/velodrome/markets.js.map +0 -1
  716. package/dist/swap/providers/velodrome/types.d.ts.map +0 -1
  717. package/dist/swap/providers/velodrome/types.js.map +0 -1
  718. package/dist/types/lend/contracts.d.ts.map +0 -1
  719. package/dist/types/lend/contracts.js +0 -2
  720. package/dist/types/lend/contracts.js.map +0 -1
  721. package/dist/utils/approve.test.d.ts.map +0 -1
  722. package/dist/utils/approve.test.js.map +0 -1
  723. package/dist/utils/assets.test.d.ts.map +0 -1
  724. package/dist/utils/assets.test.js.map +0 -1
  725. package/dist/utils/ens.d.ts.map +0 -1
  726. package/dist/utils/ens.js.map +0 -1
  727. package/dist/utils/ens.test.d.ts +0 -2
  728. package/dist/utils/ens.test.d.ts.map +0 -1
  729. package/dist/utils/ens.test.js.map +0 -1
  730. package/dist/utils/markets.d.ts +0 -17
  731. package/dist/utils/markets.d.ts.map +0 -1
  732. package/dist/utils/markets.js +0 -25
  733. package/dist/utils/markets.js.map +0 -1
  734. package/dist/utils/validateAddresses.test.d.ts.map +0 -1
  735. package/dist/utils/validateAddresses.test.js.map +0 -1
  736. package/src/core/asset/__mocks__/mockAsset.ts +0 -13
  737. package/src/lend/index.ts +0 -3
  738. package/src/swap/index.ts +0 -19
  739. package/src/swap/providers/velodrome/encoding/routers/approval.ts +0 -45
  740. package/src/utils/markets.ts +0 -35
  741. /package/dist/{lend → actions/lend}/core/__tests__/LendProvider.test.d.ts +0 -0
  742. /package/dist/{lend → actions/lend}/index.d.ts +0 -0
  743. /package/dist/{lend → actions/lend}/index.js +0 -0
  744. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.d.ts +0 -0
  745. /package/dist/{lend → actions/lend}/namespaces/ActionsLendNamespace.js +0 -0
  746. /package/dist/{lend → actions/lend}/namespaces/__tests__/ActionsLendNamespace.spec.d.ts +0 -0
  747. /package/dist/{lend → actions/lend}/namespaces/__tests__/BaseLendNamespace.spec.d.ts +0 -0
  748. /package/dist/{lend → actions/lend}/namespaces/__tests__/WalletLendNamespace.spec.d.ts +0 -0
  749. /package/dist/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.js +0 -0
  750. /package/dist/{lend → actions/lend}/providers/aave/__tests__/AaveLendProvider.test.d.ts +0 -0
  751. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.d.ts +0 -0
  752. /package/dist/{lend → actions/lend}/providers/aave/abis/pool.js +0 -0
  753. /package/dist/{lend → actions/lend}/providers/aave/addresses.d.ts +0 -0
  754. /package/dist/{lend → actions/lend}/providers/aave/addresses.js +0 -0
  755. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.d.ts +0 -0
  756. /package/dist/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.js +0 -0
  757. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/MorphoLendProvider.test.d.ts +0 -0
  758. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/api.test.d.ts +0 -0
  759. /package/dist/{lend → actions/lend}/providers/morpho/__tests__/sdk.test.d.ts +0 -0
  760. /package/dist/{lend → actions/lend}/providers/morpho/api.d.ts +0 -0
  761. /package/dist/{lend → actions/lend}/providers/morpho/api.js +0 -0
  762. /package/dist/{swap/providers/uniswap → actions/shared/morpho}/types.js +0 -0
  763. /package/dist/{swap → actions/swap}/core/__tests__/SwapProvider.test.d.ts +0 -0
  764. /package/dist/{swap → actions/swap}/index.d.ts +0 -0
  765. /package/dist/{swap → actions/swap}/index.js +0 -0
  766. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.d.ts +0 -0
  767. /package/dist/{swap → actions/swap}/namespaces/ActionsSwapNamespace.js +0 -0
  768. /package/dist/{swap → actions/swap}/namespaces/__tests__/BaseSwapNamespace.spec.d.ts +0 -0
  769. /package/dist/{swap → actions/swap}/namespaces/__tests__/WalletSwapNamespace.spec.d.ts +0 -0
  770. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/UniswapSwapProvider.test.d.ts +0 -0
  771. /package/dist/{swap → actions/swap}/providers/uniswap/__tests__/sdk.test.d.ts +0 -0
  772. /package/dist/{swap → actions/swap}/providers/uniswap/abis.d.ts +0 -0
  773. /package/dist/{swap → actions/swap}/providers/uniswap/abis.js +0 -0
  774. /package/dist/{swap/providers/velodrome → actions/swap/providers/uniswap}/types.js +0 -0
  775. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.d.ts +0 -0
  776. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.network.test.js +0 -0
  777. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.routing.test.d.ts +0 -0
  778. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/VelodromeSwapProvider.test.d.ts +0 -0
  779. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.cl.test.d.ts +0 -0
  780. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.js +0 -0
  781. /package/dist/{swap → actions/swap}/providers/velodrome/__tests__/encoding.v2.test.d.ts +0 -0
  782. /package/dist/{swap → actions/swap}/providers/velodrome/abis.d.ts +0 -0
  783. /package/dist/{swap → actions/swap}/providers/velodrome/abis.js +0 -0
  784. /package/dist/{swap → actions/swap}/providers/velodrome/addresses.js +0 -0
  785. /package/dist/services/{ChainManager.spec.d.ts → __tests__/ChainManager.spec.d.ts} +0 -0
  786. /package/dist/services/{tokenBalance.spec.d.ts → __tests__/tokenBalance.spec.d.ts} +0 -0
  787. /package/dist/{ens → services/nameservices/ens/__tests__}/EnsNamespace.spec.d.ts +0 -0
  788. /package/dist/{ens → services/nameservices/ens}/errors.d.ts +0 -0
  789. /package/dist/{ens → services/nameservices/ens}/errors.js +0 -0
  790. /package/dist/{ens → services/nameservices/ens}/types.js +0 -0
  791. /package/dist/utils/{approve.test.d.ts → __tests__/approve.test.d.ts} +0 -0
  792. /package/dist/utils/{assets.test.d.ts → __tests__/assets.test.d.ts} +0 -0
  793. /package/dist/utils/{validateAddresses.test.d.ts → __tests__/validateAddresses.test.d.ts} +0 -0
  794. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.d.ts +0 -0
  795. /package/dist/{core → wallet/core}/utils/__tests__/retryOnStaleRead.spec.js +0 -0
  796. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.d.ts +0 -0
  797. /package/dist/{core → wallet/core}/utils/retryOnStaleRead.js +0 -0
  798. /package/src/{lend → actions/lend}/__mocks__/MockMarkets.ts +0 -0
  799. /package/src/{lend → actions/lend}/namespaces/ActionsLendNamespace.ts +0 -0
  800. /package/src/{lend → actions/lend}/providers/aave/__mocks__/mockReserve.ts +0 -0
  801. /package/src/{lend → actions/lend}/providers/aave/abis/pool.ts +0 -0
  802. /package/src/{lend → actions/lend}/providers/aave/addresses.ts +0 -0
  803. /package/src/{lend → actions/lend}/providers/morpho/__mocks__/mockVault.ts +0 -0
  804. /package/src/{lend → actions/lend}/providers/morpho/api.ts +0 -0
  805. /package/src/{types/lend/contracts.ts → actions/shared/morpho/types.ts} +0 -0
  806. /package/src/{swap → actions/swap}/providers/uniswap/abis.ts +0 -0
  807. /package/src/{swap → actions/swap}/providers/uniswap/types.ts +0 -0
  808. /package/src/{swap → actions/swap}/providers/velodrome/__tests__/encoding.helpers.ts +0 -0
  809. /package/src/{swap → actions/swap}/providers/velodrome/abis.ts +0 -0
  810. /package/src/{swap → actions/swap}/providers/velodrome/addresses.ts +0 -0
  811. /package/src/{swap → actions/swap}/providers/velodrome/types.ts +0 -0
  812. /package/src/{ens → services/nameservices/ens}/errors.ts +0 -0
  813. /package/src/{ens → services/nameservices/ens}/types.ts +0 -0
  814. /package/src/utils/{assets.test.ts → __tests__/assets.test.ts} +0 -0
  815. /package/src/{core → wallet/core}/utils/retryOnStaleRead.ts +0 -0
@@ -1,8 +1,12 @@
1
1
  import type { Address } from 'viem'
2
2
 
3
3
  import type { SupportedChainId } from '@/constants/supportedChains.js'
4
- import type { LendProviderName } from '@/types/actions.js'
4
+ import type { ApprovalMode, LendProviderName } from '@/types/actions.js'
5
5
  import type { Asset } from '@/types/asset.js'
6
+ import type {
7
+ FilterAssetChain,
8
+ TransactionOptions,
9
+ } from '@/types/common/index.js'
6
10
  // Import and re-export shared transaction type for backwards compatibility
7
11
  import type { TransactionData } from '@/types/transaction.js'
8
12
  import type {
@@ -10,9 +14,9 @@ import type {
10
14
  TransactionReturnType,
11
15
  } from '@/wallet/core/wallets/abstract/types/index.js'
12
16
 
13
- export { LendProvider } from '@/lend/core/LendProvider.js'
14
- export { ActionsLendNamespace } from '@/lend/namespaces/ActionsLendNamespace.js'
15
- export { WalletLendNamespace } from '@/lend/namespaces/WalletLendNamespace.js'
17
+ export { LendProvider } from '@/actions/lend/core/LendProvider.js'
18
+ export { ActionsLendNamespace } from '@/actions/lend/namespaces/ActionsLendNamespace.js'
19
+ export { WalletLendNamespace } from '@/actions/lend/namespaces/WalletLendNamespace.js'
16
20
  export type { TransactionData }
17
21
 
18
22
  /**
@@ -68,8 +72,8 @@ export interface LendTransaction {
68
72
  hash?: string
69
73
  /** Amount lent */
70
74
  amount: bigint
71
- /** Asset address */
72
- asset: Address
75
+ /** Underlying ERC-20 address (the wrapped form for native deposits) */
76
+ assetAddress: Address
73
77
  /** Market ID */
74
78
  marketId: string
75
79
  /** Estimated APY at time of lending */
@@ -186,19 +190,6 @@ export interface LendMarket {
186
190
  metadata: LendMarketMetadata
187
191
  }
188
192
 
189
- /**
190
- * Lending options
191
- * @description Configuration options for lending operations
192
- */
193
- export interface LendOptions {
194
- /** Deadline for transaction (timestamp) */
195
- deadline?: number
196
- /** Gas limit override */
197
- gasLimit?: bigint
198
- /** Gas price override */
199
- gasPrice?: bigint
200
- }
201
-
202
193
  /**
203
194
  * Individual lending provider configuration
204
195
  * @description Configuration for a single lending provider
@@ -208,6 +199,8 @@ export interface LendProviderConfig {
208
199
  marketAllowlist?: LendMarketConfig[]
209
200
  /** Blocklist of markets to exclude from lending */
210
201
  marketBlocklist?: LendMarketConfig[]
202
+ /** Approval-amount strategy override for this provider. Overrides `LendSettings.approvalMode`. */
203
+ approvalMode?: ApprovalMode
211
204
  }
212
205
 
213
206
  /**
@@ -238,7 +231,12 @@ export interface LendOpenPositionBaseParams {
238
231
  /** Wallet address for receiving shares and as owner (auto-populated by WalletLendNamespace) */
239
232
  walletAddress?: Address
240
233
  /** Optional lending configuration */
241
- options?: LendOptions
234
+ options?: TransactionOptions
235
+ /**
236
+ * Override the wallet-level approval-amount strategy for this single supply.
237
+ * Falls back to `ActionsConfig.wallet.approvalMode` and finally to `"exact"`.
238
+ */
239
+ approvalMode?: ApprovalMode
242
240
  }
243
241
 
244
242
  /**
@@ -255,7 +253,7 @@ export interface LendOpenPositionParams extends LendOpenPositionBaseParams {
255
253
  */
256
254
  export interface LendOpenPositionInternalParams extends Omit<
257
255
  LendOpenPositionBaseParams,
258
- 'walletAddress'
256
+ 'walletAddress' | 'approvalMode'
259
257
  > {
260
258
  /** Amount to lend in wei */
261
259
  amountWei: bigint
@@ -263,6 +261,31 @@ export interface LendOpenPositionInternalParams extends Omit<
263
261
  walletAddress: Address
264
262
  }
265
263
 
264
+ /**
265
+ * Provider-supplied description of a lend open-position operation. The base
266
+ * `LendProvider` consumes this to build the surrounding `LendTransaction`,
267
+ * including the ERC-20 approval transaction (if any). Providers describe
268
+ * **what** the deposit looks like; the base derives **how** the approval is
269
+ * built from `params.asset` (native vs. ERC-20).
270
+ *
271
+ * For native-asset deposits, omit `spender` — the base reads `params.asset.type`
272
+ * and skips approval construction entirely. For ERC-20 deposits, `spender` is
273
+ * required and the base will throw if it's missing.
274
+ */
275
+ export interface LendOpenPosition {
276
+ /** Underlying ERC-20 address being deposited (the wrapped form for native deposits). */
277
+ assetAddress: Address
278
+ /**
279
+ * ERC-20 spender that needs allowance to pull `params.amountWei` from the
280
+ * wallet. Required for ERC-20 deposits; omit for native deposits.
281
+ */
282
+ spender?: Address
283
+ /** The deposit transaction itself (provider-specific calldata; `value` set for native). */
284
+ transaction: TransactionData
285
+ /** APY snapshot at the time the description was built. */
286
+ apy: number
287
+ }
288
+
266
289
  /**
267
290
  * Parameters for withdraw operation (internal)
268
291
  * @description Internal parameters required for withdrawing assets
@@ -277,7 +300,7 @@ export interface LendClosePositionParams {
277
300
  /** Wallet address for receiving assets and as owner */
278
301
  walletAddress: Address
279
302
  /** Optional withdrawal configuration */
280
- options?: LendOptions
303
+ options?: TransactionOptions
281
304
  }
282
305
 
283
306
  /**
@@ -294,7 +317,7 @@ export interface ClosePositionParams {
294
317
  /** Wallet address for receiving assets and as owner (auto-populated by WalletLendNamespace) */
295
318
  walletAddress?: Address
296
319
  /** Optional withdrawal configuration */
297
- options?: LendOptions
320
+ options?: TransactionOptions
298
321
  }
299
322
 
300
323
  /**
@@ -308,17 +331,6 @@ export interface GetPositionParams {
308
331
  asset?: Asset
309
332
  }
310
333
 
311
- /**
312
- * Common filter parameters for asset and chain
313
- * @description Base interface for filtering by asset and/or chain
314
- */
315
- export interface FilterAssetChain {
316
- /** Optional asset to filter by */
317
- asset?: Asset
318
- /** Optional chain ID to filter by */
319
- chainId?: SupportedChainId
320
- }
321
-
322
334
  /**
323
335
  * Parameters for getting lending markets
324
336
  * @description Parameters for filtering lending markets
@@ -347,11 +359,11 @@ export interface LendProviderMethods {
347
359
  /**
348
360
  * Provider implementation of openPosition method
349
361
  * @param params - Open position operation parameters
350
- * @returns Promise resolving to transaction data
362
+ * @returns Promise resolving to a `LendOpenPosition` description
351
363
  */
352
364
  _openPosition(
353
365
  params: LendOpenPositionInternalParams,
354
- ): Promise<TransactionData>
366
+ ): Promise<LendOpenPosition>
355
367
 
356
368
  /**
357
369
  * Provider implementation of closePosition method
@@ -1,3 +1,2 @@
1
1
  export * from '@/types/lend/base.js'
2
- export * from '@/types/lend/contracts.js'
3
2
  export * from '@/types/lend/morpho.js'
@@ -1,22 +1,40 @@
1
- import type { LendProvider } from '@/lend/core/LendProvider.js'
2
- import type { SwapProvider } from '@/swap/core/SwapProvider.js'
1
+ import type { LendProvider } from '@/actions/lend/core/LendProvider.js'
2
+ import type { SwapProvider } from '@/actions/swap/core/SwapProvider.js'
3
3
  import type { LendProviderConfig } from '@/types/lend/index.js'
4
4
  import type { SwapProviderConfig } from '@/types/swap/index.js'
5
5
 
6
+ /**
7
+ * Runtime list of lend provider names. Source of truth for both the
8
+ * `LendProviderName` type union and any consumer (CLI, validators) that
9
+ * needs to enumerate provider names at runtime.
10
+ */
11
+ export const LEND_PROVIDER_NAMES = ['morpho', 'aave'] as const
12
+
13
+ /** Names of available lend providers. */
14
+ export type LendProviderName = (typeof LEND_PROVIDER_NAMES)[number]
15
+
6
16
  /**
7
17
  * Map of available lend providers keyed by provider name.
8
- * Add new lend providers here this is the single source of truth.
18
+ * Add new providers by extending `LEND_PROVIDER_NAMES`.
9
19
  */
10
20
  export type LendProviders = {
11
- morpho?: LendProvider<LendProviderConfig>
12
- aave?: LendProvider<LendProviderConfig>
21
+ [K in LendProviderName]?: LendProvider<LendProviderConfig>
13
22
  }
14
23
 
24
+ /**
25
+ * Runtime list of swap provider names. Source of truth for both the
26
+ * `SwapProviderName` type union and any consumer (CLI, validators) that
27
+ * needs to enumerate provider names at runtime.
28
+ */
29
+ export const SWAP_PROVIDER_NAMES = ['uniswap', 'velodrome'] as const
30
+
31
+ /** Names of available swap providers. */
32
+ export type SwapProviderName = (typeof SWAP_PROVIDER_NAMES)[number]
33
+
15
34
  /**
16
35
  * Map of available swap providers keyed by provider name.
17
- * Add new swap providers here this is the single source of truth.
36
+ * Add new providers by extending `SWAP_PROVIDER_NAMES`.
18
37
  */
19
38
  export type SwapProviders = {
20
- uniswap?: SwapProvider<SwapProviderConfig>
21
- velodrome?: SwapProvider<SwapProviderConfig>
39
+ [K in SwapProviderName]?: SwapProvider<SwapProviderConfig>
22
40
  }
@@ -1,8 +1,8 @@
1
1
  import type { Address, Hex } from 'viem'
2
2
 
3
3
  import type { SupportedChainId } from '@/constants/supportedChains.js'
4
- import type { EnsName } from '@/ens/types.js'
5
- import type { SwapProviderName } from '@/types/actions.js'
4
+ import type { EnsName } from '@/services/nameservices/ens/types.js'
5
+ import type { ApprovalMode, SwapProviderName } from '@/types/actions.js'
6
6
  import type { Asset } from '@/types/asset.js'
7
7
  import type { TransactionData } from '@/types/transaction.js'
8
8
  import type {
@@ -10,9 +10,9 @@ import type {
10
10
  TransactionReturnType,
11
11
  } from '@/wallet/core/wallets/abstract/types/index.js'
12
12
 
13
- export { SwapProvider } from '@/swap/core/SwapProvider.js'
14
- export { ActionsSwapNamespace } from '@/swap/namespaces/ActionsSwapNamespace.js'
15
- export { WalletSwapNamespace } from '@/swap/namespaces/WalletSwapNamespace.js'
13
+ export { SwapProvider } from '@/actions/swap/core/SwapProvider.js'
14
+ export { ActionsSwapNamespace } from '@/actions/swap/namespaces/ActionsSwapNamespace.js'
15
+ export { WalletSwapNamespace } from '@/actions/swap/namespaces/WalletSwapNamespace.js'
16
16
  export type { SwapProviders } from '@/types/providers.js'
17
17
 
18
18
  /**
@@ -30,6 +30,8 @@ export interface SwapProviderConfig {
30
30
  marketAllowlist?: SwapMarketConfig[]
31
31
  /** Blocklist of swap markets to exclude */
32
32
  marketBlocklist?: SwapMarketConfig[]
33
+ /** Approval-amount strategy override for this provider. Overrides `SwapSettings.approvalMode`. */
34
+ approvalMode?: ApprovalMode
33
35
  }
34
36
 
35
37
  /**
@@ -93,6 +95,11 @@ export interface WalletSwapParams {
93
95
  recipient?: Address | EnsName
94
96
  /** Explicitly select a swap provider. Overrides routing config. */
95
97
  provider?: SwapProviderName
98
+ /**
99
+ * Override the wallet-level approval-amount strategy for this single swap.
100
+ * Falls back to `ActionsConfig.wallet.approvalMode` and finally to `"exact"`.
101
+ */
102
+ approvalMode?: ApprovalMode
96
103
  }
97
104
 
98
105
  /**
@@ -117,6 +124,8 @@ export interface ResolvedSwapParams {
117
124
  recipient: Address
118
125
  walletAddress: Address
119
126
  chainId: SupportedChainId
127
+ /** Resolved approval-amount strategy (per-call → wallet config → "exact"). */
128
+ approvalMode: ApprovalMode
120
129
  }
121
130
 
122
131
  /**
@@ -239,17 +248,20 @@ export interface SwapQuote {
239
248
  /** Estimated gas cost as raw bigint (native decimals) */
240
249
  gasEstimate?: bigint
241
250
  /**
242
- * Wallet address that will execute this quote.
243
- * Set by WalletSwapNamespace before execution not available on price-only quotes.
244
- * Used to check existing on-chain allowances and skip redundant approvals.
251
+ * Recipient address baked into execution.swapCalldata at quote time.
252
+ * Required. To execute a quote on a wallet, the quote must have been
253
+ * generated for that wallet (recipient === wallet.address); otherwise
254
+ * WalletSwapNamespace.execute throws. Re-quote via wallet.swap.getQuote
255
+ * when the executor differs from the quote's recipient.
245
256
  */
246
- recipient?: Address
257
+ recipient: Address
247
258
  /**
248
- * The recipient address baked into execution.swapCalldata at quote time.
249
- * If recipient differs from quotedRecipient at execute time, calldata is re-encoded
250
- * with the correct recipient to prevent tokens from being sent to the wrong address.
259
+ * Per-call override for the approval-amount strategy. When set, the provider
260
+ * uses this for the swap's approvals instead of the wallet-level config
261
+ * default. When unset, the provider falls back to the wallet's
262
+ * `approvalMode` config and finally to `"exact"`.
251
263
  */
252
- quotedRecipient: Address
264
+ approvalMode?: ApprovalMode
253
265
  }
254
266
 
255
267
  /**
@@ -1,7 +1,8 @@
1
1
  import type { Address, PublicClient } from 'viem'
2
- import { decodeFunctionData } from 'viem'
2
+ import { decodeFunctionData, maxUint160, maxUint256 } from 'viem'
3
3
  import { describe, expect, it, vi } from 'vitest'
4
4
 
5
+ import { PERMIT2_ABI } from '@/utils/abi/permit2.js'
5
6
  import {
6
7
  buildApprovalTxIfNeeded,
7
8
  buildErc20ApprovalTx,
@@ -11,23 +12,11 @@ import {
11
12
  checkTokenAllowance,
12
13
  DEFAULT_PERMIT2_EXPIRY_SECONDS,
13
14
  getApprovalDeficit,
15
+ resolveApprovalMode,
16
+ resolveErc20ApprovalAmount,
17
+ resolvePermit2ApprovalAmount,
14
18
  } from '@/utils/approve.js'
15
19
 
16
- const PERMIT2_ABI = [
17
- {
18
- name: 'approve',
19
- type: 'function',
20
- stateMutability: 'nonpayable',
21
- inputs: [
22
- { name: 'token', type: 'address' },
23
- { name: 'spender', type: 'address' },
24
- { name: 'amount', type: 'uint160' },
25
- { name: 'expiration', type: 'uint48' },
26
- ],
27
- outputs: [],
28
- },
29
- ] as const
30
-
31
20
  const TOKEN = '0x1111111111111111111111111111111111111111' as Address
32
21
  const OWNER = '0x2222222222222222222222222222222222222222' as Address
33
22
  const SPENDER = '0x3333333333333333333333333333333333333333' as Address
@@ -89,8 +78,8 @@ describe('checkTokenAllowance', () => {
89
78
  })
90
79
 
91
80
  describe('buildTokenApprovalTx', () => {
92
- it('builds max approval to Permit2', () => {
93
- const tx = buildTokenApprovalTx(TOKEN, PERMIT2)
81
+ it('builds approval to Permit2 for the given amount', () => {
82
+ const tx = buildTokenApprovalTx(TOKEN, PERMIT2, maxUint256)
94
83
 
95
84
  expect(tx.to).toBe(TOKEN)
96
85
  expect(tx.value).toBe(0n)
@@ -98,6 +87,50 @@ describe('buildTokenApprovalTx', () => {
98
87
  // Should encode approve(permit2, maxUint256)
99
88
  expect(tx.data.length).toBeGreaterThan(10)
100
89
  })
90
+
91
+ it('respects an exact-amount caller override', () => {
92
+ const tx = buildTokenApprovalTx(TOKEN, PERMIT2, 12345n)
93
+ expect(tx.to).toBe(TOKEN)
94
+ expect(tx.data).toMatch(/^0x/)
95
+ })
96
+ })
97
+
98
+ describe('resolveApprovalMode', () => {
99
+ it('prefers per-call when set', () => {
100
+ expect(resolveApprovalMode('max', 'exact', 'exact')).toBe('max')
101
+ })
102
+
103
+ it('falls through to provider default when per-call is undefined', () => {
104
+ expect(resolveApprovalMode(undefined, 'max', 'exact')).toBe('max')
105
+ })
106
+
107
+ it('falls through to global default when per-call and provider are undefined', () => {
108
+ expect(resolveApprovalMode(undefined, undefined, 'max')).toBe('max')
109
+ })
110
+
111
+ it('defaults to "exact" when nothing is set', () => {
112
+ expect(resolveApprovalMode(undefined, undefined, undefined)).toBe('exact')
113
+ })
114
+ })
115
+
116
+ describe('resolveErc20ApprovalAmount', () => {
117
+ it('returns required amount for "exact"', () => {
118
+ expect(resolveErc20ApprovalAmount('exact', 100n)).toBe(100n)
119
+ })
120
+
121
+ it('returns maxUint256 for "max"', () => {
122
+ expect(resolveErc20ApprovalAmount('max', 100n)).toBe(maxUint256)
123
+ })
124
+ })
125
+
126
+ describe('resolvePermit2ApprovalAmount', () => {
127
+ it('returns required amount for "exact"', () => {
128
+ expect(resolvePermit2ApprovalAmount('exact', 100n)).toBe(100n)
129
+ })
130
+
131
+ it('returns maxUint160 for "max" (Permit2 allowance is uint160-typed)', () => {
132
+ expect(resolvePermit2ApprovalAmount('max', 100n)).toBe(maxUint160)
133
+ })
101
134
  })
102
135
 
103
136
  describe('buildPermit2ApprovalTx', () => {
@@ -0,0 +1,52 @@
1
+ import { describe, expect, it } from 'vitest'
2
+
3
+ import { MockUSDCAsset } from '@/__mocks__/MockAssets.js'
4
+ import type { LendConfig } from '@/types/actions.js'
5
+ import type { LendMarketConfig } from '@/types/lend/base.js'
6
+ import { getLendMarketAllowlist } from '@/utils/lendConfig.js'
7
+
8
+ const morphoMarket: LendMarketConfig = {
9
+ address: '0x0000000000000000000000000000000000000001',
10
+ chainId: 130,
11
+ name: 'Morpho USDC',
12
+ asset: MockUSDCAsset,
13
+ lendProvider: 'morpho',
14
+ }
15
+
16
+ const aaveMarket: LendMarketConfig = {
17
+ address: '0x0000000000000000000000000000000000000002',
18
+ chainId: 130,
19
+ name: 'Aave USDC',
20
+ asset: MockUSDCAsset,
21
+ lendProvider: 'aave',
22
+ }
23
+
24
+ describe('getLendMarketAllowlist', () => {
25
+ it('returns empty list when lend config is undefined', () => {
26
+ expect(getLendMarketAllowlist(undefined)).toEqual([])
27
+ })
28
+
29
+ it('flattens allowlists across all providers', () => {
30
+ const lend: LendConfig = {
31
+ morpho: { marketAllowlist: [morphoMarket] },
32
+ aave: { marketAllowlist: [aaveMarket] },
33
+ }
34
+ expect(getLendMarketAllowlist(lend)).toEqual([morphoMarket, aaveMarket])
35
+ })
36
+
37
+ it('skips the settings sibling key', () => {
38
+ const lend: LendConfig = {
39
+ morpho: { marketAllowlist: [morphoMarket] },
40
+ settings: { approvalMode: 'max' },
41
+ }
42
+ expect(getLendMarketAllowlist(lend)).toEqual([morphoMarket])
43
+ })
44
+
45
+ it('returns empty list when no provider declares an allowlist', () => {
46
+ const lend: LendConfig = {
47
+ morpho: {},
48
+ settings: { approvalMode: 'exact' },
49
+ }
50
+ expect(getLendMarketAllowlist(lend)).toEqual([])
51
+ })
52
+ })
@@ -0,0 +1,53 @@
1
+ import { describe, expect, it } from 'vitest'
2
+
3
+ import { serializeBigInt } from '@/utils/serializers.js'
4
+
5
+ describe('serializeBigInt', () => {
6
+ it('coerces bigints to decimal strings', () => {
7
+ expect(serializeBigInt({ amount: 1n })).toEqual({ amount: '1' })
8
+ })
9
+
10
+ it('preserves precision for large bigints', () => {
11
+ const huge = 1234567890123456789n
12
+ expect(serializeBigInt({ n: huge })).toEqual({ n: '1234567890123456789' })
13
+ })
14
+
15
+ it('never emits scientific notation', () => {
16
+ const big = 10n ** 30n
17
+ expect(serializeBigInt({ n: big }).n).toBe(
18
+ '1000000000000000000000000000000',
19
+ )
20
+ })
21
+
22
+ it('recurses through arrays and nested objects', () => {
23
+ expect(
24
+ serializeBigInt({
25
+ balances: [
26
+ { chainId: 84532, amount: 100n },
27
+ { chainId: 10, amount: 200n },
28
+ ],
29
+ }),
30
+ ).toEqual({
31
+ balances: [
32
+ { chainId: 84532, amount: '100' },
33
+ { chainId: 10, amount: '200' },
34
+ ],
35
+ })
36
+ })
37
+
38
+ it('passes through non-bigint primitives untouched', () => {
39
+ expect(serializeBigInt({ s: 'hello', n: 42, b: true, z: null })).toEqual({
40
+ s: 'hello',
41
+ n: 42,
42
+ b: true,
43
+ z: null,
44
+ })
45
+ })
46
+
47
+ it('returns a fresh object (no shared references)', () => {
48
+ const input = { a: { b: 1n } }
49
+ const output = serializeBigInt(input)
50
+ expect(output).not.toBe(input)
51
+ expect(output.a).not.toBe(input.a)
52
+ })
53
+ })
@@ -7,20 +7,20 @@ import {
7
7
  getMockAuthorizationContext,
8
8
  } from '@/__mocks__/MockPrivyClient.js'
9
9
  import { Actions } from '@/actions.js'
10
- import {
11
- NATIVELY_SUPPORTED_ASSETS,
12
- OP_DEMO,
13
- USDC_DEMO,
14
- } from '@/constants/assets.js'
15
10
  import {
16
11
  POOL_ADDRESSES_MAINNET,
17
12
  POOL_ADDRESSES_TESTNET,
18
13
  WETH_GATEWAY_ADDRESSES_MAINNET,
19
14
  WETH_GATEWAY_ADDRESSES_TESTNET,
20
- } from '@/lend/providers/aave/addresses.js'
21
- import { MORPHO_CONTRACTS } from '@/lend/providers/morpho/contracts.js'
22
- import { UNISWAP_ADDRESSES } from '@/swap/providers/uniswap/addresses.js'
23
- import { VELODROME_CHAINS } from '@/swap/providers/velodrome/addresses.js'
15
+ } from '@/actions/lend/providers/aave/addresses.js'
16
+ import { MORPHO_CONTRACTS } from '@/actions/shared/morpho/contracts.js'
17
+ import { UNISWAP_ADDRESSES } from '@/actions/swap/providers/uniswap/addresses.js'
18
+ import { VELODROME_CHAINS } from '@/actions/swap/providers/velodrome/addresses.js'
19
+ import {
20
+ NATIVELY_SUPPORTED_ASSETS,
21
+ OP_DEMO,
22
+ USDC_DEMO,
23
+ } from '@/constants/assets.js'
24
24
  import type { Asset } from '@/types/asset.js'
25
25
  import type { LendMarketConfig } from '@/types/lend/index.js'
26
26
  import {
@@ -0,0 +1,33 @@
1
+ /**
2
+ * Permit2 ABI (subset for approvals).
3
+ * @see https://github.com/Uniswap/permit2
4
+ */
5
+ export const PERMIT2_ABI = [
6
+ {
7
+ name: 'allowance',
8
+ type: 'function',
9
+ stateMutability: 'view',
10
+ inputs: [
11
+ { name: 'owner', type: 'address' },
12
+ { name: 'token', type: 'address' },
13
+ { name: 'spender', type: 'address' },
14
+ ],
15
+ outputs: [
16
+ { name: 'amount', type: 'uint160' },
17
+ { name: 'expiration', type: 'uint48' },
18
+ { name: 'nonce', type: 'uint48' },
19
+ ],
20
+ },
21
+ {
22
+ name: 'approve',
23
+ type: 'function',
24
+ stateMutability: 'nonpayable',
25
+ inputs: [
26
+ { name: 'token', type: 'address' },
27
+ { name: 'spender', type: 'address' },
28
+ { name: 'amount', type: 'uint160' },
29
+ { name: 'expiration', type: 'uint48' },
30
+ ],
31
+ outputs: [],
32
+ },
33
+ ] as const
@@ -1,44 +1,13 @@
1
1
  import type { Address, PublicClient } from 'viem'
2
- import { encodeFunctionData, erc20Abi, maxUint256 } from 'viem'
2
+ import { encodeFunctionData, erc20Abi, maxUint160, maxUint256 } from 'viem'
3
3
 
4
+ import type { ApprovalMode } from '@/types/actions.js'
4
5
  import type { TransactionData } from '@/types/transaction.js'
6
+ import { PERMIT2_ABI } from '@/utils/abi/permit2.js'
5
7
 
6
8
  /** Default Permit2 approval expiry: 30 days in seconds */
7
9
  export const DEFAULT_PERMIT2_EXPIRY_SECONDS = 30 * 24 * 60 * 60
8
10
 
9
- /**
10
- * Permit2 ABI (subset for approvals)
11
- */
12
- const PERMIT2_ABI = [
13
- {
14
- name: 'allowance',
15
- type: 'function',
16
- stateMutability: 'view',
17
- inputs: [
18
- { name: 'owner', type: 'address' },
19
- { name: 'token', type: 'address' },
20
- { name: 'spender', type: 'address' },
21
- ],
22
- outputs: [
23
- { name: 'amount', type: 'uint160' },
24
- { name: 'expiration', type: 'uint48' },
25
- { name: 'nonce', type: 'uint48' },
26
- ],
27
- },
28
- {
29
- name: 'approve',
30
- type: 'function',
31
- stateMutability: 'nonpayable',
32
- inputs: [
33
- { name: 'token', type: 'address' },
34
- { name: 'spender', type: 'address' },
35
- { name: 'amount', type: 'uint160' },
36
- { name: 'expiration', type: 'uint48' },
37
- ],
38
- outputs: [],
39
- },
40
- ] as const
41
-
42
11
  /**
43
12
  * Permit2 allowance info
44
13
  */
@@ -76,14 +45,56 @@ export async function checkPermit2Allowance(params: {
76
45
 
77
46
  /**
78
47
  * Build ERC20 token approval transaction to Permit2.
79
- * Uses maxUint256 — the Uniswap-canonical pattern.
80
- * Permit2 is immutable with no owner; spending is scoped by its own allowance system.
48
+ *
49
+ * Permit2 is immutable with no owner; in the canonical Uniswap pattern this
50
+ * approval is granted as `maxUint256` once and reused across many swaps.
51
+ * Callers can opt back into exact-amount approvals by passing the explicit
52
+ * `requiredAmount`, which trades the round-trip cost on every swap for a
53
+ * tighter on-chain allowance.
81
54
  */
82
55
  export function buildTokenApprovalTx(
83
56
  token: Address,
84
57
  permit2Address: Address,
58
+ amount: bigint,
85
59
  ): TransactionData {
86
- return buildErc20ApprovalTx(token, permit2Address, maxUint256)
60
+ return buildErc20ApprovalTx(token, permit2Address, amount)
61
+ }
62
+
63
+ /**
64
+ * Resolve the effective {@link ApprovalMode} from the per-call → per-provider
65
+ * → shared-settings precedence chain, defaulting to `"exact"`. Mirrors how
66
+ * `defaultSlippage` resolves across the same layers.
67
+ */
68
+ export function resolveApprovalMode(
69
+ perCall: ApprovalMode | undefined,
70
+ providerDefault: ApprovalMode | undefined,
71
+ globalDefault: ApprovalMode | undefined,
72
+ ): ApprovalMode {
73
+ return perCall ?? providerDefault ?? globalDefault ?? 'exact'
74
+ }
75
+
76
+ /**
77
+ * Pick an approval amount for an ERC-20 → spender allowance based on the
78
+ * caller's chosen {@link ApprovalMode}.
79
+ * @param mode `"exact"` returns `requiredAmount`; `"max"` returns `maxUint256`.
80
+ */
81
+ export function resolveErc20ApprovalAmount(
82
+ mode: ApprovalMode,
83
+ requiredAmount: bigint,
84
+ ): bigint {
85
+ return mode === 'max' ? maxUint256 : requiredAmount
86
+ }
87
+
88
+ /**
89
+ * Pick an approval amount for Permit2's inner (token, spender) allowance —
90
+ * which is uint160-typed, not uint256.
91
+ * @param mode `"exact"` returns `requiredAmount`; `"max"` returns `maxUint160`.
92
+ */
93
+ export function resolvePermit2ApprovalAmount(
94
+ mode: ApprovalMode,
95
+ requiredAmount: bigint,
96
+ ): bigint {
97
+ return mode === 'max' ? maxUint160 : requiredAmount
87
98
  }
88
99
 
89
100
  /**