@zofai/zo-sdk 0.1.92

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 (275) hide show
  1. package/.claude/settings.local.json +9 -0
  2. package/.gitattributes +4 -0
  3. package/.prettierrc.js +9 -0
  4. package/README.md +28 -0
  5. package/dist/abstract/BaseAPI.cjs +206 -0
  6. package/dist/abstract/BaseAPI.cjs.map +1 -0
  7. package/dist/abstract/BaseAPI.d.cts +172 -0
  8. package/dist/abstract/BaseAPI.d.cts.map +1 -0
  9. package/dist/abstract/BaseAPI.d.mts +172 -0
  10. package/dist/abstract/BaseAPI.d.mts.map +1 -0
  11. package/dist/abstract/BaseAPI.mjs +202 -0
  12. package/dist/abstract/BaseAPI.mjs.map +1 -0
  13. package/dist/abstract/BaseDataAPI.cjs +140 -0
  14. package/dist/abstract/BaseDataAPI.cjs.map +1 -0
  15. package/dist/abstract/BaseDataAPI.d.cts +89 -0
  16. package/dist/abstract/BaseDataAPI.d.cts.map +1 -0
  17. package/dist/abstract/BaseDataAPI.d.mts +89 -0
  18. package/dist/abstract/BaseDataAPI.d.mts.map +1 -0
  19. package/dist/abstract/BaseDataAPI.mjs +136 -0
  20. package/dist/abstract/BaseDataAPI.mjs.map +1 -0
  21. package/dist/abstract/index.cjs +12 -0
  22. package/dist/abstract/index.cjs.map +1 -0
  23. package/dist/abstract/index.d.cts +7 -0
  24. package/dist/abstract/index.d.cts.map +1 -0
  25. package/dist/abstract/index.d.mts +7 -0
  26. package/dist/abstract/index.d.mts.map +1 -0
  27. package/dist/abstract/index.mjs +7 -0
  28. package/dist/abstract/index.mjs.map +1 -0
  29. package/dist/api.cjs +779 -0
  30. package/dist/api.cjs.map +1 -0
  31. package/dist/api.d.cts +75 -0
  32. package/dist/api.d.cts.map +1 -0
  33. package/dist/api.d.mts +75 -0
  34. package/dist/api.d.mts.map +1 -0
  35. package/dist/api.mjs +775 -0
  36. package/dist/api.mjs.map +1 -0
  37. package/dist/bcs.cjs +42 -0
  38. package/dist/bcs.cjs.map +1 -0
  39. package/dist/bcs.d.cts +91 -0
  40. package/dist/bcs.d.cts.map +1 -0
  41. package/dist/bcs.d.mts +91 -0
  42. package/dist/bcs.d.mts.map +1 -0
  43. package/dist/bcs.mjs +39 -0
  44. package/dist/bcs.mjs.map +1 -0
  45. package/dist/consts/deployments-shared-mainnet.json +50 -0
  46. package/dist/consts/deployments-shared-testnet.json +45 -0
  47. package/dist/consts/deployments-slp-mainnet.json +600 -0
  48. package/dist/consts/deployments-slp-testnet.json +87 -0
  49. package/dist/consts/deployments-usdz-mainnet.json +494 -0
  50. package/dist/consts/deployments-usdz-testnet.json +98 -0
  51. package/dist/consts/deployments-zbtcvc-mainnet.json +180 -0
  52. package/dist/consts/deployments-zlp-mainnet.json +791 -0
  53. package/dist/consts/deployments-zlp-testnet.json +76 -0
  54. package/dist/consts/index.cjs +200 -0
  55. package/dist/consts/index.cjs.map +1 -0
  56. package/dist/consts/index.d.cts +157 -0
  57. package/dist/consts/index.d.cts.map +1 -0
  58. package/dist/consts/index.d.mts +157 -0
  59. package/dist/consts/index.d.mts.map +1 -0
  60. package/dist/consts/index.mjs +189 -0
  61. package/dist/consts/index.mjs.map +1 -0
  62. package/dist/consts/price_id_to_object_id.mainnet.json +56 -0
  63. package/dist/consts/price_id_to_object_id.testnet.json +17 -0
  64. package/dist/data.cjs +919 -0
  65. package/dist/data.cjs.map +1 -0
  66. package/dist/data.d.cts +235 -0
  67. package/dist/data.d.cts.map +1 -0
  68. package/dist/data.d.mts +235 -0
  69. package/dist/data.d.mts.map +1 -0
  70. package/dist/data.mjs +915 -0
  71. package/dist/data.mjs.map +1 -0
  72. package/dist/factory/SDKFactory.cjs +228 -0
  73. package/dist/factory/SDKFactory.cjs.map +1 -0
  74. package/dist/factory/SDKFactory.d.cts +84 -0
  75. package/dist/factory/SDKFactory.d.cts.map +1 -0
  76. package/dist/factory/SDKFactory.d.mts +84 -0
  77. package/dist/factory/SDKFactory.d.mts.map +1 -0
  78. package/dist/factory/SDKFactory.mjs +222 -0
  79. package/dist/factory/SDKFactory.mjs.map +1 -0
  80. package/dist/implementations/SLPAPI.cjs +1794 -0
  81. package/dist/implementations/SLPAPI.cjs.map +1 -0
  82. package/dist/implementations/SLPAPI.d.cts +183 -0
  83. package/dist/implementations/SLPAPI.d.cts.map +1 -0
  84. package/dist/implementations/SLPAPI.d.mts +183 -0
  85. package/dist/implementations/SLPAPI.d.mts.map +1 -0
  86. package/dist/implementations/SLPAPI.mjs +1790 -0
  87. package/dist/implementations/SLPAPI.mjs.map +1 -0
  88. package/dist/implementations/SLPDataAPI.cjs +1384 -0
  89. package/dist/implementations/SLPDataAPI.cjs.map +1 -0
  90. package/dist/implementations/SLPDataAPI.d.cts +158 -0
  91. package/dist/implementations/SLPDataAPI.d.cts.map +1 -0
  92. package/dist/implementations/SLPDataAPI.d.mts +158 -0
  93. package/dist/implementations/SLPDataAPI.d.mts.map +1 -0
  94. package/dist/implementations/SLPDataAPI.mjs +1380 -0
  95. package/dist/implementations/SLPDataAPI.mjs.map +1 -0
  96. package/dist/implementations/USDZAPI.cjs +1676 -0
  97. package/dist/implementations/USDZAPI.cjs.map +1 -0
  98. package/dist/implementations/USDZAPI.d.cts +180 -0
  99. package/dist/implementations/USDZAPI.d.cts.map +1 -0
  100. package/dist/implementations/USDZAPI.d.mts +180 -0
  101. package/dist/implementations/USDZAPI.d.mts.map +1 -0
  102. package/dist/implementations/USDZAPI.mjs +1672 -0
  103. package/dist/implementations/USDZAPI.mjs.map +1 -0
  104. package/dist/implementations/USDZDataAPI.cjs +1209 -0
  105. package/dist/implementations/USDZDataAPI.cjs.map +1 -0
  106. package/dist/implementations/USDZDataAPI.d.cts +191 -0
  107. package/dist/implementations/USDZDataAPI.d.cts.map +1 -0
  108. package/dist/implementations/USDZDataAPI.d.mts +191 -0
  109. package/dist/implementations/USDZDataAPI.d.mts.map +1 -0
  110. package/dist/implementations/USDZDataAPI.mjs +1205 -0
  111. package/dist/implementations/USDZDataAPI.mjs.map +1 -0
  112. package/dist/implementations/ZBTCVCAPI.cjs +906 -0
  113. package/dist/implementations/ZBTCVCAPI.cjs.map +1 -0
  114. package/dist/implementations/ZBTCVCAPI.d.cts +107 -0
  115. package/dist/implementations/ZBTCVCAPI.d.cts.map +1 -0
  116. package/dist/implementations/ZBTCVCAPI.d.mts +107 -0
  117. package/dist/implementations/ZBTCVCAPI.d.mts.map +1 -0
  118. package/dist/implementations/ZBTCVCAPI.mjs +902 -0
  119. package/dist/implementations/ZBTCVCAPI.mjs.map +1 -0
  120. package/dist/implementations/ZBTCVCDataAPI.cjs +829 -0
  121. package/dist/implementations/ZBTCVCDataAPI.cjs.map +1 -0
  122. package/dist/implementations/ZBTCVCDataAPI.d.cts +94 -0
  123. package/dist/implementations/ZBTCVCDataAPI.d.cts.map +1 -0
  124. package/dist/implementations/ZBTCVCDataAPI.d.mts +94 -0
  125. package/dist/implementations/ZBTCVCDataAPI.d.mts.map +1 -0
  126. package/dist/implementations/ZBTCVCDataAPI.mjs +825 -0
  127. package/dist/implementations/ZBTCVCDataAPI.mjs.map +1 -0
  128. package/dist/implementations/ZLPAPI.cjs +1948 -0
  129. package/dist/implementations/ZLPAPI.cjs.map +1 -0
  130. package/dist/implementations/ZLPAPI.d.cts +192 -0
  131. package/dist/implementations/ZLPAPI.d.cts.map +1 -0
  132. package/dist/implementations/ZLPAPI.d.mts +192 -0
  133. package/dist/implementations/ZLPAPI.d.mts.map +1 -0
  134. package/dist/implementations/ZLPAPI.mjs +1944 -0
  135. package/dist/implementations/ZLPAPI.mjs.map +1 -0
  136. package/dist/implementations/ZLPDataAPI.cjs +1267 -0
  137. package/dist/implementations/ZLPDataAPI.cjs.map +1 -0
  138. package/dist/implementations/ZLPDataAPI.d.cts +193 -0
  139. package/dist/implementations/ZLPDataAPI.d.cts.map +1 -0
  140. package/dist/implementations/ZLPDataAPI.d.mts +193 -0
  141. package/dist/implementations/ZLPDataAPI.d.mts.map +1 -0
  142. package/dist/implementations/ZLPDataAPI.mjs +1263 -0
  143. package/dist/implementations/ZLPDataAPI.mjs.map +1 -0
  144. package/dist/implementations/index.cjs +26 -0
  145. package/dist/implementations/index.cjs.map +1 -0
  146. package/dist/implementations/index.d.cts +13 -0
  147. package/dist/implementations/index.d.cts.map +1 -0
  148. package/dist/implementations/index.d.mts +13 -0
  149. package/dist/implementations/index.d.mts.map +1 -0
  150. package/dist/implementations/index.mjs +15 -0
  151. package/dist/implementations/index.mjs.map +1 -0
  152. package/dist/index.cjs +69 -0
  153. package/dist/index.cjs.map +1 -0
  154. package/dist/index.d.cts +51 -0
  155. package/dist/index.d.cts.map +1 -0
  156. package/dist/index.d.mts +51 -0
  157. package/dist/index.d.mts.map +1 -0
  158. package/dist/index.mjs +51 -0
  159. package/dist/index.mjs.map +1 -0
  160. package/dist/interfaces/base.cjs +7 -0
  161. package/dist/interfaces/base.cjs.map +1 -0
  162. package/dist/interfaces/base.d.cts +346 -0
  163. package/dist/interfaces/base.d.cts.map +1 -0
  164. package/dist/interfaces/base.d.mts +346 -0
  165. package/dist/interfaces/base.d.mts.map +1 -0
  166. package/dist/interfaces/base.mjs +6 -0
  167. package/dist/interfaces/base.mjs.map +1 -0
  168. package/dist/interfaces/index.cjs +31 -0
  169. package/dist/interfaces/index.cjs.map +1 -0
  170. package/dist/interfaces/index.d.cts +15 -0
  171. package/dist/interfaces/index.d.cts.map +1 -0
  172. package/dist/interfaces/index.d.mts +15 -0
  173. package/dist/interfaces/index.d.mts.map +1 -0
  174. package/dist/interfaces/index.mjs +15 -0
  175. package/dist/interfaces/index.mjs.map +1 -0
  176. package/dist/interfaces/slp.cjs +7 -0
  177. package/dist/interfaces/slp.cjs.map +1 -0
  178. package/dist/interfaces/slp.d.cts +179 -0
  179. package/dist/interfaces/slp.d.cts.map +1 -0
  180. package/dist/interfaces/slp.d.mts +179 -0
  181. package/dist/interfaces/slp.d.mts.map +1 -0
  182. package/dist/interfaces/slp.mjs +6 -0
  183. package/dist/interfaces/slp.mjs.map +1 -0
  184. package/dist/interfaces/usdz.cjs +7 -0
  185. package/dist/interfaces/usdz.cjs.map +1 -0
  186. package/dist/interfaces/usdz.d.cts +104 -0
  187. package/dist/interfaces/usdz.d.cts.map +1 -0
  188. package/dist/interfaces/usdz.d.mts +104 -0
  189. package/dist/interfaces/usdz.d.mts.map +1 -0
  190. package/dist/interfaces/usdz.mjs +6 -0
  191. package/dist/interfaces/usdz.mjs.map +1 -0
  192. package/dist/interfaces/zbtcvc.cjs +7 -0
  193. package/dist/interfaces/zbtcvc.cjs.map +1 -0
  194. package/dist/interfaces/zbtcvc.d.cts +64 -0
  195. package/dist/interfaces/zbtcvc.d.cts.map +1 -0
  196. package/dist/interfaces/zbtcvc.d.mts +64 -0
  197. package/dist/interfaces/zbtcvc.d.mts.map +1 -0
  198. package/dist/interfaces/zbtcvc.mjs +6 -0
  199. package/dist/interfaces/zbtcvc.mjs.map +1 -0
  200. package/dist/interfaces/zlp.cjs +7 -0
  201. package/dist/interfaces/zlp.cjs.map +1 -0
  202. package/dist/interfaces/zlp.d.cts +114 -0
  203. package/dist/interfaces/zlp.d.cts.map +1 -0
  204. package/dist/interfaces/zlp.d.mts +114 -0
  205. package/dist/interfaces/zlp.d.mts.map +1 -0
  206. package/dist/interfaces/zlp.mjs +6 -0
  207. package/dist/interfaces/zlp.mjs.map +1 -0
  208. package/dist/oracle.cjs +118 -0
  209. package/dist/oracle.cjs.map +1 -0
  210. package/dist/oracle.d.cts +25 -0
  211. package/dist/oracle.d.cts.map +1 -0
  212. package/dist/oracle.d.mts +25 -0
  213. package/dist/oracle.d.mts.map +1 -0
  214. package/dist/oracle.mjs +114 -0
  215. package/dist/oracle.mjs.map +1 -0
  216. package/dist/utils.cjs +129 -0
  217. package/dist/utils.cjs.map +1 -0
  218. package/dist/utils.d.cts +44 -0
  219. package/dist/utils.d.cts.map +1 -0
  220. package/dist/utils.d.mts +44 -0
  221. package/dist/utils.d.mts.map +1 -0
  222. package/dist/utils.mjs +115 -0
  223. package/dist/utils.mjs.map +1 -0
  224. package/docs/SUMMARY.md +10 -0
  225. package/docs/api-reference.md +32 -0
  226. package/docs/architecture.md +14 -0
  227. package/docs/common-operations.md +52 -0
  228. package/docs/error-handling.md +17 -0
  229. package/docs/getting-started.md +60 -0
  230. package/docs/introduction.md +15 -0
  231. package/docs/lp-specific-features.md +96 -0
  232. package/docs/type-safety.md +29 -0
  233. package/eslint.config.mjs +18 -0
  234. package/package.json +42 -0
  235. package/src/abstract/BaseAPI.ts +575 -0
  236. package/src/abstract/BaseDataAPI.ts +207 -0
  237. package/src/abstract/index.ts +7 -0
  238. package/src/api.ts +1100 -0
  239. package/src/bcs.ts +45 -0
  240. package/src/consts/deployments-shared-mainnet.json +50 -0
  241. package/src/consts/deployments-shared-testnet.json +45 -0
  242. package/src/consts/deployments-slp-mainnet.json +600 -0
  243. package/src/consts/deployments-slp-testnet.json +87 -0
  244. package/src/consts/deployments-usdz-mainnet.json +494 -0
  245. package/src/consts/deployments-usdz-testnet.json +98 -0
  246. package/src/consts/deployments-zbtcvc-mainnet.json +180 -0
  247. package/src/consts/deployments-zlp-mainnet.json +791 -0
  248. package/src/consts/deployments-zlp-testnet.json +76 -0
  249. package/src/consts/index.ts +345 -0
  250. package/src/consts/price_id_to_object_id.mainnet.json +56 -0
  251. package/src/consts/price_id_to_object_id.testnet.json +17 -0
  252. package/src/data.ts +1279 -0
  253. package/src/factory/SDKFactory.ts +340 -0
  254. package/src/implementations/SLPAPI.ts +2722 -0
  255. package/src/implementations/SLPDataAPI.ts +1839 -0
  256. package/src/implementations/USDZAPI.ts +2488 -0
  257. package/src/implementations/USDZDataAPI.ts +1548 -0
  258. package/src/implementations/ZBTCVCAPI.ts +1337 -0
  259. package/src/implementations/ZBTCVCDataAPI.ts +993 -0
  260. package/src/implementations/ZLPAPI.ts +2888 -0
  261. package/src/implementations/ZLPDataAPI.ts +1603 -0
  262. package/src/implementations/index.ts +16 -0
  263. package/src/index.ts +58 -0
  264. package/src/interfaces/base.ts +838 -0
  265. package/src/interfaces/index.ts +50 -0
  266. package/src/interfaces/slp.ts +268 -0
  267. package/src/interfaces/usdz.ts +181 -0
  268. package/src/interfaces/zbtcvc.ts +116 -0
  269. package/src/interfaces/zlp.ts +244 -0
  270. package/src/oracle.ts +153 -0
  271. package/src/utils.ts +168 -0
  272. package/tests/api.test.ts +219 -0
  273. package/tests/data.test.ts +156 -0
  274. package/tests/oracle.test.ts +33 -0
  275. package/tsconfig.json +22 -0
