@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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ian2018cs/agenthub",
3
- "version": "0.2.4",
3
+ "version": "0.2.5",
4
4
  "description": "A web-based UI for AI Agents",
5
5
  "type": "module",
6
6
  "main": "server/index.js",
@@ -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
- // Use getContextUsage() for accurate SDK-reported context window data
804
- try {
805
- const contextUsage = await queryInstance.getContextUsage();
806
- if (contextUsage && contextUsage.maxTokens > 0) {
807
- mutableWriter.send({
808
- type: 'token-budget',
809
- data: {
810
- used: contextUsage.totalTokens,
811
- total: contextUsage.maxTokens,
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