@lifi/perps-sdk 0.1.1-alpha.8 → 0.2.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (748) hide show
  1. package/README.md +38 -15
  2. package/dist/cjs/agent/AgentManager.d.ts +5 -5
  3. package/dist/cjs/agent/AgentManager.d.ts.map +1 -1
  4. package/dist/cjs/agent/AgentManager.js +16 -14
  5. package/dist/cjs/agent/AgentManager.js.map +1 -1
  6. package/dist/cjs/client/PerpsClient.d.ts +75 -21
  7. package/dist/cjs/client/PerpsClient.d.ts.map +1 -1
  8. package/dist/cjs/client/PerpsClient.js +642 -173
  9. package/dist/cjs/client/PerpsClient.js.map +1 -1
  10. package/dist/cjs/client/createPerpsClient.d.ts +15 -2
  11. package/dist/cjs/client/createPerpsClient.d.ts.map +1 -1
  12. package/dist/cjs/client/createPerpsClient.js +6 -3
  13. package/dist/cjs/client/createPerpsClient.js.map +1 -1
  14. package/dist/cjs/client/projectAccountConfigSettings.d.ts +3 -0
  15. package/dist/cjs/client/projectAccountConfigSettings.d.ts.map +1 -0
  16. package/dist/cjs/client/projectAccountConfigSettings.js +17 -0
  17. package/dist/cjs/client/projectAccountConfigSettings.js.map +1 -0
  18. package/dist/cjs/client/types.d.ts +49 -26
  19. package/dist/cjs/client/types.d.ts.map +1 -1
  20. package/dist/cjs/client/types.js +6 -0
  21. package/dist/cjs/client/types.js.map +1 -1
  22. package/dist/cjs/errors/PerpsError.d.ts +2 -3
  23. package/dist/cjs/errors/PerpsError.d.ts.map +1 -1
  24. package/dist/cjs/errors/PerpsError.js +3 -15
  25. package/dist/cjs/errors/PerpsError.js.map +1 -1
  26. package/dist/cjs/errors/constants.d.ts +0 -10
  27. package/dist/cjs/errors/constants.d.ts.map +1 -1
  28. package/dist/cjs/errors/constants.js +1 -12
  29. package/dist/cjs/errors/constants.js.map +1 -1
  30. package/dist/cjs/index.d.ts +37 -31
  31. package/dist/cjs/index.d.ts.map +1 -1
  32. package/dist/cjs/index.js +87 -42
  33. package/dist/cjs/index.js.map +1 -1
  34. package/dist/cjs/providers/hyperliquid/accountConfig.d.ts +3 -0
  35. package/dist/cjs/providers/hyperliquid/accountConfig.d.ts.map +1 -0
  36. package/dist/cjs/providers/hyperliquid/accountConfig.js +41 -0
  37. package/dist/cjs/providers/hyperliquid/accountConfig.js.map +1 -0
  38. package/dist/cjs/providers/lighter/accountConfig.d.ts +3 -0
  39. package/dist/cjs/providers/lighter/accountConfig.d.ts.map +1 -0
  40. package/dist/cjs/providers/lighter/accountConfig.js +45 -0
  41. package/dist/cjs/providers/lighter/accountConfig.js.map +1 -0
  42. package/dist/cjs/realtime/PerpsWsClient.d.ts +7 -1
  43. package/dist/cjs/realtime/PerpsWsClient.d.ts.map +1 -1
  44. package/dist/cjs/realtime/PerpsWsClient.js +36 -23
  45. package/dist/cjs/realtime/PerpsWsClient.js.map +1 -1
  46. package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.d.ts +9 -5
  47. package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
  48. package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.js +158 -52
  49. package/dist/cjs/realtime/hyperliquid/HyperliquidWsProvider.js.map +1 -1
  50. package/dist/cjs/realtime/hyperliquid/types.d.ts +11 -9
  51. package/dist/cjs/realtime/hyperliquid/types.d.ts.map +1 -1
  52. package/dist/cjs/realtime/lighter/LighterWsProvider.d.ts +48 -0
  53. package/dist/cjs/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
  54. package/dist/cjs/realtime/lighter/LighterWsProvider.js +424 -0
  55. package/dist/cjs/realtime/lighter/LighterWsProvider.js.map +1 -0
  56. package/dist/cjs/realtime/lighter/types.d.ts +84 -0
  57. package/dist/cjs/realtime/lighter/types.d.ts.map +1 -0
  58. package/dist/cjs/{dex → realtime/lighter}/types.js.map +1 -1
  59. package/dist/cjs/services/createAction.d.ts +11 -0
  60. package/dist/cjs/services/createAction.d.ts.map +1 -0
  61. package/dist/cjs/services/{submitAuthorization.js → createAction.js} +7 -6
  62. package/dist/cjs/services/createAction.js.map +1 -0
  63. package/dist/cjs/services/executeAction.d.ts +11 -0
  64. package/dist/cjs/services/executeAction.d.ts.map +1 -0
  65. package/dist/cjs/services/{submitOrder.js → executeAction.js} +6 -5
  66. package/dist/cjs/services/executeAction.js.map +1 -0
  67. package/dist/cjs/services/getAccount.d.ts +1 -1
  68. package/dist/cjs/services/getAccount.d.ts.map +1 -1
  69. package/dist/cjs/services/getAccount.js +1 -1
  70. package/dist/cjs/services/getAccount.js.map +1 -1
  71. package/dist/cjs/services/getActivity.d.ts +13 -0
  72. package/dist/cjs/services/getActivity.d.ts.map +1 -0
  73. package/dist/cjs/services/getActivity.js +21 -0
  74. package/dist/cjs/services/getActivity.js.map +1 -0
  75. package/dist/cjs/services/getAsset.d.ts +8 -0
  76. package/dist/cjs/services/getAsset.d.ts.map +1 -0
  77. package/dist/cjs/services/{getMarkets.js → getAsset.js} +6 -4
  78. package/dist/cjs/services/getAsset.js.map +1 -0
  79. package/dist/cjs/services/getAssets.d.ts +7 -0
  80. package/dist/cjs/services/getAssets.d.ts.map +1 -0
  81. package/dist/cjs/services/{getMarket.js → getAssets.js} +5 -5
  82. package/dist/cjs/services/getAssets.js.map +1 -0
  83. package/dist/cjs/services/getFills.d.ts +12 -0
  84. package/dist/cjs/services/getFills.d.ts.map +1 -0
  85. package/dist/cjs/services/{getHistory.js → getFills.js} +7 -5
  86. package/dist/cjs/services/getFills.js.map +1 -0
  87. package/dist/cjs/services/getOhlcv.d.ts +1 -1
  88. package/dist/cjs/services/getOhlcv.d.ts.map +1 -1
  89. package/dist/cjs/services/getOhlcv.js +2 -2
  90. package/dist/cjs/services/getOhlcv.js.map +1 -1
  91. package/dist/cjs/services/getOrder.d.ts +1 -1
  92. package/dist/cjs/services/getOrder.d.ts.map +1 -1
  93. package/dist/cjs/services/getOrder.js +2 -2
  94. package/dist/cjs/services/getOrder.js.map +1 -1
  95. package/dist/cjs/services/getOrderbook.d.ts +1 -1
  96. package/dist/cjs/services/getOrderbook.d.ts.map +1 -1
  97. package/dist/cjs/services/getOrderbook.js +2 -2
  98. package/dist/cjs/services/getOrderbook.js.map +1 -1
  99. package/dist/cjs/services/getOrders.d.ts +11 -0
  100. package/dist/cjs/services/getOrders.d.ts.map +1 -0
  101. package/dist/cjs/services/getOrders.js +15 -0
  102. package/dist/cjs/services/getOrders.js.map +1 -0
  103. package/dist/cjs/services/getPositions.d.ts +11 -0
  104. package/dist/cjs/services/getPositions.d.ts.map +1 -0
  105. package/dist/cjs/services/getPositions.js +15 -0
  106. package/dist/cjs/services/getPositions.js.map +1 -0
  107. package/dist/cjs/services/getPrices.d.ts +1 -1
  108. package/dist/cjs/services/getPrices.d.ts.map +1 -1
  109. package/dist/cjs/services/getPrices.js +1 -1
  110. package/dist/cjs/services/getPrices.js.map +1 -1
  111. package/dist/cjs/services/getProviders.d.ts +4 -0
  112. package/dist/cjs/services/getProviders.d.ts.map +1 -0
  113. package/dist/cjs/services/{getDexes.js → getProviders.js} +4 -4
  114. package/dist/cjs/services/getProviders.js.map +1 -0
  115. package/dist/cjs/signers/lighter/LighterKeyStore.d.ts +20 -0
  116. package/dist/cjs/signers/lighter/LighterKeyStore.d.ts.map +1 -0
  117. package/dist/cjs/signers/lighter/LighterKeyStore.js +42 -0
  118. package/dist/cjs/signers/lighter/LighterKeyStore.js.map +1 -0
  119. package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.d.ts +66 -0
  120. package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
  121. package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.js +141 -0
  122. package/dist/cjs/signers/lighter/LighterReadOnlyTokenManager.js.map +1 -0
  123. package/dist/cjs/signers/lighter/LighterSigner.d.ts +41 -0
  124. package/dist/cjs/signers/lighter/LighterSigner.d.ts.map +1 -0
  125. package/dist/cjs/signers/lighter/LighterSigner.js +176 -0
  126. package/dist/cjs/signers/lighter/LighterSigner.js.map +1 -0
  127. package/dist/cjs/signers/lighter/index.d.ts +9 -0
  128. package/dist/cjs/signers/lighter/index.d.ts.map +1 -0
  129. package/dist/cjs/signers/lighter/index.js +20 -0
  130. package/dist/cjs/signers/lighter/index.js.map +1 -0
  131. package/dist/cjs/signers/lighter/wasmLoader.d.ts +42 -0
  132. package/dist/cjs/signers/lighter/wasmLoader.d.ts.map +1 -0
  133. package/dist/cjs/signers/lighter/wasmLoader.js +166 -0
  134. package/dist/cjs/signers/lighter/wasmLoader.js.map +1 -0
  135. package/dist/cjs/utils/accountSummary.d.ts +9 -0
  136. package/dist/cjs/utils/accountSummary.d.ts.map +1 -0
  137. package/dist/cjs/utils/accountSummary.js +83 -0
  138. package/dist/cjs/utils/accountSummary.js.map +1 -0
  139. package/dist/cjs/utils/assertNever.d.ts +2 -0
  140. package/dist/cjs/utils/assertNever.d.ts.map +1 -0
  141. package/dist/cjs/utils/assertNever.js +7 -0
  142. package/dist/cjs/utils/assertNever.js.map +1 -0
  143. package/dist/cjs/utils/calculations.d.ts +16 -0
  144. package/dist/cjs/utils/calculations.d.ts.map +1 -0
  145. package/dist/cjs/utils/calculations.js +71 -0
  146. package/dist/cjs/utils/calculations.js.map +1 -0
  147. package/dist/cjs/utils/hyperliquid/index.d.ts +3 -0
  148. package/dist/cjs/utils/hyperliquid/index.d.ts.map +1 -0
  149. package/dist/cjs/utils/hyperliquid/index.js +11 -0
  150. package/dist/cjs/utils/hyperliquid/index.js.map +1 -0
  151. package/dist/cjs/utils/hyperliquid/liquidation.d.ts +3 -0
  152. package/dist/cjs/utils/hyperliquid/liquidation.d.ts.map +1 -0
  153. package/dist/cjs/utils/hyperliquid/liquidation.js +24 -0
  154. package/dist/cjs/utils/hyperliquid/liquidation.js.map +1 -0
  155. package/dist/cjs/utils/hyperliquid/orderFormatting.d.ts +4 -0
  156. package/dist/cjs/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
  157. package/dist/cjs/utils/hyperliquid/orderFormatting.js +33 -0
  158. package/dist/cjs/utils/hyperliquid/orderFormatting.js.map +1 -0
  159. package/dist/cjs/utils/orderClassification.d.ts +8 -0
  160. package/dist/cjs/utils/orderClassification.d.ts.map +1 -0
  161. package/dist/cjs/utils/orderClassification.js +39 -0
  162. package/dist/cjs/utils/orderClassification.js.map +1 -0
  163. package/dist/cjs/utils/orderMath.d.ts +6 -0
  164. package/dist/cjs/utils/orderMath.d.ts.map +1 -0
  165. package/dist/cjs/utils/orderMath.js +71 -0
  166. package/dist/cjs/utils/orderMath.js.map +1 -0
  167. package/dist/cjs/utils/parse.d.ts +2 -0
  168. package/dist/cjs/utils/parse.d.ts.map +1 -0
  169. package/dist/cjs/utils/parse.js +14 -0
  170. package/dist/cjs/utils/parse.js.map +1 -0
  171. package/dist/cjs/utils/positionMath.d.ts +26 -0
  172. package/dist/cjs/utils/positionMath.d.ts.map +1 -0
  173. package/dist/cjs/utils/positionMath.js +38 -0
  174. package/dist/cjs/utils/positionMath.js.map +1 -0
  175. package/dist/cjs/utils/request.d.ts.map +1 -1
  176. package/dist/cjs/utils/request.js +19 -4
  177. package/dist/cjs/utils/request.js.map +1 -1
  178. package/dist/cjs/utils/signTypedData.d.ts +2 -0
  179. package/dist/cjs/utils/signTypedData.d.ts.map +1 -1
  180. package/dist/cjs/utils/signTypedData.js +10 -3
  181. package/dist/cjs/utils/signTypedData.js.map +1 -1
  182. package/dist/cjs/utils/units.d.ts +3 -0
  183. package/dist/cjs/utils/units.d.ts.map +1 -0
  184. package/dist/cjs/utils/units.js +18 -0
  185. package/dist/cjs/utils/units.js.map +1 -0
  186. package/dist/cjs/utils/validation.d.ts +2 -0
  187. package/dist/cjs/utils/validation.d.ts.map +1 -0
  188. package/dist/cjs/utils/validation.js +16 -0
  189. package/dist/cjs/utils/validation.js.map +1 -0
  190. package/dist/cjs/version.d.ts +1 -1
  191. package/dist/cjs/version.js +1 -1
  192. package/dist/cjs/wasm/lighter-signer.wasm +0 -0
  193. package/dist/cjs/wasm/wasm_exec.js +575 -0
  194. package/dist/esm/agent/AgentManager.d.ts +9 -9
  195. package/dist/esm/agent/AgentManager.d.ts.map +1 -1
  196. package/dist/esm/agent/AgentManager.js +20 -18
  197. package/dist/esm/agent/AgentManager.js.map +1 -1
  198. package/dist/esm/agent/storage.d.ts +1 -1
  199. package/dist/esm/agent/storage.js +1 -1
  200. package/dist/esm/client/PerpsClient.d.ts +226 -144
  201. package/dist/esm/client/PerpsClient.d.ts.map +1 -1
  202. package/dist/esm/client/PerpsClient.js +869 -320
  203. package/dist/esm/client/PerpsClient.js.map +1 -1
  204. package/dist/esm/client/createPerpsClient.d.ts +30 -51
  205. package/dist/esm/client/createPerpsClient.d.ts.map +1 -1
  206. package/dist/esm/client/createPerpsClient.js +6 -21
  207. package/dist/esm/client/createPerpsClient.js.map +1 -1
  208. package/dist/esm/client/projectAccountConfigSettings.d.ts +18 -0
  209. package/dist/esm/client/projectAccountConfigSettings.d.ts.map +1 -0
  210. package/dist/esm/client/projectAccountConfigSettings.js +29 -0
  211. package/dist/esm/client/projectAccountConfigSettings.js.map +1 -0
  212. package/dist/esm/client/types.d.ts +115 -49
  213. package/dist/esm/client/types.d.ts.map +1 -1
  214. package/dist/esm/client/types.js +11 -1
  215. package/dist/esm/client/types.js.map +1 -1
  216. package/dist/esm/errors/PerpsError.d.ts +2 -3
  217. package/dist/esm/errors/PerpsError.d.ts.map +1 -1
  218. package/dist/esm/errors/PerpsError.js +3 -15
  219. package/dist/esm/errors/PerpsError.js.map +1 -1
  220. package/dist/esm/errors/constants.d.ts +0 -10
  221. package/dist/esm/errors/constants.d.ts.map +1 -1
  222. package/dist/esm/errors/constants.js +0 -11
  223. package/dist/esm/errors/constants.js.map +1 -1
  224. package/dist/esm/index.d.ts +37 -31
  225. package/dist/esm/index.d.ts.map +1 -1
  226. package/dist/esm/index.js +27 -22
  227. package/dist/esm/index.js.map +1 -1
  228. package/dist/esm/providers/hyperliquid/accountConfig.d.ts +13 -0
  229. package/dist/esm/providers/hyperliquid/accountConfig.d.ts.map +1 -0
  230. package/dist/esm/providers/hyperliquid/accountConfig.js +69 -0
  231. package/dist/esm/providers/hyperliquid/accountConfig.js.map +1 -0
  232. package/dist/esm/providers/lighter/accountConfig.d.ts +13 -0
  233. package/dist/esm/providers/lighter/accountConfig.d.ts.map +1 -0
  234. package/dist/esm/providers/lighter/accountConfig.js +79 -0
  235. package/dist/esm/providers/lighter/accountConfig.js.map +1 -0
  236. package/dist/esm/realtime/PerpsWsClient.d.ts +13 -1
  237. package/dist/esm/realtime/PerpsWsClient.d.ts.map +1 -1
  238. package/dist/esm/realtime/PerpsWsClient.js +36 -23
  239. package/dist/esm/realtime/PerpsWsClient.js.map +1 -1
  240. package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.d.ts +11 -5
  241. package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
  242. package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.js +170 -53
  243. package/dist/esm/realtime/hyperliquid/HyperliquidWsProvider.js.map +1 -1
  244. package/dist/esm/realtime/hyperliquid/types.d.ts +11 -9
  245. package/dist/esm/realtime/hyperliquid/types.d.ts.map +1 -1
  246. package/dist/esm/realtime/lighter/LighterWsProvider.d.ts +68 -0
  247. package/dist/esm/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
  248. package/dist/esm/realtime/lighter/LighterWsProvider.js +474 -0
  249. package/dist/esm/realtime/lighter/LighterWsProvider.js.map +1 -0
  250. package/dist/esm/realtime/lighter/types.d.ts +108 -0
  251. package/dist/esm/realtime/lighter/types.d.ts.map +1 -0
  252. package/dist/esm/realtime/lighter/types.js +14 -0
  253. package/dist/esm/realtime/lighter/types.js.map +1 -0
  254. package/dist/esm/services/createAction.d.ts +11 -0
  255. package/dist/esm/services/createAction.d.ts.map +1 -0
  256. package/dist/esm/services/createAction.js +14 -0
  257. package/dist/esm/services/createAction.js.map +1 -0
  258. package/dist/esm/services/executeAction.d.ts +11 -0
  259. package/dist/esm/services/executeAction.d.ts.map +1 -0
  260. package/dist/esm/services/executeAction.js +14 -0
  261. package/dist/esm/services/executeAction.js.map +1 -0
  262. package/dist/esm/services/getAccount.d.ts +7 -7
  263. package/dist/esm/services/getAccount.d.ts.map +1 -1
  264. package/dist/esm/services/getAccount.js +6 -6
  265. package/dist/esm/services/getAccount.js.map +1 -1
  266. package/dist/esm/services/getActivity.d.ts +49 -0
  267. package/dist/esm/services/getActivity.d.ts.map +1 -0
  268. package/dist/esm/services/getActivity.js +47 -0
  269. package/dist/esm/services/getActivity.js.map +1 -0
  270. package/dist/esm/services/getAsset.d.ts +20 -0
  271. package/dist/esm/services/getAsset.d.ts.map +1 -0
  272. package/dist/esm/services/getAsset.js +18 -0
  273. package/dist/esm/services/getAsset.js.map +1 -0
  274. package/dist/esm/services/getAssets.d.ts +18 -0
  275. package/dist/esm/services/getAssets.d.ts.map +1 -0
  276. package/dist/esm/services/getAssets.js +18 -0
  277. package/dist/esm/services/getAssets.js.map +1 -0
  278. package/dist/{types/services/getHistory.d.ts → esm/services/getFills.d.ts} +17 -13
  279. package/dist/esm/services/getFills.d.ts.map +1 -0
  280. package/dist/esm/services/{getHistory.js → getFills.js} +13 -11
  281. package/dist/esm/services/getFills.js.map +1 -0
  282. package/dist/esm/services/getOhlcv.d.ts +4 -4
  283. package/dist/esm/services/getOhlcv.d.ts.map +1 -1
  284. package/dist/esm/services/getOhlcv.js +4 -4
  285. package/dist/esm/services/getOhlcv.js.map +1 -1
  286. package/dist/esm/services/getOrder.d.ts +4 -4
  287. package/dist/esm/services/getOrder.d.ts.map +1 -1
  288. package/dist/esm/services/getOrder.js +4 -4
  289. package/dist/esm/services/getOrder.js.map +1 -1
  290. package/dist/esm/services/getOrderbook.d.ts +4 -4
  291. package/dist/esm/services/getOrderbook.d.ts.map +1 -1
  292. package/dist/esm/services/getOrderbook.js +4 -4
  293. package/dist/esm/services/getOrderbook.js.map +1 -1
  294. package/dist/esm/services/getOrders.d.ts +27 -0
  295. package/dist/esm/services/getOrders.d.ts.map +1 -0
  296. package/dist/esm/services/getOrders.js +23 -0
  297. package/dist/esm/services/getOrders.js.map +1 -0
  298. package/dist/esm/services/getPositions.d.ts +27 -0
  299. package/dist/esm/services/getPositions.d.ts.map +1 -0
  300. package/dist/esm/services/getPositions.js +23 -0
  301. package/dist/esm/services/getPositions.js.map +1 -0
  302. package/dist/esm/services/getPrices.d.ts +5 -5
  303. package/dist/esm/services/getPrices.d.ts.map +1 -1
  304. package/dist/esm/services/getPrices.js +4 -4
  305. package/dist/esm/services/getPrices.js.map +1 -1
  306. package/dist/esm/services/getProviders.d.ts +20 -0
  307. package/dist/esm/services/getProviders.d.ts.map +1 -0
  308. package/dist/esm/services/getProviders.js +21 -0
  309. package/dist/esm/services/getProviders.js.map +1 -0
  310. package/dist/esm/signers/lighter/LighterKeyStore.d.ts +29 -0
  311. package/dist/esm/signers/lighter/LighterKeyStore.d.ts.map +1 -0
  312. package/dist/esm/signers/lighter/LighterKeyStore.js +53 -0
  313. package/dist/esm/signers/lighter/LighterKeyStore.js.map +1 -0
  314. package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.d.ts +174 -0
  315. package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
  316. package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.js +214 -0
  317. package/dist/esm/signers/lighter/LighterReadOnlyTokenManager.js.map +1 -0
  318. package/dist/esm/signers/lighter/LighterSigner.d.ts +88 -0
  319. package/dist/esm/signers/lighter/LighterSigner.d.ts.map +1 -0
  320. package/dist/esm/signers/lighter/LighterSigner.js +226 -0
  321. package/dist/esm/signers/lighter/LighterSigner.js.map +1 -0
  322. package/dist/esm/signers/lighter/index.d.ts +9 -0
  323. package/dist/esm/signers/lighter/index.d.ts.map +1 -0
  324. package/dist/esm/signers/lighter/index.js +5 -0
  325. package/dist/esm/signers/lighter/index.js.map +1 -0
  326. package/dist/esm/signers/lighter/wasmLoader.d.ts +71 -0
  327. package/dist/esm/signers/lighter/wasmLoader.d.ts.map +1 -0
  328. package/dist/esm/signers/lighter/wasmLoader.js +181 -0
  329. package/dist/esm/signers/lighter/wasmLoader.js.map +1 -0
  330. package/dist/esm/utils/accountSummary.d.ts +13 -0
  331. package/dist/esm/utils/accountSummary.d.ts.map +1 -0
  332. package/dist/esm/utils/accountSummary.js +97 -0
  333. package/dist/esm/utils/accountSummary.js.map +1 -0
  334. package/dist/esm/utils/assertNever.d.ts +19 -0
  335. package/dist/esm/utils/assertNever.d.ts.map +1 -0
  336. package/dist/esm/utils/assertNever.js +21 -0
  337. package/dist/esm/utils/assertNever.js.map +1 -0
  338. package/dist/esm/utils/calculations.d.ts +109 -0
  339. package/dist/esm/utils/calculations.d.ts.map +1 -0
  340. package/dist/esm/utils/calculations.js +154 -0
  341. package/dist/esm/utils/calculations.js.map +1 -0
  342. package/dist/esm/utils/hyperliquid/index.d.ts +3 -0
  343. package/dist/esm/utils/hyperliquid/index.d.ts.map +1 -0
  344. package/dist/esm/utils/hyperliquid/index.js +3 -0
  345. package/dist/esm/utils/hyperliquid/index.js.map +1 -0
  346. package/dist/esm/utils/hyperliquid/liquidation.d.ts +46 -0
  347. package/dist/esm/utils/hyperliquid/liquidation.d.ts.map +1 -0
  348. package/dist/esm/utils/hyperliquid/liquidation.js +63 -0
  349. package/dist/esm/utils/hyperliquid/liquidation.js.map +1 -0
  350. package/dist/esm/utils/hyperliquid/orderFormatting.d.ts +44 -0
  351. package/dist/esm/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
  352. package/dist/esm/utils/hyperliquid/orderFormatting.js +79 -0
  353. package/dist/esm/utils/hyperliquid/orderFormatting.js.map +1 -0
  354. package/dist/esm/utils/orderClassification.d.ts +29 -0
  355. package/dist/esm/utils/orderClassification.d.ts.map +1 -0
  356. package/dist/esm/utils/orderClassification.js +53 -0
  357. package/dist/esm/utils/orderClassification.js.map +1 -0
  358. package/dist/esm/utils/orderMath.d.ts +40 -0
  359. package/dist/esm/utils/orderMath.d.ts.map +1 -0
  360. package/dist/esm/utils/orderMath.js +99 -0
  361. package/dist/esm/utils/orderMath.js.map +1 -0
  362. package/dist/esm/utils/parse.d.ts +18 -0
  363. package/dist/esm/utils/parse.d.ts.map +1 -0
  364. package/dist/esm/utils/parse.js +28 -0
  365. package/dist/esm/utils/parse.js.map +1 -0
  366. package/dist/esm/utils/positionMath.d.ts +78 -0
  367. package/dist/esm/utils/positionMath.d.ts.map +1 -0
  368. package/dist/esm/utils/positionMath.js +83 -0
  369. package/dist/esm/utils/positionMath.js.map +1 -0
  370. package/dist/esm/utils/request.d.ts +1 -2
  371. package/dist/esm/utils/request.d.ts.map +1 -1
  372. package/dist/esm/utils/request.js +23 -7
  373. package/dist/esm/utils/request.js.map +1 -1
  374. package/dist/esm/utils/signTypedData.d.ts +8 -10
  375. package/dist/esm/utils/signTypedData.d.ts.map +1 -1
  376. package/dist/esm/utils/signTypedData.js +15 -14
  377. package/dist/esm/utils/signTypedData.js.map +1 -1
  378. package/dist/esm/utils/units.d.ts +20 -0
  379. package/dist/esm/utils/units.d.ts.map +1 -0
  380. package/dist/esm/utils/units.js +31 -0
  381. package/dist/esm/utils/units.js.map +1 -0
  382. package/dist/esm/utils/validation.d.ts +15 -0
  383. package/dist/esm/utils/validation.d.ts.map +1 -0
  384. package/dist/esm/utils/validation.js +26 -0
  385. package/dist/esm/utils/validation.js.map +1 -0
  386. package/dist/esm/version.d.ts +1 -1
  387. package/dist/esm/version.js +1 -1
  388. package/dist/esm/wasm/lighter-signer.wasm +0 -0
  389. package/dist/esm/wasm/wasm_exec.js +575 -0
  390. package/dist/types/agent/AgentManager.d.ts +9 -9
  391. package/dist/types/agent/AgentManager.d.ts.map +1 -1
  392. package/dist/types/agent/storage.d.ts +1 -1
  393. package/dist/types/client/PerpsClient.d.ts +226 -144
  394. package/dist/types/client/PerpsClient.d.ts.map +1 -1
  395. package/dist/types/client/createPerpsClient.d.ts +30 -51
  396. package/dist/types/client/createPerpsClient.d.ts.map +1 -1
  397. package/dist/types/client/projectAccountConfigSettings.d.ts +18 -0
  398. package/dist/types/client/projectAccountConfigSettings.d.ts.map +1 -0
  399. package/dist/types/client/types.d.ts +115 -49
  400. package/dist/types/client/types.d.ts.map +1 -1
  401. package/dist/types/errors/PerpsError.d.ts +2 -3
  402. package/dist/types/errors/PerpsError.d.ts.map +1 -1
  403. package/dist/types/errors/constants.d.ts +0 -10
  404. package/dist/types/errors/constants.d.ts.map +1 -1
  405. package/dist/types/index.d.ts +37 -31
  406. package/dist/types/index.d.ts.map +1 -1
  407. package/dist/types/providers/hyperliquid/accountConfig.d.ts +13 -0
  408. package/dist/types/providers/hyperliquid/accountConfig.d.ts.map +1 -0
  409. package/dist/types/providers/lighter/accountConfig.d.ts +13 -0
  410. package/dist/types/providers/lighter/accountConfig.d.ts.map +1 -0
  411. package/dist/types/realtime/PerpsWsClient.d.ts +13 -1
  412. package/dist/types/realtime/PerpsWsClient.d.ts.map +1 -1
  413. package/dist/types/realtime/hyperliquid/HyperliquidWsProvider.d.ts +11 -5
  414. package/dist/types/realtime/hyperliquid/HyperliquidWsProvider.d.ts.map +1 -1
  415. package/dist/types/realtime/hyperliquid/types.d.ts +11 -9
  416. package/dist/types/realtime/hyperliquid/types.d.ts.map +1 -1
  417. package/dist/types/realtime/lighter/LighterWsProvider.d.ts +68 -0
  418. package/dist/types/realtime/lighter/LighterWsProvider.d.ts.map +1 -0
  419. package/dist/types/realtime/lighter/types.d.ts +108 -0
  420. package/dist/types/realtime/lighter/types.d.ts.map +1 -0
  421. package/dist/types/services/createAction.d.ts +11 -0
  422. package/dist/types/services/createAction.d.ts.map +1 -0
  423. package/dist/types/services/executeAction.d.ts +11 -0
  424. package/dist/types/services/executeAction.d.ts.map +1 -0
  425. package/dist/types/services/getAccount.d.ts +7 -7
  426. package/dist/types/services/getAccount.d.ts.map +1 -1
  427. package/dist/types/services/getActivity.d.ts +49 -0
  428. package/dist/types/services/getActivity.d.ts.map +1 -0
  429. package/dist/types/services/getAsset.d.ts +20 -0
  430. package/dist/types/services/getAsset.d.ts.map +1 -0
  431. package/dist/types/services/getAssets.d.ts +18 -0
  432. package/dist/types/services/getAssets.d.ts.map +1 -0
  433. package/dist/{esm/services/getHistory.d.ts → types/services/getFills.d.ts} +17 -13
  434. package/dist/types/services/getFills.d.ts.map +1 -0
  435. package/dist/types/services/getOhlcv.d.ts +4 -4
  436. package/dist/types/services/getOhlcv.d.ts.map +1 -1
  437. package/dist/types/services/getOrder.d.ts +4 -4
  438. package/dist/types/services/getOrder.d.ts.map +1 -1
  439. package/dist/types/services/getOrderbook.d.ts +4 -4
  440. package/dist/types/services/getOrderbook.d.ts.map +1 -1
  441. package/dist/types/services/getOrders.d.ts +27 -0
  442. package/dist/types/services/getOrders.d.ts.map +1 -0
  443. package/dist/types/services/getPositions.d.ts +27 -0
  444. package/dist/types/services/getPositions.d.ts.map +1 -0
  445. package/dist/types/services/getPrices.d.ts +5 -5
  446. package/dist/types/services/getPrices.d.ts.map +1 -1
  447. package/dist/types/services/getProviders.d.ts +20 -0
  448. package/dist/types/services/getProviders.d.ts.map +1 -0
  449. package/dist/types/signers/lighter/LighterKeyStore.d.ts +29 -0
  450. package/dist/types/signers/lighter/LighterKeyStore.d.ts.map +1 -0
  451. package/dist/types/signers/lighter/LighterReadOnlyTokenManager.d.ts +174 -0
  452. package/dist/types/signers/lighter/LighterReadOnlyTokenManager.d.ts.map +1 -0
  453. package/dist/types/signers/lighter/LighterSigner.d.ts +88 -0
  454. package/dist/types/signers/lighter/LighterSigner.d.ts.map +1 -0
  455. package/dist/types/signers/lighter/index.d.ts +9 -0
  456. package/dist/types/signers/lighter/index.d.ts.map +1 -0
  457. package/dist/types/signers/lighter/wasmLoader.d.ts +71 -0
  458. package/dist/types/signers/lighter/wasmLoader.d.ts.map +1 -0
  459. package/dist/types/utils/accountSummary.d.ts +13 -0
  460. package/dist/types/utils/accountSummary.d.ts.map +1 -0
  461. package/dist/types/utils/assertNever.d.ts +19 -0
  462. package/dist/types/utils/assertNever.d.ts.map +1 -0
  463. package/dist/types/utils/calculations.d.ts +109 -0
  464. package/dist/types/utils/calculations.d.ts.map +1 -0
  465. package/dist/types/utils/hyperliquid/index.d.ts +3 -0
  466. package/dist/types/utils/hyperliquid/index.d.ts.map +1 -0
  467. package/dist/types/utils/hyperliquid/liquidation.d.ts +46 -0
  468. package/dist/types/utils/hyperliquid/liquidation.d.ts.map +1 -0
  469. package/dist/types/utils/hyperliquid/orderFormatting.d.ts +44 -0
  470. package/dist/types/utils/hyperliquid/orderFormatting.d.ts.map +1 -0
  471. package/dist/types/utils/orderClassification.d.ts +29 -0
  472. package/dist/types/utils/orderClassification.d.ts.map +1 -0
  473. package/dist/types/utils/orderMath.d.ts +40 -0
  474. package/dist/types/utils/orderMath.d.ts.map +1 -0
  475. package/dist/types/utils/parse.d.ts +18 -0
  476. package/dist/types/utils/parse.d.ts.map +1 -0
  477. package/dist/types/utils/positionMath.d.ts +78 -0
  478. package/dist/types/utils/positionMath.d.ts.map +1 -0
  479. package/dist/types/utils/request.d.ts +1 -2
  480. package/dist/types/utils/request.d.ts.map +1 -1
  481. package/dist/types/utils/signTypedData.d.ts +8 -10
  482. package/dist/types/utils/signTypedData.d.ts.map +1 -1
  483. package/dist/types/utils/units.d.ts +20 -0
  484. package/dist/types/utils/units.d.ts.map +1 -0
  485. package/dist/types/utils/validation.d.ts +15 -0
  486. package/dist/types/utils/validation.d.ts.map +1 -0
  487. package/dist/types/version.d.ts +1 -1
  488. package/package.json +16 -8
  489. package/src/agent/AgentManager.ts +21 -19
  490. package/src/agent/storage.ts +1 -1
  491. package/src/client/PerpsClient.ts +1221 -396
  492. package/src/client/createPerpsClient.ts +39 -54
  493. package/src/client/projectAccountConfigSettings.ts +39 -0
  494. package/src/client/types.ts +130 -52
  495. package/src/errors/PerpsError.ts +3 -22
  496. package/src/errors/constants.ts +0 -11
  497. package/src/index.ts +115 -47
  498. package/src/providers/hyperliquid/accountConfig.ts +92 -0
  499. package/src/providers/lighter/accountConfig.ts +103 -0
  500. package/src/realtime/PerpsWsClient.ts +67 -32
  501. package/src/realtime/hyperliquid/HyperliquidWsProvider.ts +199 -64
  502. package/src/realtime/hyperliquid/types.ts +8 -10
  503. package/src/realtime/lighter/LighterWsProvider.ts +682 -0
  504. package/src/realtime/lighter/types.ts +121 -0
  505. package/src/services/createAction.ts +41 -0
  506. package/src/services/executeAction.ts +41 -0
  507. package/src/services/getAccount.ts +8 -8
  508. package/src/services/getActivity.ts +77 -0
  509. package/src/services/getAsset.ts +37 -0
  510. package/src/services/getAssets.ts +32 -0
  511. package/src/services/{getHistory.ts → getFills.ts} +23 -17
  512. package/src/services/getOhlcv.ts +14 -11
  513. package/src/services/getOrder.ts +11 -8
  514. package/src/services/getOrderbook.ts +11 -8
  515. package/src/services/getOrders.ts +45 -0
  516. package/src/services/getPositions.ts +45 -0
  517. package/src/services/getPrices.ts +6 -6
  518. package/src/services/{getDexes.ts → getProviders.ts} +10 -10
  519. package/src/signers/lighter/LighterKeyStore.ts +74 -0
  520. package/src/signers/lighter/LighterReadOnlyTokenManager.ts +358 -0
  521. package/src/signers/lighter/LighterSigner.ts +396 -0
  522. package/src/signers/lighter/index.ts +36 -0
  523. package/src/signers/lighter/wasmLoader.ts +291 -0
  524. package/src/utils/accountSummary.ts +130 -0
  525. package/src/utils/assertNever.ts +22 -0
  526. package/src/utils/calculations.ts +209 -0
  527. package/src/utils/hyperliquid/index.ts +9 -0
  528. package/src/utils/hyperliquid/liquidation.ts +71 -0
  529. package/src/utils/hyperliquid/orderFormatting.ts +96 -0
  530. package/src/utils/orderClassification.ts +64 -0
  531. package/src/utils/orderMath.ts +130 -0
  532. package/src/utils/parse.ts +28 -0
  533. package/src/utils/positionMath.ts +107 -0
  534. package/src/utils/request.ts +26 -7
  535. package/src/utils/signTypedData.ts +19 -15
  536. package/src/utils/units.ts +32 -0
  537. package/src/utils/validation.ts +35 -0
  538. package/src/version.ts +1 -1
  539. package/wasm/lighter-signer.wasm +0 -0
  540. package/wasm/wasm_exec.js +575 -0
  541. package/dist/cjs/dex/hyperliquid.d.ts +0 -3
  542. package/dist/cjs/dex/hyperliquid.d.ts.map +0 -1
  543. package/dist/cjs/dex/hyperliquid.js +0 -21
  544. package/dist/cjs/dex/hyperliquid.js.map +0 -1
  545. package/dist/cjs/dex/registry.d.ts +0 -3
  546. package/dist/cjs/dex/registry.d.ts.map +0 -1
  547. package/dist/cjs/dex/registry.js +0 -16
  548. package/dist/cjs/dex/registry.js.map +0 -1
  549. package/dist/cjs/dex/types.d.ts +0 -13
  550. package/dist/cjs/dex/types.d.ts.map +0 -1
  551. package/dist/cjs/errors/AgentError.d.ts +0 -10
  552. package/dist/cjs/errors/AgentError.d.ts.map +0 -1
  553. package/dist/cjs/errors/AgentError.js +0 -23
  554. package/dist/cjs/errors/AgentError.js.map +0 -1
  555. package/dist/cjs/errors/HTTPError.d.ts +0 -11
  556. package/dist/cjs/errors/HTTPError.d.ts.map +0 -1
  557. package/dist/cjs/errors/HTTPError.js +0 -62
  558. package/dist/cjs/errors/HTTPError.js.map +0 -1
  559. package/dist/cjs/errors/PerpsSDKError.d.ts +0 -9
  560. package/dist/cjs/errors/PerpsSDKError.d.ts.map +0 -1
  561. package/dist/cjs/errors/PerpsSDKError.js +0 -36
  562. package/dist/cjs/errors/PerpsSDKError.js.map +0 -1
  563. package/dist/cjs/errors/ServerError.d.ts +0 -10
  564. package/dist/cjs/errors/ServerError.d.ts.map +0 -1
  565. package/dist/cjs/errors/ServerError.js +0 -24
  566. package/dist/cjs/errors/ServerError.js.map +0 -1
  567. package/dist/cjs/errors/ValidationError.d.ts +0 -9
  568. package/dist/cjs/errors/ValidationError.d.ts.map +0 -1
  569. package/dist/cjs/errors/ValidationError.js +0 -23
  570. package/dist/cjs/errors/ValidationError.js.map +0 -1
  571. package/dist/cjs/errors/utils/rootCause.d.ts +0 -6
  572. package/dist/cjs/errors/utils/rootCause.d.ts.map +0 -1
  573. package/dist/cjs/errors/utils/rootCause.js +0 -41
  574. package/dist/cjs/errors/utils/rootCause.js.map +0 -1
  575. package/dist/cjs/services/cancelOrder.d.ts +0 -10
  576. package/dist/cjs/services/cancelOrder.d.ts.map +0 -1
  577. package/dist/cjs/services/cancelOrder.js +0 -16
  578. package/dist/cjs/services/cancelOrder.js.map +0 -1
  579. package/dist/cjs/services/createAuthorization.d.ts +0 -10
  580. package/dist/cjs/services/createAuthorization.d.ts.map +0 -1
  581. package/dist/cjs/services/createAuthorization.js +0 -16
  582. package/dist/cjs/services/createAuthorization.js.map +0 -1
  583. package/dist/cjs/services/createOrder.d.ts +0 -21
  584. package/dist/cjs/services/createOrder.d.ts.map +0 -1
  585. package/dist/cjs/services/createOrder.js +0 -27
  586. package/dist/cjs/services/createOrder.js.map +0 -1
  587. package/dist/cjs/services/createWithdrawal.d.ts +0 -9
  588. package/dist/cjs/services/createWithdrawal.d.ts.map +0 -1
  589. package/dist/cjs/services/createWithdrawal.js +0 -15
  590. package/dist/cjs/services/createWithdrawal.js.map +0 -1
  591. package/dist/cjs/services/getDexes.d.ts +0 -4
  592. package/dist/cjs/services/getDexes.d.ts.map +0 -1
  593. package/dist/cjs/services/getDexes.js.map +0 -1
  594. package/dist/cjs/services/getHistory.d.ts +0 -10
  595. package/dist/cjs/services/getHistory.d.ts.map +0 -1
  596. package/dist/cjs/services/getHistory.js.map +0 -1
  597. package/dist/cjs/services/getMarket.d.ts +0 -8
  598. package/dist/cjs/services/getMarket.d.ts.map +0 -1
  599. package/dist/cjs/services/getMarket.js.map +0 -1
  600. package/dist/cjs/services/getMarkets.d.ts +0 -7
  601. package/dist/cjs/services/getMarkets.d.ts.map +0 -1
  602. package/dist/cjs/services/getMarkets.js.map +0 -1
  603. package/dist/cjs/services/submitAuthorization.d.ts +0 -10
  604. package/dist/cjs/services/submitAuthorization.d.ts.map +0 -1
  605. package/dist/cjs/services/submitAuthorization.js.map +0 -1
  606. package/dist/cjs/services/submitOrder.d.ts +0 -10
  607. package/dist/cjs/services/submitOrder.d.ts.map +0 -1
  608. package/dist/cjs/services/submitOrder.js.map +0 -1
  609. package/dist/cjs/services/submitWithdrawal.d.ts +0 -9
  610. package/dist/cjs/services/submitWithdrawal.d.ts.map +0 -1
  611. package/dist/cjs/services/submitWithdrawal.js +0 -15
  612. package/dist/cjs/services/submitWithdrawal.js.map +0 -1
  613. package/dist/esm/dex/hyperliquid.d.ts +0 -3
  614. package/dist/esm/dex/hyperliquid.d.ts.map +0 -1
  615. package/dist/esm/dex/hyperliquid.js +0 -19
  616. package/dist/esm/dex/hyperliquid.js.map +0 -1
  617. package/dist/esm/dex/registry.d.ts +0 -3
  618. package/dist/esm/dex/registry.d.ts.map +0 -1
  619. package/dist/esm/dex/registry.js +0 -13
  620. package/dist/esm/dex/registry.js.map +0 -1
  621. package/dist/esm/dex/types.d.ts +0 -15
  622. package/dist/esm/dex/types.d.ts.map +0 -1
  623. package/dist/esm/dex/types.js +0 -2
  624. package/dist/esm/dex/types.js.map +0 -1
  625. package/dist/esm/errors/AgentError.d.ts +0 -25
  626. package/dist/esm/errors/AgentError.d.ts.map +0 -1
  627. package/dist/esm/errors/AgentError.js +0 -35
  628. package/dist/esm/errors/AgentError.js.map +0 -1
  629. package/dist/esm/errors/HTTPError.d.ts +0 -11
  630. package/dist/esm/errors/HTTPError.d.ts.map +0 -1
  631. package/dist/esm/errors/HTTPError.js +0 -61
  632. package/dist/esm/errors/HTTPError.js.map +0 -1
  633. package/dist/esm/errors/PerpsSDKError.d.ts +0 -40
  634. package/dist/esm/errors/PerpsSDKError.d.ts.map +0 -1
  635. package/dist/esm/errors/PerpsSDKError.js +0 -67
  636. package/dist/esm/errors/PerpsSDKError.js.map +0 -1
  637. package/dist/esm/errors/ServerError.d.ts +0 -23
  638. package/dist/esm/errors/ServerError.d.ts.map +0 -1
  639. package/dist/esm/errors/ServerError.js +0 -34
  640. package/dist/esm/errors/ServerError.js.map +0 -1
  641. package/dist/esm/errors/ValidationError.d.ts +0 -23
  642. package/dist/esm/errors/ValidationError.d.ts.map +0 -1
  643. package/dist/esm/errors/ValidationError.js +0 -34
  644. package/dist/esm/errors/ValidationError.js.map +0 -1
  645. package/dist/esm/errors/utils/rootCause.d.ts +0 -71
  646. package/dist/esm/errors/utils/rootCause.d.ts.map +0 -1
  647. package/dist/esm/errors/utils/rootCause.js +0 -99
  648. package/dist/esm/errors/utils/rootCause.js.map +0 -1
  649. package/dist/esm/services/cancelOrder.d.ts +0 -51
  650. package/dist/esm/services/cancelOrder.d.ts.map +0 -1
  651. package/dist/esm/services/cancelOrder.js +0 -50
  652. package/dist/esm/services/cancelOrder.js.map +0 -1
  653. package/dist/esm/services/createAuthorization.d.ts +0 -51
  654. package/dist/esm/services/createAuthorization.d.ts.map +0 -1
  655. package/dist/esm/services/createAuthorization.js +0 -50
  656. package/dist/esm/services/createAuthorization.js.map +0 -1
  657. package/dist/esm/services/createOrder.d.ts +0 -74
  658. package/dist/esm/services/createOrder.d.ts.map +0 -1
  659. package/dist/esm/services/createOrder.js +0 -62
  660. package/dist/esm/services/createOrder.js.map +0 -1
  661. package/dist/esm/services/createWithdrawal.d.ts +0 -49
  662. package/dist/esm/services/createWithdrawal.d.ts.map +0 -1
  663. package/dist/esm/services/createWithdrawal.js +0 -49
  664. package/dist/esm/services/createWithdrawal.js.map +0 -1
  665. package/dist/esm/services/getDexes.d.ts +0 -20
  666. package/dist/esm/services/getDexes.d.ts.map +0 -1
  667. package/dist/esm/services/getDexes.js +0 -21
  668. package/dist/esm/services/getDexes.js.map +0 -1
  669. package/dist/esm/services/getHistory.d.ts.map +0 -1
  670. package/dist/esm/services/getHistory.js.map +0 -1
  671. package/dist/esm/services/getMarket.d.ts +0 -27
  672. package/dist/esm/services/getMarket.d.ts.map +0 -1
  673. package/dist/esm/services/getMarket.js +0 -25
  674. package/dist/esm/services/getMarket.js.map +0 -1
  675. package/dist/esm/services/getMarkets.d.ts +0 -25
  676. package/dist/esm/services/getMarkets.d.ts.map +0 -1
  677. package/dist/esm/services/getMarkets.js +0 -23
  678. package/dist/esm/services/getMarkets.js.map +0 -1
  679. package/dist/esm/services/submitAuthorization.d.ts +0 -42
  680. package/dist/esm/services/submitAuthorization.d.ts.map +0 -1
  681. package/dist/esm/services/submitAuthorization.js +0 -41
  682. package/dist/esm/services/submitAuthorization.js.map +0 -1
  683. package/dist/esm/services/submitOrder.d.ts +0 -44
  684. package/dist/esm/services/submitOrder.d.ts.map +0 -1
  685. package/dist/esm/services/submitOrder.js +0 -43
  686. package/dist/esm/services/submitOrder.js.map +0 -1
  687. package/dist/esm/services/submitWithdrawal.d.ts +0 -40
  688. package/dist/esm/services/submitWithdrawal.d.ts.map +0 -1
  689. package/dist/esm/services/submitWithdrawal.js +0 -40
  690. package/dist/esm/services/submitWithdrawal.js.map +0 -1
  691. package/dist/types/dex/hyperliquid.d.ts +0 -3
  692. package/dist/types/dex/hyperliquid.d.ts.map +0 -1
  693. package/dist/types/dex/registry.d.ts +0 -3
  694. package/dist/types/dex/registry.d.ts.map +0 -1
  695. package/dist/types/dex/types.d.ts +0 -15
  696. package/dist/types/dex/types.d.ts.map +0 -1
  697. package/dist/types/errors/AgentError.d.ts +0 -25
  698. package/dist/types/errors/AgentError.d.ts.map +0 -1
  699. package/dist/types/errors/HTTPError.d.ts +0 -11
  700. package/dist/types/errors/HTTPError.d.ts.map +0 -1
  701. package/dist/types/errors/PerpsSDKError.d.ts +0 -40
  702. package/dist/types/errors/PerpsSDKError.d.ts.map +0 -1
  703. package/dist/types/errors/ServerError.d.ts +0 -23
  704. package/dist/types/errors/ServerError.d.ts.map +0 -1
  705. package/dist/types/errors/ValidationError.d.ts +0 -23
  706. package/dist/types/errors/ValidationError.d.ts.map +0 -1
  707. package/dist/types/errors/utils/rootCause.d.ts +0 -71
  708. package/dist/types/errors/utils/rootCause.d.ts.map +0 -1
  709. package/dist/types/services/cancelOrder.d.ts +0 -51
  710. package/dist/types/services/cancelOrder.d.ts.map +0 -1
  711. package/dist/types/services/createAuthorization.d.ts +0 -51
  712. package/dist/types/services/createAuthorization.d.ts.map +0 -1
  713. package/dist/types/services/createOrder.d.ts +0 -74
  714. package/dist/types/services/createOrder.d.ts.map +0 -1
  715. package/dist/types/services/createWithdrawal.d.ts +0 -49
  716. package/dist/types/services/createWithdrawal.d.ts.map +0 -1
  717. package/dist/types/services/getDexes.d.ts +0 -20
  718. package/dist/types/services/getDexes.d.ts.map +0 -1
  719. package/dist/types/services/getHistory.d.ts.map +0 -1
  720. package/dist/types/services/getMarket.d.ts +0 -27
  721. package/dist/types/services/getMarket.d.ts.map +0 -1
  722. package/dist/types/services/getMarkets.d.ts +0 -25
  723. package/dist/types/services/getMarkets.d.ts.map +0 -1
  724. package/dist/types/services/submitAuthorization.d.ts +0 -42
  725. package/dist/types/services/submitAuthorization.d.ts.map +0 -1
  726. package/dist/types/services/submitOrder.d.ts +0 -44
  727. package/dist/types/services/submitOrder.d.ts.map +0 -1
  728. package/dist/types/services/submitWithdrawal.d.ts +0 -40
  729. package/dist/types/services/submitWithdrawal.d.ts.map +0 -1
  730. package/src/dex/hyperliquid.ts +0 -20
  731. package/src/dex/registry.ts +0 -15
  732. package/src/dex/types.ts +0 -16
  733. package/src/errors/AgentError.ts +0 -43
  734. package/src/errors/HTTPError.ts +0 -72
  735. package/src/errors/PerpsSDKError.ts +0 -79
  736. package/src/errors/ServerError.ts +0 -41
  737. package/src/errors/ValidationError.ts +0 -38
  738. package/src/errors/utils/rootCause.ts +0 -112
  739. package/src/services/cancelOrder.ts +0 -75
  740. package/src/services/createAuthorization.ts +0 -79
  741. package/src/services/createOrder.ts +0 -116
  742. package/src/services/createWithdrawal.ts +0 -76
  743. package/src/services/getMarket.ts +0 -41
  744. package/src/services/getMarkets.ts +0 -37
  745. package/src/services/submitAuthorization.ts +0 -70
  746. package/src/services/submitOrder.ts +0 -72
  747. package/src/services/submitWithdrawal.ts +0 -67
  748. /package/dist/cjs/{dex → realtime/lighter}/types.js +0 -0
