hedgequantx 2.9.243 → 2.9.245

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hedgequantx",
3
- "version": "2.9.243",
3
+ "version": "2.9.245",
4
4
  "description": "HedgeQuantX - Prop Futures Trading CLI",
5
5
  "main": "src/app.js",
6
6
  "bin": {
@@ -126,18 +126,15 @@ const executeAlgo = async ({ service, account, contract, config, strategy: strat
126
126
  sessionLogger.signal(dir, signal.entry, signal.confidence, signalLog.details);
127
127
 
128
128
  if (!running) {
129
- const riskLog = smartLogs.getRiskCheckLog(false, 'Algo stopped');
130
- ui.addLog('risk', riskLog.message);
129
+ ui.addLog('risk', 'Algo stopped - ignoring signal');
131
130
  return;
132
131
  }
133
132
  if (pendingOrder) {
134
- const riskLog = smartLogs.getRiskCheckLog(false, 'Order pending');
135
- ui.addLog('risk', riskLog.message);
133
+ ui.addLog('risk', 'Order pending - wait for fill');
136
134
  return;
137
135
  }
138
136
  if (currentPosition !== 0) {
139
- const riskLog = smartLogs.getRiskCheckLog(false, `Position open (${currentPosition})`);
140
- ui.addLog('risk', riskLog.message);
137
+ ui.addLog('risk', `Position open (${currentPosition}) - close first`);
141
138
  return;
142
139
  }
143
140
 
@@ -222,19 +222,20 @@ const handleNewOrderResponse = (service, data) => {
222
222
  debug('New order response:', JSON.stringify(res));
223
223
 
224
224
  // Emit as orderNotification for the placeOrder listener
225
- if (res.basketId || res.orderId) {
226
- const order = {
227
- basketId: res.basketId || res.orderId,
228
- accountId: res.accountId,
229
- symbol: res.symbol,
230
- exchange: res.exchange || 'CME',
231
- status: res.rpCode?.[0] === '0' ? 2 : 5, // 2=Working, 5=Rejected
232
- notifyType: res.rpCode?.[0] === '0' ? 1 : 0, // 1=Accepted
233
- rpCode: res.rpCode,
234
- userMsg: res.userMsg,
235
- };
236
- service.emit('orderNotification', order);
237
- }
225
+ // Even if no basketId, emit for rejection handling
226
+ const isRejected = res.rpCode?.[0] !== '0';
227
+ const order = {
228
+ basketId: res.basketId || res.orderId || res.userMsg?.[0] || 'unknown',
229
+ accountId: res.accountId,
230
+ symbol: res.symbol,
231
+ exchange: res.exchange || 'CME',
232
+ status: isRejected ? 5 : 2, // 2=Working, 5=Rejected
233
+ notifyType: isRejected ? 0 : 1, // 1=Accepted
234
+ rpCode: res.rpCode,
235
+ rqHandlerRpCode: res.rqHandlerRpCode, // Also include request handler response code
236
+ userMsg: res.userMsg,
237
+ };
238
+ service.emit('orderNotification', order);
238
239
 
239
240
  // Also emit specific event
240
241
  service.emit('newOrderResponse', res);
@@ -145,18 +145,27 @@ const placeOrder = async (service, orderData) => {
145
145
  orderTag,
146
146
  });
147
147
  } else if (status === 5 || status === 6) {
148
- // Extract rejection reason from rpCode[1] if available
148
+ // Extract rejection reason from rpCode[1] or rqHandlerRpCode[1]
149
149
  const rpCode = order.rpCode;
150
+ const rqCode = order.rqHandlerRpCode;
150
151
  let errorMsg = `Order rejected: status ${status}`;
152
+
153
+ // Try rpCode first, then rqHandlerRpCode
151
154
  if (rpCode && Array.isArray(rpCode) && rpCode.length > 1 && rpCode[1]) {
152
- errorMsg = `Order rejected: ${rpCode[1]}`;
155
+ errorMsg = `Rejected: ${rpCode[1]}`;
156
+ } else if (rqCode && Array.isArray(rqCode) && rqCode.length > 1 && rqCode[1]) {
157
+ errorMsg = `Rejected: ${rqCode[1]}`;
158
+ } else if (rpCode && Array.isArray(rpCode) && rpCode[0] && rpCode[0] !== '0') {
159
+ errorMsg = `Rejected: code ${rpCode[0]}`;
153
160
  }
161
+
154
162
  resolve({
155
163
  success: false,
156
164
  error: errorMsg,
157
165
  orderId: order.basketId,
158
166
  orderTag,
159
167
  rpCode,
168
+ rqHandlerRpCode: rqCode,
160
169
  });
161
170
  }
162
171
  }