hedgequantx 2.6.161 → 2.6.163

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 (57) hide show
  1. package/package.json +1 -1
  2. package/src/menus/ai-agent-connect.js +181 -0
  3. package/src/menus/ai-agent-models.js +219 -0
  4. package/src/menus/ai-agent-oauth.js +292 -0
  5. package/src/menus/ai-agent-ui.js +141 -0
  6. package/src/menus/ai-agent.js +88 -1489
  7. package/src/pages/algo/copy-engine.js +449 -0
  8. package/src/pages/algo/copy-trading.js +11 -543
  9. package/src/pages/algo/smart-logs-data.js +218 -0
  10. package/src/pages/algo/smart-logs.js +9 -214
  11. package/src/pages/algo/ui-constants.js +144 -0
  12. package/src/pages/algo/ui-summary.js +184 -0
  13. package/src/pages/algo/ui.js +42 -526
  14. package/src/pages/stats-calculations.js +191 -0
  15. package/src/pages/stats-ui.js +381 -0
  16. package/src/pages/stats.js +14 -507
  17. package/src/services/ai/client-analysis.js +194 -0
  18. package/src/services/ai/client-models.js +333 -0
  19. package/src/services/ai/client.js +6 -489
  20. package/src/services/ai/index.js +2 -257
  21. package/src/services/ai/providers/direct-providers.js +323 -0
  22. package/src/services/ai/providers/index.js +8 -472
  23. package/src/services/ai/providers/other-providers.js +104 -0
  24. package/src/services/ai/proxy-install.js +249 -0
  25. package/src/services/ai/proxy-manager.js +29 -411
  26. package/src/services/ai/proxy-remote.js +161 -0
  27. package/src/services/ai/supervisor-optimize.js +215 -0
  28. package/src/services/ai/supervisor-sync.js +178 -0
  29. package/src/services/ai/supervisor.js +50 -515
  30. package/src/services/ai/validation.js +250 -0
  31. package/src/services/hqx-server-events.js +110 -0
  32. package/src/services/hqx-server-handlers.js +217 -0
  33. package/src/services/hqx-server-latency.js +136 -0
  34. package/src/services/hqx-server.js +51 -403
  35. package/src/services/position-constants.js +28 -0
  36. package/src/services/position-exit-logic.js +174 -0
  37. package/src/services/position-manager.js +90 -629
  38. package/src/services/position-momentum.js +206 -0
  39. package/src/services/projectx/accounts.js +142 -0
  40. package/src/services/projectx/index.js +40 -289
  41. package/src/services/projectx/trading.js +180 -0
  42. package/src/services/rithmic/contracts.js +218 -0
  43. package/src/services/rithmic/handlers.js +2 -208
  44. package/src/services/rithmic/index.js +28 -712
  45. package/src/services/rithmic/latency-tracker.js +182 -0
  46. package/src/services/rithmic/market-data-decoders.js +229 -0
  47. package/src/services/rithmic/market-data.js +1 -278
  48. package/src/services/rithmic/orders-fast.js +246 -0
  49. package/src/services/rithmic/orders.js +1 -251
  50. package/src/services/rithmic/proto-decoders.js +403 -0
  51. package/src/services/rithmic/protobuf.js +7 -443
  52. package/src/services/rithmic/specs.js +146 -0
  53. package/src/services/rithmic/trade-history.js +254 -0
  54. package/src/services/strategy/hft-signal-calc.js +147 -0
  55. package/src/services/strategy/hft-tick.js +33 -133
  56. package/src/services/tradovate/index.js +6 -119
  57. package/src/services/tradovate/orders.js +145 -0
