summaryrefslogtreecommitdiffhomepage
path: root/packages
diff options
context:
space:
mode:
authorFrank <[email protected]>2025-09-25 17:02:21 -0400
committerFrank <[email protected]>2025-09-25 17:02:23 -0400
commit6e712f9faf4e83c3e063ab2d2daeb7fd38194ca8 (patch)
treec683de129ba12fcc87d39fb900fe4ea3db9bff92 /packages
parentb207ed2b7b4080c3c6e0b2bc8430abcb4a894cad (diff)
downloadopencode-6e712f9faf4e83c3e063ab2d2daeb7fd38194ca8.tar.gz
opencode-6e712f9faf4e83c3e063ab2d2daeb7fd38194ca8.zip
zen: fix parsing cache write tokens
Diffstat (limited to 'packages')
-rw-r--r--packages/console/app/src/routes/zen/handler.ts1
-rw-r--r--packages/console/app/src/routes/zen/v1/messages.ts13
2 files changed, 8 insertions, 6 deletions
diff --git a/packages/console/app/src/routes/zen/handler.ts b/packages/console/app/src/routes/zen/handler.ts
index 2ff3ca073..deab024c7 100644
--- a/packages/console/app/src/routes/zen/handler.ts
+++ b/packages/console/app/src/routes/zen/handler.ts
@@ -161,7 +161,6 @@ export async function handler(
logger.metric({ time_to_first_byte: Date.now() - startTimestamp })
}
responseLength += value.length
- console.log(decoder.decode(value, { stream: true }))
buffer += decoder.decode(value, { stream: true })
const parts = buffer.split("\n\n")
diff --git a/packages/console/app/src/routes/zen/v1/messages.ts b/packages/console/app/src/routes/zen/v1/messages.ts
index 1fd85d5c7..4a7dda5f7 100644
--- a/packages/console/app/src/routes/zen/v1/messages.ts
+++ b/packages/console/app/src/routes/zen/v1/messages.ts
@@ -30,22 +30,25 @@ export function POST(input: APIEvent) {
let json
try {
- json = JSON.parse(data.slice(6)) as { usage?: Usage }
+ json = JSON.parse(data.slice(6))
} catch (e) {
return
}
- if (!json.usage) return
+ // ie. { type: "message_start"; message: { usage: Usage } }
+ // ie. { type: "message_delta"; usage: Usage }
+ const usageUpdate = json.usage ?? json.message?.usage
+ if (!usageUpdate) return
usage = {
...usage,
- ...json.usage,
+ ...usageUpdate,
cache_creation: {
...usage?.cache_creation,
- ...json.usage.cache_creation,
+ ...usageUpdate.cache_creation,
},
server_tool_use: {
...usage?.server_tool_use,
- ...json.usage.server_tool_use,
+ ...usageUpdate.server_tool_use,
},
}
},