@ian2018cs/agenthub 0.2.4 → 0.2.5
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/server/claude-sdk.js +30 -23
package/package.json
CHANGED
package/server/claude-sdk.js
CHANGED
|
@@ -800,29 +800,15 @@ async function queryClaudeSDK(command, options = {}, ws) {
|
|
|
800
800
|
|
|
801
801
|
// Extract and send token budget updates from result messages
|
|
802
802
|
if (message.type === 'result') {
|
|
803
|
-
//
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
percentage: contextUsage.percentage,
|
|
813
|
-
categories: contextUsage.categories
|
|
814
|
-
}
|
|
815
|
-
});
|
|
816
|
-
}
|
|
817
|
-
} catch (contextErr) {
|
|
818
|
-
// Fallback to modelUsage if getContextUsage() fails
|
|
819
|
-
const tokenBudget = extractTokenBudget(message);
|
|
820
|
-
if (tokenBudget) {
|
|
821
|
-
mutableWriter.send({
|
|
822
|
-
type: 'token-budget',
|
|
823
|
-
data: tokenBudget
|
|
824
|
-
});
|
|
825
|
-
}
|
|
803
|
+
// getContextUsage() cannot be called here — SDK closes the IPC stream
|
|
804
|
+
// immediately after sending the result message (ERR_STREAM_WRITE_AFTER_END).
|
|
805
|
+
// Use extractTokenBudget() which reads from the result message payload directly.
|
|
806
|
+
const tokenBudget = extractTokenBudget(message);
|
|
807
|
+
if (tokenBudget) {
|
|
808
|
+
mutableWriter.send({
|
|
809
|
+
type: 'token-budget',
|
|
810
|
+
data: tokenBudget
|
|
811
|
+
});
|
|
826
812
|
}
|
|
827
813
|
|
|
828
814
|
// Record usage to database for admin statistics
|
|
@@ -890,6 +876,27 @@ async function queryClaudeSDK(command, options = {}, ws) {
|
|
|
890
876
|
}
|
|
891
877
|
}
|
|
892
878
|
}
|
|
879
|
+
|
|
880
|
+
// Call getContextUsage() on assistant messages (stream is still open at this point)
|
|
881
|
+
// to get accurate, SDK-reported context window data including real maxTokens.
|
|
882
|
+
if (message.type === 'assistant' && message.message?.usage) {
|
|
883
|
+
try {
|
|
884
|
+
const contextUsage = await queryInstance.getContextUsage();
|
|
885
|
+
if (contextUsage && contextUsage.maxTokens > 0) {
|
|
886
|
+
mutableWriter.send({
|
|
887
|
+
type: 'token-budget',
|
|
888
|
+
data: {
|
|
889
|
+
used: contextUsage.totalTokens,
|
|
890
|
+
total: contextUsage.maxTokens,
|
|
891
|
+
percentage: contextUsage.percentage,
|
|
892
|
+
categories: contextUsage.categories
|
|
893
|
+
}
|
|
894
|
+
});
|
|
895
|
+
}
|
|
896
|
+
} catch (_) {
|
|
897
|
+
// Not critical — result message will send a fallback update
|
|
898
|
+
}
|
|
899
|
+
}
|
|
893
900
|
}
|
|
894
901
|
|
|
895
902
|
// Clean up session on completion
|