@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
@@ -2,257 +2,726 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PerpsClient = void 0;
4
4
  const perps_types_1 = require("@lifi/perps-types");
5
- const registry_js_1 = require("../dex/registry.js");
6
- const constants_js_1 = require("../errors/constants.js");
5
+ const viem_1 = require("viem");
6
+ const storage_js_1 = require("../agent/storage.js");
7
7
  const PerpsError_js_1 = require("../errors/PerpsError.js");
8
- const cancelOrder_js_1 = require("../services/cancelOrder.js");
9
- const createAuthorization_js_1 = require("../services/createAuthorization.js");
10
- const createOrder_js_1 = require("../services/createOrder.js");
11
- const createWithdrawal_js_1 = require("../services/createWithdrawal.js");
12
- const submitAuthorization_js_1 = require("../services/submitAuthorization.js");
13
- const submitOrder_js_1 = require("../services/submitOrder.js");
14
- const submitWithdrawal_js_1 = require("../services/submitWithdrawal.js");
8
+ const createAction_js_1 = require("../services/createAction.js");
9
+ const executeAction_js_1 = require("../services/executeAction.js");
10
+ const getAccount_js_1 = require("../services/getAccount.js");
11
+ const getProviders_js_1 = require("../services/getProviders.js");
12
+ const index_js_1 = require("../signers/lighter/index.js");
15
13
  const signTypedData_js_1 = require("../utils/signTypedData.js");
16
14
  const createPerpsClient_js_1 = require("./createPerpsClient.js");
