@clober/v2-sdk 0.0.5 → 0.0.6-0.dev

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 (342) hide show
  1. package/README.md +12 -4
  2. package/dist/cjs/abis/core/book-manager-abi.js +112 -0
  3. package/dist/cjs/abis/core/book-manager-abi.js.map +1 -0
  4. package/dist/cjs/abis/core/book-viewer-abi.js +137 -5
  5. package/dist/cjs/abis/core/book-viewer-abi.js.map +1 -1
  6. package/dist/cjs/abis/core/controller-abi.js +29 -24
  7. package/dist/cjs/abis/core/controller-abi.js.map +1 -1
  8. package/dist/cjs/abis/rebalancer/minter-abi.js +262 -0
  9. package/dist/cjs/abis/rebalancer/minter-abi.js.map +1 -0
  10. package/dist/cjs/abis/rebalancer/mock-swap-abi.js +95 -0
  11. package/dist/cjs/abis/rebalancer/mock-swap-abi.js.map +1 -0
  12. package/dist/cjs/abis/rebalancer/operator-abi.js +370 -0
  13. package/dist/cjs/abis/rebalancer/operator-abi.js.map +1 -0
  14. package/dist/cjs/abis/rebalancer/rebalancer-abi.js +1235 -0
  15. package/dist/cjs/abis/rebalancer/rebalancer-abi.js.map +1 -0
  16. package/dist/cjs/abis/rebalancer/strategy-abi.js +633 -0
  17. package/dist/cjs/abis/rebalancer/strategy-abi.js.map +1 -0
  18. package/dist/cjs/apis/chart-logs.js +163 -0
  19. package/dist/cjs/apis/chart-logs.js.map +1 -0
  20. package/dist/cjs/apis/market.js +40 -21
  21. package/dist/cjs/apis/market.js.map +1 -1
  22. package/dist/cjs/apis/odos.js +100 -0
  23. package/dist/cjs/apis/odos.js.map +1 -0
  24. package/dist/cjs/apis/open-order.js +60 -28
  25. package/dist/cjs/apis/open-order.js.map +1 -1
  26. package/dist/cjs/apis/pool.js +61 -0
  27. package/dist/cjs/apis/pool.js.map +1 -0
  28. package/dist/cjs/apis/strategy.js +23 -0
  29. package/dist/cjs/apis/strategy.js.map +1 -0
  30. package/dist/cjs/approval.js +85 -31
  31. package/dist/cjs/approval.js.map +1 -1
  32. package/dist/cjs/call.js +672 -155
  33. package/dist/cjs/call.js.map +1 -1
  34. package/dist/cjs/constants/addresses.js +41 -1
  35. package/dist/cjs/constants/addresses.js.map +1 -1
  36. package/dist/cjs/constants/chain.js +22 -2
  37. package/dist/cjs/constants/chain.js.map +1 -1
  38. package/dist/cjs/constants/currency.js +27 -2
  39. package/dist/cjs/constants/currency.js.map +1 -1
  40. package/dist/cjs/constants/fee.js +15 -2
  41. package/dist/cjs/constants/fee.js.map +1 -1
  42. package/dist/cjs/constants/permit.js +13 -0
  43. package/dist/cjs/constants/permit.js.map +1 -0
  44. package/dist/cjs/constants/price.js +2 -1
  45. package/dist/cjs/constants/price.js.map +1 -1
  46. package/dist/cjs/constants/subgraph.js +38 -0
  47. package/dist/cjs/constants/subgraph.js.map +1 -0
  48. package/dist/cjs/constants/test-chain.js +27 -0
  49. package/dist/cjs/constants/test-chain.js.map +1 -0
  50. package/dist/cjs/constants/tick.js +6 -0
  51. package/dist/cjs/constants/tick.js.map +1 -0
  52. package/dist/cjs/index.js +20 -6
  53. package/dist/cjs/index.js.map +1 -1
  54. package/dist/cjs/model/book.js +62 -35
  55. package/dist/cjs/model/book.js.map +1 -1
  56. package/dist/cjs/model/chart-log.js +3 -0
  57. package/dist/cjs/model/chart-log.js.map +1 -0
  58. package/dist/cjs/model/market.js +61 -26
  59. package/dist/cjs/model/market.js.map +1 -1
  60. package/dist/cjs/model/pool.js +136 -0
  61. package/dist/cjs/model/pool.js.map +1 -0
  62. package/dist/cjs/model/strategy.js +3 -0
  63. package/dist/cjs/model/strategy.js.map +1 -0
  64. package/dist/cjs/signature.js +28 -20
  65. package/dist/cjs/signature.js.map +1 -1
  66. package/dist/cjs/type.js +16 -1
  67. package/dist/cjs/type.js.map +1 -1
  68. package/dist/cjs/utils/allowance.js +39 -0
  69. package/dist/cjs/utils/allowance.js.map +1 -0
  70. package/dist/cjs/utils/approval.js +2 -3
  71. package/dist/cjs/utils/approval.js.map +1 -1
  72. package/dist/cjs/utils/bigint.js +13 -0
  73. package/dist/cjs/utils/bigint.js.map +1 -0
  74. package/dist/cjs/utils/book-id.js +7 -7
  75. package/dist/cjs/utils/book-id.js.map +1 -1
  76. package/dist/cjs/utils/build-transaction.js +9 -9
  77. package/dist/cjs/utils/build-transaction.js.map +1 -1
  78. package/dist/cjs/utils/currency.js +87 -5
  79. package/dist/cjs/utils/currency.js.map +1 -1
  80. package/dist/cjs/utils/market.js +1 -1
  81. package/dist/cjs/utils/market.js.map +1 -1
  82. package/dist/cjs/utils/math.js +3 -1
  83. package/dist/cjs/utils/math.js.map +1 -1
  84. package/dist/cjs/utils/open.js +35 -25
  85. package/dist/cjs/utils/open.js.map +1 -1
  86. package/dist/cjs/utils/order.js +100 -0
  87. package/dist/cjs/utils/order.js.map +1 -0
  88. package/dist/cjs/utils/pool-key.js +17 -0
  89. package/dist/cjs/utils/pool-key.js.map +1 -0
  90. package/dist/cjs/utils/pool.js +88 -0
  91. package/dist/cjs/utils/pool.js.map +1 -0
  92. package/dist/cjs/utils/prices.js +40 -5
  93. package/dist/cjs/utils/prices.js.map +1 -1
  94. package/dist/cjs/utils/tick.js +12 -1
  95. package/dist/cjs/utils/tick.js.map +1 -1
  96. package/dist/cjs/utils/unit-size.js +48 -0
  97. package/dist/cjs/utils/unit-size.js.map +1 -0
  98. package/dist/cjs/utils.js +16 -0
  99. package/dist/cjs/utils.js.map +1 -0
  100. package/dist/cjs/view.js +229 -40
  101. package/dist/cjs/view.js.map +1 -1
  102. package/dist/esm/abis/core/book-manager-abi.js +109 -0
  103. package/dist/esm/abis/core/book-manager-abi.js.map +1 -0
  104. package/dist/esm/abis/core/book-viewer-abi.js +137 -5
  105. package/dist/esm/abis/core/book-viewer-abi.js.map +1 -1
  106. package/dist/esm/abis/core/controller-abi.js +29 -24
  107. package/dist/esm/abis/core/controller-abi.js.map +1 -1
  108. package/dist/esm/abis/rebalancer/minter-abi.js +259 -0
  109. package/dist/esm/abis/rebalancer/minter-abi.js.map +1 -0
  110. package/dist/esm/abis/rebalancer/mock-swap-abi.js +92 -0
  111. package/dist/esm/abis/rebalancer/mock-swap-abi.js.map +1 -0
  112. package/dist/esm/abis/rebalancer/operator-abi.js +367 -0
  113. package/dist/esm/abis/rebalancer/operator-abi.js.map +1 -0
  114. package/dist/esm/abis/rebalancer/rebalancer-abi.js +1232 -0
  115. package/dist/esm/abis/rebalancer/rebalancer-abi.js.map +1 -0
  116. package/dist/esm/abis/rebalancer/strategy-abi.js +630 -0
  117. package/dist/esm/abis/rebalancer/strategy-abi.js.map +1 -0
  118. package/dist/esm/apis/chart-logs.js +159 -0
  119. package/dist/esm/apis/chart-logs.js.map +1 -0
  120. package/dist/esm/apis/market.js +41 -22
  121. package/dist/esm/apis/market.js.map +1 -1
  122. package/dist/esm/apis/odos.js +94 -0
  123. package/dist/esm/apis/odos.js.map +1 -0
  124. package/dist/esm/apis/open-order.js +61 -28
  125. package/dist/esm/apis/open-order.js.map +1 -1
  126. package/dist/esm/apis/pool.js +57 -0
  127. package/dist/esm/apis/pool.js.map +1 -0
  128. package/dist/esm/apis/strategy.js +19 -0
  129. package/dist/esm/apis/strategy.js.map +1 -0
  130. package/dist/esm/approval.js +122 -45
  131. package/dist/esm/approval.js.map +1 -1
  132. package/dist/esm/call.js +789 -265
  133. package/dist/esm/call.js.map +1 -1
  134. package/dist/esm/constants/addresses.js +42 -2
  135. package/dist/esm/constants/addresses.js.map +1 -1
  136. package/dist/esm/constants/chain.js +21 -2
  137. package/dist/esm/constants/chain.js.map +1 -1
  138. package/dist/esm/constants/currency.js +29 -2
  139. package/dist/esm/constants/currency.js.map +1 -1
  140. package/dist/esm/constants/fee.js +15 -2
  141. package/dist/esm/constants/fee.js.map +1 -1
  142. package/dist/esm/constants/permit.js +10 -0
  143. package/dist/esm/constants/permit.js.map +1 -0
  144. package/dist/esm/constants/price.js +1 -0
  145. package/dist/esm/constants/price.js.map +1 -1
  146. package/dist/esm/constants/subgraph.js +34 -0
  147. package/dist/esm/constants/subgraph.js.map +1 -0
  148. package/dist/esm/constants/test-chain.js +24 -0
  149. package/dist/esm/constants/test-chain.js.map +1 -0
  150. package/dist/esm/constants/tick.js +3 -0
  151. package/dist/esm/constants/tick.js.map +1 -0
  152. package/dist/esm/index.js +1 -0
  153. package/dist/esm/index.js.map +1 -1
  154. package/dist/esm/model/book.js +62 -35
  155. package/dist/esm/model/book.js.map +1 -1
  156. package/dist/esm/model/chart-log.js +2 -0
  157. package/dist/esm/model/chart-log.js.map +1 -0
  158. package/dist/esm/model/market.js +63 -28
  159. package/dist/esm/model/market.js.map +1 -1
  160. package/dist/esm/model/pool.js +133 -0
  161. package/dist/esm/model/pool.js.map +1 -0
  162. package/dist/esm/model/strategy.js +2 -0
  163. package/dist/esm/model/strategy.js.map +1 -0
  164. package/dist/esm/signature.js +42 -41
  165. package/dist/esm/signature.js.map +1 -1
  166. package/dist/esm/type.js +15 -0
  167. package/dist/esm/type.js.map +1 -1
  168. package/dist/esm/utils/allowance.js +35 -0
  169. package/dist/esm/utils/allowance.js.map +1 -0
  170. package/dist/esm/utils/approval.js +2 -3
  171. package/dist/esm/utils/approval.js.map +1 -1
  172. package/dist/esm/utils/bigint.js +7 -0
  173. package/dist/esm/utils/bigint.js.map +1 -0
  174. package/dist/esm/utils/book-id.js +7 -7
  175. package/dist/esm/utils/book-id.js.map +1 -1
  176. package/dist/esm/utils/build-transaction.js +9 -9
  177. package/dist/esm/utils/build-transaction.js.map +1 -1
  178. package/dist/esm/utils/currency.js +85 -4
  179. package/dist/esm/utils/currency.js.map +1 -1
  180. package/dist/esm/utils/market.js +1 -1
  181. package/dist/esm/utils/market.js.map +1 -1
  182. package/dist/esm/utils/math.js +1 -0
  183. package/dist/esm/utils/math.js.map +1 -1
  184. package/dist/esm/utils/open.js +33 -23
  185. package/dist/esm/utils/open.js.map +1 -1
  186. package/dist/esm/utils/order.js +96 -0
  187. package/dist/esm/utils/order.js.map +1 -0
  188. package/dist/esm/utils/pool-key.js +12 -0
  189. package/dist/esm/utils/pool-key.js.map +1 -0
  190. package/dist/esm/utils/pool.js +84 -0
  191. package/dist/esm/utils/pool.js.map +1 -0
  192. package/dist/esm/utils/prices.js +39 -5
  193. package/dist/esm/utils/prices.js.map +1 -1
  194. package/dist/esm/utils/tick.js +11 -1
  195. package/dist/esm/utils/tick.js.map +1 -1
  196. package/dist/esm/utils/unit-size.js +44 -0
  197. package/dist/esm/utils/unit-size.js.map +1 -0
  198. package/dist/esm/utils.js +4 -0
  199. package/dist/esm/utils.js.map +1 -0
  200. package/dist/esm/view.js +367 -79
  201. package/dist/esm/view.js.map +1 -1
  202. package/dist/tsconfig.build.tsbuildinfo +1 -1
  203. package/dist/types/abis/core/book-manager-abi.d.ts +82 -0
  204. package/dist/types/abis/core/book-manager-abi.d.ts.map +1 -0
  205. package/dist/types/abis/core/book-viewer-abi.d.ts +107 -5
  206. package/dist/types/abis/core/book-viewer-abi.d.ts.map +1 -1
  207. package/dist/types/abis/core/controller-abi.d.ts +23 -19
  208. package/dist/types/abis/core/controller-abi.d.ts.map +1 -1
  209. package/dist/types/abis/rebalancer/minter-abi.d.ts +198 -0
  210. package/dist/types/abis/rebalancer/minter-abi.d.ts.map +1 -0
  211. package/dist/types/abis/rebalancer/mock-swap-abi.d.ts +70 -0
  212. package/dist/types/abis/rebalancer/mock-swap-abi.d.ts.map +1 -0
  213. package/dist/types/abis/rebalancer/operator-abi.d.ts +283 -0
  214. package/dist/types/abis/rebalancer/operator-abi.d.ts.map +1 -0
  215. package/dist/types/abis/rebalancer/rebalancer-abi.d.ts +952 -0
  216. package/dist/types/abis/rebalancer/rebalancer-abi.d.ts.map +1 -0
  217. package/dist/types/abis/rebalancer/strategy-abi.d.ts +487 -0
  218. package/dist/types/abis/rebalancer/strategy-abi.d.ts.map +1 -0
  219. package/dist/types/apis/chart-logs.d.ts +5 -0
  220. package/dist/types/apis/chart-logs.d.ts.map +1 -0
  221. package/dist/types/apis/market.d.ts +2 -1
  222. package/dist/types/apis/market.d.ts.map +1 -1
  223. package/dist/types/apis/odos.d.ts +28 -0
  224. package/dist/types/apis/odos.d.ts.map +1 -0
  225. package/dist/types/apis/open-order.d.ts +4 -2
  226. package/dist/types/apis/open-order.d.ts.map +1 -1
  227. package/dist/types/apis/pool.d.ts +5 -0
  228. package/dist/types/apis/pool.d.ts.map +1 -0
  229. package/dist/types/apis/strategy.d.ts +5 -0
  230. package/dist/types/apis/strategy.d.ts.map +1 -0
  231. package/dist/types/approval.d.ts +47 -15
  232. package/dist/types/approval.d.ts.map +1 -1
  233. package/dist/types/call.d.ts +250 -122
  234. package/dist/types/call.d.ts.map +1 -1
  235. package/dist/types/constants/addresses.d.ts +4 -0
  236. package/dist/types/constants/addresses.d.ts.map +1 -1
  237. package/dist/types/constants/chain.d.ts +6 -2
  238. package/dist/types/constants/chain.d.ts.map +1 -1
  239. package/dist/types/constants/currency.d.ts.map +1 -1
  240. package/dist/types/constants/fee.d.ts +7 -2
  241. package/dist/types/constants/fee.d.ts.map +1 -1
  242. package/dist/types/constants/permit.d.ts +10 -0
  243. package/dist/types/constants/permit.d.ts.map +1 -0
  244. package/dist/types/constants/price.d.ts +1 -0
  245. package/dist/types/constants/price.d.ts.map +1 -1
  246. package/dist/types/constants/subgraph.d.ts +5 -0
  247. package/dist/types/constants/subgraph.d.ts.map +1 -0
  248. package/dist/types/constants/test-chain.d.ts +3 -0
  249. package/dist/types/constants/test-chain.d.ts.map +1 -0
  250. package/dist/types/constants/tick.d.ts +3 -0
  251. package/dist/types/constants/tick.d.ts.map +1 -0
  252. package/dist/types/index.d.ts +1 -0
  253. package/dist/types/index.d.ts.map +1 -1
  254. package/dist/types/model/book.d.ts +25 -33
  255. package/dist/types/model/book.d.ts.map +1 -1
  256. package/dist/types/model/chart-log.d.ts +9 -0
  257. package/dist/types/model/chart-log.d.ts.map +1 -0
  258. package/dist/types/model/currency.d.ts +7 -0
  259. package/dist/types/model/currency.d.ts.map +1 -1
  260. package/dist/types/model/depth.d.ts +4 -3
  261. package/dist/types/model/depth.d.ts.map +1 -1
  262. package/dist/types/model/market.d.ts +24 -13
  263. package/dist/types/model/market.d.ts.map +1 -1
  264. package/dist/types/model/open-order.d.ts +11 -6
  265. package/dist/types/model/open-order.d.ts.map +1 -1
  266. package/dist/types/model/pool.d.ts +38 -0
  267. package/dist/types/model/pool.d.ts.map +1 -0
  268. package/dist/types/model/strategy.d.ts +6 -0
  269. package/dist/types/model/strategy.d.ts.map +1 -0
  270. package/dist/types/signature.d.ts +19 -25
  271. package/dist/types/signature.d.ts.map +1 -1
  272. package/dist/types/type.d.ts +63 -5
  273. package/dist/types/type.d.ts.map +1 -1
  274. package/dist/types/utils/allowance.d.ts +3 -0
  275. package/dist/types/utils/allowance.d.ts.map +1 -0
  276. package/dist/types/utils/approval.d.ts +2 -1
  277. package/dist/types/utils/approval.d.ts.map +1 -1
  278. package/dist/types/utils/bigint.d.ts +4 -0
  279. package/dist/types/utils/bigint.d.ts.map +1 -0
  280. package/dist/types/utils/book-id.d.ts +2 -1
  281. package/dist/types/utils/book-id.d.ts.map +1 -1
  282. package/dist/types/utils/build-transaction.d.ts +3 -3
  283. package/dist/types/utils/build-transaction.d.ts.map +1 -1
  284. package/dist/types/utils/currency.d.ts +5 -1
  285. package/dist/types/utils/currency.d.ts.map +1 -1
  286. package/dist/types/utils/math.d.ts +1 -0
  287. package/dist/types/utils/math.d.ts.map +1 -1
  288. package/dist/types/utils/open.d.ts +2 -1
  289. package/dist/types/utils/open.d.ts.map +1 -1
  290. package/dist/types/utils/order.d.ts +9 -0
  291. package/dist/types/utils/order.d.ts.map +1 -0
  292. package/dist/types/utils/pool-key.d.ts +3 -0
  293. package/dist/types/utils/pool-key.d.ts.map +1 -0
  294. package/dist/types/utils/pool.d.ts +11 -0
  295. package/dist/types/utils/pool.d.ts.map +1 -0
  296. package/dist/types/utils/prices.d.ts +13 -2
  297. package/dist/types/utils/prices.d.ts.map +1 -1
  298. package/dist/types/utils/tick.d.ts +1 -0
  299. package/dist/types/utils/tick.d.ts.map +1 -1
  300. package/dist/types/utils/unit-size.d.ts +5 -0
  301. package/dist/types/utils/unit-size.d.ts.map +1 -0
  302. package/dist/types/utils.d.ts +4 -0
  303. package/dist/types/utils.d.ts.map +1 -0
  304. package/dist/types/view.d.ts +283 -46
  305. package/dist/types/view.d.ts.map +1 -1
  306. package/package.json +1 -1
  307. package/dist/cjs/abis/core/params-abi.js +0 -62
  308. package/dist/cjs/abis/core/params-abi.js.map +0 -1
  309. package/dist/cjs/apis/subgraph.js +0 -26
  310. package/dist/cjs/apis/subgraph.js.map +0 -1
  311. package/dist/cjs/constants/client.js +0 -14
  312. package/dist/cjs/constants/client.js.map +0 -1
  313. package/dist/cjs/constants/subgraph-url.js +0 -8
  314. package/dist/cjs/constants/subgraph-url.js.map +0 -1
  315. package/dist/cjs/utils/decorator.js +0 -13
  316. package/dist/cjs/utils/decorator.js.map +0 -1
  317. package/dist/cjs/utils/unit.js +0 -34
  318. package/dist/cjs/utils/unit.js.map +0 -1
  319. package/dist/esm/abis/core/params-abi.js +0 -59
  320. package/dist/esm/abis/core/params-abi.js.map +0 -1
  321. package/dist/esm/apis/subgraph.js +0 -22
  322. package/dist/esm/apis/subgraph.js.map +0 -1
  323. package/dist/esm/constants/client.js +0 -10
  324. package/dist/esm/constants/client.js.map +0 -1
  325. package/dist/esm/constants/subgraph-url.js +0 -5
  326. package/dist/esm/constants/subgraph-url.js.map +0 -1
  327. package/dist/esm/utils/decorator.js +0 -9
  328. package/dist/esm/utils/decorator.js.map +0 -1
  329. package/dist/esm/utils/unit.js +0 -30
  330. package/dist/esm/utils/unit.js.map +0 -1
  331. package/dist/types/abis/core/params-abi.d.ts +0 -21
  332. package/dist/types/abis/core/params-abi.d.ts.map +0 -1
  333. package/dist/types/apis/subgraph.d.ts +0 -3
  334. package/dist/types/apis/subgraph.d.ts.map +0 -1
  335. package/dist/types/constants/client.d.ts +0 -5
  336. package/dist/types/constants/client.d.ts.map +0 -1
  337. package/dist/types/constants/subgraph-url.d.ts +0 -5
  338. package/dist/types/constants/subgraph-url.d.ts.map +0 -1
  339. package/dist/types/utils/decorator.d.ts +0 -6
  340. package/dist/types/utils/decorator.d.ts.map +0 -1
  341. package/dist/types/utils/unit.d.ts +0 -4
  342. package/dist/types/utils/unit.d.ts.map +0 -1
