2026-02-18 14:23:16 -06:00
|
|
|
import { asString, asNumber, parseObject, parseJson } from "@paperclip/adapter-utils/server-utils";
|
2026-02-18 13:53:03 -06:00
|
|
|
|
|
|
|
|
export function parseCodexJsonl(stdout: string) {
|
|
|
|
|
let sessionId: string | null = null;
|
|
|
|
|
const messages: string[] = [];
|
|
|
|
|
const usage = {
|
|
|
|
|
inputTokens: 0,
|
|
|
|
|
cachedInputTokens: 0,
|
|
|
|
|
outputTokens: 0,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
for (const rawLine of stdout.split(/\r?\n/)) {
|
|
|
|
|
const line = rawLine.trim();
|
|
|
|
|
if (!line) continue;
|
|
|
|
|
|
|
|
|
|
const event = parseJson(line);
|
|
|
|
|
if (!event) continue;
|
|
|
|
|
|
|
|
|
|
const type = asString(event.type, "");
|
|
|
|
|
if (type === "thread.started") {
|
|
|
|
|
sessionId = asString(event.thread_id, sessionId ?? "") || sessionId;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (type === "item.completed") {
|
|
|
|
|
const item = parseObject(event.item);
|
|
|
|
|
if (asString(item.type, "") === "agent_message") {
|
|
|
|
|
const text = asString(item.text, "");
|
|
|
|
|
if (text) messages.push(text);
|
|
|
|
|
}
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (type === "turn.completed") {
|
|
|
|
|
const usageObj = parseObject(event.usage);
|
|
|
|
|
usage.inputTokens = asNumber(usageObj.input_tokens, usage.inputTokens);
|
|
|
|
|
usage.cachedInputTokens = asNumber(usageObj.cached_input_tokens, usage.cachedInputTokens);
|
|
|
|
|
usage.outputTokens = asNumber(usageObj.output_tokens, usage.outputTokens);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
sessionId,
|
|
|
|
|
summary: messages.join("\n\n").trim(),
|
|
|
|
|
usage,
|
|
|
|
|
};
|
|
|
|
|
}
|