@mmmbuto/zai-codex-bridge 0.1.8 → 0.1.10
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 +1 -1
- package/src/server.js +22 -3
package/package.json
CHANGED
package/src/server.js
CHANGED
|
@@ -260,6 +260,7 @@ async function streamChatToResponses(stream, res) {
|
|
|
260
260
|
let buffer = '';
|
|
261
261
|
let chunkCount = 0;
|
|
262
262
|
let deltaCount = 0;
|
|
263
|
+
let lastParsed = null; // Keep track of last parsed SSE for ID extraction
|
|
263
264
|
|
|
264
265
|
log('debug', 'Starting to process stream');
|
|
265
266
|
|
|
@@ -284,14 +285,32 @@ async function streamChatToResponses(stream, res) {
|
|
|
284
285
|
// Check for stream end
|
|
285
286
|
if (data === '[DONE]') {
|
|
286
287
|
log('info', `Stream end received - wrote ${deltaCount} deltas total`);
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
288
|
+
|
|
289
|
+
// Send response.completed event (required by Codex Responses API)
|
|
290
|
+
// Map Z.AI usage format to Responses API format
|
|
291
|
+
const zaiUsage = lastParsed?.usage;
|
|
292
|
+
const completedEvent = {
|
|
293
|
+
id: lastParsed?.id || 'msg_' + Date.now(),
|
|
294
|
+
usage: zaiUsage ? {
|
|
295
|
+
input_tokens: zaiUsage.prompt_tokens || 0,
|
|
296
|
+
output_tokens: zaiUsage.completion_tokens || 0,
|
|
297
|
+
total_tokens: zaiUsage.total_tokens || 0
|
|
298
|
+
} : {
|
|
299
|
+
input_tokens: 0,
|
|
300
|
+
output_tokens: 0,
|
|
301
|
+
total_tokens: 0
|
|
302
|
+
}
|
|
303
|
+
};
|
|
304
|
+
|
|
305
|
+
res.write(`event: response.completed\n`);
|
|
306
|
+
res.write(`data: ${JSON.stringify(completedEvent)}\n\n`);
|
|
307
|
+
log('info', 'Sent response.completed event');
|
|
290
308
|
return;
|
|
291
309
|
}
|
|
292
310
|
|
|
293
311
|
try {
|
|
294
312
|
const parsed = JSON.parse(data);
|
|
313
|
+
lastParsed = parsed; // Save for later use in completed event
|
|
295
314
|
log('debug', 'Parsed SSE:', JSON.stringify(parsed).substring(0, 150));
|
|
296
315
|
|
|
297
316
|
const delta = parsed.choices?.[0]?.delta;
|