@pcircle/claude-code-buddy-mcp 2.3.1
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/LICENSE +661 -0
- package/README.md +599 -0
- package/README.zh-TW.md +577 -0
- package/dist/__benchmarks__/performance-fixes.bench.d.ts +8 -0
- package/dist/__benchmarks__/performance-fixes.bench.d.ts.map +1 -0
- package/dist/__benchmarks__/performance-fixes.bench.js +213 -0
- package/dist/__benchmarks__/performance-fixes.bench.js.map +1 -0
- package/dist/agents/DevelopmentButler.d.ts +80 -0
- package/dist/agents/DevelopmentButler.d.ts.map +1 -0
- package/dist/agents/DevelopmentButler.js +328 -0
- package/dist/agents/DevelopmentButler.js.map +1 -0
- package/dist/agents/E2EHealingAgent.d.ts +30 -0
- package/dist/agents/E2EHealingAgent.d.ts.map +1 -0
- package/dist/agents/E2EHealingAgent.js +162 -0
- package/dist/agents/E2EHealingAgent.js.map +1 -0
- package/dist/agents/TestWriterAgent.d.ts +26 -0
- package/dist/agents/TestWriterAgent.d.ts.map +1 -0
- package/dist/agents/TestWriterAgent.js +139 -0
- package/dist/agents/TestWriterAgent.js.map +1 -0
- package/dist/agents/base/AgentExecutor.d.ts +7 -0
- package/dist/agents/base/AgentExecutor.d.ts.map +1 -0
- package/dist/agents/base/AgentExecutor.js +13 -0
- package/dist/agents/base/AgentExecutor.js.map +1 -0
- package/dist/agents/base/index.d.ts +2 -0
- package/dist/agents/base/index.d.ts.map +1 -0
- package/dist/agents/base/index.js +2 -0
- package/dist/agents/base/index.js.map +1 -0
- package/dist/agents/e2e-healing/analyzers/EvidenceCollector.d.ts +24 -0
- package/dist/agents/e2e-healing/analyzers/EvidenceCollector.d.ts.map +1 -0
- package/dist/agents/e2e-healing/analyzers/EvidenceCollector.js +55 -0
- package/dist/agents/e2e-healing/analyzers/EvidenceCollector.js.map +1 -0
- package/dist/agents/e2e-healing/analyzers/FailureAnalyzer.d.ts +22 -0
- package/dist/agents/e2e-healing/analyzers/FailureAnalyzer.d.ts.map +1 -0
- package/dist/agents/e2e-healing/analyzers/FailureAnalyzer.js +36 -0
- package/dist/agents/e2e-healing/analyzers/FailureAnalyzer.js.map +1 -0
- package/dist/agents/e2e-healing/config.d.ts +4 -0
- package/dist/agents/e2e-healing/config.d.ts.map +1 -0
- package/dist/agents/e2e-healing/config.js +28 -0
- package/dist/agents/e2e-healing/config.js.map +1 -0
- package/dist/agents/e2e-healing/generators/FixGenerator.d.ts +21 -0
- package/dist/agents/e2e-healing/generators/FixGenerator.d.ts.map +1 -0
- package/dist/agents/e2e-healing/generators/FixGenerator.js +33 -0
- package/dist/agents/e2e-healing/generators/FixGenerator.js.map +1 -0
- package/dist/agents/e2e-healing/orchestrator/TestOrchestrator.d.ts +29 -0
- package/dist/agents/e2e-healing/orchestrator/TestOrchestrator.d.ts.map +1 -0
- package/dist/agents/e2e-healing/orchestrator/TestOrchestrator.js +70 -0
- package/dist/agents/e2e-healing/orchestrator/TestOrchestrator.js.map +1 -0
- package/dist/agents/e2e-healing/policy/GraduatedAutonomyPolicy.d.ts +30 -0
- package/dist/agents/e2e-healing/policy/GraduatedAutonomyPolicy.d.ts.map +1 -0
- package/dist/agents/e2e-healing/policy/GraduatedAutonomyPolicy.js +115 -0
- package/dist/agents/e2e-healing/policy/GraduatedAutonomyPolicy.js.map +1 -0
- package/dist/agents/e2e-healing/runners/PlaywrightRunner.d.ts +19 -0
- package/dist/agents/e2e-healing/runners/PlaywrightRunner.d.ts.map +1 -0
- package/dist/agents/e2e-healing/runners/PlaywrightRunner.js +79 -0
- package/dist/agents/e2e-healing/runners/PlaywrightRunner.js.map +1 -0
- package/dist/agents/e2e-healing/safety/CircuitBreaker.d.ts +26 -0
- package/dist/agents/e2e-healing/safety/CircuitBreaker.d.ts.map +1 -0
- package/dist/agents/e2e-healing/safety/CircuitBreaker.js +75 -0
- package/dist/agents/e2e-healing/safety/CircuitBreaker.js.map +1 -0
- package/dist/agents/e2e-healing/safety/RollbackManager.d.ts +31 -0
- package/dist/agents/e2e-healing/safety/RollbackManager.d.ts.map +1 -0
- package/dist/agents/e2e-healing/safety/RollbackManager.js +130 -0
- package/dist/agents/e2e-healing/safety/RollbackManager.js.map +1 -0
- package/dist/agents/e2e-healing/safety/SafetyGate.d.ts +21 -0
- package/dist/agents/e2e-healing/safety/SafetyGate.d.ts.map +1 -0
- package/dist/agents/e2e-healing/safety/SafetyGate.js +62 -0
- package/dist/agents/e2e-healing/safety/SafetyGate.js.map +1 -0
- package/dist/agents/e2e-healing/safety/ScopeLimiter.d.ts +14 -0
- package/dist/agents/e2e-healing/safety/ScopeLimiter.d.ts.map +1 -0
- package/dist/agents/e2e-healing/safety/ScopeLimiter.js +36 -0
- package/dist/agents/e2e-healing/safety/ScopeLimiter.js.map +1 -0
- package/dist/agents/e2e-healing/sdk/AgentSDKAdapter.d.ts +29 -0
- package/dist/agents/e2e-healing/sdk/AgentSDKAdapter.d.ts.map +1 -0
- package/dist/agents/e2e-healing/sdk/AgentSDKAdapter.js +86 -0
- package/dist/agents/e2e-healing/sdk/AgentSDKAdapter.js.map +1 -0
- package/dist/agents/e2e-healing/types.d.ts +46 -0
- package/dist/agents/e2e-healing/types.d.ts.map +1 -0
- package/dist/agents/e2e-healing/types.js +2 -0
- package/dist/agents/e2e-healing/types.js.map +1 -0
- package/dist/agents/knowledge/KnowledgeGraph.d.ts +26 -0
- package/dist/agents/knowledge/KnowledgeGraph.d.ts.map +1 -0
- package/dist/agents/knowledge/KnowledgeGraph.js +106 -0
- package/dist/agents/knowledge/KnowledgeGraph.js.map +1 -0
- package/dist/agents/knowledge/KnowledgeGraphSQLite.d.ts +42 -0
- package/dist/agents/knowledge/KnowledgeGraphSQLite.d.ts.map +1 -0
- package/dist/agents/knowledge/KnowledgeGraphSQLite.js +349 -0
- package/dist/agents/knowledge/KnowledgeGraphSQLite.js.map +1 -0
- package/dist/agents/knowledge/index.d.ts +94 -0
- package/dist/agents/knowledge/index.d.ts.map +1 -0
- package/dist/agents/knowledge/index.js +296 -0
- package/dist/agents/knowledge/index.js.map +1 -0
- package/dist/agents/knowledge/storage/KnowledgeGraphStore.d.ts +25 -0
- package/dist/agents/knowledge/storage/KnowledgeGraphStore.d.ts.map +1 -0
- package/dist/agents/knowledge/storage/KnowledgeGraphStore.js +342 -0
- package/dist/agents/knowledge/storage/KnowledgeGraphStore.js.map +1 -0
- package/dist/agents/knowledge/types.d.ts +21 -0
- package/dist/agents/knowledge/types.d.ts.map +1 -0
- package/dist/agents/knowledge/types.js +2 -0
- package/dist/agents/knowledge/types.js.map +1 -0
- package/dist/agents/templates/ci-templates.d.ts +8 -0
- package/dist/agents/templates/ci-templates.d.ts.map +1 -0
- package/dist/agents/templates/ci-templates.js +119 -0
- package/dist/agents/templates/ci-templates.js.map +1 -0
- package/dist/agents/templates/test-templates.d.ts +18 -0
- package/dist/agents/templates/test-templates.d.ts.map +1 -0
- package/dist/agents/templates/test-templates.js +22 -0
- package/dist/agents/templates/test-templates.js.map +1 -0
- package/dist/config/index.d.ts +51 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +96 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/models.d.ts +47 -0
- package/dist/config/models.d.ts.map +1 -0
- package/dist/config/models.js +57 -0
- package/dist/config/models.js.map +1 -0
- package/dist/config/simple-config.d.ts +32 -0
- package/dist/config/simple-config.d.ts.map +1 -0
- package/dist/config/simple-config.js +225 -0
- package/dist/config/simple-config.js.map +1 -0
- package/dist/core/AgentRegistry.d.ts +32 -0
- package/dist/core/AgentRegistry.d.ts.map +1 -0
- package/dist/core/AgentRegistry.js +281 -0
- package/dist/core/AgentRegistry.js.map +1 -0
- package/dist/core/BackgroundExecutor.d.ts +56 -0
- package/dist/core/BackgroundExecutor.d.ts.map +1 -0
- package/dist/core/BackgroundExecutor.js +492 -0
- package/dist/core/BackgroundExecutor.js.map +1 -0
- package/dist/core/BackgroundExecutorConstants.d.ts +8 -0
- package/dist/core/BackgroundExecutorConstants.d.ts.map +1 -0
- package/dist/core/BackgroundExecutorConstants.js +8 -0
- package/dist/core/BackgroundExecutorConstants.js.map +1 -0
- package/dist/core/CheckpointDetector.d.ts +25 -0
- package/dist/core/CheckpointDetector.d.ts.map +1 -0
- package/dist/core/CheckpointDetector.js +67 -0
- package/dist/core/CheckpointDetector.js.map +1 -0
- package/dist/core/ExecutionMonitor.d.ts +29 -0
- package/dist/core/ExecutionMonitor.d.ts.map +1 -0
- package/dist/core/ExecutionMonitor.js +124 -0
- package/dist/core/ExecutionMonitor.js.map +1 -0
- package/dist/core/ExecutionQueue.d.ts +21 -0
- package/dist/core/ExecutionQueue.d.ts.map +1 -0
- package/dist/core/ExecutionQueue.js +104 -0
- package/dist/core/ExecutionQueue.js.map +1 -0
- package/dist/core/HealthCheck.d.ts +39 -0
- package/dist/core/HealthCheck.d.ts.map +1 -0
- package/dist/core/HealthCheck.js +219 -0
- package/dist/core/HealthCheck.js.map +1 -0
- package/dist/core/HookIntegration.d.ts +45 -0
- package/dist/core/HookIntegration.d.ts.map +1 -0
- package/dist/core/HookIntegration.js +241 -0
- package/dist/core/HookIntegration.js.map +1 -0
- package/dist/core/MCPToolInterface.d.ts +120 -0
- package/dist/core/MCPToolInterface.d.ts.map +1 -0
- package/dist/core/MCPToolInterface.js +376 -0
- package/dist/core/MCPToolInterface.js.map +1 -0
- package/dist/core/PromptEnhancer.d.ts +13 -0
- package/dist/core/PromptEnhancer.d.ts.map +1 -0
- package/dist/core/PromptEnhancer.js +112 -0
- package/dist/core/PromptEnhancer.js.map +1 -0
- package/dist/core/ResourceMonitor.d.ts +32 -0
- package/dist/core/ResourceMonitor.d.ts.map +1 -0
- package/dist/core/ResourceMonitor.js +181 -0
- package/dist/core/ResourceMonitor.js.map +1 -0
- package/dist/core/ResultHandler.d.ts +9 -0
- package/dist/core/ResultHandler.d.ts.map +1 -0
- package/dist/core/ResultHandler.js +60 -0
- package/dist/core/ResultHandler.js.map +1 -0
- package/dist/core/ServiceLocator.d.ts +10 -0
- package/dist/core/ServiceLocator.d.ts.map +1 -0
- package/dist/core/ServiceLocator.js +29 -0
- package/dist/core/ServiceLocator.js.map +1 -0
- package/dist/core/SessionContextMonitor.d.ts +41 -0
- package/dist/core/SessionContextMonitor.d.ts.map +1 -0
- package/dist/core/SessionContextMonitor.js +156 -0
- package/dist/core/SessionContextMonitor.js.map +1 -0
- package/dist/core/SessionTokenTracker.d.ts +43 -0
- package/dist/core/SessionTokenTracker.d.ts.map +1 -0
- package/dist/core/SessionTokenTracker.js +76 -0
- package/dist/core/SessionTokenTracker.js.map +1 -0
- package/dist/core/TaskScheduler.d.ts +19 -0
- package/dist/core/TaskScheduler.d.ts.map +1 -0
- package/dist/core/TaskScheduler.js +59 -0
- package/dist/core/TaskScheduler.js.map +1 -0
- package/dist/core/WorkflowGuidanceEngine.d.ts +35 -0
- package/dist/core/WorkflowGuidanceEngine.d.ts.map +1 -0
- package/dist/core/WorkflowGuidanceEngine.js +104 -0
- package/dist/core/WorkflowGuidanceEngine.js.map +1 -0
- package/dist/core/types.d.ts +66 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +11 -0
- package/dist/core/types.js.map +1 -0
- package/dist/db/ConnectionPool.d.ts +47 -0
- package/dist/db/ConnectionPool.d.ts.map +1 -0
- package/dist/db/ConnectionPool.js +432 -0
- package/dist/db/ConnectionPool.js.map +1 -0
- package/dist/db/QueryCache.d.ts +46 -0
- package/dist/db/QueryCache.d.ts.map +1 -0
- package/dist/db/QueryCache.js +229 -0
- package/dist/db/QueryCache.js.map +1 -0
- package/dist/errors/index.d.ts +62 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +124 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/evolution/ABTestManager.d.ts +21 -0
- package/dist/evolution/ABTestManager.d.ts.map +1 -0
- package/dist/evolution/ABTestManager.js +183 -0
- package/dist/evolution/ABTestManager.js.map +1 -0
- package/dist/evolution/AdaptationEngine.d.ts +60 -0
- package/dist/evolution/AdaptationEngine.d.ts.map +1 -0
- package/dist/evolution/AdaptationEngine.js +313 -0
- package/dist/evolution/AdaptationEngine.js.map +1 -0
- package/dist/evolution/AgentEvolutionConfig.d.ts +32 -0
- package/dist/evolution/AgentEvolutionConfig.d.ts.map +1 -0
- package/dist/evolution/AgentEvolutionConfig.js +329 -0
- package/dist/evolution/AgentEvolutionConfig.js.map +1 -0
- package/dist/evolution/ContextMatcher.d.ts +24 -0
- package/dist/evolution/ContextMatcher.d.ts.map +1 -0
- package/dist/evolution/ContextMatcher.js +85 -0
- package/dist/evolution/ContextMatcher.js.map +1 -0
- package/dist/evolution/EvolutionBootstrap.d.ts +69 -0
- package/dist/evolution/EvolutionBootstrap.d.ts.map +1 -0
- package/dist/evolution/EvolutionBootstrap.js +332 -0
- package/dist/evolution/EvolutionBootstrap.js.map +1 -0
- package/dist/evolution/EvolutionMonitor.d.ts +111 -0
- package/dist/evolution/EvolutionMonitor.d.ts.map +1 -0
- package/dist/evolution/EvolutionMonitor.js +540 -0
- package/dist/evolution/EvolutionMonitor.js.map +1 -0
- package/dist/evolution/FeedbackCollector.d.ts +26 -0
- package/dist/evolution/FeedbackCollector.d.ts.map +1 -0
- package/dist/evolution/FeedbackCollector.js +93 -0
- package/dist/evolution/FeedbackCollector.js.map +1 -0
- package/dist/evolution/KnowledgeTransferManager.d.ts +16 -0
- package/dist/evolution/KnowledgeTransferManager.d.ts.map +1 -0
- package/dist/evolution/KnowledgeTransferManager.js +34 -0
- package/dist/evolution/KnowledgeTransferManager.js.map +1 -0
- package/dist/evolution/LearningManager.d.ts +79 -0
- package/dist/evolution/LearningManager.d.ts.map +1 -0
- package/dist/evolution/LearningManager.js +582 -0
- package/dist/evolution/LearningManager.js.map +1 -0
- package/dist/evolution/LearningManagerConstants.d.ts +55 -0
- package/dist/evolution/LearningManagerConstants.d.ts.map +1 -0
- package/dist/evolution/LearningManagerConstants.js +55 -0
- package/dist/evolution/LearningManagerConstants.js.map +1 -0
- package/dist/evolution/MultiObjectiveOptimizer.d.ts +9 -0
- package/dist/evolution/MultiObjectiveOptimizer.d.ts.map +1 -0
- package/dist/evolution/MultiObjectiveOptimizer.js +92 -0
- package/dist/evolution/MultiObjectiveOptimizer.js.map +1 -0
- package/dist/evolution/PatternExplainer.d.ts +14 -0
- package/dist/evolution/PatternExplainer.d.ts.map +1 -0
- package/dist/evolution/PatternExplainer.js +113 -0
- package/dist/evolution/PatternExplainer.js.map +1 -0
- package/dist/evolution/PerformanceTracker.d.ts +43 -0
- package/dist/evolution/PerformanceTracker.d.ts.map +1 -0
- package/dist/evolution/PerformanceTracker.js +453 -0
- package/dist/evolution/PerformanceTracker.js.map +1 -0
- package/dist/evolution/PerformanceTrackerConstants.d.ts +5 -0
- package/dist/evolution/PerformanceTrackerConstants.d.ts.map +1 -0
- package/dist/evolution/PerformanceTrackerConstants.js +5 -0
- package/dist/evolution/PerformanceTrackerConstants.js.map +1 -0
- package/dist/evolution/StatisticalAnalyzer.d.ts +20 -0
- package/dist/evolution/StatisticalAnalyzer.d.ts.map +1 -0
- package/dist/evolution/StatisticalAnalyzer.js +154 -0
- package/dist/evolution/StatisticalAnalyzer.js.map +1 -0
- package/dist/evolution/TransferabilityChecker.d.ts +11 -0
- package/dist/evolution/TransferabilityChecker.d.ts.map +1 -0
- package/dist/evolution/TransferabilityChecker.js +78 -0
- package/dist/evolution/TransferabilityChecker.js.map +1 -0
- package/dist/evolution/index.d.ts +11 -0
- package/dist/evolution/index.d.ts.map +1 -0
- package/dist/evolution/index.js +9 -0
- package/dist/evolution/index.js.map +1 -0
- package/dist/evolution/instrumentation/SpanTracker.d.ts +64 -0
- package/dist/evolution/instrumentation/SpanTracker.d.ts.map +1 -0
- package/dist/evolution/instrumentation/SpanTracker.js +229 -0
- package/dist/evolution/instrumentation/SpanTracker.js.map +1 -0
- package/dist/evolution/instrumentation/withEvolutionTracking.d.ts +19 -0
- package/dist/evolution/instrumentation/withEvolutionTracking.d.ts.map +1 -0
- package/dist/evolution/instrumentation/withEvolutionTracking.js +256 -0
- package/dist/evolution/instrumentation/withEvolutionTracking.js.map +1 -0
- package/dist/evolution/integration-test-scenarios.d.ts +56 -0
- package/dist/evolution/integration-test-scenarios.d.ts.map +1 -0
- package/dist/evolution/integration-test-scenarios.js +131 -0
- package/dist/evolution/integration-test-scenarios.js.map +1 -0
- package/dist/evolution/links/LinkManager.d.ts +17 -0
- package/dist/evolution/links/LinkManager.d.ts.map +1 -0
- package/dist/evolution/links/LinkManager.js +41 -0
- package/dist/evolution/links/LinkManager.js.map +1 -0
- package/dist/evolution/storage/EvolutionStore.d.ts +87 -0
- package/dist/evolution/storage/EvolutionStore.d.ts.map +1 -0
- package/dist/evolution/storage/EvolutionStore.js +2 -0
- package/dist/evolution/storage/EvolutionStore.js.map +1 -0
- package/dist/evolution/storage/IEvolutionStore.d.ts +87 -0
- package/dist/evolution/storage/IEvolutionStore.d.ts.map +1 -0
- package/dist/evolution/storage/IEvolutionStore.js +2 -0
- package/dist/evolution/storage/IEvolutionStore.js.map +1 -0
- package/dist/evolution/storage/SQLiteStore.d.ts +115 -0
- package/dist/evolution/storage/SQLiteStore.d.ts.map +1 -0
- package/dist/evolution/storage/SQLiteStore.enhanced.d.ts +35 -0
- package/dist/evolution/storage/SQLiteStore.enhanced.d.ts.map +1 -0
- package/dist/evolution/storage/SQLiteStore.enhanced.js +514 -0
- package/dist/evolution/storage/SQLiteStore.enhanced.js.map +1 -0
- package/dist/evolution/storage/SQLiteStore.js +915 -0
- package/dist/evolution/storage/SQLiteStore.js.map +1 -0
- package/dist/evolution/storage/deprecated/SQLiteStore.basic.d.ts +109 -0
- package/dist/evolution/storage/deprecated/SQLiteStore.basic.d.ts.map +1 -0
- package/dist/evolution/storage/deprecated/SQLiteStore.basic.js +1033 -0
- package/dist/evolution/storage/deprecated/SQLiteStore.basic.js.map +1 -0
- package/dist/evolution/storage/index.d.ts +6 -0
- package/dist/evolution/storage/index.d.ts.map +1 -0
- package/dist/evolution/storage/index.js +3 -0
- package/dist/evolution/storage/index.js.map +1 -0
- package/dist/evolution/storage/migrations/MigrationManager.d.ts +17 -0
- package/dist/evolution/storage/migrations/MigrationManager.d.ts.map +1 -0
- package/dist/evolution/storage/migrations/MigrationManager.js +242 -0
- package/dist/evolution/storage/migrations/MigrationManager.js.map +1 -0
- package/dist/evolution/storage/repositories/AdaptationRepository.d.ts +17 -0
- package/dist/evolution/storage/repositories/AdaptationRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/AdaptationRepository.js +82 -0
- package/dist/evolution/storage/repositories/AdaptationRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/CostRecordsRepository.d.ts +43 -0
- package/dist/evolution/storage/repositories/CostRecordsRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/CostRecordsRepository.js +157 -0
- package/dist/evolution/storage/repositories/CostRecordsRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/ExecutionRepository.d.ts +12 -0
- package/dist/evolution/storage/repositories/ExecutionRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/ExecutionRepository.js +87 -0
- package/dist/evolution/storage/repositories/ExecutionRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/PatternRepository.d.ts +12 -0
- package/dist/evolution/storage/repositories/PatternRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/PatternRepository.js +150 -0
- package/dist/evolution/storage/repositories/PatternRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/PerformanceMetricsRepository.d.ts +39 -0
- package/dist/evolution/storage/repositories/PerformanceMetricsRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/PerformanceMetricsRepository.js +130 -0
- package/dist/evolution/storage/repositories/PerformanceMetricsRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/RewardRepository.d.ts +17 -0
- package/dist/evolution/storage/repositories/RewardRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/RewardRepository.js +82 -0
- package/dist/evolution/storage/repositories/RewardRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/SpanRepository.d.ts +14 -0
- package/dist/evolution/storage/repositories/SpanRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/SpanRepository.js +191 -0
- package/dist/evolution/storage/repositories/SpanRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/StatsRepository.d.ts +16 -0
- package/dist/evolution/storage/repositories/StatsRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/StatsRepository.js +271 -0
- package/dist/evolution/storage/repositories/StatsRepository.js.map +1 -0
- package/dist/evolution/storage/repositories/TaskRepository.d.ts +16 -0
- package/dist/evolution/storage/repositories/TaskRepository.d.ts.map +1 -0
- package/dist/evolution/storage/repositories/TaskRepository.js +93 -0
- package/dist/evolution/storage/repositories/TaskRepository.js.map +1 -0
- package/dist/evolution/storage/schema.d.ts +81 -0
- package/dist/evolution/storage/schema.d.ts.map +1 -0
- package/dist/evolution/storage/schema.js +241 -0
- package/dist/evolution/storage/schema.js.map +1 -0
- package/dist/evolution/storage/types.d.ts +402 -0
- package/dist/evolution/storage/types.d.ts.map +1 -0
- package/dist/evolution/storage/types.js +2 -0
- package/dist/evolution/storage/types.js.map +1 -0
- package/dist/evolution/storage/validation.d.ts +12 -0
- package/dist/evolution/storage/validation.d.ts.map +1 -0
- package/dist/evolution/storage/validation.js +88 -0
- package/dist/evolution/storage/validation.js.map +1 -0
- package/dist/evolution/types.d.ts +214 -0
- package/dist/evolution/types.d.ts.map +1 -0
- package/dist/evolution/types.js +2 -0
- package/dist/evolution/types.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +32 -0
- package/dist/index.js.map +1 -0
- package/dist/knowledge-graph/index.d.ts +27 -0
- package/dist/knowledge-graph/index.d.ts.map +1 -0
- package/dist/knowledge-graph/index.js +353 -0
- package/dist/knowledge-graph/index.js.map +1 -0
- package/dist/knowledge-graph/types.d.ts +37 -0
- package/dist/knowledge-graph/types.d.ts.map +1 -0
- package/dist/knowledge-graph/types.js +2 -0
- package/dist/knowledge-graph/types.js.map +1 -0
- package/dist/management/UninstallManager.d.ts +23 -0
- package/dist/management/UninstallManager.d.ts.map +1 -0
- package/dist/management/UninstallManager.js +186 -0
- package/dist/management/UninstallManager.js.map +1 -0
- package/dist/management/index.d.ts +3 -0
- package/dist/management/index.d.ts.map +1 -0
- package/dist/management/index.js +2 -0
- package/dist/management/index.js.map +1 -0
- package/dist/mcp/BuddyCommands.d.ts +13 -0
- package/dist/mcp/BuddyCommands.d.ts.map +1 -0
- package/dist/mcp/BuddyCommands.js +110 -0
- package/dist/mcp/BuddyCommands.js.map +1 -0
- package/dist/mcp/ClaudeMdReloader.d.ts +37 -0
- package/dist/mcp/ClaudeMdReloader.d.ts.map +1 -0
- package/dist/mcp/ClaudeMdReloader.js +92 -0
- package/dist/mcp/ClaudeMdReloader.js.map +1 -0
- package/dist/mcp/HumanInLoopUI.d.ts +23 -0
- package/dist/mcp/HumanInLoopUI.d.ts.map +1 -0
- package/dist/mcp/HumanInLoopUI.js +92 -0
- package/dist/mcp/HumanInLoopUI.js.map +1 -0
- package/dist/mcp/ServerInitializer.d.ts +47 -0
- package/dist/mcp/ServerInitializer.d.ts.map +1 -0
- package/dist/mcp/ServerInitializer.js +89 -0
- package/dist/mcp/ServerInitializer.js.map +1 -0
- package/dist/mcp/SessionBootstrapper.d.ts +11 -0
- package/dist/mcp/SessionBootstrapper.d.ts.map +1 -0
- package/dist/mcp/SessionBootstrapper.js +67 -0
- package/dist/mcp/SessionBootstrapper.js.map +1 -0
- package/dist/mcp/ToolDefinitions.d.ts +42 -0
- package/dist/mcp/ToolDefinitions.d.ts.map +1 -0
- package/dist/mcp/ToolDefinitions.js +234 -0
- package/dist/mcp/ToolDefinitions.js.map +1 -0
- package/dist/mcp/ToolRouter.d.ts +22 -0
- package/dist/mcp/ToolRouter.d.ts.map +1 -0
- package/dist/mcp/ToolRouter.js +102 -0
- package/dist/mcp/ToolRouter.js.map +1 -0
- package/dist/mcp/handlers/BuddyHandlers.d.ts +14 -0
- package/dist/mcp/handlers/BuddyHandlers.d.ts.map +1 -0
- package/dist/mcp/handlers/BuddyHandlers.js +152 -0
- package/dist/mcp/handlers/BuddyHandlers.js.map +1 -0
- package/dist/mcp/handlers/ResourceHandlers.d.ts +3 -0
- package/dist/mcp/handlers/ResourceHandlers.d.ts.map +1 -0
- package/dist/mcp/handlers/ResourceHandlers.js +86 -0
- package/dist/mcp/handlers/ResourceHandlers.js.map +1 -0
- package/dist/mcp/handlers/ToolHandlers.d.ts +52 -0
- package/dist/mcp/handlers/ToolHandlers.d.ts.map +1 -0
- package/dist/mcp/handlers/ToolHandlers.js +914 -0
- package/dist/mcp/handlers/ToolHandlers.js.map +1 -0
- package/dist/mcp/handlers/index.d.ts +4 -0
- package/dist/mcp/handlers/index.d.ts.map +1 -0
- package/dist/mcp/handlers/index.js +4 -0
- package/dist/mcp/handlers/index.js.map +1 -0
- package/dist/mcp/index.d.ts +5 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +3 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/schemas/OutputSchemas.d.ts +368 -0
- package/dist/mcp/schemas/OutputSchemas.d.ts.map +1 -0
- package/dist/mcp/schemas/OutputSchemas.js +191 -0
- package/dist/mcp/schemas/OutputSchemas.js.map +1 -0
- package/dist/mcp/server.d.ts +17 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +184 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/add-observations.d.ts +48 -0
- package/dist/mcp/tools/add-observations.d.ts.map +1 -0
- package/dist/mcp/tools/add-observations.js +64 -0
- package/dist/mcp/tools/add-observations.js.map +1 -0
- package/dist/mcp/tools/buddy-do.d.ts +14 -0
- package/dist/mcp/tools/buddy-do.d.ts.map +1 -0
- package/dist/mcp/tools/buddy-do.js +77 -0
- package/dist/mcp/tools/buddy-do.js.map +1 -0
- package/dist/mcp/tools/buddy-help.d.ts +13 -0
- package/dist/mcp/tools/buddy-help.d.ts.map +1 -0
- package/dist/mcp/tools/buddy-help.js +52 -0
- package/dist/mcp/tools/buddy-help.js.map +1 -0
- package/dist/mcp/tools/buddy-remember.d.ts +15 -0
- package/dist/mcp/tools/buddy-remember.d.ts.map +1 -0
- package/dist/mcp/tools/buddy-remember.js +77 -0
- package/dist/mcp/tools/buddy-remember.js.map +1 -0
- package/dist/mcp/tools/create-entities.d.ts +57 -0
- package/dist/mcp/tools/create-entities.d.ts.map +1 -0
- package/dist/mcp/tools/create-entities.js +64 -0
- package/dist/mcp/tools/create-entities.js.map +1 -0
- package/dist/mcp/tools/create-relations.d.ts +60 -0
- package/dist/mcp/tools/create-relations.d.ts.map +1 -0
- package/dist/mcp/tools/create-relations.js +84 -0
- package/dist/mcp/tools/create-relations.js.map +1 -0
- package/dist/mcp/tools/health-check.d.ts +10 -0
- package/dist/mcp/tools/health-check.d.ts.map +1 -0
- package/dist/mcp/tools/health-check.js +37 -0
- package/dist/mcp/tools/health-check.js.map +1 -0
- package/dist/mcp/tools/recall-memory.d.ts +31 -0
- package/dist/mcp/tools/recall-memory.d.ts.map +1 -0
- package/dist/mcp/tools/recall-memory.js +31 -0
- package/dist/mcp/tools/recall-memory.js.map +1 -0
- package/dist/mcp/validation.d.ts +88 -0
- package/dist/mcp/validation.d.ts.map +1 -0
- package/dist/mcp/validation.js +119 -0
- package/dist/mcp/validation.js.map +1 -0
- package/dist/memory/ProjectAutoTracker.d.ts +36 -0
- package/dist/memory/ProjectAutoTracker.d.ts.map +1 -0
- package/dist/memory/ProjectAutoTracker.js +200 -0
- package/dist/memory/ProjectAutoTracker.js.map +1 -0
- package/dist/memory/ProjectMemoryCleanup.d.ts +17 -0
- package/dist/memory/ProjectMemoryCleanup.d.ts.map +1 -0
- package/dist/memory/ProjectMemoryCleanup.js +57 -0
- package/dist/memory/ProjectMemoryCleanup.js.map +1 -0
- package/dist/memory/ProjectMemoryManager.d.ts +15 -0
- package/dist/memory/ProjectMemoryManager.d.ts.map +1 -0
- package/dist/memory/ProjectMemoryManager.js +36 -0
- package/dist/memory/ProjectMemoryManager.js.map +1 -0
- package/dist/orchestrator/AgentRouter.d.ts +20 -0
- package/dist/orchestrator/AgentRouter.d.ts.map +1 -0
- package/dist/orchestrator/AgentRouter.js +274 -0
- package/dist/orchestrator/AgentRouter.js.map +1 -0
- package/dist/orchestrator/CostTracker.d.ts +25 -0
- package/dist/orchestrator/CostTracker.d.ts.map +1 -0
- package/dist/orchestrator/CostTracker.js +199 -0
- package/dist/orchestrator/CostTracker.js.map +1 -0
- package/dist/orchestrator/GlobalResourcePool.d.ts +59 -0
- package/dist/orchestrator/GlobalResourcePool.d.ts.map +1 -0
- package/dist/orchestrator/GlobalResourcePool.js +224 -0
- package/dist/orchestrator/GlobalResourcePool.js.map +1 -0
- package/dist/orchestrator/GlobalResourcePoolConstants.d.ts +22 -0
- package/dist/orchestrator/GlobalResourcePoolConstants.d.ts.map +1 -0
- package/dist/orchestrator/GlobalResourcePoolConstants.js +22 -0
- package/dist/orchestrator/GlobalResourcePoolConstants.js.map +1 -0
- package/dist/orchestrator/TaskAnalyzer.d.ts +15 -0
- package/dist/orchestrator/TaskAnalyzer.d.ts.map +1 -0
- package/dist/orchestrator/TaskAnalyzer.js +234 -0
- package/dist/orchestrator/TaskAnalyzer.js.map +1 -0
- package/dist/orchestrator/TaskAnalyzerConstants.d.ts +16 -0
- package/dist/orchestrator/TaskAnalyzerConstants.d.ts.map +1 -0
- package/dist/orchestrator/TaskAnalyzerConstants.js +16 -0
- package/dist/orchestrator/TaskAnalyzerConstants.js.map +1 -0
- package/dist/orchestrator/example.d.ts +2 -0
- package/dist/orchestrator/example.d.ts.map +1 -0
- package/dist/orchestrator/example.js +118 -0
- package/dist/orchestrator/example.js.map +1 -0
- package/dist/orchestrator/index.d.ts +82 -0
- package/dist/orchestrator/index.d.ts.map +1 -0
- package/dist/orchestrator/index.js +364 -0
- package/dist/orchestrator/index.js.map +1 -0
- package/dist/orchestrator/router.d.ts +48 -0
- package/dist/orchestrator/router.d.ts.map +1 -0
- package/dist/orchestrator/router.js +126 -0
- package/dist/orchestrator/router.js.map +1 -0
- package/dist/orchestrator/types.d.ts +60 -0
- package/dist/orchestrator/types.d.ts.map +1 -0
- package/dist/orchestrator/types.js +2 -0
- package/dist/orchestrator/types.js.map +1 -0
- package/dist/planning/PlanningEngine.d.ts +52 -0
- package/dist/planning/PlanningEngine.d.ts.map +1 -0
- package/dist/planning/PlanningEngine.js +271 -0
- package/dist/planning/PlanningEngine.js.map +1 -0
- package/dist/planning/TaskDecomposer.d.ts +32 -0
- package/dist/planning/TaskDecomposer.d.ts.map +1 -0
- package/dist/planning/TaskDecomposer.js +152 -0
- package/dist/planning/TaskDecomposer.js.map +1 -0
- package/dist/prompts/templates/PromptTemplates.d.ts +11 -0
- package/dist/prompts/templates/PromptTemplates.d.ts.map +1 -0
- package/dist/prompts/templates/PromptTemplates.js +942 -0
- package/dist/prompts/templates/PromptTemplates.js.map +1 -0
- package/dist/prompts/templates/index.d.ts +2 -0
- package/dist/prompts/templates/index.d.ts.map +1 -0
- package/dist/prompts/templates/index.js +2 -0
- package/dist/prompts/templates/index.js.map +1 -0
- package/dist/skills/SkillManager.d.ts +33 -0
- package/dist/skills/SkillManager.d.ts.map +1 -0
- package/dist/skills/SkillManager.js +153 -0
- package/dist/skills/SkillManager.js.map +1 -0
- package/dist/skills/index.d.ts +3 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +2 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/telemetry/TelemetryCollector.d.ts +19 -0
- package/dist/telemetry/TelemetryCollector.d.ts.map +1 -0
- package/dist/telemetry/TelemetryCollector.js +62 -0
- package/dist/telemetry/TelemetryCollector.js.map +1 -0
- package/dist/telemetry/TelemetryStore.d.ts +20 -0
- package/dist/telemetry/TelemetryStore.d.ts.map +1 -0
- package/dist/telemetry/TelemetryStore.js +126 -0
- package/dist/telemetry/TelemetryStore.js.map +1 -0
- package/dist/telemetry/index.d.ts +8 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +33 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/sanitization.d.ts +6 -0
- package/dist/telemetry/sanitization.d.ts.map +1 -0
- package/dist/telemetry/sanitization.js +180 -0
- package/dist/telemetry/sanitization.js.map +1 -0
- package/dist/telemetry/types.d.ts +73 -0
- package/dist/telemetry/types.d.ts.map +1 -0
- package/dist/telemetry/types.js +16 -0
- package/dist/telemetry/types.js.map +1 -0
- package/dist/templates/git-education-templates.d.ts +26 -0
- package/dist/templates/git-education-templates.d.ts.map +1 -0
- package/dist/templates/git-education-templates.js +455 -0
- package/dist/templates/git-education-templates.js.map +1 -0
- package/dist/types/AgentClassification.d.ts +6 -0
- package/dist/types/AgentClassification.d.ts.map +1 -0
- package/dist/types/AgentClassification.js +7 -0
- package/dist/types/AgentClassification.js.map +1 -0
- package/dist/types/Checkpoint.d.ts +12 -0
- package/dist/types/Checkpoint.d.ts.map +1 -0
- package/dist/types/Checkpoint.js +13 -0
- package/dist/types/Checkpoint.js.map +1 -0
- package/dist/types/toonify.d.ts +91 -0
- package/dist/types/toonify.d.ts.map +1 -0
- package/dist/types/toonify.js +18 -0
- package/dist/types/toonify.js.map +1 -0
- package/dist/ui/AsciiProgressBar.d.ts +29 -0
- package/dist/ui/AsciiProgressBar.d.ts.map +1 -0
- package/dist/ui/AsciiProgressBar.js +131 -0
- package/dist/ui/AsciiProgressBar.js.map +1 -0
- package/dist/ui/AttributionManager.d.ts +19 -0
- package/dist/ui/AttributionManager.d.ts.map +1 -0
- package/dist/ui/AttributionManager.js +107 -0
- package/dist/ui/AttributionManager.js.map +1 -0
- package/dist/ui/Dashboard.d.ts +24 -0
- package/dist/ui/Dashboard.d.ts.map +1 -0
- package/dist/ui/Dashboard.js +135 -0
- package/dist/ui/Dashboard.js.map +1 -0
- package/dist/ui/LoadingIndicator.d.ts +53 -0
- package/dist/ui/LoadingIndicator.d.ts.map +1 -0
- package/dist/ui/LoadingIndicator.js +174 -0
- package/dist/ui/LoadingIndicator.js.map +1 -0
- package/dist/ui/MetricsStore.d.ts +15 -0
- package/dist/ui/MetricsStore.d.ts.map +1 -0
- package/dist/ui/MetricsStore.js +111 -0
- package/dist/ui/MetricsStore.js.map +1 -0
- package/dist/ui/ProgressRenderer.d.ts +24 -0
- package/dist/ui/ProgressRenderer.d.ts.map +1 -0
- package/dist/ui/ProgressRenderer.js +121 -0
- package/dist/ui/ProgressRenderer.js.map +1 -0
- package/dist/ui/ResponseFormatter.d.ts +42 -0
- package/dist/ui/ResponseFormatter.d.ts.map +1 -0
- package/dist/ui/ResponseFormatter.js +243 -0
- package/dist/ui/ResponseFormatter.js.map +1 -0
- package/dist/ui/UIEventBus.d.ts +38 -0
- package/dist/ui/UIEventBus.d.ts.map +1 -0
- package/dist/ui/UIEventBus.js +173 -0
- package/dist/ui/UIEventBus.js.map +1 -0
- package/dist/ui/index.d.ts +8 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +6 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/theme.d.ts +292 -0
- package/dist/ui/theme.d.ts.map +1 -0
- package/dist/ui/theme.js +153 -0
- package/dist/ui/theme.js.map +1 -0
- package/dist/ui/types.d.ts +146 -0
- package/dist/ui/types.d.ts.map +1 -0
- package/dist/ui/types.js +16 -0
- package/dist/ui/types.js.map +1 -0
- package/dist/utils/ILogger.d.ts +7 -0
- package/dist/utils/ILogger.d.ts.map +1 -0
- package/dist/utils/ILogger.js +2 -0
- package/dist/utils/ILogger.js.map +1 -0
- package/dist/utils/MinHeap.d.ts +15 -0
- package/dist/utils/MinHeap.d.ts.map +1 -0
- package/dist/utils/MinHeap.js +69 -0
- package/dist/utils/MinHeap.js.map +1 -0
- package/dist/utils/RateLimiter.d.ts +28 -0
- package/dist/utils/RateLimiter.d.ts.map +1 -0
- package/dist/utils/RateLimiter.js +115 -0
- package/dist/utils/RateLimiter.js.map +1 -0
- package/dist/utils/SecureKeyStore.d.ts +10 -0
- package/dist/utils/SecureKeyStore.d.ts.map +1 -0
- package/dist/utils/SecureKeyStore.js +32 -0
- package/dist/utils/SecureKeyStore.js.map +1 -0
- package/dist/utils/SystemResources.d.ts +40 -0
- package/dist/utils/SystemResources.d.ts.map +1 -0
- package/dist/utils/SystemResources.js +221 -0
- package/dist/utils/SystemResources.js.map +1 -0
- package/dist/utils/cost-tracker.d.ts +34 -0
- package/dist/utils/cost-tracker.d.ts.map +1 -0
- package/dist/utils/cost-tracker.js +92 -0
- package/dist/utils/cost-tracker.js.map +1 -0
- package/dist/utils/errorHandler.d.ts +28 -0
- package/dist/utils/errorHandler.d.ts.map +1 -0
- package/dist/utils/errorHandler.js +206 -0
- package/dist/utils/errorHandler.js.map +1 -0
- package/dist/utils/json.d.ts +13 -0
- package/dist/utils/json.d.ts.map +1 -0
- package/dist/utils/json.js +85 -0
- package/dist/utils/json.js.map +1 -0
- package/dist/utils/logger.d.ts +16 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +57 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/lru-cache.d.ts +40 -0
- package/dist/utils/lru-cache.d.ts.map +1 -0
- package/dist/utils/lru-cache.js +209 -0
- package/dist/utils/lru-cache.js.map +1 -0
- package/dist/utils/memory.d.ts +20 -0
- package/dist/utils/memory.d.ts.map +1 -0
- package/dist/utils/memory.js +53 -0
- package/dist/utils/memory.js.map +1 -0
- package/dist/utils/money.d.ts +10 -0
- package/dist/utils/money.d.ts.map +1 -0
- package/dist/utils/money.js +25 -0
- package/dist/utils/money.js.map +1 -0
- package/dist/utils/pathValidation.d.ts +2 -0
- package/dist/utils/pathValidation.d.ts.map +1 -0
- package/dist/utils/pathValidation.js +62 -0
- package/dist/utils/pathValidation.js.map +1 -0
- package/dist/utils/paths.d.ts +4 -0
- package/dist/utils/paths.d.ts.map +1 -0
- package/dist/utils/paths.js +28 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/requestId.d.ts +4 -0
- package/dist/utils/requestId.d.ts.map +1 -0
- package/dist/utils/requestId.js +17 -0
- package/dist/utils/requestId.js.map +1 -0
- package/dist/utils/retry.d.ts +20 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +226 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/toonify-adapter.d.ts +77 -0
- package/dist/utils/toonify-adapter.d.ts.map +1 -0
- package/dist/utils/toonify-adapter.js +283 -0
- package/dist/utils/toonify-adapter.js.map +1 -0
- package/dist/utils/validation.d.ts +7 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +62 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +116 -0
- package/plugin.json +21 -0
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import os from 'os';
|
|
2
|
+
import { ValidationError } from '../errors/index.js';
|
|
3
|
+
import { logger } from '../utils/logger.js';
|
|
4
|
+
export class ResourceMonitor {
|
|
5
|
+
activeBackgroundCount = 0;
|
|
6
|
+
maxBackgroundAgents;
|
|
7
|
+
thresholds;
|
|
8
|
+
activeIntervals = new Set();
|
|
9
|
+
disposed = false;
|
|
10
|
+
constructor(maxBackgroundAgents = 6, thresholds) {
|
|
11
|
+
this.maxBackgroundAgents = maxBackgroundAgents;
|
|
12
|
+
this.thresholds = {
|
|
13
|
+
maxCPU: thresholds?.maxCPU ?? 70,
|
|
14
|
+
maxMemory: thresholds?.maxMemory ?? 8192,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
getCurrentResources() {
|
|
18
|
+
const cpus = os.cpus();
|
|
19
|
+
const fallbackCores = typeof os.availableParallelism === 'function'
|
|
20
|
+
? os.availableParallelism()
|
|
21
|
+
: 1;
|
|
22
|
+
const cores = Math.max(cpus.length, fallbackCores, 1);
|
|
23
|
+
const totalMem = os.totalmem() / (1024 * 1024);
|
|
24
|
+
const freeMem = os.freemem() / (1024 * 1024);
|
|
25
|
+
const usedMem = totalMem - freeMem;
|
|
26
|
+
const loadAvg = os.loadavg()[0];
|
|
27
|
+
const cpuUsage = Math.min(100, (loadAvg / cores) * 100);
|
|
28
|
+
return {
|
|
29
|
+
cpu: {
|
|
30
|
+
usage: cpuUsage,
|
|
31
|
+
cores,
|
|
32
|
+
},
|
|
33
|
+
memory: {
|
|
34
|
+
total: totalMem,
|
|
35
|
+
used: usedMem,
|
|
36
|
+
available: freeMem,
|
|
37
|
+
usagePercent: (usedMem / totalMem) * 100,
|
|
38
|
+
},
|
|
39
|
+
activeBackgroundAgents: this.activeBackgroundCount,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
canRunBackgroundTask(config) {
|
|
43
|
+
const resources = this.getCurrentResources();
|
|
44
|
+
if (resources.activeBackgroundAgents >= this.maxBackgroundAgents) {
|
|
45
|
+
return {
|
|
46
|
+
canExecute: false,
|
|
47
|
+
reason: `Max concurrent background agents reached (${this.maxBackgroundAgents})`,
|
|
48
|
+
suggestion: 'Wait for existing tasks to complete or use foreground mode',
|
|
49
|
+
resources,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
if (resources.cpu.usage > this.thresholds.maxCPU) {
|
|
53
|
+
return {
|
|
54
|
+
canExecute: false,
|
|
55
|
+
reason: `CPU usage too high (${resources.cpu.usage.toFixed(1)}% > ${this.thresholds.maxCPU}%)`,
|
|
56
|
+
suggestion: 'Use foreground mode or wait for CPU usage to decrease',
|
|
57
|
+
resources,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
if (resources.memory.used > this.thresholds.maxMemory) {
|
|
61
|
+
return {
|
|
62
|
+
canExecute: false,
|
|
63
|
+
reason: `Memory usage too high (${resources.memory.used.toFixed(0)}MB > ${this.thresholds.maxMemory}MB)`,
|
|
64
|
+
suggestion: 'Close other applications or use foreground mode',
|
|
65
|
+
resources,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
if (config && config.resourceLimits) {
|
|
69
|
+
const { maxCPU, maxMemory } = config.resourceLimits;
|
|
70
|
+
if (maxCPU !== undefined) {
|
|
71
|
+
const availableCPU = this.thresholds.maxCPU - resources.cpu.usage;
|
|
72
|
+
if (maxCPU > availableCPU) {
|
|
73
|
+
return {
|
|
74
|
+
canExecute: false,
|
|
75
|
+
reason: `Task requires ${maxCPU}% CPU but only ${availableCPU.toFixed(1)}% available`,
|
|
76
|
+
suggestion: 'Reduce task resource requirements or wait',
|
|
77
|
+
resources,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (maxMemory !== undefined) {
|
|
82
|
+
if (maxMemory > resources.memory.available) {
|
|
83
|
+
return {
|
|
84
|
+
canExecute: false,
|
|
85
|
+
reason: `Task requires ${maxMemory}MB but only ${resources.memory.available.toFixed(0)}MB available`,
|
|
86
|
+
suggestion: 'Reduce task memory requirements or wait',
|
|
87
|
+
resources,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return {
|
|
93
|
+
canExecute: true,
|
|
94
|
+
resources,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
registerBackgroundTask() {
|
|
98
|
+
this.activeBackgroundCount++;
|
|
99
|
+
}
|
|
100
|
+
unregisterBackgroundTask() {
|
|
101
|
+
if (this.activeBackgroundCount > 0) {
|
|
102
|
+
this.activeBackgroundCount--;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
getActiveBackgroundCount() {
|
|
106
|
+
return this.activeBackgroundCount;
|
|
107
|
+
}
|
|
108
|
+
setMaxCPU(percentage) {
|
|
109
|
+
if (percentage < 0 || percentage > 100) {
|
|
110
|
+
throw new ValidationError('CPU percentage must be between 0 and 100', {
|
|
111
|
+
value: percentage,
|
|
112
|
+
min: 0,
|
|
113
|
+
max: 100,
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
this.thresholds.maxCPU = percentage;
|
|
117
|
+
}
|
|
118
|
+
setMaxMemory(megabytes) {
|
|
119
|
+
if (megabytes < 0) {
|
|
120
|
+
throw new ValidationError('Memory must be positive', {
|
|
121
|
+
value: megabytes,
|
|
122
|
+
min: 0,
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
this.thresholds.maxMemory = megabytes;
|
|
126
|
+
}
|
|
127
|
+
setMaxBackgroundAgents(count) {
|
|
128
|
+
if (count < 1) {
|
|
129
|
+
throw new ValidationError('Max background agents must be at least 1', {
|
|
130
|
+
value: count,
|
|
131
|
+
min: 1,
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
this.maxBackgroundAgents = count;
|
|
135
|
+
}
|
|
136
|
+
dispose() {
|
|
137
|
+
this.disposed = true;
|
|
138
|
+
for (const intervalId of this.activeIntervals) {
|
|
139
|
+
clearInterval(intervalId);
|
|
140
|
+
}
|
|
141
|
+
this.activeIntervals.clear();
|
|
142
|
+
logger.debug('[ResourceMonitor] Disposed all resources');
|
|
143
|
+
}
|
|
144
|
+
onThresholdExceeded(threshold, callback) {
|
|
145
|
+
if (this.disposed) {
|
|
146
|
+
throw new Error('ResourceMonitor has been disposed');
|
|
147
|
+
}
|
|
148
|
+
const intervalId = setInterval(() => {
|
|
149
|
+
try {
|
|
150
|
+
const resources = this.getCurrentResources();
|
|
151
|
+
if (threshold === 'cpu' && resources.cpu.usage > this.thresholds.maxCPU) {
|
|
152
|
+
callback(resources);
|
|
153
|
+
}
|
|
154
|
+
else if (threshold === 'memory' &&
|
|
155
|
+
resources.memory.used > this.thresholds.maxMemory) {
|
|
156
|
+
callback(resources);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
catch (error) {
|
|
160
|
+
logger.error(`[ResourceMonitor] Threshold callback error (${threshold}):`, {
|
|
161
|
+
error: error instanceof Error ? error.message : String(error),
|
|
162
|
+
threshold,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
}, 5000);
|
|
166
|
+
this.activeIntervals.add(intervalId);
|
|
167
|
+
return () => {
|
|
168
|
+
clearInterval(intervalId);
|
|
169
|
+
this.activeIntervals.delete(intervalId);
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
getStats() {
|
|
173
|
+
return {
|
|
174
|
+
activeIntervals: this.activeIntervals.size,
|
|
175
|
+
activeBackgroundAgents: this.activeBackgroundCount,
|
|
176
|
+
maxBackgroundAgents: this.maxBackgroundAgents,
|
|
177
|
+
thresholds: { ...this.thresholds },
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
//# sourceMappingURL=ResourceMonitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResourceMonitor.js","sourceRoot":"","sources":["../../src/core/ResourceMonitor.ts"],"names":[],"mappings":"AA4CA,OAAO,EAAE,MAAM,IAAI,CAAC;AAEpB,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAc5C,MAAM,OAAO,eAAe;IAClB,qBAAqB,GAAW,CAAC,CAAC;IAClC,mBAAmB,CAAS;IAC5B,UAAU,CAGhB;IAMM,eAAe,GAAwB,IAAI,GAAG,EAAE,CAAC;IAKjD,QAAQ,GAAY,KAAK,CAAC;IA+BlC,YACE,sBAA8B,CAAC,EAC/B,UAGC;QAED,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAC/C,IAAI,CAAC,UAAU,GAAG;YAChB,MAAM,EAAE,UAAU,EAAE,MAAM,IAAI,EAAE;YAChC,SAAS,EAAE,UAAU,EAAE,SAAS,IAAI,IAAI;SACzC,CAAC;IACJ,CAAC;IA0BD,mBAAmB;QACjB,MAAM,IAAI,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;QACvB,MAAM,aAAa,GAAG,OAAO,EAAE,CAAC,oBAAoB,KAAK,UAAU;YACjE,CAAC,CAAC,EAAE,CAAC,oBAAoB,EAAE;YAC3B,CAAC,CAAC,CAAC,CAAC;QACN,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;QACtD,MAAM,QAAQ,GAAG,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAC7C,MAAM,OAAO,GAAG,QAAQ,GAAG,OAAO,CAAC;QAoBnC,MAAM,OAAO,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC;QAExD,OAAO;YACL,GAAG,EAAE;gBACH,KAAK,EAAE,QAAQ;gBACf,KAAK;aACN;YACD,MAAM,EAAE;gBACN,KAAK,EAAE,QAAQ;gBACf,IAAI,EAAE,OAAO;gBACb,SAAS,EAAE,OAAO;gBAClB,YAAY,EAAE,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,GAAG;aACzC;YACD,sBAAsB,EAAE,IAAI,CAAC,qBAAqB;SACnD,CAAC;IACJ,CAAC;IAmDD,oBAAoB,CAAC,MAAwB;QAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAG7C,IAAI,SAAS,CAAC,sBAAsB,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACjE,OAAO;gBACL,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,6CAA6C,IAAI,CAAC,mBAAmB,GAAG;gBAChF,UAAU,EAAE,4DAA4D;gBACxE,SAAS;aACV,CAAC;QACJ,CAAC;QAGD,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YACjD,OAAO;gBACL,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,uBAAuB,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI;gBAC9F,UAAU,EAAE,uDAAuD;gBACnE,SAAS;aACV,CAAC;QACJ,CAAC;QAGD,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YACtD,OAAO;gBACL,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,0BAA0B,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,UAAU,CAAC,SAAS,KAAK;gBACxG,UAAU,EAAE,iDAAiD;gBAC7D,SAAS;aACV,CAAC;QACJ,CAAC;QAGD,IAAI,MAAM,IAAI,MAAM,CAAC,cAAc,EAAE,CAAC;YACpC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,cAAc,CAAC;YAGpD,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;gBACzB,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC;gBAClE,IAAI,MAAM,GAAG,YAAY,EAAE,CAAC;oBAC1B,OAAO;wBACL,UAAU,EAAE,KAAK;wBACjB,MAAM,EAAE,iBAAiB,MAAM,kBAAkB,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa;wBACrF,UAAU,EAAE,2CAA2C;wBACvD,SAAS;qBACV,CAAC;gBACJ,CAAC;YACH,CAAC;YAID,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;gBAC5B,IAAI,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;oBAC3C,OAAO;wBACL,UAAU,EAAE,KAAK;wBACjB,MAAM,EAAE,iBAAiB,SAAS,eAAe,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc;wBACpG,UAAU,EAAE,yCAAyC;wBACrD,SAAS;qBACV,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO;YACL,UAAU,EAAE,IAAI;YAChB,SAAS;SACV,CAAC;IACJ,CAAC;IAKD,sBAAsB;QACpB,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAKD,wBAAwB;QACtB,IAAI,IAAI,CAAC,qBAAqB,GAAG,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IAKD,wBAAwB;QACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAKD,SAAS,CAAC,UAAkB;QAC1B,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,GAAG,EAAE,CAAC;YACvC,MAAM,IAAI,eAAe,CAAC,0CAA0C,EAAE;gBACpE,KAAK,EAAE,UAAU;gBACjB,GAAG,EAAE,CAAC;gBACN,GAAG,EAAE,GAAG;aACT,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,UAAU,CAAC;IACtC,CAAC;IAKD,YAAY,CAAC,SAAiB;QAC5B,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;YAClB,MAAM,IAAI,eAAe,CAAC,yBAAyB,EAAE;gBACnD,KAAK,EAAE,SAAS;gBAChB,GAAG,EAAE,CAAC;aACP,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,SAAS,CAAC;IACxC,CAAC;IAKD,sBAAsB,CAAC,KAAa;QAClC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACd,MAAM,IAAI,eAAe,CAAC,0CAA0C,EAAE;gBACpE,KAAK,EAAE,KAAK;gBACZ,GAAG,EAAE,CAAC;aACP,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;IACnC,CAAC;IAiBD,OAAO;QAEL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAGrB,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YAC9C,aAAa,CAAC,UAAU,CAAC,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;QAE7B,MAAM,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC3D,CAAC;IAYD,mBAAmB,CACjB,SAA2B,EAC3B,QAA8C;QAG9C,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QAGD,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC;gBACH,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAE7C,IAAI,SAAS,KAAK,KAAK,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;oBACxE,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACtB,CAAC;qBAAM,IACL,SAAS,KAAK,QAAQ;oBACtB,SAAS,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,EACjD,CAAC;oBACD,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACtB,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAEf,MAAM,CAAC,KAAK,CAAC,+CAA+C,SAAS,IAAI,EAAE;oBACzE,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;oBAC7D,SAAS;iBACV,CAAC,CAAC;YACL,CAAC;QACH,CAAC,EAAE,IAAI,CAAC,CAAC;QAGT,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAGrC,OAAO,GAAG,EAAE;YACV,aAAa,CAAC,UAAU,CAAC,CAAC;YAE1B,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC1C,CAAC,CAAC;IACJ,CAAC;IAmBD,QAAQ;QASN,OAAO;YACL,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI;YAC1C,sBAAsB,EAAE,IAAI,CAAC,qBAAqB;YAClD,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;YAC7C,UAAU,EAAE,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE;SACnC,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BackgroundTask } from './types.js';
|
|
2
|
+
export declare class ResultHandler {
|
|
3
|
+
handleCompleted(task: BackgroundTask, result: unknown): void;
|
|
4
|
+
handleFailed(task: BackgroundTask, error: Error): void;
|
|
5
|
+
handleCancelled(task: BackgroundTask): void;
|
|
6
|
+
private executeCallback;
|
|
7
|
+
private sanitizeCallbackError;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=ResultHandler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResultHandler.d.ts","sourceRoot":"","sources":["../../src/core/ResultHandler.ts"],"names":[],"mappings":"AA+BA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAsB5C,qBAAa,aAAa;IA8BxB,eAAe,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI;IA+C5D,YAAY,CAAC,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK,GAAG,IAAI;IAoCtD,eAAe,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAmB3C,OAAO,CAAC,eAAe;IAuBvB,OAAO,CAAC,qBAAqB;CAyB9B"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { logger } from '../utils/logger.js';
|
|
2
|
+
import { looksLikeSensitive, hashValue } from '../telemetry/sanitization.js';
|
|
3
|
+
export class ResultHandler {
|
|
4
|
+
handleCompleted(task, result) {
|
|
5
|
+
task.status = 'completed';
|
|
6
|
+
task.endTime = new Date();
|
|
7
|
+
task.result = result;
|
|
8
|
+
task.progress = {
|
|
9
|
+
progress: 1.0,
|
|
10
|
+
currentStage: 'completed',
|
|
11
|
+
};
|
|
12
|
+
logger.info(`BackgroundExecutor: Task ${task.taskId} completed`);
|
|
13
|
+
this.executeCallback(() => {
|
|
14
|
+
task.config.callbacks?.onComplete?.(result);
|
|
15
|
+
}, task.taskId, 'onComplete');
|
|
16
|
+
}
|
|
17
|
+
handleFailed(task, error) {
|
|
18
|
+
task.status = 'failed';
|
|
19
|
+
task.endTime = new Date();
|
|
20
|
+
task.error = error;
|
|
21
|
+
logger.error(`BackgroundExecutor: Task ${task.taskId} failed:`, error);
|
|
22
|
+
this.executeCallback(() => {
|
|
23
|
+
task.config.callbacks?.onError?.(error);
|
|
24
|
+
}, task.taskId, 'onError');
|
|
25
|
+
}
|
|
26
|
+
handleCancelled(task) {
|
|
27
|
+
task.status = 'cancelled';
|
|
28
|
+
task.endTime = new Date();
|
|
29
|
+
logger.info(`BackgroundExecutor: Task ${task.taskId} cancelled`);
|
|
30
|
+
}
|
|
31
|
+
executeCallback(callback, taskId, callbackName) {
|
|
32
|
+
try {
|
|
33
|
+
callback();
|
|
34
|
+
}
|
|
35
|
+
catch (callbackError) {
|
|
36
|
+
const sanitizedError = this.sanitizeCallbackError(callbackError);
|
|
37
|
+
logger.error(`BackgroundExecutor: Error in ${callbackName} callback for task ${taskId}:`, sanitizedError);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
sanitizeCallbackError(error) {
|
|
41
|
+
if (error instanceof Error) {
|
|
42
|
+
const message = error.message || '';
|
|
43
|
+
const sanitized = message
|
|
44
|
+
.split('\n')
|
|
45
|
+
.map(line => (looksLikeSensitive(line) ? `[REDACTED:${hashValue(line)}]` : line))
|
|
46
|
+
.join('\n');
|
|
47
|
+
return {
|
|
48
|
+
name: error.name,
|
|
49
|
+
message: sanitized,
|
|
50
|
+
stack: error.stack,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const errorStr = String(error);
|
|
54
|
+
if (looksLikeSensitive(errorStr)) {
|
|
55
|
+
return `[REDACTED:${hashValue(errorStr)}]`;
|
|
56
|
+
}
|
|
57
|
+
return error;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=ResultHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResultHandler.js","sourceRoot":"","sources":["../../src/core/ResultHandler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare class ServiceLocator {
|
|
2
|
+
private static services;
|
|
3
|
+
static register<T>(key: string, service: T): void;
|
|
4
|
+
static get<T>(key: string): T;
|
|
5
|
+
static has(key: string): boolean;
|
|
6
|
+
static clear(): void;
|
|
7
|
+
static keys(): string[];
|
|
8
|
+
static unregister(key: string): boolean;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=ServiceLocator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceLocator.d.ts","sourceRoot":"","sources":["../../src/core/ServiceLocator.ts"],"names":[],"mappings":"AAkCA,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA0B;IAiBjD,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,IAAI;IAsBjD,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC;IAqB7B,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAehC,MAAM,CAAC,KAAK,IAAI,IAAI;IAUpB,MAAM,CAAC,IAAI,IAAI,MAAM,EAAE;IAUvB,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;CAGxC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export class ServiceLocator {
|
|
2
|
+
static services = new Map();
|
|
3
|
+
static register(key, service) {
|
|
4
|
+
if (this.services.has(key)) {
|
|
5
|
+
console.warn(`ServiceLocator: Overwriting existing service '${key}'`);
|
|
6
|
+
}
|
|
7
|
+
this.services.set(key, service);
|
|
8
|
+
}
|
|
9
|
+
static get(key) {
|
|
10
|
+
const service = this.services.get(key);
|
|
11
|
+
if (!service) {
|
|
12
|
+
throw new Error(`Service not found: ${key}`);
|
|
13
|
+
}
|
|
14
|
+
return service;
|
|
15
|
+
}
|
|
16
|
+
static has(key) {
|
|
17
|
+
return this.services.has(key);
|
|
18
|
+
}
|
|
19
|
+
static clear() {
|
|
20
|
+
this.services.clear();
|
|
21
|
+
}
|
|
22
|
+
static keys() {
|
|
23
|
+
return Array.from(this.services.keys());
|
|
24
|
+
}
|
|
25
|
+
static unregister(key) {
|
|
26
|
+
return this.services.delete(key);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=ServiceLocator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceLocator.js","sourceRoot":"","sources":["../../src/core/ServiceLocator.ts"],"names":[],"mappings":"AAkCA,MAAM,OAAO,cAAc;IACjB,MAAM,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAe,CAAC;IAiBjD,MAAM,CAAC,QAAQ,CAAI,GAAW,EAAE,OAAU;QACxC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,IAAI,CAAC,iDAAiD,GAAG,GAAG,CAAC,CAAC;QACxE,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAClC,CAAC;IAiBD,MAAM,CAAC,GAAG,CAAI,GAAW;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,sBAAsB,GAAG,EAAE,CAAC,CAAC;QAC/C,CAAC;QACD,OAAO,OAAY,CAAC;IACtB,CAAC;IAeD,MAAM,CAAC,GAAG,CAAC,GAAW;QACpB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAaD,MAAM,CAAC,KAAK;QACV,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAQD,MAAM,CAAC,IAAI;QACT,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1C,CAAC;IAQD,MAAM,CAAC,UAAU,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { SessionTokenTracker } from './SessionTokenTracker.js';
|
|
2
|
+
export type SessionHealthStatus = 'healthy' | 'warning' | 'critical';
|
|
3
|
+
export type WarningType = 'token-threshold' | 'quality-degradation' | 'context-staleness' | 'system-error';
|
|
4
|
+
export interface SessionWarning {
|
|
5
|
+
type: WarningType;
|
|
6
|
+
level: 'info' | 'warning' | 'critical';
|
|
7
|
+
message: string;
|
|
8
|
+
data?: Record<string, unknown>;
|
|
9
|
+
}
|
|
10
|
+
export interface MonitorRecommendation {
|
|
11
|
+
action: string;
|
|
12
|
+
priority: 'low' | 'medium' | 'high' | 'critical';
|
|
13
|
+
description: string;
|
|
14
|
+
reasoning: string;
|
|
15
|
+
}
|
|
16
|
+
export interface SessionHealth {
|
|
17
|
+
status: SessionHealthStatus;
|
|
18
|
+
tokenUsagePercentage: number;
|
|
19
|
+
warnings: SessionWarning[];
|
|
20
|
+
recommendations: MonitorRecommendation[];
|
|
21
|
+
timestamp: Date;
|
|
22
|
+
}
|
|
23
|
+
export declare class SessionContextMonitor {
|
|
24
|
+
private tokenTracker;
|
|
25
|
+
private static readonly MAX_QUALITY_HISTORY;
|
|
26
|
+
private static readonly MIN_SCORES_FOR_TREND;
|
|
27
|
+
private static readonly DEGRADATION_THRESHOLD;
|
|
28
|
+
private qualityHistory;
|
|
29
|
+
private lastHealthCheck;
|
|
30
|
+
constructor(tokenTracker: SessionTokenTracker);
|
|
31
|
+
checkSessionHealth(): SessionHealth;
|
|
32
|
+
recordQualityScore(score: number): void;
|
|
33
|
+
private checkQualityDegradation;
|
|
34
|
+
private determineStatus;
|
|
35
|
+
getStats(): {
|
|
36
|
+
tokenStats: import("./SessionTokenTracker.js").SessionStats;
|
|
37
|
+
qualityHistory: number[];
|
|
38
|
+
lastHealthCheck: Date | null;
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=SessionContextMonitor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionContextMonitor.d.ts","sourceRoot":"","sources":["../../src/core/SessionContextMonitor.ts"],"names":[],"mappings":"AA8DA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AA4BpE,MAAM,MAAM,mBAAmB,GAAG,SAAS,GAAG,SAAS,GAAG,UAAU,CAAC;AA6BrE,MAAM,MAAM,WAAW,GACnB,iBAAiB,GACjB,qBAAqB,GACrB,mBAAmB,GACnB,cAAc,CAAC;AAmCnB,MAAM,WAAW,cAAc;IAE7B,IAAI,EAAE,WAAW,CAAC;IAElB,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAAC;IAEvC,OAAO,EAAE,MAAM,CAAC;IAEhB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC;AAmCD,MAAM,WAAW,qBAAqB;IAEpC,MAAM,EAAE,MAAM,CAAC;IAEf,QAAQ,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;IAEjD,WAAW,EAAE,MAAM,CAAC;IAEpB,SAAS,EAAE,MAAM,CAAC;CACnB;AAqDD,MAAM,WAAW,aAAa;IAE5B,MAAM,EAAE,mBAAmB,CAAC;IAE5B,oBAAoB,EAAE,MAAM,CAAC;IAE7B,QAAQ,EAAE,cAAc,EAAE,CAAC;IAE3B,eAAe,EAAE,qBAAqB,EAAE,CAAC;IAEzC,SAAS,EAAE,IAAI,CAAC;CACjB;AAwDD,qBAAa,qBAAqB;IA4CpB,OAAO,CAAC,YAAY;IA1ChC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,mBAAmB,CAAM;IAEjD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAK;IAEjD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,qBAAqB,CAAQ;IAGrD,OAAO,CAAC,cAAc,CAAgB;IAEtC,OAAO,CAAC,eAAe,CAAqB;gBAiCxB,YAAY,EAAE,mBAAmB;IAkErD,kBAAkB,IAAI,aAAa;IAiJnC,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAoEvC,OAAO,CAAC,uBAAuB;IA8F/B,OAAO,CAAC,eAAe;IAgEvB,QAAQ;;;;;CAOT"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { StateError, ValidationError } from '../errors/index.js';
|
|
2
|
+
export class SessionContextMonitor {
|
|
3
|
+
tokenTracker;
|
|
4
|
+
static MAX_QUALITY_HISTORY = 10;
|
|
5
|
+
static MIN_SCORES_FOR_TREND = 3;
|
|
6
|
+
static DEGRADATION_THRESHOLD = 0.15;
|
|
7
|
+
qualityHistory = [];
|
|
8
|
+
lastHealthCheck = null;
|
|
9
|
+
constructor(tokenTracker) {
|
|
10
|
+
this.tokenTracker = tokenTracker;
|
|
11
|
+
if (!tokenTracker) {
|
|
12
|
+
throw new StateError('SessionTokenTracker is required', {
|
|
13
|
+
component: 'SessionContextMonitor',
|
|
14
|
+
requiredDependency: 'SessionTokenTracker',
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
checkSessionHealth() {
|
|
19
|
+
const warnings = [];
|
|
20
|
+
const recommendations = [];
|
|
21
|
+
let thresholdWarnings;
|
|
22
|
+
let usagePercentage;
|
|
23
|
+
try {
|
|
24
|
+
thresholdWarnings = this.tokenTracker.checkThresholds();
|
|
25
|
+
usagePercentage = this.tokenTracker.getUsagePercentage();
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
const timestamp = new Date();
|
|
29
|
+
this.lastHealthCheck = timestamp;
|
|
30
|
+
const errorMessage = error instanceof Error
|
|
31
|
+
? error.message
|
|
32
|
+
: String(error);
|
|
33
|
+
return {
|
|
34
|
+
status: 'critical',
|
|
35
|
+
tokenUsagePercentage: 0,
|
|
36
|
+
warnings: [
|
|
37
|
+
{
|
|
38
|
+
type: 'system-error',
|
|
39
|
+
level: 'critical',
|
|
40
|
+
message: `Token tracker error: ${errorMessage}`,
|
|
41
|
+
data: {},
|
|
42
|
+
},
|
|
43
|
+
],
|
|
44
|
+
recommendations: [],
|
|
45
|
+
timestamp,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
for (const tw of thresholdWarnings) {
|
|
49
|
+
warnings.push({
|
|
50
|
+
type: 'token-threshold',
|
|
51
|
+
level: tw.level,
|
|
52
|
+
message: tw.message,
|
|
53
|
+
data: {
|
|
54
|
+
threshold: tw.threshold,
|
|
55
|
+
tokensUsed: tw.tokensUsed,
|
|
56
|
+
tokensRemaining: tw.tokensRemaining,
|
|
57
|
+
},
|
|
58
|
+
});
|
|
59
|
+
if (tw.level === 'critical') {
|
|
60
|
+
recommendations.push({
|
|
61
|
+
action: 'reload-claude-md',
|
|
62
|
+
priority: 'critical',
|
|
63
|
+
description: 'Reload CLAUDE.md to refresh context',
|
|
64
|
+
reasoning: `Session approaching token limit (${tw.threshold}% used)`,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
else if (tw.level === 'warning') {
|
|
68
|
+
recommendations.push({
|
|
69
|
+
action: 'review-context',
|
|
70
|
+
priority: 'medium',
|
|
71
|
+
description: 'Review and optimize context usage',
|
|
72
|
+
reasoning: `Session token usage is high (${tw.threshold}% used)`,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
const qualityWarning = this.checkQualityDegradation();
|
|
77
|
+
if (qualityWarning) {
|
|
78
|
+
warnings.push(qualityWarning);
|
|
79
|
+
recommendations.push({
|
|
80
|
+
action: 'context-refresh',
|
|
81
|
+
priority: 'high',
|
|
82
|
+
description: 'Refresh context to improve quality',
|
|
83
|
+
reasoning: 'Quality scores showing degradation trend',
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
const status = this.determineStatus(warnings);
|
|
87
|
+
const timestamp = new Date();
|
|
88
|
+
this.lastHealthCheck = timestamp;
|
|
89
|
+
return {
|
|
90
|
+
status,
|
|
91
|
+
tokenUsagePercentage: usagePercentage,
|
|
92
|
+
warnings,
|
|
93
|
+
recommendations,
|
|
94
|
+
timestamp,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
recordQualityScore(score) {
|
|
98
|
+
if (!Number.isFinite(score) || score < 0 || score > 1) {
|
|
99
|
+
throw new ValidationError('Quality score must be a finite number between 0 and 1', {
|
|
100
|
+
providedScore: score,
|
|
101
|
+
validRange: { min: 0, max: 1 },
|
|
102
|
+
mustBeFinite: true,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
this.qualityHistory.push(score);
|
|
106
|
+
while (this.qualityHistory.length > SessionContextMonitor.MAX_QUALITY_HISTORY) {
|
|
107
|
+
this.qualityHistory.shift();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
checkQualityDegradation() {
|
|
111
|
+
if (this.qualityHistory.length < SessionContextMonitor.MIN_SCORES_FOR_TREND) {
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
const recent = this.qualityHistory.slice(-3);
|
|
115
|
+
const previous = this.qualityHistory.slice(-6, -3);
|
|
116
|
+
if (previous.length === 0) {
|
|
117
|
+
return null;
|
|
118
|
+
}
|
|
119
|
+
const recentAvg = recent.reduce((a, b) => a + b, 0) / recent.length;
|
|
120
|
+
const previousAvg = previous.reduce((a, b) => a + b, 0) / previous.length;
|
|
121
|
+
if (previousAvg === 0) {
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
124
|
+
if (recentAvg <
|
|
125
|
+
previousAvg * (1 - SessionContextMonitor.DEGRADATION_THRESHOLD)) {
|
|
126
|
+
return {
|
|
127
|
+
type: 'quality-degradation',
|
|
128
|
+
level: 'warning',
|
|
129
|
+
message: `Quality scores declining (${previousAvg.toFixed(2)} → ${recentAvg.toFixed(2)})`,
|
|
130
|
+
data: {
|
|
131
|
+
recentAvg,
|
|
132
|
+
previousAvg,
|
|
133
|
+
dropPercentage: ((previousAvg - recentAvg) / previousAvg) * 100,
|
|
134
|
+
},
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
return null;
|
|
138
|
+
}
|
|
139
|
+
determineStatus(warnings) {
|
|
140
|
+
const hasCritical = warnings.some((w) => w.level === 'critical');
|
|
141
|
+
const hasWarning = warnings.some((w) => w.level === 'warning');
|
|
142
|
+
if (hasCritical)
|
|
143
|
+
return 'critical';
|
|
144
|
+
if (hasWarning)
|
|
145
|
+
return 'warning';
|
|
146
|
+
return 'healthy';
|
|
147
|
+
}
|
|
148
|
+
getStats() {
|
|
149
|
+
return {
|
|
150
|
+
tokenStats: this.tokenTracker.getStats(),
|
|
151
|
+
qualityHistory: [...this.qualityHistory],
|
|
152
|
+
lastHealthCheck: this.lastHealthCheck,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=SessionContextMonitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionContextMonitor.js","sourceRoot":"","sources":["../../src/core/SessionContextMonitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export interface TokenUsage {
|
|
2
|
+
inputTokens: number;
|
|
3
|
+
outputTokens: number;
|
|
4
|
+
timestamp?: Date;
|
|
5
|
+
}
|
|
6
|
+
export interface ThresholdConfig {
|
|
7
|
+
percentage: number;
|
|
8
|
+
level: 'info' | 'warning' | 'critical';
|
|
9
|
+
}
|
|
10
|
+
export interface ThresholdWarning {
|
|
11
|
+
threshold: number;
|
|
12
|
+
level: 'info' | 'warning' | 'critical';
|
|
13
|
+
tokensUsed: number;
|
|
14
|
+
tokensRemaining: number;
|
|
15
|
+
message: string;
|
|
16
|
+
}
|
|
17
|
+
export interface SessionStats {
|
|
18
|
+
totalTokens: number;
|
|
19
|
+
tokenLimit: number;
|
|
20
|
+
usagePercentage: number;
|
|
21
|
+
tokensRemaining: number;
|
|
22
|
+
interactionCount: number;
|
|
23
|
+
triggeredThresholds: number[];
|
|
24
|
+
}
|
|
25
|
+
export interface SessionTokenTrackerConfig {
|
|
26
|
+
tokenLimit: number;
|
|
27
|
+
thresholds?: ThresholdConfig[];
|
|
28
|
+
}
|
|
29
|
+
export declare class SessionTokenTracker {
|
|
30
|
+
private totalTokens;
|
|
31
|
+
private tokenLimit;
|
|
32
|
+
private thresholds;
|
|
33
|
+
private usageHistory;
|
|
34
|
+
private triggeredThresholds;
|
|
35
|
+
constructor(config: SessionTokenTrackerConfig);
|
|
36
|
+
recordUsage(usage: TokenUsage): void;
|
|
37
|
+
getTotalTokens(): number;
|
|
38
|
+
getUsagePercentage(): number;
|
|
39
|
+
checkThresholds(): ThresholdWarning[];
|
|
40
|
+
getStats(): SessionStats;
|
|
41
|
+
reset(): void;
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=SessionTokenTracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionTokenTracker.d.ts","sourceRoot":"","sources":["../../src/core/SessionTokenTracker.ts"],"names":[],"mappings":"AA+DA,MAAM,WAAW,UAAU;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB;AAKD,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAAC;CACxC;AAKD,MAAM,WAAW,gBAAgB;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAAC;IACvC,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,OAAO,EAAE,MAAM,CAAC;CACjB;AAKD,MAAM,WAAW,YAAY;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,mBAAmB,EAAE,MAAM,EAAE,CAAC;CAC/B;AAKD,MAAM,WAAW,yBAAyB;IACxC,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,eAAe,EAAE,CAAC;CAChC;AAwCD,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,WAAW,CAAa;IAChC,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAoB;IACtC,OAAO,CAAC,YAAY,CAAoB;IACxC,OAAO,CAAC,mBAAmB,CAA0B;gBAEzC,MAAM,EAAE,yBAAyB;IA6C7C,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAkCpC,cAAc,IAAI,MAAM;IAuBxB,kBAAkB,IAAI,MAAM;IAQ5B,eAAe,IAAI,gBAAgB,EAAE;IA0BrC,QAAQ,IAAI,YAAY;IAcxB,KAAK,IAAI,IAAI;CAKd"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { ValidationError } from '../errors/index.js';
|
|
2
|
+
export class SessionTokenTracker {
|
|
3
|
+
totalTokens = 0;
|
|
4
|
+
tokenLimit;
|
|
5
|
+
thresholds;
|
|
6
|
+
usageHistory = [];
|
|
7
|
+
triggeredThresholds = new Set();
|
|
8
|
+
constructor(config) {
|
|
9
|
+
if (config.tokenLimit <= 0) {
|
|
10
|
+
throw new ValidationError('Token limit must be positive', {
|
|
11
|
+
providedValue: config.tokenLimit,
|
|
12
|
+
expectedCondition: 'positive number (> 0)',
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
this.tokenLimit = config.tokenLimit;
|
|
16
|
+
this.thresholds = config.thresholds || [
|
|
17
|
+
{ percentage: 80, level: 'warning' },
|
|
18
|
+
{ percentage: 90, level: 'critical' },
|
|
19
|
+
];
|
|
20
|
+
}
|
|
21
|
+
recordUsage(usage) {
|
|
22
|
+
if (usage.inputTokens < 0 || usage.outputTokens < 0) {
|
|
23
|
+
throw new ValidationError('Token counts must be non-negative', {
|
|
24
|
+
inputTokens: usage.inputTokens,
|
|
25
|
+
outputTokens: usage.outputTokens,
|
|
26
|
+
expectedCondition: 'non-negative numbers (>= 0)',
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
const total = usage.inputTokens + usage.outputTokens;
|
|
30
|
+
this.totalTokens += total;
|
|
31
|
+
this.usageHistory.push({
|
|
32
|
+
...usage,
|
|
33
|
+
timestamp: usage.timestamp || new Date(),
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
getTotalTokens() {
|
|
37
|
+
return this.totalTokens;
|
|
38
|
+
}
|
|
39
|
+
getUsagePercentage() {
|
|
40
|
+
return (this.totalTokens / this.tokenLimit) * 100;
|
|
41
|
+
}
|
|
42
|
+
checkThresholds() {
|
|
43
|
+
const percentage = this.getUsagePercentage();
|
|
44
|
+
const warnings = [];
|
|
45
|
+
for (const threshold of this.thresholds) {
|
|
46
|
+
if (percentage >= threshold.percentage &&
|
|
47
|
+
!this.triggeredThresholds.has(threshold.percentage)) {
|
|
48
|
+
this.triggeredThresholds.add(threshold.percentage);
|
|
49
|
+
warnings.push({
|
|
50
|
+
threshold: threshold.percentage,
|
|
51
|
+
level: threshold.level,
|
|
52
|
+
tokensUsed: this.totalTokens,
|
|
53
|
+
tokensRemaining: this.tokenLimit - this.totalTokens,
|
|
54
|
+
message: `Session token usage at ${threshold.percentage}% (${this.totalTokens}/${this.tokenLimit} tokens)`,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return warnings;
|
|
59
|
+
}
|
|
60
|
+
getStats() {
|
|
61
|
+
return {
|
|
62
|
+
totalTokens: this.totalTokens,
|
|
63
|
+
tokenLimit: this.tokenLimit,
|
|
64
|
+
usagePercentage: this.getUsagePercentage(),
|
|
65
|
+
tokensRemaining: this.tokenLimit - this.totalTokens,
|
|
66
|
+
interactionCount: this.usageHistory.length,
|
|
67
|
+
triggeredThresholds: Array.from(this.triggeredThresholds),
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
reset() {
|
|
71
|
+
this.totalTokens = 0;
|
|
72
|
+
this.usageHistory = [];
|
|
73
|
+
this.triggeredThresholds.clear();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=SessionTokenTracker.js.map
|