15
+ const projectAccountConfigSettings_js_1 = require("./projectAccountConfigSettings.js");
16
+ const types_js_1 = require("./types.js");
17
+ const MAX_NONCE_RETRIES = 3;
18
+ function findActionDescriptor(metadata, action) {
19
+ const descriptor = [
20
+ ...metadata.setup,
21
+ ...metadata.options,
22
+ ...metadata.actions,
23
+ ].find((d) => d.type === action);
24
+ if (!descriptor) {
25
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `Provider '${metadata.key}' does not declare action '${action}'.`);
26
+ }
27
+ return descriptor;
28
+ }
17
29
  class PerpsClient {
18
30
  sdkClient;
31
+ storage;
19
32
  signingModes = new Map();
33
+ providerMetadataCache = new Map();
34
+ _signer;
35
+ lighterConfig;
36
+ lighterReadOnlyTokenOptions;
37
+ _lighterSigner;
38
+ _lighterKeyStore;
39
+ _lighterReadOnlyTokenManager;
20
40
  constructor(options) {
41
+ this.storage = options.storage ?? storage_js_1.localStorageAdapter;
42
+ this.lighterConfig = options.lighter;
43
+ this.lighterReadOnlyTokenOptions = options.lighterReadOnlyToken;
21
44
  this.sdkClient = (0, createPerpsClient_js_1.createPerpsClient)({
22
45
  integrator: options.integrator,
23
46
  apiKey: options.apiKey,
24
47
  apiUrl: options.apiUrl,
25
- storage: options.storage,
48
+ storage: this.storage,
49
+ providers: options.providers,
50
+ });
51
+ }
52
+ getLighterSigner() {
53
+ if (!this._lighterSigner) {
54
+ this._lighterSigner = new index_js_1.LighterSigner(this.lighterConfig);
55
+ }
56
+ return this._lighterSigner;
57
+ }
58
+ getLighterKeyStore() {
59
+ if (!this._lighterKeyStore) {
60
+ this._lighterKeyStore = new index_js_1.LighterKeyStore(this.storage);
61
+ }
62
+ return this._lighterKeyStore;
63
+ }
64
+ getLighterReadOnlyTokenManager() {
65
+ if (!this._lighterReadOnlyTokenManager) {
66
+ this._lighterReadOnlyTokenManager = new index_js_1.LighterReadOnlyTokenManager({
67
+ storage: this.storage,
68
+ ...this.lighterReadOnlyTokenOptions,
69
+ });
70
+ }
71
+ return this._lighterReadOnlyTokenManager;
72
+ }
73
+ setSigner(signer) {
74
+ this._signer = signer;
75
+ Object.defineProperty(this.sdkClient, 'signer', {
76
+ get: () => this._signer,
77
+ configurable: true,
26
78
  });
27
79
  }
28
80
  get client() {
29
81
  return this.sdkClient;
30
82
  }
31
- modeKey(address, dex) {
32
- return `${address.toLowerCase()}:${dex.toLowerCase()}`;
83
+ modeKey(address, provider) {
84
+ return `${address.toLowerCase()}:${provider.toLowerCase()}`;
33
85
  }
34
- async setSigningMode(address, dex, mode) {
35
- const key = this.modeKey(address, dex);
36
- this.signingModes.set(key, mode);
37
- if (mode === 'USER_AGENT') {
38
- await this.sdkClient.agentManager.getOrCreateAgent(address, dex);
86
+ signingModeStorageKey(address, provider) {
87
+ return `lifi-perps-mode:${address.toLowerCase()}:${provider.toLowerCase()}`;
88
+ }
89
+ async getProviderMetadata(provider) {
90
+ const cached = this.providerMetadataCache.get(provider);
91
+ if (cached) {
92
+ return cached;
93
+ }
94
+ const { providers } = await (0, getProviders_js_1.getProviders)(this.sdkClient);
95
+ for (const d of providers) {
96
+ this.providerMetadataCache.set(d.key, d);
39
97
  }
98
+ const metadata = this.providerMetadataCache.get(provider);
99
+ if (!metadata) {
100
+ const error = new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `Unsupported provider: ${provider}`);
101
+ error.tool = '@lifi/perps-sdk';
102
+ throw error;
103
+ }
104
+ return metadata;
40
105
  }
41
- getSigningMode(address, dex) {
42
- return this.signingModes.get(this.modeKey(address, dex)) ?? 'USER';
106
+ static EXPLICIT_INPUT_PREREQUISITES = new Set([perps_types_1.ActionType.ACCOUNT_MODE, perps_types_1.ActionType.ACCOUNT_TYPE]);
107
+ buildPrerequisiteInputs(prerequisites, mode, agentAddress) {
108
+ return prerequisites
109
+ .filter((p) => {
110
+ if (PerpsClient.EXPLICIT_INPUT_PREREQUISITES.has(p.type)) {
111
+ return false;
112
+ }
113
+ if (mode === types_js_1.SigningMode.USER) {
114
+ if (!p.signers.includes(perps_types_1.PerpsSigner.USER)) {
115
+ return false;
116
+ }
117
+ if (p.type === perps_types_1.ActionType.APPROVE_AGENT) {
118
+ return false;
119
+ }
120
+ return true;
121
+ }
122
+ return true;
123
+ })
124
+ .map((p) => {
125
+ const params = {};
126
+ if (p.type === perps_types_1.ActionType.APPROVE_AGENT && agentAddress) {
127
+ params.agentAddress = agentAddress;
128
+ }
129
+ return {
130
+ key: p.type,
131
+ ...(Object.keys(params).length > 0 ? { params } : {}),
132
+ };
133
+ });
43
134
  }
44
- async getAgentAddress(address, dex) {
45
- const agent = await this.sdkClient.agentManager.getAgent(address, dex);
135
+ async resolveSignerForAction(action, address, provider) {
136
+ const mode = await this.loadSigningMode(address, provider);
137
+ if (mode !== types_js_1.SigningMode.USER_AGENT) {
138
+ return undefined;
139
+ }
140
+ const metadata = await this.getProviderMetadata(provider);
141
+ const allActions = [
142
+ ...metadata.setup,
143
+ ...metadata.options,
144
+ ...metadata.actions,
145
+ ];
146
+ const descriptor = allActions.find((d) => d.type === action);
147
+ if (!descriptor?.signers.includes(perps_types_1.PerpsSigner.AGENT)) {
148
+ return undefined;
149
+ }
150
+ const agent = await this.sdkClient.agentManager.getAgent(address, provider);
46
151
  return agent.address;
47
152
  }
48
- async hasAgent(address, dex) {
49
- return this.sdkClient.agentManager.hasAgent(address, dex);
153
+ async providerUsesAgent(provider) {
154
+ const metadata = await this.getProviderMetadata(provider);
155
+ const all = [...metadata.setup, ...metadata.options, ...metadata.actions];
156
+ return all.some((d) => d.signers.includes(perps_types_1.PerpsSigner.AGENT));
50
157
  }
51
- async removeAgent(address, dex) {
52
- await this.sdkClient.agentManager.removeAgent(address, dex);
53
- this.signingModes.delete(this.modeKey(address, dex));
158
+ async autoSignAndExecute(provider, address, action, actions, descriptor) {
159
+ switch (descriptor.signingMethod) {
160
+ case perps_types_1.SigningMethod.EIP712: {
161
+ const eip712Actions = actions;
162
+ if (descriptor.signers.includes(perps_types_1.PerpsSigner.AGENT)) {
163
+ const agent = await this.sdkClient.agentManager.getAgent(address, provider);
164
+ const signedActions = await Promise.all(eip712Actions.map(async (a) => ({
165
+ action: a.action,
166
+ typedData: a.typedData,
167
+ signature: await (0, signTypedData_js_1.signTypedData)(agent.privateKey, a.typedData),
168
+ })));
169
+ return (0, executeAction_js_1.executeAction)(this.sdkClient, {
170
+ provider,
171
+ address,
172
+ signerAddress: agent.address,
173
+ action,
174
+ actions: signedActions,
175
+ });
176
+ }
177
+ if (descriptor.signers.includes(perps_types_1.PerpsSigner.USER)) {
178
+ const signer = this.sdkClient.signer;
179
+ if (!signer) {
180
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `Action '${action}' requires a user-wallet signature, but no signer was configured. Pass a WalletClient to createPerpsClient({ signer }).`);
181
+ }
182
+ const signedActions = await Promise.all(eip712Actions.map(async (a) => ({
183
+ action: a.action,
184
+ typedData: a.typedData,
185
+ signature: await (0, signTypedData_js_1.signTypedDataWithSigner)(signer, a.typedData),
186
+ })));
187
+ return (0, executeAction_js_1.executeAction)(this.sdkClient, {
188
+ provider,
189
+ address,
190
+ signerAddress: address,
191
+ action,
192
+ actions: signedActions,
193
+ });
194
+ }
195
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `Action '${action}' descriptor names no supported signer (signers=[${descriptor.signers.join(', ')}]).`);
196
+ }
197
+ case perps_types_1.SigningMethod.WASM_BLOB: {
198
+ const wasmActions = actions;
199
+ const signedActions = await this.signWasmBlobActions(provider, address, wasmActions);
200
+ return (0, executeAction_js_1.executeAction)(this.sdkClient, {
201
+ provider,
202
+ address,
203
+ signerAddress: address,
204
+ action,
205
+ actions: signedActions,
206
+ });
207
+ }
208
+ case perps_types_1.SigningMethod.EVM_TX: {
209
+ const evmActions = actions;
210
+ const signedActions = await this.signEvmTxActions(evmActions);
211
+ return (0, executeAction_js_1.executeAction)(this.sdkClient, {
212
+ provider,
213
+ address,
214
+ signerAddress: address,
215
+ action,
216
+ actions: signedActions,
217
+ });
218
+ }
219
+ default:
220
+ throw new Error(`Unknown signingMethod: ${descriptor.signingMethod}`);
221
+ }
54
222
  }
55
- async buildAuthorization(params) {
56
- const mode = this.getSigningMode(params.address, params.dex);
57
- let { signerAddress } = params;
58
- if (mode === 'USER_AGENT') {
59
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
60
- signerAddress = signerAddress ?? agent.address;
223
+ async signPrerequisite(provider, address, step) {
224
+ if ('typedData' in step) {
225
+ if (!this.sdkClient.signer) {
226
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'EIP-712 prerequisite signing requires a wallet signer. Pass ' +
227
+ '`signer` to createPerpsClient or call setSigner(walletClient).');
228
+ }
229
+ return {
230
+ action: step.action,
231
+ typedData: step.typedData,
232
+ signature: await (0, signTypedData_js_1.signTypedDataWithSigner)(this.sdkClient.signer, step.typedData),
233
+ };
61
234
  }
62
- return (0, createAuthorization_js_1.createAuthorization)(this.sdkClient, {
63
- ...params,
64
- signerAddress,
65
- });
235
+ if ('wasmSignParams' in step) {
236
+ const [signed] = await this.signWasmBlobActions(provider, address, [step]);
237
+ return signed;
238
+ }
239
+ if ('txParams' in step) {
240
+ const [signed] = await this.signEvmTxActions([step]);
241
+ return signed;
242
+ }
243
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'Unknown ActionStep shape — expected typedData, wasmSignParams, or txParams.');
66
244
  }
67
- async submitAuthorizations(params) {
68
- const mode = this.getSigningMode(params.address, params.dex);
69
- let { signerAddress } = params;
70
- if (mode === 'USER_AGENT') {
71
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
72
- signerAddress = signerAddress ?? agent.address;
245
+ async signEvmTxActions(actions) {
246
+ if (!this.sdkClient.signer) {
247
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'EVM_TX signing requires a wallet signer. Pass `signer` to ' +
248
+ 'createPerpsClient or call setSigner(walletClient).');
249
+ }
250
+ const { signer } = this.sdkClient;
251
+ const signed = [];
252
+ for (const step of actions) {
253
+ const params = step.txParams;
254
+ const txHash = await signer.writeContract({
255
+ address: params.to,
256
+ abi: (0, viem_1.parseAbi)(params.abi),
257
+ functionName: params.functionName,
258
+ args: params.args,
259
+ chain: signer.chain,
260
+ account: signer.account,
261
+ });
262
+ signed.push({
263
+ action: step.action,
264
+ txParams: step.txParams,
265
+ txHash,
266
+ });
73
267
  }
74
- return (0, submitAuthorization_js_1.submitAuthorization)(this.sdkClient, { ...params, signerAddress });
268
+ return signed;
75
269
  }
76
- async buildOrder(params) {
77
- const mode = this.getSigningMode(params.address, params.dex);
78
- let signerAddress;
79
- if (mode === 'USER_AGENT') {
80
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
81
- signerAddress = agent.address;
270
+ async signWasmBlobActions(provider, address, actions) {
271
+ const signed = [];
272
+ for (const step of actions) {
273
+ if (step.action === perps_types_1.ActionType.REGISTER_API_KEY) {
274
+ signed.push(await this.signRegisterApiKey(provider, address, step));
275
+ }
276
+ else if (step.action === perps_types_1.ActionType.ACCOUNT_TYPE) {
277
+ signed.push(await this.signAccountTierChange(address, step));
278
+ }
279
+ else {
280
+ signed.push(await this.signStandardWasmAction(provider, address, step));
281
+ }
82
282
  }
83
- return (0, createOrder_js_1.createOrder)(this.sdkClient, {
84
- dex: params.dex,
85
- address: params.address,
86
- signerAddress,
87
- clientOrderId: params.clientOrderId,
88
- symbol: params.symbol,
89
- side: params.side,
90
- type: params.type,
91
- size: params.size,
92
- price: params.price,
93
- leverage: params.leverage,
94
- reduceOnly: params.reduceOnly,
95
- timeInForce: params.timeInForce,
96
- expiresAt: params.expiresAt,
97
- takeProfit: params.takeProfit,
98
- stopLoss: params.stopLoss,
99
- });
283
+ return signed;
100
284
  }
101
- async buildCancelOrder(params) {
102
- const mode = this.getSigningMode(params.address, params.dex);
103
- let signerAddress;
104
- if (mode === 'USER_AGENT') {
105
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
106
- signerAddress = agent.address;
285
+ async signStandardWasmAction(provider, address, step) {
286
+ const apiKey = await this.getLighterKeyStore().get(address);
287
+ if (!apiKey) {
288
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `No Lighter API key registered for ${address}. ` +
289
+ 'Run prepareAccount / REGISTER_API_KEY first.');
107
290
  }
108
- return (0, cancelOrder_js_1.cancelOrder)(this.sdkClient, {
109
- dex: params.dex,
110
- address: params.address,
111
- signerAddress,
112
- ids: params.ids,
291
+ const signer = this.getLighterSigner();
292
+ const signedTx = await signer.sign(step.action, step.wasmSignParams, {
293
+ apiKeyPrivateKey: apiKey.apiKeyPrivateKey,
294
+ apiKeyIndex: apiKey.apiKeyIndex,
295
+ accountIndex: apiKey.accountIndex,
113
296
  });
297
+ void provider;
298
+ return {
299
+ action: step.action,
300
+ wasmSignParams: step.wasmSignParams,
301
+ signedTx,
302
+ };
114
303
  }
115
- async placeOrder(params) {
116
- const mode = this.getSigningMode(params.address, params.dex);
117
- if (mode !== 'USER_AGENT') {
118
- throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.ValidationError, `${constants_js_1.PerpsErrorMessage.InvalidSigningMode} placeOrder() requires USER_AGENT mode. Use createOrder() + submitOrder() for USER mode.`);
304
+ async signRegisterApiKey(provider, address, step) {
305
+ if (!this.sdkClient.signer) {
306
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'REGISTER_API_KEY requires a wallet signer — pass `signer` to ' +
307
+ 'createPerpsClient or call setSigner(walletClient).');
119
308
  }
120
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
121
- const { actions } = await (0, createOrder_js_1.createOrder)(this.sdkClient, {
122
- dex: params.dex,
123
- address: params.address,
124
- signerAddress: agent.address,
125
- clientOrderId: params.clientOrderId,
126
- symbol: params.symbol,
127
- side: params.side,
128
- type: params.type,
129
- size: params.size,
130
- price: params.price,
131
- leverage: params.leverage,
132
- reduceOnly: params.reduceOnly,
133
- timeInForce: params.timeInForce,
134
- expiresAt: params.expiresAt,
135
- takeProfit: params.takeProfit,
136
- stopLoss: params.stopLoss,
309
+ const params = step.wasmSignParams;
310
+ const apiKeyIndex = params.api_key_index ?? index_js_1.DEFAULT_API_KEY_INDEX;
311
+ const nonce = params.nonce;
312
+ if (typeof nonce !== 'number') {
313
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'REGISTER_API_KEY wasmSignParams is missing `nonce`.');
314
+ }
315
+ const account = await (0, getAccount_js_1.getAccount)(this.sdkClient, { provider, address });
316
+ if (account.config.provider !== 'lighter') {
317
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `REGISTER_API_KEY requires a Lighter account, but getAccount ` +
318
+ `returned config for provider '${account.config.provider}'.`);
319
+ }
320
+ const accountIndex = account.config.accountIndex;
321
+ const signer = this.getLighterSigner();
322
+ const keypair = await signer.generateAPIKey();
323
+ const changePubKey = await signer.signChangePubKey(keypair.publicKey, keypair.privateKey, nonce, apiKeyIndex, accountIndex);
324
+ const l1Signature = await this.sdkClient.signer.signMessage({
325
+ account: this.sdkClient.signer.account,
326
+ message: changePubKey.messageToSign,
137
327
  });
138
- const signedActions = await Promise.all(actions.map(async (a) => ({
139
- action: a.action,
140
- typedData: a.typedData,
141
- signature: await (0, signTypedData_js_1.signTypedData)(agent.privateKey, a.typedData),
142
- })));
143
- return (0, submitOrder_js_1.submitOrder)(this.sdkClient, {
144
- dex: params.dex,
145
- address: params.address,
146
- signerAddress: agent.address,
147
- actions: signedActions,
328
+ const txInfoWithL1Sig = signer.embedL1Signature(changePubKey.txInfo, l1Signature);
329
+ const apiKey = {
330
+ accountIndex,
331
+ apiKeyIndex,
332
+ apiKeyPrivateKey: keypair.privateKey,
333
+ apiKeyPublicKey: keypair.publicKey,
334
+ };
335
+ await this.getLighterKeyStore().set(address, apiKey);
336
+ return {
337
+ action: step.action,
338
+ wasmSignParams: {
339
+ ...step.wasmSignParams,
340
+ new_public_key: keypair.publicKey,
341
+ },
342
+ signedTx: {
343
+ txType: changePubKey.txType,
344
+ txInfo: txInfoWithL1Sig,
345
+ txHash: changePubKey.txHash,
346
+ },
347
+ };
348
+ }
349
+ async signAccountTierChange(address, step) {
350
+ const apiKey = await this.getLighterKeyStore().get(address);
351
+ if (!apiKey) {
352
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `No Lighter API key registered for ${address}. ` +
353
+ 'Run prepareAccount / REGISTER_API_KEY first.');
354
+ }
355
+ const signer = this.getLighterSigner();
356
+ const deadline = Math.floor(Date.now() / 1000) + 60 * 60;
357
+ const authToken = await signer.createAuthToken(deadline, {
358
+ apiKeyPrivateKey: apiKey.apiKeyPrivateKey,
359
+ apiKeyIndex: apiKey.apiKeyIndex,
360
+ accountIndex: apiKey.accountIndex,
148
361
  });
362
+ return {
363
+ action: step.action,
364
+ wasmSignParams: step.wasmSignParams,
365
+ signedTx: {
366
+ txType: 0,
367
+ txInfo: authToken,
368
+ txHash: '',
369
+ },
370
+ };
149
371
  }
150
- async cancelOrders(params) {
151
- const mode = this.getSigningMode(params.address, params.dex);
152
- if (mode !== 'USER_AGENT') {
153
- throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.ValidationError, `${constants_js_1.PerpsErrorMessage.InvalidSigningMode} cancelOrders() requires USER_AGENT mode. Use cancelOrder() + submitOrder() for USER mode.`);
372
+ async createLighterAuthToken(address, deadlineSeconds, accountIndex) {
373
+ const apiKey = await this.getLighterKeyStore().get(address);
374
+ const resolvedAccountIndex = accountIndex ?? apiKey?.accountIndex;
375
+ if (resolvedAccountIndex !== undefined) {
376
+ const stored = await this.getLighterReadOnlyTokenManager().get(address, resolvedAccountIndex);
377
+ if (stored) {
378
+ return stored.token;
379
+ }
154
380
  }
155
- const agent = await this.sdkClient.agentManager.getAgent(params.address, params.dex);
156
- const { actions } = await (0, cancelOrder_js_1.cancelOrder)(this.sdkClient, {
157
- dex: params.dex,
158
- address: params.address,
159
- signerAddress: agent.address,
160
- ids: params.ids,
381
+ if (!apiKey) {
382
+ return undefined;
383
+ }
384
+ const deadline = deadlineSeconds ?? Math.floor(Date.now() / 1000) + 60 * 60;
385
+ const signer = this.getLighterSigner();
386
+ return signer.createAuthToken(deadline, {
387
+ apiKeyPrivateKey: apiKey.apiKeyPrivateKey,
388
+ apiKeyIndex: apiKey.apiKeyIndex,
389
+ accountIndex: apiKey.accountIndex,
161
390
  });
162
- const signedActions = await Promise.all(actions.map(async (a) => ({
163
- action: a.action,
164
- typedData: a.typedData,
165
- signature: await (0, signTypedData_js_1.signTypedData)(agent.privateKey, a.typedData),
166
- })));
167
- return (0, submitOrder_js_1.submitOrder)(this.sdkClient, {
168
- dex: params.dex,
169
- address: params.address,
170
- signerAddress: agent.address,
171
- actions: signedActions,
391
+ }
392
+ async approveReadOnlyToken(address, params) {
393
+ if (!this.sdkClient.signer) {
394
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, 'approveReadOnlyToken requires a wallet signer — pass `signer` to ' +
395
+ 'createPerpsClient or call setSigner(walletClient).');
396
+ }
397
+ const signer = (0, index_js_1.walletClientSigner)(this.sdkClient.signer);
398
+ return this.getLighterReadOnlyTokenManager().approve(signer, {
399
+ address,
400
+ ...params,
172
401
  });
173
402
  }
174
- async submitSignedOrder(params) {
175
- return (0, submitOrder_js_1.submitOrder)(this.sdkClient, params);
403
+ async isLighterReadOnlyTokenExpiringSoon(address, accountIndex, thresholdDays) {
404
+ return this.getLighterReadOnlyTokenManager().isReadOnlyTokenExpiringSoon(address, accountIndex, thresholdDays);
176
405
  }
177
- async buildWithdrawal(params) {
178
- return (0, createWithdrawal_js_1.createWithdrawal)(this.sdkClient, {
179
- dex: params.dex,
406
+ async buildAction(action, params) {
407
+ const signerAddress = await this.resolveSignerForAction(action, params.address, params.provider);
408
+ return (0, createAction_js_1.createAction)(this.sdkClient, {
409
+ provider: params.provider,
180
410
  address: params.address,
181
- withdrawal: params.withdrawal,
411
+ signerAddress,
412
+ action,
413
+ params: params.params,
182
414
  });
183
415
  }
184
- async submitWithdrawal(params) {
185
- return (0, submitWithdrawal_js_1.submitWithdrawal)(this.sdkClient, params);
416
+ async setSigningMode(address, provider, mode) {
417
+ const key = this.modeKey(address, provider);
418
+ this.signingModes.set(key, mode);
419
+ await this.storage.set(this.signingModeStorageKey(address, provider), mode);
420
+ if (mode === types_js_1.SigningMode.USER_AGENT &&
421
+ (await this.providerUsesAgent(provider))) {
422
+ await this.sdkClient.agentManager.getOrCreateAgent(address, provider);
423
+ }
424
+ }
425
+ getSigningMode(address, provider) {
426
+ return (this.signingModes.get(this.modeKey(address, provider)) ??
427
+ types_js_1.SigningMode.USER_AGENT);
428
+ }
429
+ async loadSigningMode(address, provider) {
430
+ const key = this.modeKey(address, provider);
431
+ if (this.signingModes.has(key)) {
432
+ return this.signingModes.get(key);
433
+ }
434
+ const stored = await this.storage.get(this.signingModeStorageKey(address, provider));
435
+ const mode = stored === types_js_1.SigningMode.USER_AGENT || stored === types_js_1.SigningMode.USER
436
+ ? stored
437
+ : types_js_1.SigningMode.USER_AGENT;
438
+ this.signingModes.set(key, mode);
439
+ return mode;
440
+ }
441
+ async loadAgentMode(address, provider) {
442
+ const mode = await this.loadSigningMode(address, provider);
443
+ return mode === types_js_1.SigningMode.USER_AGENT;
444
+ }
445
+ async setAgentMode(address, provider, useAgent) {
446
+ await this.setSigningMode(address, provider, useAgent ? types_js_1.SigningMode.USER_AGENT : types_js_1.SigningMode.USER);
447
+ }
448
+ async getAgentAddress(address, provider) {
449
+ const agent = await this.sdkClient.agentManager.getAgent(address, provider);
450
+ return agent.address;
186
451
  }
187
- async getRequiredAuthorizations(params) {
188
- const { dex, address } = params;
189
- const mode = this.getSigningMode(address, dex);
190
- const provider = (0, registry_js_1.getDexAuthProvider)(dex);
452
+ async hasAgent(address, provider) {
453
+ return this.sdkClient.agentManager.hasAgent(address, provider);
454
+ }
455
+ async removeAgent(address, provider) {
456
+ await this.sdkClient.agentManager.removeAgent(address, provider);
457
+ this.signingModes.delete(this.modeKey(address, provider));
458
+ await this.storage.remove(this.signingModeStorageKey(address, provider));
459
+ }
460
+ async getAccount(params) {
461
+ const [response, metadata] = await Promise.all([
462
+ (0, getAccount_js_1.getAccount)(this.sdkClient, params),
463
+ this.getProviderMetadata(params.provider),
464
+ ]);
465
+ const settings = (0, projectAccountConfigSettings_js_1.projectAccountConfigSettings)(response.config, metadata.setup, metadata.options);
466
+ return { ...response, settings };
467
+ }
468
+ async accountExists(provider, address) {
469
+ try {
470
+ await (0, getAccount_js_1.getAccount)(this.sdkClient, { provider, address });
471
+ return true;
472
+ }
473
+ catch (err) {
474
+ if (err instanceof PerpsError_js_1.PerpsError &&
475
+ err.code === perps_types_1.PerpsErrorCode.AccountNotFound) {
476
+ return false;
477
+ }
478
+ throw err;
479
+ }
480
+ }
481
+ async checkSetup(params) {
482
+ const { provider, address } = params;
483
+ const mode = await this.loadSigningMode(address, provider);
484
+ const metadata = await this.getProviderMetadata(provider);
485
+ const usesAgent = [
486
+ ...metadata.setup,
487
+ ...metadata.options,
488
+ ...metadata.actions,
489
+ ].some((d) => d.signers.includes(perps_types_1.PerpsSigner.AGENT));
191
490
  let agentAddress;
192
- if (mode === 'USER_AGENT') {
193
- const agent = await this.sdkClient.agentManager.getOrCreateAgent(address, dex);
491
+ if (mode === types_js_1.SigningMode.USER_AGENT && usesAgent) {
492
+ const agent = await this.sdkClient.agentManager.getOrCreateAgent(address, provider);
194
493
  agentAddress = agent.address;
195
494
  }
196
- const authInputs = provider.getAuthorizationInputs({
197
- signingMode: mode,
198
- agentAddress,
199
- });
200
- const allInputs = [...authInputs.user, ...authInputs.agent];
495
+ const allInputs = this.buildPrerequisiteInputs(metadata.setup, mode, agentAddress);
201
496
  if (allInputs.length === 0) {
202
- return { userAuthorizations: [], agentAuthorizations: [], isReady: true };
497
+ return { userPrerequisites: [], agentPrerequisites: [], isReady: true };
498
+ }
499
+ const signersByAction = new Map();
500
+ for (const desc of metadata.setup) {
501
+ signersByAction.set(desc.type, desc.signers);
203
502
  }
204
- const { actions } = await this.buildAuthorization({
205
- dex,
503
+ const { actions } = await this.buildPrerequisites({
504
+ provider,
206
505
  address,
207
- authorizations: allInputs,
506
+ signerAddress: agentAddress,
208
507
  });
209
508
  if (actions.length === 0) {
210
- return { userAuthorizations: [], agentAuthorizations: [], isReady: true };
509
+ return { userPrerequisites: [], agentPrerequisites: [], isReady: true };
211
510
  }
212
- const agentKeys = new Set(authInputs.agent.map((a) => a.key));
213
- const userAuthorizations = actions.filter((a) => !agentKeys.has(a.action));
214
- const agentAuthorizations = actions.filter((a) => agentKeys.has(a.action));
511
+ const userPrerequisites = actions.filter((a) => {
512
+ const signers = signersByAction.get(a.action) ?? [];
513
+ return signers.includes(perps_types_1.PerpsSigner.USER);
514
+ });
515
+ const agentPrerequisites = actions.filter((a) => {
516
+ const signers = signersByAction.get(a.action) ?? [];
517
+ return signers.includes(perps_types_1.PerpsSigner.AGENT);
518
+ });
215
519
  return {
216
- userAuthorizations,
217
- agentAuthorizations,
520
+ userPrerequisites,
521
+ agentPrerequisites,
218
522
  isReady: false,
219
523
  };
220
524
  }
221
- async executeAuthorizations(params) {
222
- const { dex, address, required, userSignedActions } = params;
223
- const mode = this.getSigningMode(address, dex);
525
+ async buildPrerequisites(params) {
526
+ const mode = await this.loadSigningMode(params.address, params.provider);
527
+ let { signerAddress } = params;
528
+ if (mode === types_js_1.SigningMode.USER_AGENT && !signerAddress) {
529
+ const agent = await this.sdkClient.agentManager.getAgent(params.address, params.provider);
530
+ signerAddress = agent.address;
531
+ }
532
+ const metadata = await this.getProviderMetadata(params.provider);
533
+ const allInputs = this.buildPrerequisiteInputs(metadata.setup, mode, signerAddress);
534
+ const allActions = [];
535
+ for (const input of allInputs) {
536
+ const { actions } = await (0, createAction_js_1.createAction)(this.sdkClient, {
537
+ provider: params.provider,
538
+ address: params.address,
539
+ signerAddress,
540
+ action: input.key,
541
+ params: (input.params ?? {}),
542
+ });
543
+ allActions.push(...actions);
544
+ }
545
+ return { actions: allActions };
546
+ }
547
+ static DEFAULT_ACCOUNT_MODE = 'unifiedAccount';
548
+ async prepareAccountModeChange(provider, address, mode) {
549
+ const account = await (0, getAccount_js_1.getAccount)(this.sdkClient, { provider, address });
550
+ if (account.config.provider !== 'hyperliquid') {
551
+ throw new PerpsError_js_1.PerpsError(perps_types_1.PerpsErrorCode.SDKError, `prepareAccountModeChange is Hyperliquid-specific, but ` +
552
+ `getAccount returned config for provider ` +
553
+ `'${account.config.provider}'.`);
554
+ }
555
+ const currentStatus = account.config.abstractionMode;
556
+ if (currentStatus === mode) {
557
+ return {};
558
+ }
559
+ if (currentStatus == null) {
560
+ const agent = await this.sdkClient.agentManager.getAgent(address, provider);
561
+ const { actions } = await (0, createAction_js_1.createAction)(this.sdkClient, {
562
+ provider,
563
+ address,
564
+ signerAddress: agent.address,
565
+ action: perps_types_1.ActionType.ACCOUNT_MODE,
566
+ params: { mode },
567
+ });
568
+ if (actions.length === 0) {
569
+ return { results: { results: [] } };
570
+ }
571
+ const signedActions = await Promise.all(actions.map(async (a) => ({
572
+ action: a.action,
573
+ typedData: a.typedData,
574
+ signature: await (0, signTypedData_js_1.signTypedData)(agent.privateKey, a.typedData),
575
+ })));
576
+ const results = await (0, executeAction_js_1.executeAction)(this.sdkClient, {
577
+ provider,
578
+ address,
579
+ signerAddress: agent.address,
580
+ action: perps_types_1.ActionType.ACCOUNT_MODE,
581
+ actions: signedActions,
582
+ });
583
+ return { results };
584
+ }
585
+ const { actions: fallbackActions } = await (0, createAction_js_1.createAction)(this.sdkClient, {
586
+ provider,
587
+ address,
588
+ action: perps_types_1.ActionType.ACCOUNT_MODE,
589
+ params: { mode },
590
+ });
591
+ return {
592
+ fallback: fallbackActions.length > 0 ? fallbackActions : undefined,
593
+ };
594
+ }
595
+ static hasWritableAccountMode(metadata) {
596
+ const item = [...metadata.setup, ...metadata.options].find((i) => i.type === perps_types_1.ActionType.ACCOUNT_MODE);
597
+ if (!item) {
598
+ return false;
599
+ }
600
+ const modeParam = item.params.find((p) => p.name === 'mode');
601
+ if (!modeParam) {
602
+ return false;
603
+ }
604
+ if (!modeParam.values || modeParam.values.length === 0) {
605
+ return false;
606
+ }
607
+ return !modeParam.readOnly;
608
+ }
609
+ async satisfySetup(params) {
610
+ const { provider, address, required, userSignedActions } = params;
611
+ const mode = await this.loadSigningMode(address, provider);
224
612
  let userResults = { results: [] };
225
613
  if (userSignedActions.length > 0) {
226
- const signerAddress = mode === 'USER_AGENT'
227
- ? (await this.sdkClient.agentManager.getAgent(address, dex)).address
614
+ const signerAddress = mode === types_js_1.SigningMode.USER_AGENT
615
+ ? (await this.sdkClient.agentManager.getAgent(address, provider))
616
+ .address
228
617
  : address;
229
- userResults = await (0, submitAuthorization_js_1.submitAuthorization)(this.sdkClient, {
230
- dex,
618
+ const firstAction = required.userPrerequisites[0]?.action;
619
+ userResults = await (0, executeAction_js_1.executeAction)(this.sdkClient, {
620
+ provider,
231
621
  address,
232
622
  signerAddress,
623
+ action: (firstAction ?? perps_types_1.ActionType.APPROVE_AGENT),
233
624
  actions: userSignedActions,
234
625
  });
235
- const failed = userResults.results.find((r) => !r.success);
236
- if (failed) {
626
+ const mandatoryFailure = userResults.results.find((r) => !r.success);
627
+ if (mandatoryFailure) {
237
628
  return { userResults };
238
629
  }
239
630
  }
240
- if (required.agentAuthorizations.length > 0 && mode === 'USER_AGENT') {
241
- const agent = await this.sdkClient.agentManager.getAgent(address, dex);
242
- const signedAgentActions = await Promise.all(required.agentAuthorizations.map(async (action) => ({
631
+ let agentResults;
632
+ let fallbackUserPrerequisites;
633
+ if (mode === types_js_1.SigningMode.USER_AGENT) {
634
+ const justApprovedAgent = userResults.results.some((r) => r.success && r.action === perps_types_1.ActionType.APPROVE_AGENT);
635
+ if (justApprovedAgent) {
636
+ const metadata = await this.getProviderMetadata(provider);
637
+ if (PerpsClient.hasWritableAccountMode(metadata)) {
638
+ const upgrade = await this.prepareAccountModeChange(provider, address, PerpsClient.DEFAULT_ACCOUNT_MODE);
639
+ agentResults = upgrade.results;
640
+ fallbackUserPrerequisites = upgrade.fallback;
641
+ }
642
+ }
643
+ }
644
+ if (required.agentPrerequisites.length > 0 &&
645
+ mode === types_js_1.SigningMode.USER_AGENT) {
646
+ const agent = await this.sdkClient.agentManager.getAgent(address, provider);
647
+ const signedAgentActions = await Promise.all(required.agentPrerequisites.map(async (action) => ({
243
648
  action: action.action,
244
649
  typedData: action.typedData,
245
650
  signature: await (0, signTypedData_js_1.signTypedData)(agent.privateKey, action.typedData),
246
651
  })));
247
- const agentResults = await (0, submitAuthorization_js_1.submitAuthorization)(this.sdkClient, {
248
- dex,
652
+ const firstAction = required.agentPrerequisites[0]?.action;
653
+ const stagedResults = await (0, executeAction_js_1.executeAction)(this.sdkClient, {
654
+ provider,
249
655
  address,
250
656
  signerAddress: agent.address,
657
+ action: (firstAction ?? perps_types_1.ActionType.ACCOUNT_MODE),
251
658
  actions: signedAgentActions,
252
659
  });
253
- return { userResults, agentResults };
660
+ agentResults = {
661
+ results: [...(agentResults?.results ?? []), ...stagedResults.results],
662
+ };
663
+ }
664
+ return {
665
+ userResults,
666
+ ...(agentResults ? { agentResults } : {}),
667
+ ...(fallbackUserPrerequisites ? { fallbackUserPrerequisites } : {}),
668
+ };
669
+ }
670
+ async placeOrder(params) {
671
+ return this.execute({ ...params, action: perps_types_1.ActionType.PLACE_ORDER, params });
672
+ }
673
+ async placeTriggerOrder(params) {
674
+ return this.execute({
675
+ ...params,
676
+ action: perps_types_1.ActionType.PLACE_TRIGGER_ORDER,
677
+ params,
678
+ });
679
+ }
680
+ async cancelOrders(params) {
681
+ return this.execute({ ...params, action: perps_types_1.ActionType.CANCEL_ORDER, params });
682
+ }
683
+ async modifyOrders(params) {
684
+ return this.execute({ ...params, action: perps_types_1.ActionType.MODIFY_ORDER, params });
685
+ }
686
+ async updatePositionMargin(params) {
687
+ return this.execute({
688
+ ...params,
689
+ action: perps_types_1.ActionType.UPDATE_POSITION_MARGIN,
690
+ params,
691
+ });
692
+ }
693
+ async withdraw(params) {
694
+ return this.execute({
695
+ provider: params.provider,
696
+ address: params.address,
697
+ action: perps_types_1.ActionType.WITHDRAWAL,
698
+ params: params.withdrawal,
699
+ });
700
+ }
701
+ async execute(params) {
702
+ await this.loadSigningMode(params.address, params.provider);
703
+ const metadata = await this.getProviderMetadata(params.provider);
704
+ const descriptor = findActionDescriptor(metadata, params.action);
705
+ let lastError;
706
+ for (let attempt = 0; attempt < MAX_NONCE_RETRIES; attempt++) {
707
+ const { actions } = await this.buildAction(params.action, {
708
+ provider: params.provider,
709
+ address: params.address,
710
+ params: params.params,
711
+ });
712
+ try {
713
+ return await this.autoSignAndExecute(params.provider, params.address, params.action, actions, descriptor);
714
+ }
715
+ catch (err) {
716
+ if (err instanceof PerpsError_js_1.PerpsError &&
717
+ err.code === perps_types_1.PerpsErrorCode.InvalidNonce) {
718
+ lastError = err;
719
+ continue;
720
+ }
721
+ throw err;
722
+ }
254
723
  }
255
- return { userResults };
724
+ throw lastError;
256
725
  }
257
726
  }
258
727
  exports.PerpsClient = PerpsClient;