@@ -0,0 +1,682 @@
1
+ import type {
2
+ Address,
3
+ Fill,
4
+ Order,
5
+ Position,
6
+ Subscription,
7
+ SubscriptionEvent,
8
+ } from '@lifi/perps-types'
9
+ import type {
10
+ LtAccountPosition,
11
+ LtOrder,
12
+ LtTrade,
13
+ } from '@lifi/perps-types/providers/lighter'
14
+ import {
15
+ mapFill,
16
+ mapOrderDetail,
17
+ mapPosition,
18
+ } from '@lifi/perps-types/providers/lighter'
19
+ import { ReconnectingWebSocket } from '../ReconnectingWebSocket.js'
20
+ import type { SubscriptionListener, WsProvider } from '../types.js'
21
+ import type {
22
+ LtOrderBookDetail,
23
+ LtOrderBookDetailsResponse,
24
+ LtWsAccountAllOrdersMessage,
25
+ LtWsAccountAllPositionsMessage,
26
+ LtWsAccountAllTradesMessage,
27
+ LtWsAccountByL1Response,
28
+ LtWsMarketStats,
29
+ LtWsMarketStatsAllMessage,
30
+ LtWsMessage,
31
+ LtWsOrderBook,
32
+ LtWsOrderBookMessage,
33
+ } from './types.js'
34
+
35
+ // ---------------------------------------------------------------------------
36
+ // LighterWsProvider
37
+ //
38
+ // Public channels: `prices` (market_stats/all), `orderbook` (order_book/N).
39
+ // Authenticated channels (require an `authProvider` option):
40
+ // - orderUpdates → account_all_orders/{account_index}
41
+ // - fills → account_all_trades/{account_index}
42
+ // - positions → account_all_positions/{account_index}
43
+ //
44
+ // Auth pattern (per Lighter WS spec): the subscribe payload carries the
45
+ // token directly — `{ type: "subscribe", channel: "...", auth: "<token>" }`.
46
+ // Tokens are minted via the Lighter WASM signer (CreateAuthToken) by the
47
+ // caller; we re-request a fresh token on every subscribe send so reconnects
48
+ // after the original token expires automatically pick up a new one.
49
+ //
50
+ // account_index is resolved per-address via `/api/v1/account?by=l1_address`
51
+ // and cached for the lifetime of the provider — Lighter's account index is
52
+ // stable for a given L1 wallet.
53
+ //
54
+ // Symbol → market_id mapping is fetched once from Lighter's public
55
+ // `/api/v1/orderBookDetails` endpoint. The UI's assetId IS Lighter's symbol
56
+ // (e.g. "BTC"), so we use it as the join key.
57
+ //
58
+ // Orderbook is stateful: the first message is a full snapshot, subsequent
59
+ // messages are deltas where size=0 deletes a level.
60
+ // ---------------------------------------------------------------------------
61
+
62
+ const DEFAULT_WS_URL = 'wss://mainnet.zklighter.elliot.ai/stream'
63
+ const DEFAULT_REST_URL = 'https://mainnet.zklighter.elliot.ai'
64
+ const KEEPALIVE_INTERVAL_MS = 30_000
65
+
66
+ const LIGHTER_AUTH_CHANNEL = {
67
+ orderUpdates: 'account_all_orders',
68
+ fills: 'account_all_trades',
69
+ positions: 'account_all_positions',
70
+ } as const
71
+
72
+ /**
73
+ * Mints a fresh Lighter auth token for the given L1 address, or returns
74
+ * `undefined` if no API key is registered. Called both on initial subscribe
75
+ * and on every reconnect, so it must always return a token valid for at
76
+ * least the next few minutes.
77
+ */
78
+ export type LighterAuthProvider = (
79
+ address: Address
80
+ ) => Promise<string | undefined>
81
+
82
+ interface SubState {
83
+ /** Ref count — we send unsubscribe when this drops to zero. */
84
+ count: number
85
+ /** Raw Lighter WS channel name (e.g. `order_book/5`, `account_all_orders/42`). */
86
+ channel: string
87
+ /** L1 address that triggered this sub (auth channels only). */
88
+ address?: Address
89
+ /** Whether this channel needs an `auth` field on each subscribe send. */
90
+ needsAuth: boolean
91
+ }
92
+
93
+ interface OrderbookState {
94
+ bids: Map<string, string>
95
+ asks: Map<string, string>
96
+ assetId: string
97
+ }
98
+
99
+ export interface LighterWsProviderOptions {
100
+ /** REST base URL for fetching `orderBookDetails`. Defaults to mainnet. */
101
+ restUrl?: string
102
+ /** Pre-populated symbol→market_id map to skip the REST call. */
103
+ symbolMap?: Record<string, number>
104
+ /**
105
+ * Async function returning a Lighter auth token for an address. Required
106
+ * for authenticated channels (orderUpdates, positions). Without it those
107
+ * subscriptions will throw at subscribe time.
108
+ */
109
+ authProvider?: LighterAuthProvider
110
+ }
111
+
112
+ export class LighterWsProvider implements WsProvider {
113
+ private readonly rws: ReconnectingWebSocket
114
+ private readonly restUrl: string
115
+ private readonly providerKey: string
116
+ private readonly authProvider: LighterAuthProvider | undefined
117
+
118
+ private readonly subs = new Map<string, SubState>()
119
+ private readonly listeners = new Map<string, Set<SubscriptionListener>>()
120
+ private readonly orderbooks = new Map<number, OrderbookState>()
121
+ private lastPricesByAssetId: Record<string, string> = {}
122
+
123
+ private symbolToMarketId: Map<string, number>
124
+ private marketIdToSymbol: Map<number, string>
125
+ private marketMetadataPromise: Promise<void> | undefined
126
+
127
+ private readonly accountIndexCache = new Map<string, number>()
128
+ private readonly accountIndexPromises = new Map<string, Promise<number>>()
129
+
130
+ private keepaliveTimer: ReturnType<typeof setInterval> | undefined
131
+
132
+ constructor(
133
+ wsUrl: string = DEFAULT_WS_URL,
134
+ providerKey = 'lighter',
135
+ options: LighterWsProviderOptions = {}
136
+ ) {
137
+ this.providerKey = providerKey
138
+ this.restUrl = options.restUrl ?? DEFAULT_REST_URL
139
+ this.authProvider = options.authProvider
140
+ this.symbolToMarketId = new Map(Object.entries(options.symbolMap ?? {}))
141
+ this.marketIdToSymbol = new Map(
142
+ [...this.symbolToMarketId].map(([s, m]) => [m, s])
143
+ )
144
+
145
+ this.rws = new ReconnectingWebSocket(wsUrl)
146
+ this.rws.on('message', (data) => this.handleMessage(data))
147
+ this.rws.on('open', () => {
148
+ void this.onOpen()
149
+ })
150
+ this.rws.on('close', () => this.stopKeepalive())
151
+ }
152
+
153
+ async subscribe(
154
+ sub: Subscription,
155
+ listener: SubscriptionListener
156
+ ): Promise<() => void> {
157
+ // Lighter has no live OHLC channel — there's nothing to subscribe to.
158
+ // Return a no-op unsubscribe so the caller's UX (chart still rendering
159
+ // from REST history + price-tick mid line) is unaffected, instead of
160
+ // throwing and surfacing a console error on every chart mount.
161
+ if (sub.channel === 'candle') {
162
+ void listener
163
+ return () => {}
164
+ }
165
+
166
+ await this.ensureMarketMetadata()
167
+
168
+ const { channel, needsAuth, address } = await this.resolveChannel(sub)
169
+ const key = this.toKey(sub)
170
+ if (!this.listeners.has(key)) {
171
+ this.listeners.set(key, new Set())
172
+ }
173
+ this.listeners.get(key)?.add(listener)
174
+
175
+ const existing = this.subs.get(key)
176
+ if (existing) {
177
+ existing.count++
178
+ } else {
179
+ this.subs.set(key, { count: 1, channel, needsAuth, address })
180
+ await this.rws.ready()
181
+ await this.sendSubscribe(channel, needsAuth, address)
182
+ }
183
+
184
+ return () => {
185
+ this.listeners.get(key)?.delete(listener)
186
+ const s = this.subs.get(key)
187
+ if (!s) {
188
+ return
189
+ }
190
+ s.count--
191
+ if (s.count <= 0) {
192
+ this.subs.delete(key)
193
+ this.listeners.delete(key)
194
+ if (sub.channel === 'orderbook') {
195
+ const id = this.symbolToMarketId.get(sub.assetId)
196
+ if (id !== undefined) {
197
+ this.orderbooks.delete(id)
198
+ }
199
+ }
200
+ this.rws.send(
201
+ JSON.stringify({ type: 'unsubscribe', channel: s.channel })
202
+ )
203
+ }
204
+ }
205
+ }
206
+
207
+ close(): void {
208
+ this.stopKeepalive()
209
+ this.rws.close()
210
+ this.subs.clear()
211
+ this.listeners.clear()
212
+ this.orderbooks.clear()
213
+ this.lastPricesByAssetId = {}
214
+ }
215
+
216
+ private async onOpen(): Promise<void> {
217
+ this.startKeepalive()
218
+ for (const [, s] of this.subs) {
219
+ await this.sendSubscribe(s.channel, s.needsAuth, s.address)
220
+ }
221
+ }
222
+
223
+ private async sendSubscribe(
224
+ channel: string,
225
+ needsAuth: boolean,
226
+ address: Address | undefined
227
+ ): Promise<void> {
228
+ const payload: { type: 'subscribe'; channel: string; auth?: string } = {
229
+ type: 'subscribe',
230
+ channel,
231
+ }
232
+ if (needsAuth) {
233
+ if (!this.authProvider || !address) {
234
+ throw new Error(
235
+ `Lighter WS channel '${channel}' requires authentication but no authProvider was supplied.`
236
+ )
237
+ }
238
+ const token = await this.authProvider(address)
239
+ if (!token) {
240
+ throw new Error(
241
+ `Lighter WS channel '${channel}' requires authentication but no token was available for ${address}.`
242
+ )
243
+ }
244
+ payload.auth = token
245
+ }
246
+ this.rws.send(JSON.stringify(payload))
247
+ }
248
+
249
+ private startKeepalive(): void {
250
+ this.stopKeepalive()
251
+ this.keepaliveTimer = setInterval(() => {
252
+ this.rws.send(JSON.stringify({ type: 'ping' }))
253
+ }, KEEPALIVE_INTERVAL_MS)
254
+ }
255
+
256
+ private stopKeepalive(): void {
257
+ if (this.keepaliveTimer !== undefined) {
258
+ clearInterval(this.keepaliveTimer)
259
+ this.keepaliveTimer = undefined
260
+ }
261
+ }
262
+
263
+ private toKey(sub: Subscription): string {
264
+ switch (sub.channel) {
265
+ case 'prices':
266
+ return 'prices'
267
+ case 'orderbook':
268
+ return `orderbook:${sub.assetId}`
269
+ case 'orderUpdates':
270
+ return `orderUpdates:${sub.address.toLowerCase()}`
271
+ case 'fills':
272
+ return `fills:${sub.address.toLowerCase()}`
273
+ case 'positions':
274
+ return `positions:${sub.address.toLowerCase()}`
275
+ case 'candle':
276
+ case 'spotBalances':
277
+ throw new Error(`Lighter WS does not support channel: ${sub.channel}.`)
278
+ }
279
+ }
280
+
281
+ private async resolveChannel(sub: Subscription): Promise<{
282
+ channel: string
283
+ needsAuth: boolean
284
+ address?: Address
285
+ }> {
286
+ if (sub.channel === 'prices') {
287
+ return { channel: 'market_stats/all', needsAuth: false }
288
+ }
289
+ if (sub.channel === 'orderbook') {
290
+ const id = this.symbolToMarketId.get(sub.assetId)
291
+ if (id === undefined) {
292
+ throw new Error(
293
+ `Lighter WS: unknown market for assetId '${sub.assetId}'. ` +
294
+ 'Is the symbol mapping out of date?'
295
+ )
296
+ }
297
+ return { channel: `order_book/${id}`, needsAuth: false }
298
+ }
299
+ if (
300
+ sub.channel === 'orderUpdates' ||
301
+ sub.channel === 'fills' ||
302
+ sub.channel === 'positions'
303
+ ) {
304
+ const accountIndex = await this.resolveAccountIndex(sub.address)
305
+ const lighterChannel = LIGHTER_AUTH_CHANNEL[sub.channel]
306
+ // `account_all_trades` is publicly readable per the Lighter WS spec —
307
+ // an auth token only filters events to the user's own account, which
308
+ // we don't currently use to scope further. Skip the token here so a
309
+ // user without a registered API key still gets their fill stream.
310
+ const needsAuth = sub.channel !== 'fills'
311
+ return {
312
+ channel: `${lighterChannel}/${accountIndex}`,
313
+ needsAuth,
314
+ address: sub.address,
315
+ }
316
+ }
317
+ throw new Error(
318
+ `Lighter WS does not support channel: ${(sub as { channel: string }).channel}.`
319
+ )
320
+ }
321
+
322
+ private async resolveAccountIndex(address: Address): Promise<number> {
323
+ const lc = address.toLowerCase()
324
+ const cached = this.accountIndexCache.get(lc)
325
+ if (cached !== undefined) {
326
+ return cached
327
+ }
328
+ let p = this.accountIndexPromises.get(lc)
329
+ if (!p) {
330
+ p = this.fetchAccountIndex(address).finally(() => {
331
+ this.accountIndexPromises.delete(lc)
332
+ })
333
+ this.accountIndexPromises.set(lc, p)
334
+ }
335
+ const idx = await p
336
+ this.accountIndexCache.set(lc, idx)
337
+ return idx
338
+ }
339
+
340
+ private async fetchAccountIndex(address: Address): Promise<number> {
341
+ const url = `${this.restUrl}/api/v1/account?by=l1_address&value=${encodeURIComponent(address)}`
342
+ const response = await fetch(url)
343
+ if (!response.ok) {
344
+ throw new Error(
345
+ `Failed to resolve Lighter account for ${address}: ${response.status}`
346
+ )
347
+ }
348
+ const body = (await response.json()) as LtWsAccountByL1Response
349
+ const idx = body.accounts?.[0]?.index
350
+ if (typeof idx !== 'number') {
351
+ throw new Error(`No Lighter account found for ${address}`)
352
+ }
353
+ return idx
354
+ }
355
+
356
+ private async ensureMarketMetadata(): Promise<void> {
357
+ if (this.symbolToMarketId.size > 0) {
358
+ return
359
+ }
360
+ if (!this.marketMetadataPromise) {
361
+ this.marketMetadataPromise = this.fetchMarketMetadata()
362
+ }
363
+ await this.marketMetadataPromise
364
+ }
365
+
366
+ private async fetchMarketMetadata(): Promise<void> {
367
+ const response = await fetch(`${this.restUrl}/api/v1/orderBookDetails`)
368
+ if (!response.ok) {
369
+ throw new Error(
370
+ `Failed to fetch Lighter orderBookDetails: ${response.status}`
371
+ )
372
+ }
373
+ const body = (await response.json()) as LtOrderBookDetailsResponse
374
+ for (const d of body.order_book_details ?? []) {
375
+ this.registerMarket(d)
376
+ }
377
+ }
378
+
379
+ private registerMarket(d: LtOrderBookDetail): void {
380
+ this.symbolToMarketId.set(d.symbol, d.market_id)
381
+ this.marketIdToSymbol.set(d.market_id, d.symbol)
382
+ }
383
+
384
+ private handleMessage(raw: string): void {
385
+ let msg: LtWsMessage
386
+ try {
387
+ msg = JSON.parse(raw) as LtWsMessage
388
+ } catch {
389
+ return
390
+ }
391
+
392
+ if (msg.type === 'ping') {
393
+ this.rws.send(JSON.stringify({ type: 'pong' }))
394
+ return
395
+ }
396
+
397
+ if (
398
+ msg.type === 'subscribed/market_stats' ||
399
+ msg.type === 'update/market_stats'
400
+ ) {
401
+ this.handleMarketStats(msg as LtWsMarketStatsAllMessage)
402
+ return
403
+ }
404
+
405
+ if (
406
+ msg.type === 'subscribed/order_book' ||
407
+ msg.type === 'update/order_book'
408
+ ) {
409
+ this.handleOrderBook(
410
+ msg as LtWsOrderBookMessage,
411
+ msg.type === 'subscribed/order_book'
412
+ )
413
+ return
414
+ }
415
+
416
+ if (
417
+ msg.type === 'subscribed/account_all_orders' ||
418
+ msg.type === 'update/account_all_orders'
419
+ ) {
420
+ this.handleAccountOrders(msg as LtWsAccountAllOrdersMessage)
421
+ return
422
+ }
423
+
424
+ if (
425
+ msg.type === 'subscribed/account_all_trades' ||
426
+ msg.type === 'update/account_all_trades'
427
+ ) {
428
+ this.handleAccountTrades(msg as LtWsAccountAllTradesMessage)
429
+ return
430
+ }
431
+
432
+ if (
433
+ msg.type === 'subscribed/account_all_positions' ||
434
+ msg.type === 'update/account_all_positions'
435
+ ) {
436
+ this.handleAccountPositions(msg as LtWsAccountAllPositionsMessage)
437
+ return
438
+ }
439
+ }
440
+
441
+ private handleAccountOrders(msg: LtWsAccountAllOrdersMessage): void {
442
+ const address = this.addressFromChannel(msg.channel, 'account_all_orders')
443
+ if (!address) {
444
+ return
445
+ }
446
+ const raw = collectAuthChannelItems<LtOrder>(msg, 'orders')
447
+ const orders: Order[] = raw.map((o) =>
448
+ mapOrderDetail(
449
+ o,
450
+ this.marketIdToSymbol.get(o.market_index) ?? `market_${o.market_index}`
451
+ )
452
+ )
453
+ this.emit(`orderUpdates:${address}`, {
454
+ channel: 'orderUpdates',
455
+ data: orders,
456
+ })
457
+ }
458
+
459
+ private handleAccountTrades(msg: LtWsAccountAllTradesMessage): void {
460
+ const address = this.addressFromChannel(msg.channel, 'account_all_trades')
461
+ if (!address) {
462
+ return
463
+ }
464
+ const accountIndex = this.accountIndexCache.get(address)
465
+ if (accountIndex === undefined) {
466
+ return
467
+ }
468
+ const raw = collectAuthChannelItems<LtTrade>(msg, 'trades')
469
+ const fills: Fill[] = raw.map((t) =>
470
+ mapFill(
471
+ t,
472
+ accountIndex,
473
+ this.marketIdToSymbol.get(t.market_id) ?? `market_${t.market_id}`
474
+ )
475
+ )
476
+ this.emit(`fills:${address}`, { channel: 'fills', data: fills })
477
+ }
478
+
479
+ private handleAccountPositions(msg: LtWsAccountAllPositionsMessage): void {
480
+ const address = this.addressFromChannel(
481
+ msg.channel,
482
+ 'account_all_positions'
483
+ )
484
+ if (!address) {
485
+ return
486
+ }
487
+ const raw = collectAuthChannelItems<LtAccountPosition>(msg, 'positions')
488
+ const positions: Position[] = raw
489
+ .filter((p) => parseFloat(p.position) !== 0)
490
+ .map((p) =>
491
+ mapPosition(
492
+ p,
493
+ this.marketIdToSymbol.get(p.market_id) ??
494
+ p.symbol ??
495
+ `market_${p.market_id}`
496
+ )
497
+ )
498
+ this.emit(`positions:${address}`, {
499
+ channel: 'positions',
500
+ data: positions,
501
+ })
502
+ }
503
+
504
+ /**
505
+ * Reverse-lookup the L1 address from an auth-channel message. The subscribe
506
+ * payload uses `/` (e.g. `account_all_orders/42`) but the server sends
507
+ * responses with `:` (e.g. `account_all_orders:42`) — both forms are
508
+ * accepted here so reconnect resubscriptions and live updates both route
509
+ * correctly.
510
+ */
511
+ private addressFromChannel(
512
+ channel: string | undefined,
513
+ prefix: string
514
+ ): string | null {
515
+ if (!channel || !channel.startsWith(prefix)) {
516
+ return null
517
+ }
518
+ const sep = channel[prefix.length]
519
+ if (sep !== '/' && sep !== ':') {
520
+ return null
521
+ }
522
+ const idx = Number(channel.slice(prefix.length + 1))
523
+ if (!Number.isFinite(idx)) {
524
+ return null
525
+ }
526
+ for (const [addr, cachedIdx] of this.accountIndexCache) {
527
+ if (cachedIdx === idx) {
528
+ return addr
529
+ }
530
+ }
531
+ return null
532
+ }
533
+
534
+ private handleMarketStats(msg: LtWsMarketStatsAllMessage): void {
535
+ const stats = msg.market_stats
536
+ if (!stats) {
537
+ return
538
+ }
539
+ const updates: Record<string, string> = {}
540
+ for (const value of Object.values(stats)) {
541
+ const entry = value as LtWsMarketStats
542
+ const symbol = this.marketIdToSymbol.get(entry.market_id)
543
+ if (!symbol) {
544
+ continue
545
+ }
546
+ updates[symbol] = entry.last_trade_price
547
+ }
548
+ if (Object.keys(updates).length === 0) {
549
+ return
550
+ }
551
+ this.lastPricesByAssetId = { ...this.lastPricesByAssetId, ...updates }
552
+ this.emit('prices', {
553
+ channel: 'prices',
554
+ data: this.lastPricesByAssetId,
555
+ })
556
+ }
557
+
558
+ private handleOrderBook(
559
+ msg: LtWsOrderBookMessage,
560
+ isSnapshot: boolean
561
+ ): void {
562
+ const marketId = this.marketIdFromChannel(msg.channel)
563
+ if (marketId === null) {
564
+ return
565
+ }
566
+ const assetId = this.marketIdToSymbol.get(marketId)
567
+ if (!assetId) {
568
+ return
569
+ }
570
+
571
+ let state = this.orderbooks.get(marketId)
572
+ if (!state || isSnapshot) {
573
+ state = { bids: new Map(), asks: new Map(), assetId }
574
+ this.orderbooks.set(marketId, state)
575
+ }
576
+
577
+ applyLevels(state.bids, msg.order_book.bids)
578
+ applyLevels(state.asks, msg.order_book.asks)
579
+
580
+ this.emit(`orderbook:${assetId}`, {
581
+ channel: 'orderbook',
582
+ data: {
583
+ provider: this.providerKey,
584
+ assetId,
585
+ bids: mapToLevels(
586
+ state.bids,
587
+ (a, b) => Number(b.price) - Number(a.price)
588
+ ),
589
+ asks: mapToLevels(
590
+ state.asks,
591
+ (a, b) => Number(a.price) - Number(b.price)
592
+ ),
593
+ timestamp: Date.now(),
594
+ },
595
+ })
596
+ }
597
+
598
+ private marketIdFromChannel(channel: string | undefined): number | null {
599
+ if (!channel?.startsWith('order_book')) {
600
+ return null
601
+ }
602
+ const tail = channel.slice('order_book'.length)
603
+ if (tail.length < 2 || (tail[0] !== '/' && tail[0] !== ':')) {
604
+ return null
605
+ }
606
+ const n = Number(tail.slice(1))
607
+ return Number.isFinite(n) ? n : null
608
+ }
609
+
610
+ private emit(key: string, event: SubscriptionEvent): void {
611
+ const fns = this.listeners.get(key)
612
+ if (!fns) {
613
+ return
614
+ }
615
+ for (const fn of fns) {
616
+ fn(event)
617
+ }
618
+ }
619
+ }
620
+
621
+ function applyLevels(
622
+ book: Map<string, string>,
623
+ levels: LtWsOrderBook['bids']
624
+ ): void {
625
+ for (const level of levels) {
626
+ if (level.size === '0' || Number(level.size) === 0) {
627
+ book.delete(level.price)
628
+ } else {
629
+ book.set(level.price, level.size)
630
+ }
631
+ }
632
+ }
633
+
634
+ function mapToLevels(
635
+ book: Map<string, string>,
636
+ compare: (a: { price: string }, b: { price: string }) => number
637
+ ): Array<{ price: string; size: string }> {
638
+ const levels = [...book].map(([price, size]) => ({ price, size }))
639
+ levels.sort(compare)
640
+ return levels
641
+ }
642
+
643
+ /**
644
+ * Extract items from an auth-channel payload field. The field may be:
645
+ * - a flat array (e.g. `trades: []` on the initial subscribed snapshot)
646
+ * - an object indexed by market index with array values
647
+ * (e.g. `orders: { "0": [Order] }` on update messages)
648
+ * - an object indexed by market index with single-object values
649
+ * (e.g. `positions: { "0": Position }` — one position per market)
650
+ *
651
+ * All three shapes are flattened to a single T[] for uniform downstream
652
+ * handling. Returns undefined when the field is absent, so the caller can
653
+ * fall back to a nested `data` wrapper (kept for compatibility with older
654
+ * Lighter WS versions).
655
+ */
656
+ function extractItems<T>(value: unknown): T[] | undefined {
657
+ if (value === undefined || value === null) {
658
+ return undefined
659
+ }
660
+ if (Array.isArray(value)) {
661
+ return value as T[]
662
+ }
663
+ if (typeof value === 'object') {
664
+ return Object.values(value as Record<string, unknown>).flatMap((v) =>
665
+ Array.isArray(v) ? (v as T[]) : [v as T]
666
+ )
667
+ }
668
+ return undefined
669
+ }
670
+
671
+ function collectAuthChannelItems<T>(
672
+ msg: { [k: string]: unknown },
673
+ field: string
674
+ ): T[] {
675
+ return (
676
+ extractItems<T>(msg[field]) ??
677
+ extractItems<T>(
678
+ (msg.data as Record<string, unknown> | undefined)?.[field]
679
+ ) ??
680
+ []
681
+ )
682
+ }