package/dist/cjs/call.js CHANGED
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.cancelOrders = exports.cancelOrder = exports.claimOrders = exports.claimOrder = exports.marketOrder = exports.limitOrder = exports.openMarket = void 0;
3
+ exports.updateStrategyPrice = exports.rebalance = exports.removeLiquidity = exports.addLiquidity = exports.openPool = exports.cancelOrders = exports.cancelOrder = exports.claimOrders = exports.claimOrder = exports.marketOrder = exports.limitOrder = exports.openMarket = void 0;
4
4
  const viem_1 = require("viem");
5
5
  const chain_1 = require("./constants/chain");
6
- const unit_1 = require("./utils/unit");
6
+ const unit_size_1 = require("./utils/unit-size");
7
7
  const controller_abi_1 = require("./abis/core/controller-abi");
8
8
  const time_1 = require("./utils/time");
9
9
  const build_transaction_1 = require("./utils/build-transaction");
@@ -15,57 +15,88 @@ const tick_1 = require("./utils/tick");
15
15
  const view_1 = require("./view");
16
16
  const book_id_1 = require("./utils/book-id");
17
17
  const approval_1 = require("./utils/approval");
18
- const decorator_1 = require("./utils/decorator");
19
- exports.openMarket = (0, decorator_1.decorator)(async ({ chainId, inputToken, outputToken, }) => {
20
- const market = await (0, market_1.fetchMarket)(chainId, [inputToken, outputToken]);
18
+ const order_1 = require("./utils/order");
19
+ const bigint_1 = require("./utils/bigint");
20
+ const pool_1 = require("./apis/pool");
21
+ const rebalancer_abi_1 = require("./abis/rebalancer/rebalancer-abi");
22
+ const pool_2 = require("./utils/pool");
23
+ const odos_1 = require("./apis/odos");
24
+ const minter_abi_1 = require("./abis/rebalancer/minter-abi");
25
+ const permit_1 = require("./constants/permit");
26
+ const math_1 = require("./utils/math");
27
+ const pool_key_1 = require("./utils/pool-key");
28
+ const operator_abi_1 = require("./abis/rebalancer/operator-abi");
29
+ const openMarket = async ({ chainId, userAddress, inputToken, outputToken, options, }) => {
30
+ const publicClient = (0, viem_1.createPublicClient)({
31
+ chain: chain_1.CHAIN_MAP[chainId],
32
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
33
+ });
34
+ const market = await (0, market_1.fetchMarket)(publicClient, chainId, [inputToken, outputToken], !!(options && options.useSubgraph));
21
35
  const isBid = (0, viem_1.isAddressEqual)(market.quote.address, inputToken);
22
- if ((isBid && !market.bidBookOpen) || (!isBid && !market.askBookOpen)) {
23
- const unit = await (0, unit_1.calculateUnit)(chainId, isBid ? market.quote : market.base);
24
- return (0, build_transaction_1.buildTransaction)(chainId, {
36
+ if ((isBid && !market.bidBook.isOpened) ||
37
+ (!isBid && !market.askBook.isOpened)) {
38
+ const unitSize = await (0, unit_size_1.calculateUnitSize)(publicClient, chainId, isBid ? market.quote : market.base);
39
+ return (0, build_transaction_1.buildTransaction)(publicClient, {
40
+ chain: chain_1.CHAIN_MAP[chainId],
25
41
  address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
42
+ account: userAddress,
26
43
  abi: controller_abi_1.CONTROLLER_ABI,
27
44
  functionName: 'open',
28
45
  args: [
29
46
  [
30
47
  {
31
48
  key: {
32
- base: inputToken,
33
- unit,
34
- quote: outputToken,
35
- makerPolicy: fee_1.MAKER_DEFAULT_POLICY.value,
49
+ base: outputToken,
50
+ unitSize,
51
+ quote: inputToken,
52
+ makerPolicy: fee_1.MAKER_DEFAULT_POLICY[chainId].value,
36
53
  hooks: viem_1.zeroAddress,
37
- takerPolicy: fee_1.TAKER_DEFAULT_POLICY.value,
54
+ takerPolicy: fee_1.TAKER_DEFAULT_POLICY[chainId].value,
38
55
  },
39
56
  hookData: viem_1.zeroHash,
40
57
  },
41
58
  ],
42
59
  (0, time_1.getDeadlineTimestampInSeconds)(),
43
60
  ],
44
- });
61
+ }, options?.gasLimit);
45
62
  }
46
63
  return undefined;
47
- });
48
- exports.limitOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, inputToken, outputToken, amount, price, options, }) => {
49
- const market = await (0, market_1.fetchMarket)(chainId, [inputToken, outputToken]);
64
+ };
65
+ exports.openMarket = openMarket;
66
+ const limitOrder = async ({ chainId, userAddress, inputToken, outputToken, amount, price, options, }) => {
67
+ const [roundingUpMakeBid, roundingDownMakeAsk, roundingDownTakenBid, roundingUpTakenAsk,] = [
68
+ options?.roundingUpMakeBid ? options.roundingUpMakeBid : false,
69
+ options?.roundingDownMakeAsk ? options.roundingDownMakeAsk : false,
70
+ options?.roundingDownTakenBid ? options.roundingDownTakenBid : false,
71
+ options?.roundingUpTakenAsk ? options.roundingUpTakenAsk : false,
72
+ ];
73
+ const publicClient = (0, viem_1.createPublicClient)({
74
+ chain: chain_1.CHAIN_MAP[chainId],
75
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
76
+ });
77
+ const market = await (0, market_1.fetchMarket)(publicClient, chainId, [inputToken, outputToken], !!(options && options.useSubgraph));
50
78
  const isBid = (0, viem_1.isAddressEqual)(market.quote.address, inputToken);
51
- if ((isBid && !market.bidBookOpen) || (!isBid && !market.askBookOpen)) {
79
+ const [inputCurrency, outputCurrency] = isBid
80
+ ? [market.quote, market.base]
81
+ : [market.base, market.quote];
82
+ if ((isBid && !market.bidBook.isOpened) ||
83
+ (!isBid && !market.askBook.isOpened)) {
52
84
  throw new Error(`
53
85
  Open the market before placing a limit order.
54
86
  import { openMarket } from '@clober/v2-sdk'
55
87
 
56
- const transaction = await openMarket(
57
- ${chainId},
58
- '${inputToken}',
59
- '${outputToken}',
60
- )
88
+ const transaction = await openMarket({
89
+ chainId: ${chainId},
90
+ inputToken: '${inputToken}',
91
+ outputToken: '${outputToken}',
92
+ })
61
93
  `);
62
94
  }
63
- const rawPrice = (0, prices_1.parsePrice)(Number(price), market.quote.decimals, market.base.decimals);
64
- const tick = isBid ? (0, tick_1.fromPrice)(rawPrice) : (0, tick_1.fromPrice)((0, tick_1.invertPrice)(rawPrice));
95
+ const { roundingDownTick, roundingUpTick } = (0, prices_1.parsePrice)(Number(price), market.quote.decimals, market.base.decimals);
65
96
  const tokensToSettle = [inputToken, outputToken].filter((address) => !(0, viem_1.isAddressEqual)(address, viem_1.zeroAddress));
66
- const quoteAmount = (0, viem_1.parseUnits)(amount, isBid ? market.quote.decimals : market.base.decimals);
67
- const [unit, { spendAmount, bookId }] = await Promise.all([
68
- (0, unit_1.calculateUnit)(chainId, isBid ? market.quote : market.base),
97
+ const quoteAmount = (0, viem_1.parseUnits)(amount, inputCurrency.decimals);
98
+ const [unitSize, { takenAmount, spentAmount, bookId, events }] = await Promise.all([
99
+ (0, unit_size_1.calculateUnitSize)(publicClient, chainId, inputCurrency),
69
100
  (0, view_1.getExpectedOutput)({
70
101
  chainId,
71
102
  inputToken,
@@ -73,28 +104,26 @@ exports.limitOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, i
73
104
  amountIn: amount,
74
105
  options: {
75
106
  ...options,
107
+ limitPrice: price,
76
108
  },
77
109
  }),
78
110
  ]);
79
111
  const isETH = (0, viem_1.isAddressEqual)(inputToken, viem_1.zeroAddress);
80
- const permitParamsList = options?.signature && !isETH
81
- ? [
82
- {
83
- token: inputToken,
84
- permitAmount: quoteAmount,
85
- signature: options.signature,
86
- },
87
- ]
88
- : [];
89
112
  const makeParam = {
90
- id: (0, book_id_1.toBookId)(inputToken, outputToken, unit),
91
- tick: Number(tick),
113
+ id: (0, book_id_1.toBookId)(chainId, inputToken, outputToken, unitSize),
114
+ tick: options?.makeTick
115
+ ? Number(options.makeTick)
116
+ : Number(isBid
117
+ ? roundingUpMakeBid
118
+ ? roundingUpTick
119
+ : roundingDownTick
120
+ : (0, tick_1.invertTick)(roundingDownMakeAsk ? roundingDownTick : roundingUpTick)),
92
121
  quoteAmount,
93
122
  hookData: viem_1.zeroHash,
94
123
  };
95
- if (options?.postOnly === true || spendAmount === '0') {
124
+ if (options?.postOnly === true || spentAmount === '0') {
96
125
  return {
97
- transaction: await (0, build_transaction_1.buildTransaction)(chainId, {
126
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
98
127
  chain: chain_1.CHAIN_MAP[chainId],
99
128
  account: userAddress,
100
129
  address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
@@ -103,28 +132,38 @@ exports.limitOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, i
103
132
  args: [
104
133
  [makeParam],
105
134
  tokensToSettle,
106
- permitParamsList,
135
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
107
136
  (0, time_1.getDeadlineTimestampInSeconds)(),
108
137
  ],
109
138
  value: isETH ? quoteAmount : 0n,
110
- }),
139
+ }, options?.gasLimit),
111
140
  result: {
112
141
  make: {
113
- amount: (0, viem_1.formatUnits)(quoteAmount, isBid ? market.quote.decimals : market.base.decimals),
114
- currency: isBid ? market.quote : market.base,
142
+ amount: (0, viem_1.formatUnits)(quoteAmount, inputCurrency.decimals),
143
+ currency: inputCurrency,
115
144
  direction: 'in',
145
+ price: (0, prices_1.formatPrice)(isBid
146
+ ? (0, tick_1.toPrice)(BigInt(makeParam.tick))
147
+ : (0, tick_1.toPrice)((0, tick_1.invertTick)(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
116
148
  },
117
- take: {
149
+ spent: {
118
150
  amount: '0',
119
- currency: isBid ? market.base : market.quote,
151
+ currency: inputCurrency,
152
+ direction: 'in',
153
+ events: [],
154
+ },
155
+ taken: {
156
+ amount: '0',
157
+ currency: outputCurrency,
120
158
  direction: 'out',
159
+ events: [],
121
160
  },
122
161
  },
123
162
  };
124
163
  }
125
164
  else {
126
165
  return {
127
- transaction: await (0, build_transaction_1.buildTransaction)(chainId, {
166
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
128
167
  chain: chain_1.CHAIN_MAP[chainId],
129
168
  account: userAddress,
130
169
  address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
@@ -135,7 +174,15 @@ exports.limitOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, i
135
174
  {
136
175
  takeBookId: bookId,
137
176
  makeBookId: makeParam.id,
138
- limitPrice: rawPrice,
177
+ limitPrice: options?.takeLimitTick
178
+ ? (0, tick_1.toPrice)(options.takeLimitTick)
179
+ : (0, tick_1.toPrice)(isBid
180
+ ? (0, tick_1.invertTick)(roundingUpTakenAsk
181
+ ? roundingUpTick
182
+ : roundingDownTick)
183
+ : roundingDownTakenBid
184
+ ? roundingDownTick
185
+ : roundingUpTick),
139
186
  tick: makeParam.tick,
140
187
  quoteAmount,
141
188
  takeHookData: viem_1.zeroHash,
@@ -143,30 +190,61 @@ exports.limitOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, i
143
190
  },
144
191
  ],
145
192
  tokensToSettle,
146
- permitParamsList,
193
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
147
194
  (0, time_1.getDeadlineTimestampInSeconds)(),
148
195
  ],
149
196
  value: isETH ? quoteAmount : 0n,
150
- }),
197
+ }, options?.gasLimit),
151
198
  result: {
152
199
  make: {
153
- amount: (0, viem_1.formatUnits)(quoteAmount, isBid ? market.quote.decimals : market.base.decimals),
154
- currency: isBid ? market.quote : market.base,
200
+ amount: (0, viem_1.formatUnits)(quoteAmount - (0, viem_1.parseUnits)(spentAmount, inputCurrency.decimals), inputCurrency.decimals),
201
+ currency: inputCurrency,
202
+ direction: 'in',
203
+ price: (0, prices_1.formatPrice)(isBid
204
+ ? (0, tick_1.toPrice)(BigInt(makeParam.tick))
205
+ : (0, tick_1.toPrice)((0, tick_1.invertTick)(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
206
+ },
207
+ spent: {
208
+ amount: spentAmount,
209
+ currency: inputCurrency,
155
210
  direction: 'in',
211
+ events: events.map(({ price, spentAmount }) => ({
212
+ price,
213
+ amount: spentAmount,
214
+ })),
156
215
  },
157
- take: {
158
- amount: spendAmount,
159
- currency: isBid ? market.base : market.quote,
216
+ taken: {
217
+ amount: takenAmount,
218
+ currency: outputCurrency,
160
219
  direction: 'out',
220
+ events: events.map(({ price, takenAmount }) => ({
221
+ price,
222
+ amount: takenAmount,
223
+ })),
161
224
  },
162
225
  },
163
226
  };
164
227
  }
165
- });
166
- exports.marketOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, inputToken, outputToken, amount, options, }) => {
167
- const market = await (0, market_1.fetchMarket)(chainId, [inputToken, outputToken]);
168
- const isBid = (0, viem_1.isAddressEqual)(market.quote.address, inputToken);
169
- if ((isBid && !market.bidBookOpen) || (!isBid && !market.askBookOpen)) {
228
+ };
229
+ exports.limitOrder = limitOrder;
230
+ const marketOrder = async ({ chainId, userAddress, inputToken, outputToken, amountIn, amountOut, options, }) => {
231
+ if (!amountIn && !amountOut) {
232
+ throw new Error('Either amountIn or amountOut must be provided');
233
+ }
234
+ else if (amountIn && amountOut) {
235
+ throw new Error('Only one of amountIn or amountOut can be provided');
236
+ }
237
+ const publicClient = (0, viem_1.createPublicClient)({
238
+ chain: chain_1.CHAIN_MAP[chainId],
239
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
240
+ });
241
+ const market = await (0, market_1.fetchMarket)(publicClient, chainId, [inputToken, outputToken], !!(options && options.useSubgraph));
242
+ const isTakingBid = (0, viem_1.isAddressEqual)(market.base.address, inputToken);
243
+ const [inputCurrency, outputCurrency] = isTakingBid
244
+ ? [market.base, market.quote]
245
+ : [market.quote, market.base];
246
+ if ((isTakingBid && !market.bidBook.isOpened) ||
247
+ (!isTakingBid && !market.askBook.isOpened)) {
170
248
  throw new Error(`
171
249
  Open the market before placing a market order.
172
250
  import { openMarket } from '@clober/v2-sdk'
@@ -178,51 +256,135 @@ exports.marketOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress,
178
256
  )
179
257
  `);
180
258
  }
181
- const rawLimitPrice = (0, prices_1.parsePrice)(Number(options?.limitPrice ?? '0'), market.quote.decimals, market.base.decimals);
182
259
  const tokensToSettle = [inputToken, outputToken].filter((address) => !(0, viem_1.isAddressEqual)(address, viem_1.zeroAddress));
183
- const quoteAmount = (0, viem_1.parseUnits)(amount, isBid ? market.quote.decimals : market.base.decimals);
184
- const { bookId, takenAmount } = await (0, view_1.getExpectedOutput)({
185
- chainId,
186
- inputToken,
187
- outputToken,
188
- amountIn: amount,
189
- options: {
190
- ...options,
191
- },
192
- });
193
260
  const isETH = (0, viem_1.isAddressEqual)(inputToken, viem_1.zeroAddress);
194
- const permitParamsList = options?.signature && !isETH
195
- ? [
196
- {
197
- token: inputToken,
198
- permitAmount: quoteAmount,
199
- signature: options.signature,
261
+ if (amountIn && !amountOut) {
262
+ const { bookId, takenAmount, spentAmount, events } = await (0, view_1.getExpectedOutput)({
263
+ chainId,
264
+ inputToken,
265
+ outputToken,
266
+ amountIn,
267
+ options: {
268
+ ...options,
200
269
  },
201
- ]
202
- : [];
203
- return (0, build_transaction_1.buildTransaction)(chainId, {
204
- chain: chain_1.CHAIN_MAP[chainId],
205
- account: userAddress,
206
- address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
207
- abi: controller_abi_1.CONTROLLER_ABI,
208
- functionName: 'take',
209
- args: [
210
- [
211
- {
212
- id: bookId,
213
- limitPrice: isBid ? (0, tick_1.invertPrice)(rawLimitPrice) : rawLimitPrice,
214
- quoteAmount: takenAmount,
215
- hookData: viem_1.zeroHash,
270
+ });
271
+ const baseAmount = (0, viem_1.parseUnits)(amountIn, inputCurrency.decimals);
272
+ return {
273
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
274
+ chain: chain_1.CHAIN_MAP[chainId],
275
+ account: userAddress,
276
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
277
+ abi: controller_abi_1.CONTROLLER_ABI,
278
+ functionName: 'spend',
279
+ args: [
280
+ [
281
+ {
282
+ id: bookId,
283
+ limitPrice: 0n,
284
+ baseAmount,
285
+ minQuoteAmount: options?.slippage
286
+ ? (0, bigint_1.applyPercent)((0, viem_1.parseUnits)(takenAmount, outputCurrency.decimals), 100 - options.slippage)
287
+ : 0n,
288
+ hookData: viem_1.zeroHash,
289
+ },
290
+ ],
291
+ tokensToSettle,
292
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
293
+ (0, time_1.getDeadlineTimestampInSeconds)(),
294
+ ],
295
+ value: isETH ? baseAmount : 0n,
296
+ }, options?.gasLimit),
297
+ result: {
298
+ spent: {
299
+ amount: spentAmount,
300
+ currency: inputCurrency,
301
+ direction: 'in',
302
+ events: events.map(({ price, spentAmount }) => ({
303
+ price,
304
+ amount: spentAmount,
305
+ })),
216
306
  },
217
- ],
218
- tokensToSettle,
219
- permitParamsList,
220
- (0, time_1.getDeadlineTimestampInSeconds)(),
221
- ],
222
- value: isETH ? quoteAmount : 0n,
223
- });
224
- });
225
- exports.claimOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, id, options, }) => {
307
+ taken: {
308
+ amount: takenAmount,
309
+ currency: outputCurrency,
310
+ direction: 'out',
311
+ events: events.map(({ price, takenAmount }) => ({
312
+ price,
313
+ amount: takenAmount,
314
+ })),
315
+ },
316
+ },
317
+ };
318
+ }
319
+ else if (!amountIn && amountOut) {
320
+ const { bookId, spentAmount, takenAmount, events } = await (0, view_1.getExpectedInput)({
321
+ chainId,
322
+ inputToken,
323
+ outputToken,
324
+ amountOut,
325
+ options: {
326
+ ...options,
327
+ },
328
+ });
329
+ const quoteAmount = (0, viem_1.parseUnits)(amountOut, outputCurrency.decimals);
330
+ const baseAmount = (0, viem_1.parseUnits)(spentAmount, inputCurrency.decimals);
331
+ const maxBaseAmount = options?.erc20PermitParam?.permitAmount ??
332
+ (options?.slippage
333
+ ? (0, bigint_1.applyPercent)(baseAmount, 100 + options.slippage)
334
+ : isETH
335
+ ? baseAmount
336
+ : 2n ** 256n - 1n);
337
+ return {
338
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
339
+ chain: chain_1.CHAIN_MAP[chainId],
340
+ account: userAddress,
341
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
342
+ abi: controller_abi_1.CONTROLLER_ABI,
343
+ functionName: 'take',
344
+ args: [
345
+ [
346
+ {
347
+ id: bookId,
348
+ limitPrice: 0n,
349
+ quoteAmount,
350
+ maxBaseAmount,
351
+ hookData: viem_1.zeroHash,
352
+ },
353
+ ],
354
+ tokensToSettle,
355
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
356
+ (0, time_1.getDeadlineTimestampInSeconds)(),
357
+ ],
358
+ value: isETH ? maxBaseAmount : 0n,
359
+ }, options?.gasLimit),
360
+ result: {
361
+ spent: {
362
+ amount: spentAmount,
363
+ currency: inputCurrency,
364
+ direction: 'in',
365
+ events: events.map(({ price, spentAmount }) => ({
366
+ price,
367
+ amount: spentAmount,
368
+ })),
369
+ },
370
+ taken: {
371
+ amount: takenAmount,
372
+ currency: outputCurrency,
373
+ direction: 'out',
374
+ events: events.map(({ price, takenAmount }) => ({
375
+ price,
376
+ amount: takenAmount,
377
+ })),
378
+ },
379
+ },
380
+ };
381
+ }
382
+ else {
383
+ throw new Error('Either amountIn or amountOut must be provided');
384
+ }
385
+ };
386
+ exports.marketOrder = marketOrder;
387
+ const claimOrder = async ({ chainId, userAddress, id, options, }) => {
226
388
  const { transaction, result } = await (0, exports.claimOrders)({
227
389
  chainId,
228
390
  userAddress,
@@ -233,57 +395,60 @@ exports.claimOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, i
233
395
  transaction,
234
396
  result: result[0],
235
397
  };
236
- });
237
- exports.claimOrders = (0, decorator_1.decorator)(async ({ chainId, userAddress, ids, options, }) => {
238
- const isApprovedForAll = await (0, approval_1.fetchIsApprovedForAll)(chainId, userAddress);
398
+ };
399
+ exports.claimOrder = claimOrder;
400
+ const claimOrders = async ({ chainId, userAddress, ids, options, }) => {
401
+ const publicClient = (0, viem_1.createPublicClient)({
402
+ chain: chain_1.CHAIN_MAP[chainId],
403
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
404
+ });
405
+ const isApprovedForAll = await (0, approval_1.fetchIsApprovedForAll)(publicClient, chainId, userAddress);
239
406
  if (!isApprovedForAll) {
240
407
  throw new Error(`
241
408
  Set ApprovalForAll before calling this function.
242
409
  import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
243
410
 
244
- const hash = await setApprovalOfOpenOrdersForAll(
245
- ${chainId},
246
- privateKeyToAccount('0x...')
247
- )
411
+ const hash = await setApprovalOfOpenOrdersForAll({
412
+ chainId: ${chainId},
413
+ walletClient, // use viem
414
+ })
248
415
  `);
249
416
  }
250
- const openOrders = (await (0, view_1.getOpenOrders)({ chainId, userAddress, options: { ...options } })).filter((order) => ids.includes(order.id));
251
- if (openOrders.length === 0) {
252
- throw new Error(`No claimable open orders found for ${userAddress}`);
253
- }
254
- const tokensToSettle = openOrders
255
- .map((order) => [
256
- order.outputCurrency.address,
257
- order.inputCurrency.address,
258
- ])
417
+ const orders = (await (0, order_1.fetchOrders)(publicClient, chainId, ids.map((id) => BigInt(id)), !!(options && options.useSubgraph))).filter((order) => (0, viem_1.isAddressEqual)(order.user, userAddress) && order.claimable.value !== '0');
418
+ const tokensToSettle = orders
419
+ .map((order) => [order.inputCurrency.address, order.outputCurrency.address])
259
420
  .flat()
260
421
  .filter((address, index, self) => self.findIndex((c) => (0, viem_1.isAddressEqual)(c, address)) === index)
261
422
  .filter((address) => !(0, viem_1.isAddressEqual)(address, viem_1.zeroAddress));
262
423
  return {
263
- transaction: await (0, build_transaction_1.buildTransaction)(chainId, {
424
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
264
425
  chain: chain_1.CHAIN_MAP[chainId],
265
426
  account: userAddress,
266
427
  address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
267
428
  abi: controller_abi_1.CONTROLLER_ABI,
268
429
  functionName: 'claim',
269
430
  args: [
270
- openOrders.map((order) => ({
271
- id: BigInt(order.id),
431
+ orders.map(({ id }) => ({
432
+ id,
272
433
  hookData: viem_1.zeroHash,
273
434
  })),
274
435
  tokensToSettle,
275
436
  [],
276
437
  (0, time_1.getDeadlineTimestampInSeconds)(),
277
438
  ],
278
- }),
279
- result: openOrders.map((order) => ({
280
- currency: order.claimable.currency,
281
- amount: order.claimable.value,
282
- direction: 'out',
283
- })),
439
+ }, options?.gasLimit),
440
+ result: orders.reduce((acc, { claimable: { currency, value } }) => {
441
+ const index = acc.findIndex((c) => (0, viem_1.isAddressEqual)(c.currency.address, currency.address));
442
+ if (index === -1) {
443
+ return [...acc, { currency, amount: value, direction: 'out' }];
444
+ }
445
+ acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
446
+ return acc;
447
+ }, []),
284
448
  };
285
- });
286
- exports.cancelOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress, id, options, }) => {
449
+ };
450
+ exports.claimOrders = claimOrders;
451
+ const cancelOrder = async ({ chainId, userAddress, id, options, }) => {
287
452
  const { transaction, result } = await (0, exports.cancelOrders)({
288
453
  chainId,
289
454
  userAddress,
@@ -294,42 +459,41 @@ exports.cancelOrder = (0, decorator_1.decorator)(async ({ chainId, userAddress,
294
459
  transaction,
295
460
  result: result[0],
296
461
  };
297
- });
298
- exports.cancelOrders = (0, decorator_1.decorator)(async ({ chainId, userAddress, ids, options, }) => {
299
- const isApprovedForAll = await (0, approval_1.fetchIsApprovedForAll)(chainId, userAddress);
462
+ };
463
+ exports.cancelOrder = cancelOrder;
464
+ const cancelOrders = async ({ chainId, userAddress, ids, options, }) => {
465
+ const publicClient = (0, viem_1.createPublicClient)({
466
+ chain: chain_1.CHAIN_MAP[chainId],
467
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
468
+ });
469
+ const isApprovedForAll = await (0, approval_1.fetchIsApprovedForAll)(publicClient, chainId, userAddress);
300
470
  if (!isApprovedForAll) {
301
471
  throw new Error(`
302
472
  Set ApprovalForAll before calling this function.
303
473
  import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
304
474
 
305
- const hash = await setApprovalOfOpenOrdersForAll(
306
- ${chainId},
307
- privateKeyToAccount('0x...')
308
- )
475
+ const hash = await setApprovalOfOpenOrdersForAll({
476
+ chainId: ${chainId},
477
+ walletClient, // use viem
478
+ })
309
479
  `);
310
480
  }
311
- const openOrders = (await (0, view_1.getOpenOrders)({ chainId, userAddress, options: { ...options } })).filter((order) => ids.includes(order.id) && order.claimable.value !== '0');
312
- if (openOrders.length === 0) {
313
- throw new Error(`No cancelable open orders found for ${userAddress}`);
314
- }
315
- const tokensToSettle = openOrders
316
- .map((order) => [
317
- order.outputCurrency.address,
318
- order.inputCurrency.address,
319
- ])
481
+ const orders = (await (0, order_1.fetchOrders)(publicClient, chainId, ids.map((id) => BigInt(id)), !!(options && options.useSubgraph))).filter((order) => (0, viem_1.isAddressEqual)(order.user, userAddress) && order.cancelable.value !== '0');
482
+ const tokensToSettle = orders
483
+ .map((order) => [order.inputCurrency.address, order.outputCurrency.address])
320
484
  .flat()
321
485
  .filter((address, index, self) => self.findIndex((c) => (0, viem_1.isAddressEqual)(c, address)) === index)
322
486
  .filter((address) => !(0, viem_1.isAddressEqual)(address, viem_1.zeroAddress));
323
487
  return {
324
- transaction: await (0, build_transaction_1.buildTransaction)(chainId, {
488
+ transaction: await (0, build_transaction_1.buildTransaction)(publicClient, {
325
489
  chain: chain_1.CHAIN_MAP[chainId],
326
490
  account: userAddress,
327
491
  address: addresses_1.CONTRACT_ADDRESSES[chainId].Controller,
328
492
  abi: controller_abi_1.CONTROLLER_ABI,
329
493
  functionName: 'cancel',
330
494
  args: [
331
- openOrders.map((order) => ({
332
- id: BigInt(order.id),
495
+ orders.map(({ id }) => ({
496
+ id,
333
497
  leftQuoteAmount: 0n,
334
498
  hookData: viem_1.zeroHash,
335
499
  })),
@@ -337,12 +501,365 @@ exports.cancelOrders = (0, decorator_1.decorator)(async ({ chainId, userAddress,
337
501
  [],
338
502
  (0, time_1.getDeadlineTimestampInSeconds)(),
339
503
  ],
340
- }),
341
- result: openOrders.map((order) => ({
342
- currency: order.cancelable.currency,
343
- amount: order.cancelable.value,
344
- direction: 'out',
345
- })),
504
+ }, options?.gasLimit),
505
+ result: orders.reduce((acc, { cancelable: { currency, value } }) => {
506
+ const index = acc.findIndex((c) => (0, viem_1.isAddressEqual)(c.currency.address, currency.address));
507
+ if (index === -1) {
508
+ return [...acc, { currency, amount: value, direction: 'out' }];
509
+ }
510
+ acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
511
+ return acc;
512
+ }, []),
513
+ };
514
+ };
515
+ exports.cancelOrders = cancelOrders;
516
+ const openPool = async ({ chainId, userAddress, tokenA, tokenB, salt, options, }) => {
517
+ const publicClient = (0, viem_1.createPublicClient)({
518
+ chain: chain_1.CHAIN_MAP[chainId],
519
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
520
+ });
521
+ const pool = await (0, pool_1.fetchPool)(publicClient, chainId, [tokenA, tokenB], salt, !!(options && options.useSubgraph));
522
+ if (!pool.isOpened) {
523
+ return (0, build_transaction_1.buildTransaction)(publicClient, {
524
+ chain: chain_1.CHAIN_MAP[chainId],
525
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
526
+ account: userAddress,
527
+ abi: rebalancer_abi_1.REBALANCER_ABI,
528
+ functionName: 'open',
529
+ args: [
530
+ {
531
+ base: pool.market.bidBook.base.address,
532
+ unitSize: pool.market.bidBook.unitSize,
533
+ quote: pool.market.bidBook.quote.address,
534
+ makerPolicy: fee_1.MAKER_DEFAULT_POLICY[chainId].value,
535
+ hooks: viem_1.zeroAddress,
536
+ takerPolicy: fee_1.TAKER_DEFAULT_POLICY[chainId].value,
537
+ },
538
+ {
539
+ base: pool.market.askBook.base.address,
540
+ unitSize: pool.market.askBook.unitSize,
541
+ quote: pool.market.askBook.quote.address,
542
+ makerPolicy: fee_1.MAKER_DEFAULT_POLICY[chainId].value,
543
+ hooks: viem_1.zeroAddress,
544
+ takerPolicy: fee_1.TAKER_DEFAULT_POLICY[chainId].value,
545
+ },
546
+ (0, pool_key_1.toBytes32)(salt),
547
+ addresses_1.CONTRACT_ADDRESSES[chainId].Strategy,
548
+ ],
549
+ }, options?.gasLimit);
550
+ }
551
+ return undefined;
552
+ };
553
+ exports.openPool = openPool;
554
+ const addLiquidity = async ({ chainId, userAddress, token0, token1, salt, amount0, amount1, options, }) => {
555
+ const publicClient = (0, viem_1.createPublicClient)({
556
+ chain: chain_1.CHAIN_MAP[chainId],
557
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
558
+ });
559
+ const pool = await (0, pool_1.fetchPool)(publicClient, chainId, [token0, token1], salt, !!(options && options.useSubgraph));
560
+ if (!pool.isOpened) {
561
+ throw new Error(`
562
+ Open the pool before adding liquidity.
563
+ import { openPool } from '@clober/v2-sdk'
564
+
565
+ const transaction = await openPool({
566
+ chainId: ${chainId},
567
+ tokenA: '${token0}',
568
+ tokenB: '${token1}',
569
+ })
570
+ `);
571
+ }
572
+ const [amountAOrigin, amountBOrigin] = (0, viem_1.isAddressEqual)(pool.currencyA.address, (0, viem_1.getAddress)(token0))
573
+ ? [
574
+ (0, viem_1.parseUnits)(amount0 ?? '0', pool.currencyA.decimals),
575
+ (0, viem_1.parseUnits)(amount1 ?? '0', pool.currencyB.decimals),
576
+ ]
577
+ : [
578
+ (0, viem_1.parseUnits)(amount1 ?? '0', pool.currencyA.decimals),
579
+ (0, viem_1.parseUnits)(amount0 ?? '0', pool.currencyB.decimals),
580
+ ];
581
+ let [amountA, amountB] = [amountAOrigin, amountBOrigin];
582
+ const tokenAPermitParams = (0, viem_1.isAddressEqual)(pool.currencyA.address, (0, viem_1.getAddress)(token0))
583
+ ? options?.token0PermitParams ?? permit_1.emptyERC20PermitParams
584
+ : options?.token1PermitParams ?? permit_1.emptyERC20PermitParams;
585
+ const tokenBPermitParams = (0, viem_1.isAddressEqual)(pool.currencyA.address, (0, viem_1.getAddress)(token0))
586
+ ? options?.token1PermitParams ?? permit_1.emptyERC20PermitParams
587
+ : options?.token0PermitParams ?? permit_1.emptyERC20PermitParams;
588
+ let disableSwap = !!(options && options.disableSwap);
589
+ if (pool.totalSupply === 0n ||
590
+ (pool.liquidityA === 0n && pool.liquidityB === 0n)) {
591
+ disableSwap = true;
592
+ }
593
+ const slippageLimitPercent = options?.slippage ?? 2;
594
+ const swapParams = {
595
+ inCurrency: viem_1.zeroAddress,
596
+ amount: 0n,
597
+ data: '0x',
598
+ };
599
+ if (!disableSwap) {
600
+ const token0Price = Number(options?.testnetPrice ? options.testnetPrice : '1');
601
+ const currencyBPerCurrencyA = (0, viem_1.isAddressEqual)(token1, pool.currencyB.address)
602
+ ? token0Price
603
+ : 1 / token0Price;
604
+ const swapAmountA = (0, viem_1.parseUnits)('1', pool.currencyA.decimals);
605
+ const { amountOut: swapAmountB } = await (0, odos_1.fetchQuote)({
606
+ chainId,
607
+ amountIn: swapAmountA,
608
+ tokenIn: pool.currencyA,
609
+ tokenOut: pool.currencyB,
610
+ slippageLimitPercent: 20,
611
+ userAddress: addresses_1.CONTRACT_ADDRESSES[chainId].Minter,
612
+ testnetPrice: currencyBPerCurrencyA,
613
+ });
614
+ const { deltaA, deltaB } = (0, pool_2.getIdealDelta)(amountA, amountB, pool.liquidityA, pool.liquidityB, swapAmountA, swapAmountB);
615
+ if (deltaA < 0n) {
616
+ swapParams.inCurrency = pool.currencyA.address;
617
+ swapParams.amount = -deltaA;
618
+ const { amountOut: actualDeltaB, data: calldata } = await (0, odos_1.fetchCallData)({
619
+ chainId,
620
+ amountIn: swapParams.amount,
621
+ tokenIn: pool.currencyA,
622
+ tokenOut: pool.currencyB,
623
+ slippageLimitPercent,
624
+ userAddress: addresses_1.CONTRACT_ADDRESSES[chainId].Minter,
625
+ testnetPrice: currencyBPerCurrencyA,
626
+ });
627
+ swapParams.data = calldata;
628
+ amountA += deltaA;
629
+ amountB += actualDeltaB;
630
+ }
631
+ else if (deltaB < 0n) {
632
+ swapParams.inCurrency = pool.currencyB.address;
633
+ swapParams.amount = -deltaB;
634
+ const { amountOut: actualDeltaA, data: calldata } = await (0, odos_1.fetchCallData)({
635
+ chainId,
636
+ amountIn: swapParams.amount,
637
+ tokenIn: pool.currencyB,
638
+ tokenOut: pool.currencyA,
639
+ slippageLimitPercent,
640
+ userAddress: addresses_1.CONTRACT_ADDRESSES[chainId].Minter,
641
+ testnetPrice: 1 / currencyBPerCurrencyA,
642
+ });
643
+ swapParams.data = calldata;
644
+ amountA += actualDeltaA;
645
+ amountB += deltaB;
646
+ }
647
+ }
648
+ const { mintAmount, inAmountA, inAmountB } = (0, pool_2.getExpectedMintResult)(pool.totalSupply, pool.liquidityA, pool.liquidityB, amountA, amountB, pool.currencyA, pool.currencyB);
649
+ if (mintAmount === 0n) {
650
+ return {
651
+ transaction: undefined,
652
+ result: {
653
+ currencyA: {
654
+ currency: pool.currencyA,
655
+ amount: '0',
656
+ direction: 'in',
657
+ },
658
+ currencyB: {
659
+ currency: pool.currencyB,
660
+ amount: '0',
661
+ direction: 'in',
662
+ },
663
+ lpCurrency: {
664
+ currency: pool.currencyLp,
665
+ amount: '0',
666
+ direction: 'out',
667
+ },
668
+ },
669
+ };
670
+ }
671
+ const minMintAmount = (0, bigint_1.applyPercent)(mintAmount, 100 - slippageLimitPercent);
672
+ const transaction = await (0, build_transaction_1.buildTransaction)(publicClient, {
673
+ chain: chain_1.CHAIN_MAP[chainId],
674
+ account: userAddress,
675
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Minter,
676
+ abi: minter_abi_1.MINTER_ABI,
677
+ functionName: 'mint',
678
+ args: [
679
+ pool.key,
680
+ amountAOrigin,
681
+ amountBOrigin,
682
+ minMintAmount,
683
+ {
684
+ permitAmount: tokenAPermitParams.permitAmount,
685
+ signature: tokenAPermitParams.signature,
686
+ },
687
+ {
688
+ permitAmount: tokenBPermitParams.permitAmount,
689
+ signature: tokenBPermitParams.signature,
690
+ },
691
+ swapParams,
692
+ ],
693
+ }, options?.gasLimit);
694
+ const currencyARefund = amountA - inAmountA;
695
+ const currencyBRefund = amountB - inAmountB;
696
+ const currencyAResultAmount = amountAOrigin - currencyARefund;
697
+ const currencyBResultAmount = amountBOrigin - currencyBRefund;
698
+ return {
699
+ transaction,
700
+ result: {
701
+ currencyA: {
702
+ currency: pool.currencyA,
703
+ amount: (0, viem_1.formatUnits)((0, math_1.abs)(currencyAResultAmount), pool.currencyA.decimals),
704
+ direction: currencyAResultAmount >= 0 ? 'in' : 'out',
705
+ },
706
+ currencyB: {
707
+ currency: pool.currencyB,
708
+ amount: (0, viem_1.formatUnits)((0, math_1.abs)(currencyBResultAmount), pool.currencyB.decimals),
709
+ direction: currencyBResultAmount >= 0 ? 'in' : 'out',
710
+ },
711
+ lpCurrency: {
712
+ currency: pool.currencyLp,
713
+ amount: (0, viem_1.formatUnits)(mintAmount, pool.currencyLp.decimals),
714
+ direction: 'out',
715
+ },
716
+ },
717
+ };
718
+ };
719
+ exports.addLiquidity = addLiquidity;
720
+ const removeLiquidity = async ({ chainId, userAddress, token0, token1, salt, amount, options, }) => {
721
+ const publicClient = (0, viem_1.createPublicClient)({
722
+ chain: chain_1.CHAIN_MAP[chainId],
723
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
724
+ });
725
+ const pool = await (0, pool_1.fetchPool)(publicClient, chainId, [token0, token1], salt, !!(options && options.useSubgraph));
726
+ if (!pool.isOpened) {
727
+ throw new Error(`
728
+ Open the pool before removing liquidity.
729
+ import { openPool } from '@clober/v2-sdk'
730
+
731
+ const transaction = await openPool({
732
+ chainId: ${chainId},
733
+ tokenA: '${token0}',
734
+ tokenB: '${token1}',
735
+ })
736
+ `);
737
+ }
738
+ const burnAmount = (0, viem_1.parseUnits)(amount, pool.currencyLp.decimals);
739
+ const slippageLimitPercent = options?.slippage ?? 2;
740
+ const withdrawAmountA = (burnAmount * pool.liquidityA) / pool.totalSupply;
741
+ const withdrawAmountB = (burnAmount * pool.liquidityB) / pool.totalSupply;
742
+ const minWithdrawAmountA = (0, bigint_1.applyPercent)(withdrawAmountA, 100 - slippageLimitPercent);
743
+ const minWithdrawAmountB = (0, bigint_1.applyPercent)(withdrawAmountB, 100 - slippageLimitPercent);
744
+ if (burnAmount === 0n) {
745
+ return {
746
+ transaction: undefined,
747
+ result: {
748
+ currencyA: {
749
+ currency: pool.currencyA,
750
+ amount: '0',
751
+ direction: 'out',
752
+ },
753
+ currencyB: {
754
+ currency: pool.currencyB,
755
+ amount: '0',
756
+ direction: 'out',
757
+ },
758
+ lpCurrency: {
759
+ currency: pool.currencyLp,
760
+ amount: '0',
761
+ direction: 'in',
762
+ },
763
+ },
764
+ };
765
+ }
766
+ const transaction = await (0, build_transaction_1.buildTransaction)(publicClient, {
767
+ chain: chain_1.CHAIN_MAP[chainId],
768
+ account: userAddress,
769
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
770
+ abi: rebalancer_abi_1.REBALANCER_ABI,
771
+ functionName: 'burn',
772
+ args: [pool.key, burnAmount, minWithdrawAmountA, minWithdrawAmountB],
773
+ }, options?.gasLimit);
774
+ return {
775
+ transaction,
776
+ result: {
777
+ currencyA: {
778
+ currency: pool.currencyA,
779
+ amount: (0, viem_1.formatUnits)(withdrawAmountA, pool.currencyA.decimals),
780
+ direction: 'out',
781
+ },
782
+ currencyB: {
783
+ currency: pool.currencyB,
784
+ amount: (0, viem_1.formatUnits)(withdrawAmountB, pool.currencyB.decimals),
785
+ direction: 'out',
786
+ },
787
+ lpCurrency: {
788
+ currency: pool.currencyLp,
789
+ amount: amount,
790
+ direction: 'in',
791
+ },
792
+ },
346
793
  };
347
- });
794
+ };
795
+ exports.removeLiquidity = removeLiquidity;
796
+ const rebalance = async ({ chainId, userAddress, token0, token1, salt, options, }) => {
797
+ const publicClient = (0, viem_1.createPublicClient)({
798
+ chain: chain_1.CHAIN_MAP[chainId],
799
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
800
+ });
801
+ const pool = await (0, pool_1.fetchPool)(publicClient, chainId, [token0, token1], salt, !!(options && options.useSubgraph));
802
+ if (!pool.isOpened) {
803
+ throw new Error(`
804
+ Open the pool before rebalancing pool.
805
+ import { openPool } from '@clober/v2-sdk'
806
+
807
+ const transaction = await openPool({
808
+ chainId: ${chainId},
809
+ tokenA: '${token0}',
810
+ tokenB: '${token1}',
811
+ })
812
+ `);
813
+ }
814
+ return (0, build_transaction_1.buildTransaction)(publicClient, {
815
+ chain: chain_1.CHAIN_MAP[chainId],
816
+ account: userAddress,
817
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Rebalancer,
818
+ abi: rebalancer_abi_1.REBALANCER_ABI,
819
+ functionName: 'rebalance',
820
+ args: [pool.key],
821
+ }, options?.gasLimit);
822
+ };
823
+ exports.rebalance = rebalance;
824
+ const updateStrategyPrice = async ({ chainId, userAddress, token0, token1, salt, oraclePrice, priceA, priceB, options, }) => {
825
+ const publicClient = (0, viem_1.createPublicClient)({
826
+ chain: chain_1.CHAIN_MAP[chainId],
827
+ transport: options?.rpcUrl ? (0, viem_1.http)(options.rpcUrl) : (0, viem_1.http)(),
828
+ });
829
+ const pool = await (0, pool_1.fetchPool)(publicClient, chainId, [token0, token1], salt, !!(options && options.useSubgraph));
830
+ if (!pool.isOpened) {
831
+ throw new Error(`
832
+ Open the pool before updating strategy price.
833
+ import { openPool } from '@clober/v2-sdk'
834
+
835
+ const transaction = await openPool({
836
+ chainId: ${chainId},
837
+ tokenA: '${token0}',
838
+ tokenB: '${token1}',
839
+ })
840
+ `);
841
+ }
842
+ const [roundingUpPriceA, roundingUpPriceB] = [
843
+ options?.roundingUpPriceA ? options.roundingUpPriceA : false,
844
+ options?.roundingUpPriceB ? options.roundingUpPriceB : false,
845
+ ];
846
+ const { roundingDownTick: roundingDownTickA, roundingUpTick: roundingUpTickA, } = (0, prices_1.parsePrice)(Number(priceA), pool.currencyA.decimals, pool.currencyB.decimals);
847
+ const { roundingDownTick: roundingDownTickB, roundingUpTick: roundingUpTickB, } = (0, prices_1.parsePrice)(Number(priceB), pool.currencyA.decimals, pool.currencyB.decimals);
848
+ const oracleRawPrice = (0, prices_1.convertHumanReadablePriceToRawPrice)(Number(oraclePrice), pool.currencyA.decimals, pool.currencyB.decimals);
849
+ const tickA = options?.tickA
850
+ ? Number(options.tickA)
851
+ : Number(roundingUpPriceA ? roundingUpTickA : roundingDownTickA);
852
+ const tickB = options?.tickB
853
+ ? Number(options.tickB)
854
+ : Number((0, tick_1.invertTick)(roundingUpPriceB ? roundingUpTickB : roundingDownTickB));
855
+ return (0, build_transaction_1.buildTransaction)(publicClient, {
856
+ chain: chain_1.CHAIN_MAP[chainId],
857
+ account: userAddress,
858
+ address: addresses_1.CONTRACT_ADDRESSES[chainId].Operator,
859
+ abi: operator_abi_1.OPERATOR_ABI,
860
+ functionName: 'updatePrice',
861
+ args: [pool.key, oracleRawPrice, tickA, tickB],
862
+ }, options?.gasLimit);
863
+ };
864
+ exports.updateStrategyPrice = updateStrategyPrice;
348
865
  //# sourceMappingURL=call.js.map