@@ -0,0 +1,403 @@
1
+ /**
2
+ * Rithmic Protobuf Manual Decoders
3
+ * @module services/rithmic/proto-decoders
4
+ *
5
+ * Hand-optimized decoders for Rithmic's large field ID messages.
6
+ * Faster than generic protobuf parsing for hot path.
7
+ */
8
+
9
+ // PnL field IDs (Rithmic uses very large field IDs)
10
+ const PNL_FIELDS = {
11
+ TEMPLATE_ID: 154467,
12
+ IS_SNAPSHOT: 110121,
13
+ FCM_ID: 154013,
14
+ IB_ID: 154014,
15
+ ACCOUNT_ID: 154008,
16
+ ACCOUNT_BALANCE: 156970,
17
+ CASH_ON_HAND: 156971,
18
+ MARGIN_BALANCE: 156977,
19
+ MIN_ACCOUNT_BALANCE: 156968,
20
+ OPEN_POSITION_PNL: 156961,
21
+ CLOSED_POSITION_PNL: 156963,
22
+ DAY_PNL: 157956,
23
+ DAY_OPEN_PNL: 157954,
24
+ DAY_CLOSED_PNL: 157955,
25
+ AVAILABLE_BUYING_POWER: 157015,
26
+ SSBOE: 150100,
27
+ USECS: 150101,
28
+ };
29
+
30
+ // Symbol/Contract field IDs
31
+ const SYMBOL_FIELDS = {
32
+ TEMPLATE_ID: 154467,
33
+ RP_CODE: 132766,
34
+ EXCHANGE: 110101,
35
+ PRODUCT_CODE: 110102,
36
+ PRODUCT_NAME: 110103,
37
+ SYMBOL: 110100,
38
+ TRADING_SYMBOL: 157095,
39
+ DESCRIPTION: 110114,
40
+ USER_MSG: 132760,
41
+ };
42
+
43
+ // Instrument PnL Position Update field IDs
44
+ const INSTRUMENT_PNL_FIELDS = {
45
+ TEMPLATE_ID: 154467,
46
+ IS_SNAPSHOT: 110121,
47
+ FCM_ID: 154013,
48
+ IB_ID: 154014,
49
+ ACCOUNT_ID: 154008,
50
+ SYMBOL: 110100,
51
+ EXCHANGE: 110101,
52
+ PRODUCT_CODE: 100749,
53
+ INSTRUMENT_TYPE: 110116,
54
+ FILL_BUY_QTY: 154041,
55
+ FILL_SELL_QTY: 154042,
56
+ ORDER_BUY_QTY: 154037,
57
+ ORDER_SELL_QTY: 154038,
58
+ BUY_QTY: 154260,
59
+ SELL_QTY: 154261,
60
+ AVG_OPEN_FILL_PRICE: 154434,
61
+ DAY_OPEN_PNL: 157954,
62
+ DAY_CLOSED_PNL: 157955,
63
+ DAY_PNL: 157956,
64
+ OPEN_POSITION_PNL: 156961,
65
+ OPEN_POSITION_QUANTITY: 156962,
66
+ CLOSED_POSITION_PNL: 156963,
67
+ CLOSED_POSITION_QUANTITY: 156964,
68
+ NET_QUANTITY: 156967,
69
+ SSBOE: 150100,
70
+ USECS: 150101,
71
+ };
72
+
73
+ /** Read a varint from buffer */
74
+ function readVarint(buffer, offset) {
75
+ let result = BigInt(0);
76
+ let shift = BigInt(0);
77
+ let pos = offset;
78
+
79
+ while (pos < buffer.length) {
80
+ const byte = buffer[pos++];
81
+ result |= BigInt(byte & 0x7f) << shift;
82
+ if ((byte & 0x80) === 0) {
83
+ return [Number(result), pos];
84
+ }
85
+ shift += BigInt(7);
86
+ if (shift > BigInt(63)) throw new Error('Varint too large');
87
+ }
88
+ throw new Error('Incomplete varint');
89
+ }
90
+
91
+ /** Read a length-delimited field (string/bytes) */
92
+ function readLengthDelimited(buffer, offset) {
93
+ const [length, newOffset] = readVarint(buffer, offset);
94
+ const value = buffer.slice(newOffset, newOffset + length).toString('utf8');
95
+ return [value, newOffset + length];
96
+ }
97
+
98
+ /** Skip a field based on wire type */
99
+ function skipField(buffer, offset, wireType) {
100
+ switch (wireType) {
101
+ case 0:
102
+ const [, newOffset] = readVarint(buffer, offset);
103
+ return newOffset;
104
+ case 1:
105
+ return offset + 8;
106
+ case 2:
107
+ const [length, lenOffset] = readVarint(buffer, offset);
108
+ return lenOffset + length;
109
+ case 5:
110
+ return offset + 4;
111
+ default:
112
+ throw new Error(`Unknown wire type: ${wireType}`);
113
+ }
114
+ }
115
+
116
+ /** Manually decode AccountPnL from raw bytes */
117
+ function decodeAccountPnL(buffer) {
118
+ const result = {};
119
+ let offset = 0;
120
+
121
+ while (offset < buffer.length) {
122
+ try {
123
+ const [tag, tagOffset] = readVarint(buffer, offset);
124
+ const wireType = tag & 0x7;
125
+ const fieldNumber = tag >>> 3;
126
+ offset = tagOffset;
127
+
128
+ switch (fieldNumber) {
129
+ case PNL_FIELDS.TEMPLATE_ID:
130
+ [result.templateId, offset] = readVarint(buffer, offset);
131
+ break;
132
+ case PNL_FIELDS.IS_SNAPSHOT:
133
+ const [isSnap, snapOffset] = readVarint(buffer, offset);
134
+ result.isSnapshot = isSnap !== 0;
135
+ offset = snapOffset;
136
+ break;
137
+ case PNL_FIELDS.FCM_ID:
138
+ [result.fcmId, offset] = readLengthDelimited(buffer, offset);
139
+ break;
140
+ case PNL_FIELDS.IB_ID:
141
+ [result.ibId, offset] = readLengthDelimited(buffer, offset);
142
+ break;
143
+ case PNL_FIELDS.ACCOUNT_ID:
144
+ [result.accountId, offset] = readLengthDelimited(buffer, offset);
145
+ break;
146
+ case PNL_FIELDS.ACCOUNT_BALANCE:
147
+ [result.accountBalance, offset] = readLengthDelimited(buffer, offset);
148
+ break;
149
+ case PNL_FIELDS.CASH_ON_HAND:
150
+ [result.cashOnHand, offset] = readLengthDelimited(buffer, offset);
151
+ break;
152
+ case PNL_FIELDS.MARGIN_BALANCE:
153
+ [result.marginBalance, offset] = readLengthDelimited(buffer, offset);
154
+ break;
155
+ case PNL_FIELDS.MIN_ACCOUNT_BALANCE:
156
+ [result.minAccountBalance, offset] = readLengthDelimited(buffer, offset);
157
+ break;
158
+ case PNL_FIELDS.OPEN_POSITION_PNL:
159
+ [result.openPositionPnl, offset] = readLengthDelimited(buffer, offset);
160
+ break;
161
+ case PNL_FIELDS.CLOSED_POSITION_PNL:
162
+ [result.closedPositionPnl, offset] = readLengthDelimited(buffer, offset);
163
+ break;
164
+ case PNL_FIELDS.DAY_PNL:
165
+ [result.dayPnl, offset] = readLengthDelimited(buffer, offset);
166
+ break;
167
+ case PNL_FIELDS.DAY_OPEN_PNL:
168
+ [result.dayOpenPnl, offset] = readLengthDelimited(buffer, offset);
169
+ break;
170
+ case PNL_FIELDS.DAY_CLOSED_PNL:
171
+ [result.dayClosedPnl, offset] = readLengthDelimited(buffer, offset);
172
+ break;
173
+ case PNL_FIELDS.AVAILABLE_BUYING_POWER:
174
+ [result.availableBuyingPower, offset] = readLengthDelimited(buffer, offset);
175
+ break;
176
+ case PNL_FIELDS.SSBOE:
177
+ [result.ssboe, offset] = readVarint(buffer, offset);
178
+ break;
179
+ case PNL_FIELDS.USECS:
180
+ [result.usecs, offset] = readVarint(buffer, offset);
181
+ break;
182
+ default:
183
+ offset = skipField(buffer, offset, wireType);
184
+ }
185
+ } catch (error) {
186
+ break;
187
+ }
188
+ }
189
+ return result;
190
+ }
191
+
192
+ /** Manually decode InstrumentPnLPositionUpdate from raw bytes */
193
+ function decodeInstrumentPnL(buffer) {
194
+ const result = {};
195
+ let offset = 0;
196
+
197
+ while (offset < buffer.length) {
198
+ try {
199
+ const [tag, tagOffset] = readVarint(buffer, offset);
200
+ const wireType = tag & 0x7;
201
+ const fieldNumber = tag >>> 3;
202
+ offset = tagOffset;
203
+
204
+ switch (fieldNumber) {
205
+ case INSTRUMENT_PNL_FIELDS.TEMPLATE_ID:
206
+ [result.templateId, offset] = readVarint(buffer, offset);
207
+ break;
208
+ case INSTRUMENT_PNL_FIELDS.IS_SNAPSHOT:
209
+ const [isSnap, snapOffset] = readVarint(buffer, offset);
210
+ result.isSnapshot = isSnap !== 0;
211
+ offset = snapOffset;
212
+ break;
213
+ case INSTRUMENT_PNL_FIELDS.FCM_ID:
214
+ [result.fcmId, offset] = readLengthDelimited(buffer, offset);
215
+ break;
216
+ case INSTRUMENT_PNL_FIELDS.IB_ID:
217
+ [result.ibId, offset] = readLengthDelimited(buffer, offset);
218
+ break;
219
+ case INSTRUMENT_PNL_FIELDS.ACCOUNT_ID:
220
+ [result.accountId, offset] = readLengthDelimited(buffer, offset);
221
+ break;
222
+ case INSTRUMENT_PNL_FIELDS.SYMBOL:
223
+ [result.symbol, offset] = readLengthDelimited(buffer, offset);
224
+ break;
225
+ case INSTRUMENT_PNL_FIELDS.EXCHANGE:
226
+ [result.exchange, offset] = readLengthDelimited(buffer, offset);
227
+ break;
228
+ case INSTRUMENT_PNL_FIELDS.PRODUCT_CODE:
229
+ [result.productCode, offset] = readLengthDelimited(buffer, offset);
230
+ break;
231
+ case INSTRUMENT_PNL_FIELDS.BUY_QTY:
232
+ [result.buyQty, offset] = readVarint(buffer, offset);
233
+ break;
234
+ case INSTRUMENT_PNL_FIELDS.SELL_QTY:
235
+ [result.sellQty, offset] = readVarint(buffer, offset);
236
+ break;
237
+ case INSTRUMENT_PNL_FIELDS.FILL_BUY_QTY:
238
+ [result.fillBuyQty, offset] = readVarint(buffer, offset);
239
+ break;
240
+ case INSTRUMENT_PNL_FIELDS.FILL_SELL_QTY:
241
+ [result.fillSellQty, offset] = readVarint(buffer, offset);
242
+ break;
243
+ case INSTRUMENT_PNL_FIELDS.NET_QUANTITY:
244
+ [result.netQuantity, offset] = readVarint(buffer, offset);
245
+ break;
246
+ case INSTRUMENT_PNL_FIELDS.OPEN_POSITION_QUANTITY:
247
+ [result.openPositionQuantity, offset] = readVarint(buffer, offset);
248
+ break;
249
+ case INSTRUMENT_PNL_FIELDS.AVG_OPEN_FILL_PRICE:
250
+ if (wireType === 1) {
251
+ result.avgOpenFillPrice = buffer.readDoubleLE(offset);
252
+ offset += 8;
253
+ } else {
254
+ offset = skipField(buffer, offset, wireType);
255
+ }
256
+ break;
257
+ case INSTRUMENT_PNL_FIELDS.OPEN_POSITION_PNL:
258
+ [result.openPositionPnl, offset] = readLengthDelimited(buffer, offset);
259
+ break;
260
+ case INSTRUMENT_PNL_FIELDS.CLOSED_POSITION_PNL:
261
+ [result.closedPositionPnl, offset] = readLengthDelimited(buffer, offset);
262
+ break;
263
+ case INSTRUMENT_PNL_FIELDS.DAY_PNL:
264
+ if (wireType === 1) {
265
+ result.dayPnl = buffer.readDoubleLE(offset);
266
+ offset += 8;
267
+ } else {
268
+ [result.dayPnl, offset] = readLengthDelimited(buffer, offset);
269
+ }
270
+ break;
271
+ case INSTRUMENT_PNL_FIELDS.DAY_OPEN_PNL:
272
+ if (wireType === 1) {
273
+ result.dayOpenPnl = buffer.readDoubleLE(offset);
274
+ offset += 8;
275
+ } else {
276
+ [result.dayOpenPnl, offset] = readLengthDelimited(buffer, offset);
277
+ }
278
+ break;
279
+ case INSTRUMENT_PNL_FIELDS.DAY_CLOSED_PNL:
280
+ if (wireType === 1) {
281
+ result.dayClosedPnl = buffer.readDoubleLE(offset);
282
+ offset += 8;
283
+ } else {
284
+ [result.dayClosedPnl, offset] = readLengthDelimited(buffer, offset);
285
+ }
286
+ break;
287
+ case INSTRUMENT_PNL_FIELDS.SSBOE:
288
+ [result.ssboe, offset] = readVarint(buffer, offset);
289
+ break;
290
+ case INSTRUMENT_PNL_FIELDS.USECS:
291
+ [result.usecs, offset] = readVarint(buffer, offset);
292
+ break;
293
+ default:
294
+ offset = skipField(buffer, offset, wireType);
295
+ }
296
+ } catch (error) {
297
+ break;
298
+ }
299
+ }
300
+ return result;
301
+ }
302
+
303
+ /** Decode ResponseProductCodes (template 112) */
304
+ function decodeProductCodes(buffer) {
305
+ const result = { rpCode: [] };
306
+ let offset = 0;
307
+
308
+ while (offset < buffer.length) {
309
+ try {
310
+ const [tag, tagOffset] = readVarint(buffer, offset);
311
+ const wireType = tag & 0x7;
312
+ const fieldNumber = tag >>> 3;
313
+ offset = tagOffset;
314
+
315
+ switch (fieldNumber) {
316
+ case SYMBOL_FIELDS.TEMPLATE_ID:
317
+ [result.templateId, offset] = readVarint(buffer, offset);
318
+ break;
319
+ case SYMBOL_FIELDS.RP_CODE:
320
+ let rpCode;
321
+ [rpCode, offset] = readLengthDelimited(buffer, offset);
322
+ result.rpCode.push(rpCode);
323
+ break;
324
+ case SYMBOL_FIELDS.EXCHANGE:
325
+ [result.exchange, offset] = readLengthDelimited(buffer, offset);
326
+ break;
327
+ case SYMBOL_FIELDS.PRODUCT_CODE:
328
+ [result.productCode, offset] = readLengthDelimited(buffer, offset);
329
+ break;
330
+ case SYMBOL_FIELDS.PRODUCT_NAME:
331
+ [result.productName, offset] = readLengthDelimited(buffer, offset);
332
+ break;
333
+ case SYMBOL_FIELDS.USER_MSG:
334
+ [result.userMsg, offset] = readLengthDelimited(buffer, offset);
335
+ break;
336
+ default:
337
+ offset = skipField(buffer, offset, wireType);
338
+ }
339
+ } catch (error) {
340
+ break;
341
+ }
342
+ }
343
+ return result;
344
+ }
345
+
346
+ /** Decode ResponseFrontMonthContract (template 114) */
347
+ function decodeFrontMonthContract(buffer) {
348
+ const result = { rpCode: [] };
349
+ let offset = 0;
350
+
351
+ while (offset < buffer.length) {
352
+ try {
353
+ const [tag, tagOffset] = readVarint(buffer, offset);
354
+ const wireType = tag & 0x7;
355
+ const fieldNumber = tag >>> 3;
356
+ offset = tagOffset;
357
+
358
+ switch (fieldNumber) {
359
+ case SYMBOL_FIELDS.TEMPLATE_ID:
360
+ [result.templateId, offset] = readVarint(buffer, offset);
361
+ break;
362
+ case SYMBOL_FIELDS.RP_CODE:
363
+ let rpCode;
364
+ [rpCode, offset] = readLengthDelimited(buffer, offset);
365
+ result.rpCode.push(rpCode);
366
+ break;
367
+ case SYMBOL_FIELDS.SYMBOL:
368
+ [result.symbol, offset] = readLengthDelimited(buffer, offset);
369
+ break;
370
+ case SYMBOL_FIELDS.EXCHANGE:
371
+ [result.exchange, offset] = readLengthDelimited(buffer, offset);
372
+ break;
373
+ case SYMBOL_FIELDS.TRADING_SYMBOL:
374
+ [result.tradingSymbol, offset] = readLengthDelimited(buffer, offset);
375
+ break;
376
+ case SYMBOL_FIELDS.DESCRIPTION:
377
+ [result.description, offset] = readLengthDelimited(buffer, offset);
378
+ break;
379
+ case SYMBOL_FIELDS.USER_MSG:
380
+ [result.userMsg, offset] = readLengthDelimited(buffer, offset);
381
+ break;
382
+ default:
383
+ offset = skipField(buffer, offset, wireType);
384
+ }
385
+ } catch (error) {
386
+ break;
387
+ }
388
+ }
389
+ return result;
390
+ }
391
+
392
+ module.exports = {
393
+ PNL_FIELDS,
394
+ SYMBOL_FIELDS,
395
+ INSTRUMENT_PNL_FIELDS,
396
+ readVarint,
397
+ readLengthDelimited,
398
+ skipField,
399
+ decodeAccountPnL,
400
+ decodeInstrumentPnL,
401
+ decodeProductCodes,
402
+ decodeFrontMonthContract,
403
+ };