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
|
@@ -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
|
-
|
|
130
|
-
ui.addLog('risk', riskLog.message);
|
|
129
|
+
ui.addLog('risk', 'Algo stopped - ignoring signal');
|
|
131
130
|
return;
|
|
132
131
|
}
|
|
133
132
|
if (pendingOrder) {
|
|
134
|
-
|
|
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
|
-
|
|
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
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
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]
|
|
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 = `
|
|
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
|
}
|