package/dist/data.cjs ADDED
@@ -0,0 +1,919 @@
1
+ "use strict";
2
+ /* eslint-disable class-methods-use-this */
3
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
6
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
7
+ };
8
+ var _DataAPI_instances, _DataAPI_parseMarketInfo, _DataAPI_parseVaultInfo, _DataAPI_parseSymbolInfo, _DataAPI_parseRebaseFeeModel, _DataAPI_parseReservingFeeModel, _DataAPI_parseFundingFeeModel, _DataAPI_parsePositionConfig, _DataAPI_parsePositionInfo, _DataAPI_parseOrderInfo, _DataAPI_calcRebaseFeeRate, _DataAPI_calcReservingFeeRate, _DataAPI_calcFundingFeeRate, _DataAPI_vaultUtilization, _DataAPI_calcAccReservingFeeRate, _DataAPI_calcDeltaSize, _DataAPI_calcAccFundingFeeRate, _DataAPI_calculateSymbolFundingFee, _DataAPI_calculatePositionFundingFee, _DataAPI_calculateVaultReservingFee, _DataAPI_calculatePositionReserveFee, _DataAPI_parseStakePool, _DataAPI_parseCredential, _DataAPI_refreshPool;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.DataAPI = void 0;
11
+ const utils_1 = require("@mysten/sui/utils");
12
+ const consts_1 = require("./consts/index.cjs");
13
+ const oracle_1 = require("./oracle.cjs");
14
+ const utils_2 = require("./utils.cjs");
15
+ ;
16
+ class DataAPI extends oracle_1.OracleAPI {
17
+ constructor(network, provider, apiEndpoint, connectionURL) {
18
+ super(network, provider, connectionURL);
19
+ _DataAPI_instances.add(this);
20
+ this.vaultInfoCache = {};
21
+ this.symbolInfoCache = {};
22
+ this.marketInfoCache = null;
23
+ this.positionConfigCache = {};
24
+ this.rebaseFeeModelCache = null;
25
+ this.lastUpdate = 0;
26
+ this.validateCache = () => {
27
+ super.validateCache();
28
+ if (this.lastUpdate + 1000 * 60 * 3 < Date.now()) {
29
+ this.lastUpdate = Date.now();
30
+ this.vaultInfoCache = {};
31
+ this.symbolInfoCache = {};
32
+ this.marketInfoCache = null;
33
+ this.positionConfigCache = {};
34
+ this.rebaseFeeModelCache = null;
35
+ }
36
+ };
37
+ this.valuateVaults = (tx) => {
38
+ const vaultsValuation = tx.moveCall({
39
+ target: `${this.consts.zoCore.upgradedPackage}::market::create_vaults_valuation`,
40
+ typeArguments: [`${this.consts.zoCore.package}::zlp::ZLP`],
41
+ arguments: [
42
+ tx.object(utils_1.SUI_CLOCK_OBJECT_ID),
43
+ tx.object(this.consts.zoCore.market),
44
+ ],
45
+ });
46
+ for (const key of Object.keys(this.consts.zoCore.vaults)) {
47
+ const vault = this.consts.zoCore.vaults[key];
48
+ tx.moveCall({
49
+ // todo
50
+ target: `${this.consts.zoCore.upgradedPackage}::market::valuate_vault`,
51
+ typeArguments: [
52
+ `${this.consts.zoCore.package}::zlp::ZLP`,
53
+ this.consts.coins[key].module,
54
+ ],
55
+ arguments: [
56
+ tx.object(this.consts.zoCore.market),
57
+ tx.object(vault.reservingFeeModel),
58
+ tx.object(this.consts.pythFeeder.feeder[key]),
59
+ vaultsValuation,
60
+ ],
61
+ });
62
+ }
63
+ return vaultsValuation;
64
+ };
65
+ this.valuateSymbols = (tx) => {
66
+ const symbolsValuation = tx.moveCall({
67
+ target: `${this.consts.zoCore.upgradedPackage}::market::create_symbols_valuation`,
68
+ typeArguments: [`${this.consts.zoCore.package}::zlp::ZLP`],
69
+ arguments: [
70
+ tx.object(utils_1.SUI_CLOCK_OBJECT_ID),
71
+ tx.object(this.consts.zoCore.market),
72
+ ],
73
+ });
74
+ for (const key of Object.keys(this.consts.zoCore.symbols)) {
75
+ const [direction, token] = (0, utils_2.parseSymbolKey)(key);
76
+ const symbol = this.consts.zoCore.symbols[key];
77
+ tx.moveCall({
78
+ target: `${this.consts.zoCore.upgradedPackage}::market::valuate_symbol`,
79
+ typeArguments: [
80
+ `${this.consts.zoCore.package}::zlp::ZLP`,
81
+ this.consts.coins[token].module,
82
+ `${this.consts.zoCore.package}::market::${direction.toUpperCase()}`,
83
+ ],
84
+ arguments: [
85
+ tx.object(this.consts.zoCore.market),
86
+ tx.object(symbol.fundingFeeModel),
87
+ tx.object(this.consts.pythFeeder.feeder[token]),
88
+ symbolsValuation,
89
+ ],
90
+ });
91
+ }
92
+ return symbolsValuation;
93
+ };
94
+ this.valuate = (tx) => {
95
+ const vaultsValuation = this.valuateVaults(tx);
96
+ const symbolsValuation = this.valuateSymbols(tx);
97
+ return {
98
+ vaultsValuation,
99
+ symbolsValuation,
100
+ };
101
+ };
102
+ /**
103
+ * Validates the market valuation by calling the validate_market_valuation Move function
104
+ * @param tx Transaction object
105
+ * @returns An object containing handled vaults, total weight, total vaults value, and market value
106
+ */
107
+ this.validateMarketValuation = (tx) => {
108
+ // First, create the valuations using existing methods
109
+ const vaultsValuation = this.valuateVaults(tx);
110
+ const symbolsValuation = this.valuateSymbols(tx);
111
+ // Call the validate_market_valuation Move function
112
+ const result = tx.moveCall({
113
+ target: `${this.consts.zoCore.upgradedPackage}::market::validate_market_valuation`,
114
+ typeArguments: [`${this.consts.zoCore.package}::zlp::ZLP`],
115
+ arguments: [
116
+ tx.object(this.consts.zoCore.market),
117
+ vaultsValuation,
118
+ symbolsValuation,
119
+ ],
120
+ });
121
+ return result;
122
+ };
123
+ _DataAPI_parseVaultInfo.set(this, async (raw) => {
124
+ const vaultFields = raw.data.content.fields.value.fields;
125
+ const reservingFeeModelAddr = vaultFields.reserving_fee_model;
126
+ const reservingFeeModelRaw = await this.provider.getObject({
127
+ id: reservingFeeModelAddr,
128
+ options: {
129
+ showContent: true,
130
+ },
131
+ });
132
+ const reservingFeeModel = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseReservingFeeModel).call(this, reservingFeeModelRaw);
133
+ return {
134
+ liquidity: (0, utils_2.parseValue)(vaultFields.liquidity),
135
+ reservedAmount: (0, utils_2.parseValue)(vaultFields.reserved_amount),
136
+ unrealisedReservingFeeAmount: (0, utils_2.parseValue)(vaultFields.unrealised_reserving_fee_amount),
137
+ accReservingRate: (0, utils_2.parseValue)(vaultFields.acc_reserving_rate),
138
+ enabled: vaultFields.enabled,
139
+ weight: (0, utils_2.parseValue)(vaultFields.weight),
140
+ lastUpdate: (0, utils_2.parseValue)(vaultFields.last_update),
141
+ reservingFeeModel,
142
+ priceConfig: {
143
+ maxInterval: (0, utils_2.parseValue)(vaultFields.price_config.fields.max_interval),
144
+ maxConfidence: (0, utils_2.parseValue)(vaultFields.price_config.fields.max_confidence),
145
+ precision: (0, utils_2.parseValue)(vaultFields.price_config.fields.precision),
146
+ feeder: vaultFields.price_config.fields.feeder,
147
+ },
148
+ };
149
+ });
150
+ _DataAPI_parseSymbolInfo.set(this, async (raw, long) => {
151
+ const { fields } = raw.data.content.fields.value;
152
+ const fundingFeeModelAddr = fields.funding_fee_model;
153
+ const fundingFeeModelRaw = await this.provider.getObject({
154
+ id: fundingFeeModelAddr,
155
+ options: {
156
+ showContent: true,
157
+ },
158
+ });
159
+ const fundingFeeModel = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseFundingFeeModel).call(this, fundingFeeModelRaw);
160
+ return {
161
+ openingSize: (0, utils_2.parseValue)(fields.opening_size),
162
+ openingAmount: (0, utils_2.parseValue)(fields.opening_amount),
163
+ accFundingRate: (0, utils_2.parseValue)(fields.acc_funding_rate),
164
+ realisedPnl: (0, utils_2.parseValue)(fields.realised_pnl),
165
+ unrealisedFundingFeeValue: (0, utils_2.parseValue)(fields.unrealised_funding_fee_value),
166
+ openEnabled: fields.open_enabled,
167
+ liquidateEnabled: fields.liquidate_enabled,
168
+ decreaseEnabled: fields.decrease_enabled,
169
+ lastUpdate: (0, utils_2.parseValue)(fields.last_update),
170
+ fundingFeeModel,
171
+ long,
172
+ priceConfig: {
173
+ maxInterval: (0, utils_2.parseValue)(fields.price_config.fields.max_interval),
174
+ maxConfidence: (0, utils_2.parseValue)(fields.price_config.fields.max_confidence),
175
+ precision: (0, utils_2.parseValue)(fields.price_config.fields.precision),
176
+ feeder: fields.price_config.fields.feeder,
177
+ },
178
+ };
179
+ });
180
+ this.fundingFeeRate = async (indexToken, long) => {
181
+ const symbol = await this.getSymbolInfo(indexToken, long);
182
+ if (symbol.lastUpdate <= 0) {
183
+ return 0;
184
+ }
185
+ const price = (await this.getOraclePrice(indexToken)).getPriceUnchecked().getPriceAsNumberUnchecked();
186
+ const lpSupplyAmount = (await this.getMarketInfo()).lpSupplyWithDecimals;
187
+ const model = symbol.fundingFeeModel;
188
+ const elapsed = consts_1.SECONDS_PER_EIGHT_HOUR;
189
+ const deltaSize = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcDeltaSize).call(this, symbol, price);
190
+ const pnlPerLp = (symbol.realisedPnl + symbol.unrealisedFundingFeeValue + deltaSize) / lpSupplyAmount;
191
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcFundingFeeRate).call(this, model, pnlPerLp, elapsed);
192
+ };
193
+ this.rebaseFeeRate = async (collateralToken, increase, amount) => {
194
+ let vaultValue = 0;
195
+ if (!increase && amount > 0) {
196
+ amount = -amount;
197
+ }
198
+ const value = amount * (await this.getOraclePrice(collateralToken)).getPriceUnchecked().getPriceAsNumberUnchecked() / (10 ** this.consts.coins[collateralToken].decimals);
199
+ const vaultPromises = Object.keys(this.consts.zoCore.vaults).map(async (vault) => {
200
+ const vaultInfo = await this.getVaultInfo(vault);
201
+ const reservingFeeDelta = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calculateVaultReservingFee).call(this, vaultInfo, vaultInfo.reservingFeeModel, Date.now() / 1000);
202
+ const res = (reservingFeeDelta + vaultInfo.liquidity + vaultInfo.reservedAmount) * (await this.getOraclePrice(vault)).getPriceUnchecked().getPriceAsNumberUnchecked() / (10 ** this.consts.coins[vault].decimals);
203
+ if (collateralToken === vault) {
204
+ vaultValue = res;
205
+ }
206
+ return res;
207
+ });
208
+ const vaultValues = await Promise.all(vaultPromises);
209
+ const totalVaultValue = vaultValues.reduce((acc, curr) => acc + curr, 0);
210
+ const targetRatio = Number.parseInt(this.consts.zoCore.vaults[collateralToken].weight, 10) / Object.values(this.consts.zoCore.vaults)
211
+ .map(e => Number.parseInt(e.weight, 10))
212
+ .reduce((acc, curr) => acc + curr, 0);
213
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcRebaseFeeRate).call(this, await this.getRebaseFeeModel(), increase, (vaultValue + value) / (totalVaultValue + value), targetRatio);
214
+ };
215
+ this.reservingFeeRate = async (collateralToken, amount = 0) => {
216
+ const vaultInfo = await this.getVaultInfo(collateralToken);
217
+ const vaultSupply = vaultInfo.liquidity + vaultInfo.reservedAmount + vaultInfo.unrealisedReservingFeeAmount + amount;
218
+ const utilization = vaultSupply ? ((vaultInfo.reservedAmount + amount) / vaultSupply) : 0;
219
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcReservingFeeRate).call(this, vaultInfo.reservingFeeModel, utilization, consts_1.SECONDS_PER_EIGHT_HOUR);
220
+ };
221
+ this.getProxiedHistories = async (trader, page, limit) => {
222
+ const params = new URLSearchParams({ trader });
223
+ if (page !== undefined) {
224
+ params.append('page', page.toString());
225
+ }
226
+ if (limit !== undefined) {
227
+ params.append('limit', limit.toString());
228
+ }
229
+ const url = `${this.apiEndpoint}/traderEvents?${params}`;
230
+ const res = await fetch(url, {
231
+ method: 'GET',
232
+ headers: {
233
+ 'Content-Type': 'application/json',
234
+ },
235
+ });
236
+ const response = await res.json();
237
+ // Handle both old format (array) and new format (object with data)
238
+ if (Array.isArray(response)) {
239
+ return response;
240
+ }
241
+ return response.data?.histories || [];
242
+ };
243
+ this.getProxiedHistoriesWithPagination = async (trader, page = 1, limit = 20, orderType, symbol) => {
244
+ const params = new URLSearchParams({
245
+ trader,
246
+ page: page.toString(),
247
+ limit: limit.toString(),
248
+ });
249
+ // Add filter parameters if provided
250
+ if (orderType && orderType !== 'all') {
251
+ params.append('orderType', orderType);
252
+ }
253
+ if (symbol && symbol !== 'all') {
254
+ params.append('symbol', symbol);
255
+ }
256
+ const url = `${this.apiEndpoint}/traderEvents?${params}`;
257
+ const res = await fetch(url, {
258
+ method: 'GET',
259
+ headers: {
260
+ 'Content-Type': 'application/json',
261
+ },
262
+ });
263
+ const response = await res.json();
264
+ return {
265
+ histories: response.data?.histories || [],
266
+ pagination: response.data?.pagination || {
267
+ total: 0,
268
+ page: 1,
269
+ limit: 20,
270
+ pages: 0,
271
+ },
272
+ };
273
+ };
274
+ this.getStaked = async (owner) => {
275
+ const rawCredentials = await this.provider.getOwnedObjects({
276
+ owner,
277
+ filter: {
278
+ MoveModule: {
279
+ package: this.consts.zoStaking.package,
280
+ module: 'pool',
281
+ },
282
+ },
283
+ options: {
284
+ showType: true,
285
+ showContent: true,
286
+ },
287
+ });
288
+ const pool = await this.getStakePool();
289
+ const credentials = rawCredentials.data.map((item) => __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseCredential).call(this, item, pool));
290
+ return {
291
+ credentials,
292
+ amount: credentials.reduce((acc, cur) => acc + cur.amount, BigInt(0)),
293
+ claimable: credentials.reduce((acc, cur) => acc + cur.claimable, BigInt(0)),
294
+ };
295
+ };
296
+ this.getStakePool = async () => {
297
+ const raw = await this.provider.getObject({
298
+ id: this.consts.zoStaking.pool,
299
+ options: {
300
+ showContent: true,
301
+ },
302
+ });
303
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseStakePool).call(this, raw);
304
+ };
305
+ this.provider = provider || (0, utils_2.createJsonRpcProvider)(network);
306
+ this.apiEndpoint = apiEndpoint;
307
+ }
308
+ async getPastFee(days = 7) {
309
+ // FIXME: Use Sentio data
310
+ const url = `${this.apiEndpoint}/histories/proxy/fee?days=${days}`;
311
+ const res = await fetch(url, {
312
+ method: 'GET',
313
+ headers: {
314
+ 'Content-Type': 'application/json',
315
+ },
316
+ });
317
+ return Number.parseFloat(await res.text() || '0');
318
+ }
319
+ async valuateMarket() {
320
+ const marketInfo = await this.getMarketInfo();
321
+ const days = 7;
322
+ const fee = await this.getPastFee(days);
323
+ let zlpPrice = 0;
324
+ let value = 0;
325
+ const vaultPromises = Object.keys(this.consts.zoCore.vaults).map(async (vault) => {
326
+ const vaultInfo = await this.getVaultInfo(vault);
327
+ const reservingFeeDelta = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calculateVaultReservingFee).call(this, vaultInfo, vaultInfo.reservingFeeModel, Date.now() / 1000);
328
+ return (reservingFeeDelta + vaultInfo.liquidity + vaultInfo.reservedAmount) * (await this.getOraclePrice(vault)).getPriceUnchecked().getPriceAsNumberUnchecked() / (10 ** this.consts.coins[vault].decimals);
329
+ });
330
+ const symbolPromises = Object.keys(this.consts.zoCore.symbols).map(async (symbol) => {
331
+ const [direction, tokenId] = (0, utils_2.parseSymbolKey)(symbol);
332
+ const symbolInfo = await this.getSymbolInfo(tokenId, direction === 'long');
333
+ const deltaSize = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcDeltaSize).call(this, symbolInfo, (await this.getOraclePrice(tokenId)).getPriceUnchecked().getPriceAsNumberUnchecked());
334
+ const fundingFeeDelta = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calculateSymbolFundingFee).call(this, symbolInfo, symbolInfo.fundingFeeModel, (await this.getOraclePrice(tokenId)).getPriceUnchecked().getPriceAsNumberUnchecked(), marketInfo.lpSupplyWithDecimals, Date.now() / 1000);
335
+ return fundingFeeDelta + deltaSize;
336
+ });
337
+ const [vaultValues, symbolValues] = await Promise.all([Promise.all(vaultPromises), Promise.all(symbolPromises)]);
338
+ value = vaultValues.reduce((acc, curr) => acc + curr, 0);
339
+ value += symbolValues.reduce((acc, curr) => acc + curr, 0);
340
+ zlpPrice = value / marketInfo.lpSupplyWithDecimals;
341
+ return {
342
+ marketCap: value,
343
+ zlpPrice,
344
+ zlpSupply: marketInfo.lpSupplyWithDecimals,
345
+ apr: (fee / value) * 365 / days,
346
+ };
347
+ }
348
+ async getMarketInfo() {
349
+ this.validateCache();
350
+ if (this.marketInfoCache) {
351
+ return this.marketInfoCache;
352
+ }
353
+ const rawData = await this.provider.getObject({
354
+ id: this.consts.zoCore.market,
355
+ options: {
356
+ showContent: true,
357
+ },
358
+ });
359
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseMarketInfo).call(this, rawData);
360
+ }
361
+ async getVaultInfo(vaultToken) {
362
+ this.validateCache();
363
+ if (this.vaultInfoCache[vaultToken]) {
364
+ return this.vaultInfoCache[vaultToken];
365
+ }
366
+ const rawData = await this.provider.getDynamicFieldObject({
367
+ parentId: this.consts.zoCore.vaultsParent,
368
+ name: {
369
+ type: `${this.consts.zoCore.package}::market::VaultName<${this.consts.coins[vaultToken].module}>`,
370
+ value: { dummy_field: false },
371
+ },
372
+ });
373
+ return await __classPrivateFieldGet(this, _DataAPI_parseVaultInfo, "f").call(this, rawData);
374
+ }
375
+ async getSymbolInfo(indexToken, long) {
376
+ this.validateCache();
377
+ const symbol = (0, utils_2.joinSymbol)(long ? 'long' : 'short', indexToken);
378
+ if (this.symbolInfoCache[symbol]) {
379
+ return this.symbolInfoCache[symbol];
380
+ }
381
+ const rawData = await this.provider.getDynamicFieldObject({
382
+ parentId: this.consts.zoCore.symbolsParent,
383
+ name: {
384
+ type: `${this.consts.zoCore.package}::market::SymbolName<${this.consts.coins[indexToken].module}, ${this.consts.zoCore.package}::market::${long ? 'LONG' : 'SHORT'}>`,
385
+ value: { dummy_field: false },
386
+ },
387
+ });
388
+ return await __classPrivateFieldGet(this, _DataAPI_parseSymbolInfo, "f").call(this, rawData, long);
389
+ }
390
+ async getPositionConfig(indexToken, long) {
391
+ this.validateCache();
392
+ const symbol = (0, utils_2.joinSymbol)(long ? 'long' : 'short', indexToken);
393
+ if (this.positionConfigCache[symbol]) {
394
+ return this.positionConfigCache[symbol];
395
+ }
396
+ const rawData = await this.provider.getObject({
397
+ id: this.consts.zoCore.symbols[symbol].positionConfig,
398
+ options: {
399
+ showContent: true,
400
+ },
401
+ });
402
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parsePositionConfig).call(this, rawData);
403
+ }
404
+ async getPositionCapInfoList(owner) {
405
+ const positionCapInfoList = [];
406
+ let cursor;
407
+ let hasNextPage = true;
408
+ while (hasNextPage) {
409
+ /* eslint-disable-next-line no-await-in-loop -- pagination requires sequential fetches */
410
+ const positionCaps = await this.provider.getOwnedObjects({
411
+ owner,
412
+ filter: {
413
+ MoveModule: {
414
+ package: this.consts.zoCore.package,
415
+ module: 'market',
416
+ },
417
+ },
418
+ options: {
419
+ showType: true,
420
+ },
421
+ cursor,
422
+ });
423
+ for (const positionCap of positionCaps.data) {
424
+ if (positionCap.data?.type?.includes('PositionCap')) {
425
+ positionCapInfoList.push({
426
+ positionCapId: positionCap.data.objectId,
427
+ symbol0: positionCap.data.type.split('<')[1].split(',')[0].trim(),
428
+ symbol1: positionCap.data.type.split('<')[1].split(',')[1].split(',')[0].trim(),
429
+ long: positionCap.data.type.includes('LONG'),
430
+ });
431
+ }
432
+ }
433
+ // If we don't want to fetch all pages or there are no more pages, break the loop
434
+ hasNextPage = positionCaps.hasNextPage;
435
+ cursor = positionCaps.nextCursor;
436
+ }
437
+ return positionCapInfoList;
438
+ }
439
+ async getPositionInfoList(positionCapInfoList, owner, batchSize = 10) {
440
+ const positionInfoList = [];
441
+ // Process in batches of 10
442
+ for (let i = 0; i < positionCapInfoList.length; i += batchSize) {
443
+ const batch = positionCapInfoList.slice(i, i + batchSize);
444
+ /* eslint-disable-next-line no-await-in-loop -- batch processed in parallel via Promise.all */
445
+ await Promise.all(batch.map(async (positionCapInfo) => {
446
+ try {
447
+ const positionRaw = await this.provider.getDynamicFieldObject({
448
+ parentId: this.consts.zoCore.positionsParent,
449
+ name: {
450
+ type: `${this.consts.zoCore.package}::market::PositionName<${positionCapInfo.symbol0}, ${positionCapInfo.symbol1}, ${this.consts.zoCore.package}::market::${positionCapInfo.long ? 'LONG' : 'SHORT'}>`,
451
+ value: {
452
+ owner,
453
+ id: positionCapInfo.positionCapId,
454
+ },
455
+ },
456
+ });
457
+ positionInfoList.push(await __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parsePositionInfo).call(this, positionRaw, positionCapInfo.positionCapId));
458
+ }
459
+ catch (error) {
460
+ // Position might have been deleted after force settlement
461
+ console.warn(`Failed to parse position info for position cap ID ${positionCapInfo.positionCapId}: ${error}`);
462
+ // Continue with next position without adding this one to the list
463
+ }
464
+ }));
465
+ }
466
+ return positionInfoList.sort((a, b) => a.openTimestamp > b.openTimestamp ? 1 : -1);
467
+ }
468
+ // find all open positions by positionsParent
469
+ async getOpenPositions(batchSize = 50, symbol = 'sui') {
470
+ let positionDynamicFields = [];
471
+ let _continue = true;
472
+ let cursor;
473
+ while (_continue) {
474
+ // data here will be a list of dynamic fields containing name and value
475
+ const { data, nextCursor, hasNextPage }
476
+ /* eslint-disable-next-line no-await-in-loop -- pagination requires sequential fetches */
477
+ = await this.provider.getDynamicFields({
478
+ parentId: this.consts.zoCore.positionsParent,
479
+ cursor,
480
+ });
481
+ positionDynamicFields = positionDynamicFields.concat(data);
482
+ _continue = hasNextPage;
483
+ cursor = nextCursor;
484
+ }
485
+ // Filter by symbol if provided
486
+ if (!(symbol && this.consts.coins[symbol])) {
487
+ return [];
488
+ }
489
+ const coinModule = symbol === 'sui' ? '0x2::sui::SUI' : this.consts.coins[symbol].module;
490
+ positionDynamicFields = positionDynamicFields.filter((field) => {
491
+ // Extract the second coin module from PositionName<coin1, coin2, direction>
492
+ const typeStr = field.name?.type;
493
+ if (!typeStr)
494
+ return false;
495
+ const match = typeStr.match(/PositionName<([^,\s]+),\s*([^,\s]+),\s*([^>\s]+)>/);
496
+ if (!match)
497
+ return false;
498
+ const secondCoin = match[2].trim();
499
+ return secondCoin === coinModule;
500
+ });
501
+ // then we query by dynamic field names and order by time
502
+ const positionInfoList = [];
503
+ // Process in batches of 50 (or specified batchSize)
504
+ for (let i = 0; i < positionDynamicFields.length; i += batchSize) {
505
+ const batch = positionDynamicFields.slice(i, i + batchSize);
506
+ /* eslint-disable-next-line no-await-in-loop -- batch processed in parallel via Promise.all */
507
+ await Promise.all(batch.map(async (positionDynamicField) => {
508
+ const positionRaw = await this.provider.getDynamicFieldObject({
509
+ parentId: this.consts.zoCore.positionsParent,
510
+ name: positionDynamicField.name,
511
+ });
512
+ if (positionRaw?.data?.content) {
513
+ // @ts-expect-error -- optional chain on dynamic Move content
514
+ if (positionRaw?.data?.content?.fields?.value?.fields?.closed) {
515
+ // skip closed positions
516
+ return;
517
+ }
518
+ const positionInfo = await __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parsePositionInfo).call(this, positionRaw, positionDynamicField.objectId);
519
+ if (positionInfo) {
520
+ positionInfoList.push(positionInfo);
521
+ }
522
+ }
523
+ }));
524
+ }
525
+ return positionInfoList
526
+ .filter(positionInfo => !positionInfo.closed)
527
+ .sort((a, b) => (a.openTimestamp > b.openTimestamp ? 1 : -1));
528
+ }
529
+ async getOrderCapInfoList(owner) {
530
+ const orderCapInfoList = [];
531
+ let cursor;
532
+ let hasNextPage = true;
533
+ while (hasNextPage) {
534
+ /* eslint-disable-next-line no-await-in-loop -- pagination requires sequential fetches */
535
+ const orderCaps = await this.provider.getOwnedObjects({
536
+ owner,
537
+ filter: {
538
+ MoveModule: {
539
+ package: this.consts.zoCore.package,
540
+ module: 'market',
541
+ },
542
+ },
543
+ options: {
544
+ showType: true,
545
+ showContent: true,
546
+ },
547
+ cursor,
548
+ });
549
+ for (const orderCap of orderCaps.data) {
550
+ if (orderCap.data?.type?.includes('OrderCap')) {
551
+ orderCapInfoList.push({
552
+ orderCapId: orderCap.data.objectId,
553
+ symbol0: orderCap.data.type.split('<')[1].split(',')[0].trim(),
554
+ symbol1: orderCap.data.type.split('<')[1].split(',')[1].split(',')[0].trim(),
555
+ long: orderCap.data.type.includes('LONG'),
556
+ positionId: orderCap.data.content?.fields?.position_id,
557
+ });
558
+ }
559
+ }
560
+ hasNextPage = orderCaps.hasNextPage;
561
+ cursor = orderCaps.nextCursor;
562
+ }
563
+ return orderCapInfoList;
564
+ }
565
+ async getOrderInfoList(orderCapInfoList, owner, batchSize = 10) {
566
+ const orderInfoList = [];
567
+ // Process in batches of 10
568
+ for (let i = 0; i < orderCapInfoList.length; i += batchSize) {
569
+ const batch = orderCapInfoList.slice(i, i + batchSize);
570
+ /* eslint-disable-next-line no-await-in-loop -- batch processed in parallel via Promise.all */
571
+ await Promise.all(batch.map(async (orderCapInfo) => {
572
+ try {
573
+ const orderRaw = await this.provider.getDynamicFieldObject({
574
+ parentId: this.consts.zoCore.ordersParent,
575
+ name: {
576
+ // We have enforced collateral coin type to match with fee coin type so we can use symbol0 in the first slot and the last slot of the OrderName
577
+ type: `${this.consts.zoCore.package}::market::OrderName<${orderCapInfo.symbol0}, ${orderCapInfo.symbol1}, ${this.consts.zoCore.package}::market::${orderCapInfo.long ? 'LONG' : 'SHORT'}, ${orderCapInfo.symbol0}>`,
578
+ value: {
579
+ owner,
580
+ id: orderCapInfo.orderCapId,
581
+ position_id: {
582
+ vec: orderCapInfo.positionId ? [orderCapInfo.positionId] : [],
583
+ },
584
+ },
585
+ },
586
+ });
587
+ orderInfoList.push(__classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseOrderInfo).call(this, orderRaw, orderCapInfo.orderCapId));
588
+ }
589
+ catch (error) {
590
+ // Order might have been deleted
591
+ console.warn(`Failed to parse order info for order cap ID ${orderCapInfo.orderCapId}: ${error}`);
592
+ // Continue with next order without adding this one to the list
593
+ }
594
+ }));
595
+ }
596
+ return orderInfoList.sort((a, b) => a.createdAt > b.createdAt ? 1 : -1);
597
+ }
598
+ async getRebaseFeeModel() {
599
+ this.validateCache();
600
+ if (this.rebaseFeeModelCache) {
601
+ return this.rebaseFeeModelCache;
602
+ }
603
+ const rawData = await this.provider.getObject({
604
+ id: this.consts.zoCore.rebaseFeeModel,
605
+ options: {
606
+ showContent: true,
607
+ },
608
+ });
609
+ return __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_parseRebaseFeeModel).call(this, rawData);
610
+ }
611
+ async getReferralData(referree) {
612
+ const raw = await this.provider.getDynamicFieldObject({
613
+ parentId: this.consts.zoCore.referralsParent,
614
+ name: {
615
+ type: 'address',
616
+ value: referree,
617
+ },
618
+ });
619
+ return raw;
620
+ }
621
+ async hasReferral(referree) {
622
+ const raw = await this.getReferralData(referree);
623
+ return !raw.error;
624
+ }
625
+ async getReferreeFromReferrer(referrer) {
626
+ const url = new URL(`${this.apiEndpoint}/executions`);
627
+ const data = {
628
+ projectId: `${this.network === 'mainnet' ? 'nCBQRfhN' : 'C5iFbF6X'}`,
629
+ projectSlug: `zo-${this.network}`,
630
+ projectOwner: 'zo',
631
+ sqlQuery: {
632
+ sql: `SELECT referralSender, timestamp from \`Referral_Added\` WHERE referralReferrer = '${referrer}'`,
633
+ size: 100,
634
+ },
635
+ };
636
+ const res = await fetch(url, {
637
+ method: 'POST',
638
+ headers: {
639
+ 'Content-Type': 'application/json',
640
+ },
641
+ body: JSON.stringify(data),
642
+ });
643
+ return (await res.json()).result.rows.map((e) => ({ address: e.referralSender, date: new Date(e.timestamp) }));
644
+ }
645
+ async getReferreeDetail(referree) {
646
+ const url = new URL(`${this.apiEndpoint}/executions`);
647
+ const data = {
648
+ projectId: `${this.network === 'mainnet' ? 'nCBQRfhN' : 'C5iFbF6X'}`,
649
+ projectSlug: `zo-${this.network}`,
650
+ projectOwner: 'zo',
651
+ sqlQuery: {
652
+ sql: `SELECT sum(volume) as volumeUsd, sum(rebate) as rebateUsd FROM \`User_Interaction\` WHERE distinct_id = '${referree}' and rebate != 0`,
653
+ size: 100,
654
+ },
655
+ };
656
+ const res = await fetch(url, {
657
+ method: 'POST',
658
+ headers: {
659
+ 'Content-Type': 'application/json',
660
+ },
661
+ body: JSON.stringify(data),
662
+ });
663
+ const row = (await res.json()).result.rows[0];
664
+ return {
665
+ volumeUsd: Number.parseFloat(row.volumeUsd),
666
+ rebateUsd: Number.parseFloat(row.rebateUsd),
667
+ };
668
+ }
669
+ async getReferrerDetail(referrer) {
670
+ const url = new URL(`${this.apiEndpoint}/executions`);
671
+ const data = {
672
+ projectId: `${this.network === 'mainnet' ? 'nCBQRfhN' : 'C5iFbF6X'}`,
673
+ projectSlug: `zo-${this.network}`,
674
+ projectOwner: 'zo',
675
+ sqlQuery: {
676
+ sql: `SELECT sum(volume) as volumeUsd, sum(rebate) as rebateUsd FROM \`User_Interaction\` WHERE referralReceiver = '${referrer}' and rebate != 0`,
677
+ size: 100,
678
+ },
679
+ };
680
+ const res = await fetch(url, {
681
+ method: 'POST',
682
+ headers: {
683
+ 'Content-Type': 'application/json',
684
+ },
685
+ body: JSON.stringify(data),
686
+ });
687
+ const row = (await res.json()).result.rows[0];
688
+ return {
689
+ volumeUsd: Number.parseFloat(row.volumeUsd),
690
+ rebateUsd: Number.parseFloat(row.rebateUsd),
691
+ };
692
+ }
693
+ async getReferralTxs(referrer) {
694
+ const url = new URL(`${this.apiEndpoint}/executions`);
695
+ const data = {
696
+ projectId: `${this.network === 'mainnet' ? 'nCBQRfhN' : 'C5iFbF6X'}`,
697
+ projectSlug: `zo-${this.network}`,
698
+ projectOwner: 'zo',
699
+ sqlQuery: {
700
+ sql: `SELECT distinct_id, volume, rebate, timestamp, transaction_hash FROM \`User_Interaction\` WHERE referralReceiver = '${referrer}' and rebate != 0 order by timestamp desc`,
701
+ size: 100,
702
+ },
703
+ };
704
+ const res = await fetch(url, {
705
+ method: 'POST',
706
+ headers: {
707
+ 'Content-Type': 'application/json',
708
+ },
709
+ body: JSON.stringify(data),
710
+ });
711
+ const { rows } = (await res.json()).result;
712
+ return rows.map((e) => {
713
+ return {
714
+ referree: e.distinct_id,
715
+ volume: Number.parseFloat(e.volume),
716
+ rebate: Number.parseFloat(e.rebate),
717
+ date: new Date(e.timestamp),
718
+ tx: e.transaction_hash,
719
+ };
720
+ });
721
+ }
722
+ }
723
+ exports.DataAPI = DataAPI;
724
+ _DataAPI_parseVaultInfo = new WeakMap(), _DataAPI_parseSymbolInfo = new WeakMap(), _DataAPI_instances = new WeakSet(), _DataAPI_parseMarketInfo = function _DataAPI_parseMarketInfo(raw) {
725
+ const content = raw.data.content.fields;
726
+ return {
727
+ lpSupply: content.lp_supply.fields.value,
728
+ positionId: content.positions.fields.id.id,
729
+ vaultId: content.vaults.fields.id.id,
730
+ symbolId: content.symbols.fields.id.id,
731
+ referralId: content.referrals.fields.id.id,
732
+ orderId: content.orders.fields.id.id,
733
+ rebaseFeeModel: content.rebase_fee_model,
734
+ lpSupplyWithDecimals: content.lp_supply.fields.value / (10 ** consts_1.ZLP_TOKEN_DECIMALS),
735
+ };
736
+ }, _DataAPI_parseRebaseFeeModel = function _DataAPI_parseRebaseFeeModel(raw) {
737
+ const { fields } = raw.data.content;
738
+ return {
739
+ base: (0, utils_2.parseValue)(fields.base),
740
+ multiplier: (0, utils_2.parseValue)(fields.multiplier),
741
+ };
742
+ }, _DataAPI_parseReservingFeeModel = function _DataAPI_parseReservingFeeModel(raw) {
743
+ const { fields } = raw.data.content;
744
+ return {
745
+ multiplier: (0, utils_2.parseValue)(fields.multiplier),
746
+ };
747
+ }, _DataAPI_parseFundingFeeModel = function _DataAPI_parseFundingFeeModel(raw) {
748
+ const { fields } = raw.data.content;
749
+ return {
750
+ multiplier: (0, utils_2.parseValue)(fields.multiplier),
751
+ max: (0, utils_2.parseValue)(fields.max),
752
+ };
753
+ }, _DataAPI_parsePositionConfig = function _DataAPI_parsePositionConfig(raw) {
754
+ const positionConfigFields = raw.data.content.fields.inner.fields;
755
+ return {
756
+ decreaseFeeBps: (0, utils_2.parseValue)(positionConfigFields.decrease_fee_bps),
757
+ liquidationBonus: (0, utils_2.parseValue)(positionConfigFields.liquidation_bonus),
758
+ liquidationThreshold: (0, utils_2.parseValue)(positionConfigFields.liquidation_threshold),
759
+ maxLeverage: (0, utils_2.parseValue)(positionConfigFields.max_leverage),
760
+ minHoldingDuration: (0, utils_2.parseValue)(positionConfigFields.min_holding_duration),
761
+ openFeeBps: (0, utils_2.parseValue)(positionConfigFields.open_fee_bps),
762
+ maxReservedMultiplier: (0, utils_2.parseValue)(positionConfigFields.max_reserved_multiplier),
763
+ minCollateralValue: (0, utils_2.parseValue)(positionConfigFields.min_collateral_value),
764
+ };
765
+ }, _DataAPI_parsePositionInfo = async function _DataAPI_parsePositionInfo(raw, id_) {
766
+ const { content } = raw.data;
767
+ const { fields } = content;
768
+ const positionFields = fields.value.fields;
769
+ const dataType = fields.name.type;
770
+ const positionInfo = {
771
+ id: id_,
772
+ long: dataType.includes('::market::LONG'),
773
+ owner: fields.name.fields.owner,
774
+ version: Number.parseInt(raw.data.version, 10),
775
+ collateralToken: (0, utils_2.suiSymbolToSymbol)(dataType.split('<')[1].split(',')[0].trim(), this.consts),
776
+ indexToken: (0, utils_2.suiSymbolToSymbol)(dataType.split(',')[1].trim(), this.consts),
777
+ collateralAmount: (0, utils_2.parseValue)(positionFields.collateral),
778
+ positionAmount: (0, utils_2.parseValue)(positionFields.position_amount),
779
+ reservedAmount: (0, utils_2.parseValue)(positionFields.reserved),
780
+ positionSize: (0, utils_2.parseValue)(positionFields.position_size),
781
+ lastFundingRate: (0, utils_2.parseValue)(positionFields.last_funding_rate),
782
+ lastReservingRate: (0, utils_2.parseValue)(positionFields.last_reserving_rate),
783
+ reservingFeeAmount: (0, utils_2.parseValue)(positionFields.reserving_fee_amount),
784
+ fundingFeeValue: (0, utils_2.parseValue)(positionFields.funding_fee_value),
785
+ closed: positionFields.closed,
786
+ openTimestamp: (0, utils_2.parseValue)(positionFields.open_timestamp),
787
+ };
788
+ positionInfo.reservingFeeAmount = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calculatePositionReserveFee).call(this, positionInfo, await this.getVaultInfo(positionInfo.collateralToken), (await this.getVaultInfo(positionInfo.collateralToken)).reservingFeeModel, Date.now() / 1000);
789
+ positionInfo.fundingFeeValue = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calculatePositionFundingFee).call(this, positionInfo, await this.getSymbolInfo(positionInfo.indexToken, positionInfo.long), (await this.getSymbolInfo(positionInfo.indexToken, positionInfo.long)).fundingFeeModel, (await this.getOraclePrice(positionInfo.indexToken)).getPriceUnchecked().getPriceAsNumberUnchecked(), (await this.getMarketInfo()).lpSupplyWithDecimals, Date.now() / 1000);
790
+ return positionInfo;
791
+ }, _DataAPI_parseOrderInfo = function _DataAPI_parseOrderInfo(raw, capId) {
792
+ const { content } = raw.data;
793
+ const { fields } = content.fields.value;
794
+ // Extract tokens from dataType
795
+ const dataType = content.type;
796
+ const orderType = content.fields.value.type.includes('OpenPositionOrder') ? 'OPEN_POSITION' : 'DECREASE_POSITION';
797
+ const ret = {
798
+ id: content.fields.id.id,
799
+ capId,
800
+ executed: fields.executed,
801
+ owner: content.fields.name.fields.owner,
802
+ collateralToken: (0, utils_2.suiSymbolToSymbol)(dataType.split('<')[2].split(',')[0].trim(), this.consts),
803
+ indexToken: (0, utils_2.suiSymbolToSymbol)(dataType.split(',')[1].trim(), this.consts),
804
+ feeToken: (0, utils_2.suiSymbolToSymbol)(dataType.split(',')[3].split('>')[0].trim(), this.consts),
805
+ indexPrice: (0, utils_2.parseValue)(fields.limited_index_price.fields.price || fields.limited_index_price),
806
+ collateralPriceThreshold: (0, utils_2.parseValue)(fields.collateral_price_threshold),
807
+ feeAmount: BigInt(fields.fee),
808
+ long: dataType.includes('::market::LONG'),
809
+ orderType,
810
+ createdAt: (0, utils_2.parseValue)(fields.created_at),
811
+ v11Order: !fields.limited_index_price.fields.price,
812
+ };
813
+ if (orderType === 'OPEN_POSITION') {
814
+ ret.openOrder = {
815
+ reserveAmount: BigInt(fields.reserve_amount),
816
+ collateralAmount: BigInt(fields.collateral),
817
+ openAmount: BigInt(fields.open_amount),
818
+ };
819
+ }
820
+ else {
821
+ ret.decreaseOrder = {
822
+ decreaseAmount: BigInt(fields.decrease_amount),
823
+ takeProfit: fields.take_profit,
824
+ };
825
+ }
826
+ return ret;
827
+ }, _DataAPI_calcRebaseFeeRate = function _DataAPI_calcRebaseFeeRate(model, increase, ratio, targetRatio) {
828
+ if ((increase && ratio <= targetRatio) || (!increase && ratio >= targetRatio)) {
829
+ return model.base;
830
+ }
831
+ return model.base + model.multiplier * Math.abs(ratio - targetRatio);
832
+ }, _DataAPI_calcReservingFeeRate = function _DataAPI_calcReservingFeeRate(model, utilization, elapsed) {
833
+ return model.multiplier * utilization * elapsed / consts_1.SECONDS_PER_EIGHT_HOUR;
834
+ }, _DataAPI_calcFundingFeeRate = function _DataAPI_calcFundingFeeRate(model, pnlPerRate, elapsed) {
835
+ const dailyRate = Math.min(model.multiplier * Math.abs(pnlPerRate), model.max);
836
+ const secondsRate = dailyRate * elapsed / consts_1.SECONDS_PER_EIGHT_HOUR;
837
+ return pnlPerRate >= 0 ? -secondsRate : secondsRate;
838
+ }, _DataAPI_vaultUtilization = function _DataAPI_vaultUtilization(vault) {
839
+ const supplyAmount = vault.liquidity + vault.reservedAmount + vault.unrealisedReservingFeeAmount;
840
+ if (supplyAmount === 0) {
841
+ return 0;
842
+ }
843
+ return vault.reservedAmount / supplyAmount;
844
+ }, _DataAPI_calcAccReservingFeeRate = function _DataAPI_calcAccReservingFeeRate(vault, model, timestamp) {
845
+ if (vault.lastUpdate > 0) {
846
+ const elapsed = timestamp - vault.lastUpdate;
847
+ if (elapsed > 0) {
848
+ const utilization = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_vaultUtilization).call(this, vault);
849
+ return vault.accReservingRate + __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcReservingFeeRate).call(this, model, utilization, elapsed);
850
+ }
851
+ }
852
+ return vault.accReservingRate;
853
+ }, _DataAPI_calcDeltaSize = function _DataAPI_calcDeltaSize(symbol, price) {
854
+ const latestSize = symbol.openingAmount / symbol.priceConfig.precision * price;
855
+ return symbol.long ? symbol.openingSize - latestSize : latestSize - symbol.openingSize;
856
+ }, _DataAPI_calcAccFundingFeeRate = function _DataAPI_calcAccFundingFeeRate(symbol, model, price, lpSupplyAmount, timestamp) {
857
+ if (symbol.lastUpdate > 0) {
858
+ const elapsed = timestamp - symbol.lastUpdate;
859
+ if (elapsed > 0) {
860
+ const deltaSize = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcDeltaSize).call(this, symbol, price);
861
+ const pnlPerLp = (symbol.realisedPnl + symbol.unrealisedFundingFeeValue + deltaSize) / lpSupplyAmount;
862
+ return symbol.accFundingRate + __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcFundingFeeRate).call(this, model, pnlPerLp, elapsed);
863
+ }
864
+ }
865
+ return symbol.accFundingRate;
866
+ }, _DataAPI_calculateSymbolFundingFee = function _DataAPI_calculateSymbolFundingFee(symbol, model, price, lpSupplyAmount, timestamp) {
867
+ const accFundingRate = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcAccFundingFeeRate).call(this, symbol, model, price, lpSupplyAmount, timestamp);
868
+ return symbol.unrealisedFundingFeeValue + (accFundingRate - symbol.accFundingRate) * symbol.openingSize;
869
+ }, _DataAPI_calculatePositionFundingFee = function _DataAPI_calculatePositionFundingFee(position, symbol, model, price, lpSupplyAmount, timestamp) {
870
+ const accFundingRate = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcAccFundingFeeRate).call(this, symbol, model, price, lpSupplyAmount, timestamp);
871
+ return position.fundingFeeValue + (accFundingRate - position.lastFundingRate) * position.positionSize;
872
+ }, _DataAPI_calculateVaultReservingFee = function _DataAPI_calculateVaultReservingFee(vault, model, timestamp) {
873
+ const accReservingRate = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcAccReservingFeeRate).call(this, vault, model, timestamp);
874
+ return vault.unrealisedReservingFeeAmount + (accReservingRate - vault.accReservingRate) * vault.reservedAmount;
875
+ }, _DataAPI_calculatePositionReserveFee = function _DataAPI_calculatePositionReserveFee(position, vault, model, timestamp) {
876
+ const accReservingRate = __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_calcAccReservingFeeRate).call(this, vault, model, timestamp);
877
+ return position.reservingFeeAmount + (accReservingRate - position.lastReservingRate) * position.collateralAmount;
878
+ }, _DataAPI_parseStakePool = function _DataAPI_parseStakePool(raw) {
879
+ const content = raw.data.content.fields;
880
+ const pool = {
881
+ id: content.id.id,
882
+ enabled: content.enabled,
883
+ lastUpdatedTime: (0, utils_2.parseValue)(content.last_updated_time),
884
+ stakedAmount: BigInt(content.staked_amount),
885
+ reward: BigInt(content.reward),
886
+ startTime: (0, utils_2.parseValue)(content.start_time),
887
+ endTime: (0, utils_2.parseValue)(content.end_time),
888
+ accRewardPerShare: BigInt(content.acc_reward_per_share),
889
+ lockDuration: (0, utils_2.parseValue)(content.lock_duration),
890
+ };
891
+ __classPrivateFieldGet(this, _DataAPI_instances, "m", _DataAPI_refreshPool).call(this, pool, Math.floor(Date.now() / 1000));
892
+ return pool;
893
+ }, _DataAPI_parseCredential = function _DataAPI_parseCredential(raw, pool) {
894
+ const stakedAmount = BigInt(raw.data.content.fields.stake);
895
+ const accRewardPerShare = BigInt(raw.data.content.fields.acc_reward_per_share);
896
+ return {
897
+ id: raw.data.objectId,
898
+ lockUntil: (0, utils_2.parseValue)(raw.data.content.fields.lock_until),
899
+ amount: stakedAmount,
900
+ accRewardPerShare,
901
+ claimable: ((pool.accRewardPerShare - accRewardPerShare) * stakedAmount) / BigInt(1e18),
902
+ };
903
+ }, _DataAPI_refreshPool = function _DataAPI_refreshPool(pool, timestamp) {
904
+ if (timestamp === pool.lastUpdatedTime || timestamp < pool.startTime) {
905
+ return;
906
+ }
907
+ if (pool.lastUpdatedTime === pool.endTime || pool.stakedAmount === BigInt(0)) {
908
+ return;
909
+ }
910
+ if (timestamp > pool.endTime) {
911
+ timestamp = pool.endTime;
912
+ }
913
+ const rewardAmount = pool.reward * BigInt(timestamp - pool.lastUpdatedTime)
914
+ / BigInt(pool.endTime - pool.lastUpdatedTime);
915
+ pool.lastUpdatedTime = timestamp;
916
+ const rewardPerShare = rewardAmount * BigInt(1e18) / pool.stakedAmount;
917
+ pool.accRewardPerShare += rewardPerShare;
918
+ };
919
+ //# sourceMappingURL=data.cjs.map