@newrelic/preflight 0.0.1-pre.1 → 1.0.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 +183 -0
- package/README.md +498 -0
- package/dist/alerts/alert-log.d.ts +24 -0
- package/dist/alerts/alert-log.d.ts.map +1 -0
- package/dist/alerts/alert-log.js +159 -0
- package/dist/alerts/alert-log.js.map +1 -0
- package/dist/alerts/alert-snapshot-collector.d.ts +168 -0
- package/dist/alerts/alert-snapshot-collector.d.ts.map +1 -0
- package/dist/alerts/alert-snapshot-collector.js +243 -0
- package/dist/alerts/alert-snapshot-collector.js.map +1 -0
- package/dist/alerts/local-alert-engine.d.ts +86 -0
- package/dist/alerts/local-alert-engine.d.ts.map +1 -0
- package/dist/alerts/local-alert-engine.js +466 -0
- package/dist/alerts/local-alert-engine.js.map +1 -0
- package/dist/alerts/local-alert-rule.d.ts +439 -0
- package/dist/alerts/local-alert-rule.d.ts.map +1 -0
- package/dist/alerts/local-alert-rule.js +139 -0
- package/dist/alerts/local-alert-rule.js.map +1 -0
- package/dist/alerts/os-notifier.d.ts +39 -0
- package/dist/alerts/os-notifier.d.ts.map +1 -0
- package/dist/alerts/os-notifier.js +170 -0
- package/dist/alerts/os-notifier.js.map +1 -0
- package/dist/alerts/types.d.ts +35 -0
- package/dist/alerts/types.d.ts.map +1 -0
- package/dist/alerts/types.js +8 -0
- package/dist/alerts/types.js.map +1 -0
- package/dist/config.d.ts +169 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +868 -0
- package/dist/config.js.map +1 -0
- package/dist/dashboard/dashboard-server.d.ts +38 -0
- package/dist/dashboard/dashboard-server.d.ts.map +1 -0
- package/dist/dashboard/dashboard-server.js +207 -0
- package/dist/dashboard/dashboard-server.js.map +1 -0
- package/dist/dashboard/index.d.ts +3 -0
- package/dist/dashboard/index.d.ts.map +1 -0
- package/dist/dashboard/index.js +2 -0
- package/dist/dashboard/index.js.map +1 -0
- package/dist/dashboard/live-event-bus.d.ts +99 -0
- package/dist/dashboard/live-event-bus.d.ts.map +1 -0
- package/dist/dashboard/live-event-bus.js +56 -0
- package/dist/dashboard/live-event-bus.js.map +1 -0
- package/dist/dashboard/routes/api-handler.d.ts +122 -0
- package/dist/dashboard/routes/api-handler.d.ts.map +1 -0
- package/dist/dashboard/routes/api-handler.js +1414 -0
- package/dist/dashboard/routes/api-handler.js.map +1 -0
- package/dist/dashboard/routes/replay-analyzer.d.ts +15 -0
- package/dist/dashboard/routes/replay-analyzer.d.ts.map +1 -0
- package/dist/dashboard/routes/replay-analyzer.js +227 -0
- package/dist/dashboard/routes/replay-analyzer.js.map +1 -0
- package/dist/dashboard/routes/sse-handler.d.ts +4 -0
- package/dist/dashboard/routes/sse-handler.d.ts.map +1 -0
- package/dist/dashboard/routes/sse-handler.js +122 -0
- package/dist/dashboard/routes/sse-handler.js.map +1 -0
- package/dist/dashboard/routes/static-handler.d.ts +3 -0
- package/dist/dashboard/routes/static-handler.d.ts.map +1 -0
- package/dist/dashboard/routes/static-handler.js +123 -0
- package/dist/dashboard/routes/static-handler.js.map +1 -0
- package/dist/data/alerts/conditions/01-daily-cost-spike.json +16 -0
- package/dist/data/alerts/conditions/02-low-efficiency-score.json +16 -0
- package/dist/data/alerts/conditions/03-stuck-loop-rate.json +16 -0
- package/dist/data/alerts/conditions/04-anti-pattern-rate.json +16 -0
- package/dist/data/alerts/conditions/05-session-cost-budget.json +16 -0
- package/dist/data/alerts/conditions-personal/01-personal-daily-cost.json +16 -0
- package/dist/data/alerts/conditions-personal/02-personal-session-cost.json +16 -0
- package/dist/data/alerts/conditions-personal/03-personal-low-efficiency.json +16 -0
- package/dist/data/alerts/conditions-personal/04-personal-anti-pattern-rate.json +16 -0
- package/dist/data/alerts/conditions-personal/05-personal-stuck-loop.json +16 -0
- package/dist/data/alerts/policy.json +4 -0
- package/dist/data/dashboards/ai-coding-assistant-manager-view.json +103 -0
- package/dist/data/dashboards/ai-coding-assistant-overview.json +239 -0
- package/dist/data/dashboards/ai-coding-assistant-personal.json +442 -0
- package/dist/data/dashboards/ai-coding-assistant-platform-comparison.json +320 -0
- package/dist/data/dashboards/ai-coding-assistant-security.json +275 -0
- package/dist/data/dashboards/ai-coding-assistant-session-detail.json +296 -0
- package/dist/data/dashboards/ai-coding-assistant-team-view.json +345 -0
- package/dist/deploy/data-paths.d.ts +22 -0
- package/dist/deploy/data-paths.d.ts.map +1 -0
- package/dist/deploy/data-paths.js +69 -0
- package/dist/deploy/data-paths.js.map +1 -0
- package/dist/deploy/deploy-alerts.d.ts +58 -0
- package/dist/deploy/deploy-alerts.d.ts.map +1 -0
- package/dist/deploy/deploy-alerts.js +371 -0
- package/dist/deploy/deploy-alerts.js.map +1 -0
- package/dist/deploy/deploy-dashboards.d.ts +92 -0
- package/dist/deploy/deploy-dashboards.d.ts.map +1 -0
- package/dist/deploy/deploy-dashboards.js +282 -0
- package/dist/deploy/deploy-dashboards.js.map +1 -0
- package/dist/digest/digest-formatter.d.ts +3 -0
- package/dist/digest/digest-formatter.d.ts.map +1 -0
- package/dist/digest/digest-formatter.js +37 -0
- package/dist/digest/digest-formatter.js.map +1 -0
- package/dist/digest/digest-sender.d.ts +2 -0
- package/dist/digest/digest-sender.d.ts.map +1 -0
- package/dist/digest/digest-sender.js +29 -0
- package/dist/digest/digest-sender.js.map +1 -0
- package/dist/hooks/bash-classifier.d.ts +26 -0
- package/dist/hooks/bash-classifier.d.ts.map +1 -0
- package/dist/hooks/bash-classifier.js +409 -0
- package/dist/hooks/bash-classifier.js.map +1 -0
- package/dist/hooks/collector-script.d.ts +47 -0
- package/dist/hooks/collector-script.d.ts.map +1 -0
- package/dist/hooks/collector-script.js +662 -0
- package/dist/hooks/collector-script.js.map +1 -0
- package/dist/hooks/event-processor.d.ts +65 -0
- package/dist/hooks/event-processor.d.ts.map +1 -0
- package/dist/hooks/event-processor.js +342 -0
- package/dist/hooks/event-processor.js.map +1 -0
- package/dist/hooks/index.d.ts +7 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +5 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/session-resolver.d.ts +66 -0
- package/dist/hooks/session-resolver.d.ts.map +1 -0
- package/dist/hooks/session-resolver.js +196 -0
- package/dist/hooks/session-resolver.js.map +1 -0
- package/dist/hooks/tool-parsers.d.ts +19 -0
- package/dist/hooks/tool-parsers.d.ts.map +1 -0
- package/dist/hooks/tool-parsers.js +260 -0
- package/dist/hooks/tool-parsers.js.map +1 -0
- package/dist/index.d.ts +107 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1505 -0
- package/dist/index.js.map +1 -0
- package/dist/install/cli.d.ts +11 -0
- package/dist/install/cli.d.ts.map +1 -0
- package/dist/install/cli.js +365 -0
- package/dist/install/cli.js.map +1 -0
- package/dist/install/index.d.ts +4 -0
- package/dist/install/index.d.ts.map +1 -0
- package/dist/install/index.js +3 -0
- package/dist/install/index.js.map +1 -0
- package/dist/install/install-helper.d.ts +35 -0
- package/dist/install/install-helper.d.ts.map +1 -0
- package/dist/install/install-helper.js +227 -0
- package/dist/install/install-helper.js.map +1 -0
- package/dist/install/key-validator.d.ts +19 -0
- package/dist/install/key-validator.d.ts.map +1 -0
- package/dist/install/key-validator.js +122 -0
- package/dist/install/key-validator.js.map +1 -0
- package/dist/install/migrate.d.ts +12 -0
- package/dist/install/migrate.d.ts.map +1 -0
- package/dist/install/migrate.js +115 -0
- package/dist/install/migrate.js.map +1 -0
- package/dist/install/schedule.d.ts +11 -0
- package/dist/install/schedule.d.ts.map +1 -0
- package/dist/install/schedule.js +114 -0
- package/dist/install/schedule.js.map +1 -0
- package/dist/install/setup-wizard.d.ts +40 -0
- package/dist/install/setup-wizard.d.ts.map +1 -0
- package/dist/install/setup-wizard.js +489 -0
- package/dist/install/setup-wizard.js.map +1 -0
- package/dist/lib/date.d.ts +54 -0
- package/dist/lib/date.d.ts.map +1 -0
- package/dist/lib/date.js +85 -0
- package/dist/lib/date.js.map +1 -0
- package/dist/metrics/anti-patterns.d.ts +62 -0
- package/dist/metrics/anti-patterns.d.ts.map +1 -0
- package/dist/metrics/anti-patterns.js +301 -0
- package/dist/metrics/anti-patterns.js.map +1 -0
- package/dist/metrics/api-failure-tracker.d.ts +82 -0
- package/dist/metrics/api-failure-tracker.d.ts.map +1 -0
- package/dist/metrics/api-failure-tracker.js +202 -0
- package/dist/metrics/api-failure-tracker.js.map +1 -0
- package/dist/metrics/budget-tracker.d.ts +60 -0
- package/dist/metrics/budget-tracker.d.ts.map +1 -0
- package/dist/metrics/budget-tracker.js +130 -0
- package/dist/metrics/budget-tracker.js.map +1 -0
- package/dist/metrics/claudemd-tracker.d.ts +108 -0
- package/dist/metrics/claudemd-tracker.d.ts.map +1 -0
- package/dist/metrics/claudemd-tracker.js +337 -0
- package/dist/metrics/claudemd-tracker.js.map +1 -0
- package/dist/metrics/collaboration-profile.d.ts +65 -0
- package/dist/metrics/collaboration-profile.d.ts.map +1 -0
- package/dist/metrics/collaboration-profile.js +231 -0
- package/dist/metrics/collaboration-profile.js.map +1 -0
- package/dist/metrics/context-composition-tracker.d.ts +74 -0
- package/dist/metrics/context-composition-tracker.d.ts.map +1 -0
- package/dist/metrics/context-composition-tracker.js +202 -0
- package/dist/metrics/context-composition-tracker.js.map +1 -0
- package/dist/metrics/context-tracker.d.ts +78 -0
- package/dist/metrics/context-tracker.d.ts.map +1 -0
- package/dist/metrics/context-tracker.js +222 -0
- package/dist/metrics/context-tracker.js.map +1 -0
- package/dist/metrics/context-window-tracker.d.ts +18 -0
- package/dist/metrics/context-window-tracker.d.ts.map +1 -0
- package/dist/metrics/context-window-tracker.js +35 -0
- package/dist/metrics/context-window-tracker.js.map +1 -0
- package/dist/metrics/cost-forecast.d.ts +36 -0
- package/dist/metrics/cost-forecast.d.ts.map +1 -0
- package/dist/metrics/cost-forecast.js +91 -0
- package/dist/metrics/cost-forecast.js.map +1 -0
- package/dist/metrics/cost-per-outcome.d.ts +102 -0
- package/dist/metrics/cost-per-outcome.d.ts.map +1 -0
- package/dist/metrics/cost-per-outcome.js +266 -0
- package/dist/metrics/cost-per-outcome.js.map +1 -0
- package/dist/metrics/cost-tracker.d.ts +78 -0
- package/dist/metrics/cost-tracker.d.ts.map +1 -0
- package/dist/metrics/cost-tracker.js +169 -0
- package/dist/metrics/cost-tracker.js.map +1 -0
- package/dist/metrics/decision-tracker.d.ts +49 -0
- package/dist/metrics/decision-tracker.d.ts.map +1 -0
- package/dist/metrics/decision-tracker.js +161 -0
- package/dist/metrics/decision-tracker.js.map +1 -0
- package/dist/metrics/efficiency-score.d.ts +80 -0
- package/dist/metrics/efficiency-score.d.ts.map +1 -0
- package/dist/metrics/efficiency-score.js +219 -0
- package/dist/metrics/efficiency-score.js.map +1 -0
- package/dist/metrics/git-efficiency-tracker.d.ts +165 -0
- package/dist/metrics/git-efficiency-tracker.d.ts.map +1 -0
- package/dist/metrics/git-efficiency-tracker.js +1056 -0
- package/dist/metrics/git-efficiency-tracker.js.map +1 -0
- package/dist/metrics/index.d.ts +26 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js +14 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/metrics/instruction-drift-tracker.d.ts +69 -0
- package/dist/metrics/instruction-drift-tracker.d.ts.map +1 -0
- package/dist/metrics/instruction-drift-tracker.js +213 -0
- package/dist/metrics/instruction-drift-tracker.js.map +1 -0
- package/dist/metrics/latency-decomposition.d.ts +50 -0
- package/dist/metrics/latency-decomposition.d.ts.map +1 -0
- package/dist/metrics/latency-decomposition.js +112 -0
- package/dist/metrics/latency-decomposition.js.map +1 -0
- package/dist/metrics/latency-tracker.d.ts +33 -0
- package/dist/metrics/latency-tracker.d.ts.map +1 -0
- package/dist/metrics/latency-tracker.js +93 -0
- package/dist/metrics/latency-tracker.js.map +1 -0
- package/dist/metrics/live-session-registry.d.ts +29 -0
- package/dist/metrics/live-session-registry.d.ts.map +1 -0
- package/dist/metrics/live-session-registry.js +103 -0
- package/dist/metrics/live-session-registry.js.map +1 -0
- package/dist/metrics/model-usage-tracker.d.ts +21 -0
- package/dist/metrics/model-usage-tracker.d.ts.map +1 -0
- package/dist/metrics/model-usage-tracker.js +53 -0
- package/dist/metrics/model-usage-tracker.js.map +1 -0
- package/dist/metrics/percentile.d.ts +5 -0
- package/dist/metrics/percentile.d.ts.map +1 -0
- package/dist/metrics/percentile.js +10 -0
- package/dist/metrics/percentile.js.map +1 -0
- package/dist/metrics/personal-coach.d.ts +47 -0
- package/dist/metrics/personal-coach.d.ts.map +1 -0
- package/dist/metrics/personal-coach.js +241 -0
- package/dist/metrics/personal-coach.js.map +1 -0
- package/dist/metrics/prompt-feedback.d.ts +75 -0
- package/dist/metrics/prompt-feedback.d.ts.map +1 -0
- package/dist/metrics/prompt-feedback.js +286 -0
- package/dist/metrics/prompt-feedback.js.map +1 -0
- package/dist/metrics/proxy-metrics.d.ts +54 -0
- package/dist/metrics/proxy-metrics.d.ts.map +1 -0
- package/dist/metrics/proxy-metrics.js +228 -0
- package/dist/metrics/proxy-metrics.js.map +1 -0
- package/dist/metrics/quality-proxy-tracker.d.ts +51 -0
- package/dist/metrics/quality-proxy-tracker.d.ts.map +1 -0
- package/dist/metrics/quality-proxy-tracker.js +162 -0
- package/dist/metrics/quality-proxy-tracker.js.map +1 -0
- package/dist/metrics/recommendation-engine.d.ts +72 -0
- package/dist/metrics/recommendation-engine.d.ts.map +1 -0
- package/dist/metrics/recommendation-engine.js +207 -0
- package/dist/metrics/recommendation-engine.js.map +1 -0
- package/dist/metrics/retry-detector.d.ts +43 -0
- package/dist/metrics/retry-detector.d.ts.map +1 -0
- package/dist/metrics/retry-detector.js +179 -0
- package/dist/metrics/retry-detector.js.map +1 -0
- package/dist/metrics/session-tracker.d.ts +75 -0
- package/dist/metrics/session-tracker.d.ts.map +1 -0
- package/dist/metrics/session-tracker.js +249 -0
- package/dist/metrics/session-tracker.js.map +1 -0
- package/dist/metrics/task-completion-tracker.d.ts +15 -0
- package/dist/metrics/task-completion-tracker.d.ts.map +1 -0
- package/dist/metrics/task-completion-tracker.js +27 -0
- package/dist/metrics/task-completion-tracker.js.map +1 -0
- package/dist/metrics/task-detector.d.ts +84 -0
- package/dist/metrics/task-detector.d.ts.map +1 -0
- package/dist/metrics/task-detector.js +302 -0
- package/dist/metrics/task-detector.js.map +1 -0
- package/dist/metrics/tool-selection-scorer.d.ts +39 -0
- package/dist/metrics/tool-selection-scorer.d.ts.map +1 -0
- package/dist/metrics/tool-selection-scorer.js +193 -0
- package/dist/metrics/tool-selection-scorer.js.map +1 -0
- package/dist/metrics/trend-analyzer.d.ts +92 -0
- package/dist/metrics/trend-analyzer.d.ts.map +1 -0
- package/dist/metrics/trend-analyzer.js +293 -0
- package/dist/metrics/trend-analyzer.js.map +1 -0
- package/dist/metrics/turn-cost-attributor.d.ts +41 -0
- package/dist/metrics/turn-cost-attributor.d.ts.map +1 -0
- package/dist/metrics/turn-cost-attributor.js +118 -0
- package/dist/metrics/turn-cost-attributor.js.map +1 -0
- package/dist/metrics/turn-tracker.d.ts +49 -0
- package/dist/metrics/turn-tracker.d.ts.map +1 -0
- package/dist/metrics/turn-tracker.js +192 -0
- package/dist/metrics/turn-tracker.js.map +1 -0
- package/dist/platforms/amazon-q-adapter.d.ts +10 -0
- package/dist/platforms/amazon-q-adapter.d.ts.map +1 -0
- package/dist/platforms/amazon-q-adapter.js +75 -0
- package/dist/platforms/amazon-q-adapter.js.map +1 -0
- package/dist/platforms/claude-code-adapter.d.ts +10 -0
- package/dist/platforms/claude-code-adapter.d.ts.map +1 -0
- package/dist/platforms/claude-code-adapter.js +48 -0
- package/dist/platforms/claude-code-adapter.js.map +1 -0
- package/dist/platforms/continue-adapter.d.ts +10 -0
- package/dist/platforms/continue-adapter.d.ts.map +1 -0
- package/dist/platforms/continue-adapter.js +73 -0
- package/dist/platforms/continue-adapter.js.map +1 -0
- package/dist/platforms/copilot-adapter.d.ts +37 -0
- package/dist/platforms/copilot-adapter.d.ts.map +1 -0
- package/dist/platforms/copilot-adapter.js +66 -0
- package/dist/platforms/copilot-adapter.js.map +1 -0
- package/dist/platforms/cursor-adapter.d.ts +10 -0
- package/dist/platforms/cursor-adapter.d.ts.map +1 -0
- package/dist/platforms/cursor-adapter.js +60 -0
- package/dist/platforms/cursor-adapter.js.map +1 -0
- package/dist/platforms/generic-mcp-adapter.d.ts +113 -0
- package/dist/platforms/generic-mcp-adapter.d.ts.map +1 -0
- package/dist/platforms/generic-mcp-adapter.js +139 -0
- package/dist/platforms/generic-mcp-adapter.js.map +1 -0
- package/dist/platforms/index.d.ts +15 -0
- package/dist/platforms/index.d.ts.map +1 -0
- package/dist/platforms/index.js +12 -0
- package/dist/platforms/index.js.map +1 -0
- package/dist/platforms/platform-registry.d.ts +11 -0
- package/dist/platforms/platform-registry.d.ts.map +1 -0
- package/dist/platforms/platform-registry.js +54 -0
- package/dist/platforms/platform-registry.js.map +1 -0
- package/dist/platforms/types.d.ts +36 -0
- package/dist/platforms/types.d.ts.map +1 -0
- package/dist/platforms/types.js +2 -0
- package/dist/platforms/types.js.map +1 -0
- package/dist/platforms/windsurf-adapter.d.ts +10 -0
- package/dist/platforms/windsurf-adapter.d.ts.map +1 -0
- package/dist/platforms/windsurf-adapter.js +63 -0
- package/dist/platforms/windsurf-adapter.js.map +1 -0
- package/dist/platforms/zed-adapter.d.ts +10 -0
- package/dist/platforms/zed-adapter.d.ts.map +1 -0
- package/dist/platforms/zed-adapter.js +72 -0
- package/dist/platforms/zed-adapter.js.map +1 -0
- package/dist/proxy/index.d.ts +7 -0
- package/dist/proxy/index.d.ts.map +1 -0
- package/dist/proxy/index.js +5 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/proxy/otlp-receiver.d.ts +28 -0
- package/dist/proxy/otlp-receiver.d.ts.map +1 -0
- package/dist/proxy/otlp-receiver.js +319 -0
- package/dist/proxy/otlp-receiver.js.map +1 -0
- package/dist/proxy/proxy-manager.d.ts +47 -0
- package/dist/proxy/proxy-manager.d.ts.map +1 -0
- package/dist/proxy/proxy-manager.js +338 -0
- package/dist/proxy/proxy-manager.js.map +1 -0
- package/dist/proxy/types.d.ts +72 -0
- package/dist/proxy/types.d.ts.map +1 -0
- package/dist/proxy/types.js +33 -0
- package/dist/proxy/types.js.map +1 -0
- package/dist/proxy/upstream-http.d.ts +26 -0
- package/dist/proxy/upstream-http.d.ts.map +1 -0
- package/dist/proxy/upstream-http.js +209 -0
- package/dist/proxy/upstream-http.js.map +1 -0
- package/dist/proxy/upstream-stdio.d.ts +25 -0
- package/dist/proxy/upstream-stdio.d.ts.map +1 -0
- package/dist/proxy/upstream-stdio.js +256 -0
- package/dist/proxy/upstream-stdio.js.map +1 -0
- package/dist/security/audit-trail.d.ts +74 -0
- package/dist/security/audit-trail.d.ts.map +1 -0
- package/dist/security/audit-trail.js +338 -0
- package/dist/security/audit-trail.js.map +1 -0
- package/dist/security/index.d.ts +5 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +4 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/ssrf.d.ts +2 -0
- package/dist/security/ssrf.d.ts.map +1 -0
- package/dist/security/ssrf.js +126 -0
- package/dist/security/ssrf.js.map +1 -0
- package/dist/server.d.ts +14 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +117 -0
- package/dist/server.js.map +1 -0
- package/dist/shared/__test-utils__/log-output.d.ts +49 -0
- package/dist/shared/__test-utils__/log-output.d.ts.map +1 -0
- package/dist/shared/__test-utils__/log-output.js +38 -0
- package/dist/shared/__test-utils__/log-output.js.map +1 -0
- package/dist/shared/config.d.ts +56 -0
- package/dist/shared/config.d.ts.map +1 -0
- package/dist/shared/config.js +290 -0
- package/dist/shared/config.js.map +1 -0
- package/dist/shared/errors.d.ts +139 -0
- package/dist/shared/errors.d.ts.map +1 -0
- package/dist/shared/errors.js +406 -0
- package/dist/shared/errors.js.map +1 -0
- package/dist/shared/events/factory.d.ts +143 -0
- package/dist/shared/events/factory.d.ts.map +1 -0
- package/dist/shared/events/factory.js +351 -0
- package/dist/shared/events/factory.js.map +1 -0
- package/dist/shared/events/index.d.ts +6 -0
- package/dist/shared/events/index.d.ts.map +1 -0
- package/dist/shared/events/index.js +3 -0
- package/dist/shared/events/index.js.map +1 -0
- package/dist/shared/events/serialize.d.ts +87 -0
- package/dist/shared/events/serialize.d.ts.map +1 -0
- package/dist/shared/events/serialize.js +510 -0
- package/dist/shared/events/serialize.js.map +1 -0
- package/dist/shared/events/types.d.ts +139 -0
- package/dist/shared/events/types.d.ts.map +1 -0
- package/dist/shared/events/types.js +2 -0
- package/dist/shared/events/types.js.map +1 -0
- package/dist/shared/harvest/event-buffer.d.ts +59 -0
- package/dist/shared/harvest/event-buffer.d.ts.map +1 -0
- package/dist/shared/harvest/event-buffer.js +100 -0
- package/dist/shared/harvest/event-buffer.js.map +1 -0
- package/dist/shared/harvest/harvest-scheduler.d.ts +200 -0
- package/dist/shared/harvest/harvest-scheduler.d.ts.map +1 -0
- package/dist/shared/harvest/harvest-scheduler.js +647 -0
- package/dist/shared/harvest/harvest-scheduler.js.map +1 -0
- package/dist/shared/harvest/index.d.ts +7 -0
- package/dist/shared/harvest/index.d.ts.map +1 -0
- package/dist/shared/harvest/index.js +4 -0
- package/dist/shared/harvest/index.js.map +1 -0
- package/dist/shared/harvest/metric-aggregator.d.ts +115 -0
- package/dist/shared/harvest/metric-aggregator.d.ts.map +1 -0
- package/dist/shared/harvest/metric-aggregator.js +247 -0
- package/dist/shared/harvest/metric-aggregator.js.map +1 -0
- package/dist/shared/index.d.ts +22 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/index.js +13 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/logger.d.ts +57 -0
- package/dist/shared/logger.d.ts.map +1 -0
- package/dist/shared/logger.js +166 -0
- package/dist/shared/logger.js.map +1 -0
- package/dist/shared/pricing-data.d.ts +4 -0
- package/dist/shared/pricing-data.d.ts.map +1 -0
- package/dist/shared/pricing-data.js +473 -0
- package/dist/shared/pricing-data.js.map +1 -0
- package/dist/shared/pricing.d.ts +148 -0
- package/dist/shared/pricing.d.ts.map +1 -0
- package/dist/shared/pricing.js +528 -0
- package/dist/shared/pricing.js.map +1 -0
- package/dist/shared/redact.d.ts +33 -0
- package/dist/shared/redact.d.ts.map +1 -0
- package/dist/shared/redact.js +110 -0
- package/dist/shared/redact.js.map +1 -0
- package/dist/shared/timing.d.ts +96 -0
- package/dist/shared/timing.d.ts.map +1 -0
- package/dist/shared/timing.js +173 -0
- package/dist/shared/timing.js.map +1 -0
- package/dist/shared/tokens.d.ts +145 -0
- package/dist/shared/tokens.d.ts.map +1 -0
- package/dist/shared/tokens.js +492 -0
- package/dist/shared/tokens.js.map +1 -0
- package/dist/shared/transport/events-api.d.ts +14 -0
- package/dist/shared/transport/events-api.d.ts.map +1 -0
- package/dist/shared/transport/events-api.js +29 -0
- package/dist/shared/transport/events-api.js.map +1 -0
- package/dist/shared/transport/http-client.d.ts +49 -0
- package/dist/shared/transport/http-client.d.ts.map +1 -0
- package/dist/shared/transport/http-client.js +381 -0
- package/dist/shared/transport/http-client.js.map +1 -0
- package/dist/shared/transport/index.d.ts +10 -0
- package/dist/shared/transport/index.d.ts.map +1 -0
- package/dist/shared/transport/index.js +6 -0
- package/dist/shared/transport/index.js.map +1 -0
- package/dist/shared/transport/logs-api.d.ts +29 -0
- package/dist/shared/transport/logs-api.d.ts.map +1 -0
- package/dist/shared/transport/logs-api.js +40 -0
- package/dist/shared/transport/logs-api.js.map +1 -0
- package/dist/shared/transport/metric-api.d.ts +9 -0
- package/dist/shared/transport/metric-api.d.ts.map +1 -0
- package/dist/shared/transport/metric-api.js +39 -0
- package/dist/shared/transport/metric-api.js.map +1 -0
- package/dist/shared/transport/otlp-event-bridge.d.ts +22 -0
- package/dist/shared/transport/otlp-event-bridge.d.ts.map +1 -0
- package/dist/shared/transport/otlp-event-bridge.js +50 -0
- package/dist/shared/transport/otlp-event-bridge.js.map +1 -0
- package/dist/shared/transport/otlp-shared.d.ts +14 -0
- package/dist/shared/transport/otlp-shared.d.ts.map +1 -0
- package/dist/shared/transport/otlp-shared.js +49 -0
- package/dist/shared/transport/otlp-shared.js.map +1 -0
- package/dist/shared/transport/otlp-transport.d.ts +58 -0
- package/dist/shared/transport/otlp-transport.d.ts.map +1 -0
- package/dist/shared/transport/otlp-transport.js +236 -0
- package/dist/shared/transport/otlp-transport.js.map +1 -0
- package/dist/shared/transport/types.d.ts +129 -0
- package/dist/shared/transport/types.d.ts.map +1 -0
- package/dist/shared/transport/types.js +2 -0
- package/dist/shared/transport/types.js.map +1 -0
- package/dist/shared/version.d.ts +2 -0
- package/dist/shared/version.d.ts.map +1 -0
- package/dist/shared/version.js +2 -0
- package/dist/shared/version.js.map +1 -0
- package/dist/storage/index.d.ts +7 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +4 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/local-store.d.ts +153 -0
- package/dist/storage/local-store.d.ts.map +1 -0
- package/dist/storage/local-store.js +719 -0
- package/dist/storage/local-store.js.map +1 -0
- package/dist/storage/retention.d.ts +2 -0
- package/dist/storage/retention.d.ts.map +1 -0
- package/dist/storage/retention.js +53 -0
- package/dist/storage/retention.js.map +1 -0
- package/dist/storage/session-store.d.ts +97 -0
- package/dist/storage/session-store.d.ts.map +1 -0
- package/dist/storage/session-store.js +391 -0
- package/dist/storage/session-store.js.map +1 -0
- package/dist/storage/types.d.ts +64 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/storage/weekly-summary.d.ts +61 -0
- package/dist/storage/weekly-summary.d.ts.map +1 -0
- package/dist/storage/weekly-summary.js +243 -0
- package/dist/storage/weekly-summary.js.map +1 -0
- package/dist/tools/analytics-tools.d.ts +101 -0
- package/dist/tools/analytics-tools.d.ts.map +1 -0
- package/dist/tools/analytics-tools.js +71 -0
- package/dist/tools/analytics-tools.js.map +1 -0
- package/dist/tools/cost-tools.d.ts +121 -0
- package/dist/tools/cost-tools.d.ts.map +1 -0
- package/dist/tools/cost-tools.js +174 -0
- package/dist/tools/cost-tools.js.map +1 -0
- package/dist/tools/cross-session-tools.d.ts +376 -0
- package/dist/tools/cross-session-tools.d.ts.map +1 -0
- package/dist/tools/cross-session-tools.js +820 -0
- package/dist/tools/cross-session-tools.js.map +1 -0
- package/dist/tools/extended-analytics-tools.d.ts +164 -0
- package/dist/tools/extended-analytics-tools.d.ts.map +1 -0
- package/dist/tools/extended-analytics-tools.js +121 -0
- package/dist/tools/extended-analytics-tools.js.map +1 -0
- package/dist/tools/index.d.ts +7 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +4 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/session-stats.d.ts +162 -0
- package/dist/tools/session-stats.d.ts.map +1 -0
- package/dist/tools/session-stats.js +1054 -0
- package/dist/tools/session-stats.js.map +1 -0
- package/dist/tools/workflow-tools.d.ts +126 -0
- package/dist/tools/workflow-tools.d.ts.map +1 -0
- package/dist/tools/workflow-tools.js +274 -0
- package/dist/tools/workflow-tools.js.map +1 -0
- package/dist/tracing/mcp-tracer.d.ts +4 -0
- package/dist/tracing/mcp-tracer.d.ts.map +1 -0
- package/dist/tracing/mcp-tracer.js +14 -0
- package/dist/tracing/mcp-tracer.js.map +1 -0
- package/dist/tracing/session-span.d.ts +14 -0
- package/dist/tracing/session-span.d.ts.map +1 -0
- package/dist/tracing/session-span.js +53 -0
- package/dist/tracing/session-span.js.map +1 -0
- package/dist/tracing/task-span-tracker.d.ts +11 -0
- package/dist/tracing/task-span-tracker.d.ts.map +1 -0
- package/dist/tracing/task-span-tracker.js +59 -0
- package/dist/tracing/task-span-tracker.js.map +1 -0
- package/dist/tracing/tool-call-span.d.ts +4 -0
- package/dist/tracing/tool-call-span.d.ts.map +1 -0
- package/dist/tracing/tool-call-span.js +60 -0
- package/dist/tracing/tool-call-span.js.map +1 -0
- package/dist/transport/index.d.ts +3 -0
- package/dist/transport/index.d.ts.map +1 -0
- package/dist/transport/index.js +2 -0
- package/dist/transport/index.js.map +1 -0
- package/dist/transport/log-ingest.d.ts +42 -0
- package/dist/transport/log-ingest.d.ts.map +1 -0
- package/dist/transport/log-ingest.js +151 -0
- package/dist/transport/log-ingest.js.map +1 -0
- package/dist/transport/nr-ingest.d.ts +171 -0
- package/dist/transport/nr-ingest.d.ts.map +1 -0
- package/dist/transport/nr-ingest.js +659 -0
- package/dist/transport/nr-ingest.js.map +1 -0
- package/dist/types.d.ts +45 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/web/assets/index-BrL281N-.css +2 -0
- package/dist/web/assets/index-CcaYZzXm.js +42 -0
- package/dist/web/favicon.svg +15 -0
- package/dist/web/index.html +15 -0
- package/examples/local-alert-rules.json +106 -0
- package/package.json +129 -1
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Task Boundary Detection — heuristically detects discrete "tasks" from
|
|
3
|
+
* the stream of tool calls.
|
|
4
|
+
*
|
|
5
|
+
* A task is the work Claude does between user messages: the user gives an
|
|
6
|
+
* instruction, Claude executes a series of tool calls, and eventually responds.
|
|
7
|
+
*
|
|
8
|
+
* Detection signals:
|
|
9
|
+
* 1. Idle gap > threshold (configurable, default 30s) → task complete
|
|
10
|
+
* 2. AskUserQuestion tool call → task complete (Claude is asking for direction)
|
|
11
|
+
* 3. TaskUpdate with status=completed → explicit task completion
|
|
12
|
+
*/
|
|
13
|
+
import { randomUUID } from 'node:crypto';
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
// Internal mutable task accumulator
|
|
16
|
+
// ---------------------------------------------------------------------------
|
|
17
|
+
class ActiveTask {
|
|
18
|
+
taskId;
|
|
19
|
+
startTime;
|
|
20
|
+
toolCallCount = 0;
|
|
21
|
+
toolCallsByType = new Map();
|
|
22
|
+
filesReadSet = new Set();
|
|
23
|
+
filesModifiedSet = new Set();
|
|
24
|
+
rawToolCalls = [];
|
|
25
|
+
linesChanged = 0;
|
|
26
|
+
linesAdded = 0;
|
|
27
|
+
linesRemoved = 0;
|
|
28
|
+
bashCommandsRun = 0;
|
|
29
|
+
testsRun = 0;
|
|
30
|
+
testsPassed = 0;
|
|
31
|
+
buildRun = 0;
|
|
32
|
+
buildPassed = 0;
|
|
33
|
+
askedUserQuestions = 0;
|
|
34
|
+
subAgentsSpawned = 0;
|
|
35
|
+
constructor(taskId, startTime) {
|
|
36
|
+
this.taskId = taskId;
|
|
37
|
+
this.startTime = startTime;
|
|
38
|
+
}
|
|
39
|
+
addToolCall(record) {
|
|
40
|
+
this.toolCallCount++;
|
|
41
|
+
this.rawToolCalls.push(record);
|
|
42
|
+
const tool = record.toolName;
|
|
43
|
+
this.toolCallsByType.set(tool, (this.toolCallsByType.get(tool) ?? 0) + 1);
|
|
44
|
+
// File tracking
|
|
45
|
+
const filePath = record.filePath;
|
|
46
|
+
if (filePath) {
|
|
47
|
+
if (tool === 'Read') {
|
|
48
|
+
this.filesReadSet.add(filePath);
|
|
49
|
+
}
|
|
50
|
+
else if (tool === 'Write' || tool === 'Edit') {
|
|
51
|
+
this.filesModifiedSet.add(filePath);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// Line change tracking
|
|
55
|
+
if (tool === 'Write') {
|
|
56
|
+
const lineCount = record.lineCount;
|
|
57
|
+
if (lineCount != null) {
|
|
58
|
+
this.linesAdded += lineCount;
|
|
59
|
+
this.linesChanged += lineCount;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
else if (tool === 'Edit') {
|
|
63
|
+
const newLines = record.newLineCount ?? 0;
|
|
64
|
+
const oldLines = record.oldLineCount ?? 0;
|
|
65
|
+
// Track actual additions and removals, not just net diff.
|
|
66
|
+
// An edit that replaces 10 lines with 15 lines: removed=10, added=15 (not added=5).
|
|
67
|
+
this.linesAdded += newLines;
|
|
68
|
+
this.linesRemoved += oldLines;
|
|
69
|
+
this.linesChanged += Math.abs(newLines - oldLines);
|
|
70
|
+
}
|
|
71
|
+
// Bash tracking
|
|
72
|
+
if (tool === 'Bash') {
|
|
73
|
+
this.bashCommandsRun++;
|
|
74
|
+
if (record.isTestCommand) {
|
|
75
|
+
this.testsRun++;
|
|
76
|
+
if (record.success)
|
|
77
|
+
this.testsPassed++;
|
|
78
|
+
}
|
|
79
|
+
if (record.isBuildCommand) {
|
|
80
|
+
this.buildRun++;
|
|
81
|
+
if (record.success)
|
|
82
|
+
this.buildPassed++;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// AskUserQuestion tracking
|
|
86
|
+
if (tool === 'AskUserQuestion') {
|
|
87
|
+
this.askedUserQuestions++;
|
|
88
|
+
}
|
|
89
|
+
// Agent tracking
|
|
90
|
+
if (tool === 'Agent') {
|
|
91
|
+
this.subAgentsSpawned++;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
toCompleted(endTime, estimatedCostUsd, tokensUsed) {
|
|
95
|
+
const toolCallsByType = {};
|
|
96
|
+
for (const [tool, count] of this.toolCallsByType) {
|
|
97
|
+
toolCallsByType[tool] = count;
|
|
98
|
+
}
|
|
99
|
+
return {
|
|
100
|
+
taskId: this.taskId,
|
|
101
|
+
startTime: this.startTime,
|
|
102
|
+
endTime,
|
|
103
|
+
// Cap at 4 hours to guard against inflated durations from process suspension
|
|
104
|
+
// (laptop sleep or container pause) causing the idle timer to fire on resume.
|
|
105
|
+
durationMs: Math.min(endTime - this.startTime, 4 * 60 * 60 * 1000),
|
|
106
|
+
toolCallCount: this.toolCallCount,
|
|
107
|
+
toolCallsByType,
|
|
108
|
+
filesRead: [...this.filesReadSet].sort(),
|
|
109
|
+
filesModified: [...this.filesModifiedSet].sort(),
|
|
110
|
+
linesChanged: this.linesChanged,
|
|
111
|
+
linesAdded: this.linesAdded,
|
|
112
|
+
linesRemoved: this.linesRemoved,
|
|
113
|
+
bashCommandsRun: this.bashCommandsRun,
|
|
114
|
+
testsRun: this.testsRun,
|
|
115
|
+
testsPassed: this.testsPassed,
|
|
116
|
+
buildRun: this.buildRun,
|
|
117
|
+
buildPassed: this.buildPassed,
|
|
118
|
+
estimatedCostUsd,
|
|
119
|
+
tokensUsed,
|
|
120
|
+
askedUserQuestions: this.askedUserQuestions,
|
|
121
|
+
subAgentsSpawned: this.subAgentsSpawned,
|
|
122
|
+
toolCalls: [...this.rawToolCalls],
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
// ---------------------------------------------------------------------------
|
|
127
|
+
// TaskDetector
|
|
128
|
+
// ---------------------------------------------------------------------------
|
|
129
|
+
const DEFAULT_IDLE_TIMEOUT_MS = 30_000;
|
|
130
|
+
const DEFAULT_MAX_COMPLETED_TASKS = 100;
|
|
131
|
+
export class TaskDetector {
|
|
132
|
+
idleTimeoutMs;
|
|
133
|
+
costTracker;
|
|
134
|
+
maxCompletedTasks;
|
|
135
|
+
activeTask = null;
|
|
136
|
+
completedTasks = [];
|
|
137
|
+
pendingEmission = [];
|
|
138
|
+
lifetimeCompletedCount = 0;
|
|
139
|
+
idleTimer = null;
|
|
140
|
+
// Cost/token snapshots at task start for computing deltas
|
|
141
|
+
costAtTaskStart = 0;
|
|
142
|
+
tokensAtTaskStart = 0;
|
|
143
|
+
constructor(options) {
|
|
144
|
+
this.idleTimeoutMs = options?.idleTimeoutMs ?? DEFAULT_IDLE_TIMEOUT_MS;
|
|
145
|
+
this.costTracker = options?.costTracker ?? null;
|
|
146
|
+
this.maxCompletedTasks = options?.maxCompletedTasks ?? DEFAULT_MAX_COMPLETED_TASKS;
|
|
147
|
+
}
|
|
148
|
+
recordToolCall(record) {
|
|
149
|
+
// Start a new task if none is active
|
|
150
|
+
if (this.activeTask === null) {
|
|
151
|
+
this.startNewTask(record.timestamp);
|
|
152
|
+
}
|
|
153
|
+
// Accumulate the tool call
|
|
154
|
+
this.activeTask.addToolCall(record);
|
|
155
|
+
// Check for boundary signals
|
|
156
|
+
if (record.toolName === 'AskUserQuestion') {
|
|
157
|
+
this.closeCurrentTask(record.timestamp);
|
|
158
|
+
return; // Timer not needed — task is already closed
|
|
159
|
+
}
|
|
160
|
+
if (record.toolName === 'TaskUpdate' &&
|
|
161
|
+
record.taskStatus === 'completed') {
|
|
162
|
+
this.closeCurrentTask(record.timestamp);
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
// Reset idle timer
|
|
166
|
+
this.resetIdleTimer();
|
|
167
|
+
}
|
|
168
|
+
getCurrentTask() {
|
|
169
|
+
if (this.activeTask === null)
|
|
170
|
+
return null;
|
|
171
|
+
const { costUsd, tokens } = this.computeCostDelta();
|
|
172
|
+
return this.activeTask.toCompleted(Date.now(), costUsd, tokens);
|
|
173
|
+
}
|
|
174
|
+
getCompletedTasks() {
|
|
175
|
+
return [...this.completedTasks];
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Returns tasks completed since the last drain and clears the emission queue.
|
|
179
|
+
* Safe to call on every poll cycle — each task is returned exactly once.
|
|
180
|
+
*/
|
|
181
|
+
drainNewlyCompletedTasks() {
|
|
182
|
+
const tasks = [...this.pendingEmission];
|
|
183
|
+
this.pendingEmission = [];
|
|
184
|
+
return tasks;
|
|
185
|
+
}
|
|
186
|
+
getActiveTaskId() {
|
|
187
|
+
return this.activeTask?.taskId ?? null;
|
|
188
|
+
}
|
|
189
|
+
getMetrics() {
|
|
190
|
+
const completed = this.completedTasks;
|
|
191
|
+
let avgDuration = null;
|
|
192
|
+
let avgToolCalls = null;
|
|
193
|
+
if (completed.length > 0) {
|
|
194
|
+
let totalDuration = 0;
|
|
195
|
+
let totalToolCalls = 0;
|
|
196
|
+
for (const task of completed) {
|
|
197
|
+
totalDuration += task.durationMs;
|
|
198
|
+
totalToolCalls += task.toolCallCount;
|
|
199
|
+
}
|
|
200
|
+
avgDuration = Math.round(totalDuration / completed.length);
|
|
201
|
+
avgToolCalls = Math.round((totalToolCalls / completed.length) * 100) / 100;
|
|
202
|
+
}
|
|
203
|
+
return {
|
|
204
|
+
totalTasksCompleted: this.lifetimeCompletedCount,
|
|
205
|
+
currentTaskActive: this.activeTask !== null,
|
|
206
|
+
currentTaskToolCalls: this.activeTask?.toolCallCount ?? 0,
|
|
207
|
+
averageTaskDurationMs: avgDuration,
|
|
208
|
+
averageToolCallsPerTask: avgToolCalls,
|
|
209
|
+
completedTasks: [...completed],
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
emitMetrics(aggregator) {
|
|
213
|
+
aggregator.record('ai.task.completed_count', this.completedTasks.length);
|
|
214
|
+
aggregator.record('ai.task.active', this.activeTask !== null ? 1 : 0);
|
|
215
|
+
for (const task of this.completedTasks) {
|
|
216
|
+
aggregator.record('ai.task.duration_ms', task.durationMs);
|
|
217
|
+
aggregator.record('ai.task.tool_call_count', task.toolCallCount);
|
|
218
|
+
if (task.estimatedCostUsd !== null) {
|
|
219
|
+
aggregator.record('ai.task.cost_usd', task.estimatedCostUsd);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
reset() {
|
|
224
|
+
this.clearIdleTimer();
|
|
225
|
+
this.activeTask = null;
|
|
226
|
+
this.completedTasks = [];
|
|
227
|
+
this.pendingEmission = [];
|
|
228
|
+
this.costAtTaskStart = 0;
|
|
229
|
+
this.tokensAtTaskStart = 0;
|
|
230
|
+
this.lifetimeCompletedCount = 0;
|
|
231
|
+
}
|
|
232
|
+
dispose() {
|
|
233
|
+
this.clearIdleTimer();
|
|
234
|
+
if (this.activeTask !== null) {
|
|
235
|
+
this.closeCurrentTask(Date.now());
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
// ---------------------------------------------------------------------------
|
|
239
|
+
// Private
|
|
240
|
+
// ---------------------------------------------------------------------------
|
|
241
|
+
startNewTask(timestamp) {
|
|
242
|
+
this.activeTask = new ActiveTask(randomUUID(), timestamp);
|
|
243
|
+
this.snapshotCostState();
|
|
244
|
+
}
|
|
245
|
+
closeCurrentTask(endTime) {
|
|
246
|
+
if (this.activeTask === null)
|
|
247
|
+
return;
|
|
248
|
+
const { costUsd, tokens } = this.computeCostDelta();
|
|
249
|
+
const completed = this.activeTask.toCompleted(endTime, costUsd, tokens);
|
|
250
|
+
this.completedTasks.push(completed);
|
|
251
|
+
this.pendingEmission.push(completed);
|
|
252
|
+
this.lifetimeCompletedCount++;
|
|
253
|
+
// Cap completed tasks to prevent unbounded memory
|
|
254
|
+
while (this.completedTasks.length > this.maxCompletedTasks) {
|
|
255
|
+
this.completedTasks.shift();
|
|
256
|
+
}
|
|
257
|
+
// Cap pendingEmission to the same limit (drainNewlyCompletedTasks may
|
|
258
|
+
// never be called in abnormal shutdown paths)
|
|
259
|
+
while (this.pendingEmission.length > this.maxCompletedTasks) {
|
|
260
|
+
this.pendingEmission.shift();
|
|
261
|
+
}
|
|
262
|
+
this.activeTask = null;
|
|
263
|
+
this.clearIdleTimer();
|
|
264
|
+
}
|
|
265
|
+
snapshotCostState() {
|
|
266
|
+
if (this.costTracker === null) {
|
|
267
|
+
this.costAtTaskStart = 0;
|
|
268
|
+
this.tokensAtTaskStart = 0;
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
const metrics = this.costTracker.getMetrics();
|
|
272
|
+
this.costAtTaskStart = metrics.sessionTotalCostUsd ?? 0;
|
|
273
|
+
this.tokensAtTaskStart =
|
|
274
|
+
metrics.totalInputTokens + metrics.totalOutputTokens + metrics.totalThinkingTokens;
|
|
275
|
+
}
|
|
276
|
+
computeCostDelta() {
|
|
277
|
+
if (this.costTracker === null) {
|
|
278
|
+
return { costUsd: null, tokens: 0 };
|
|
279
|
+
}
|
|
280
|
+
const metrics = this.costTracker.getMetrics();
|
|
281
|
+
const currentCost = metrics.sessionTotalCostUsd ?? 0;
|
|
282
|
+
const currentTokens = metrics.totalInputTokens + metrics.totalOutputTokens + metrics.totalThinkingTokens;
|
|
283
|
+
return {
|
|
284
|
+
costUsd: Math.max(0, currentCost - this.costAtTaskStart),
|
|
285
|
+
tokens: Math.max(0, currentTokens - this.tokensAtTaskStart),
|
|
286
|
+
};
|
|
287
|
+
}
|
|
288
|
+
resetIdleTimer() {
|
|
289
|
+
this.clearIdleTimer();
|
|
290
|
+
this.idleTimer = setTimeout(() => {
|
|
291
|
+
this.closeCurrentTask(Date.now());
|
|
292
|
+
}, this.idleTimeoutMs);
|
|
293
|
+
this.idleTimer.unref();
|
|
294
|
+
}
|
|
295
|
+
clearIdleTimer() {
|
|
296
|
+
if (this.idleTimer !== null) {
|
|
297
|
+
clearTimeout(this.idleTimer);
|
|
298
|
+
this.idleTimer = null;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
//# sourceMappingURL=task-detector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-detector.js","sourceRoot":"","sources":["../../src/metrics/task-detector.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { ToolCallRecord } from '../storage/types.js';
|
|
2
|
+
export interface ToolSelectionPenalty {
|
|
3
|
+
readonly callId: string;
|
|
4
|
+
readonly toolName: string;
|
|
5
|
+
readonly reason: 'redundant_read' | 'repeated_failure' | 'unused_output';
|
|
6
|
+
readonly penaltyScore: number;
|
|
7
|
+
readonly detail: string;
|
|
8
|
+
}
|
|
9
|
+
export interface ToolSelectionMetrics {
|
|
10
|
+
readonly score: number;
|
|
11
|
+
readonly totalCalls: number;
|
|
12
|
+
readonly penalizedCalls: number;
|
|
13
|
+
readonly penalties: readonly ToolSelectionPenalty[];
|
|
14
|
+
readonly worstOffenders: readonly ToolSelectionPenalty[];
|
|
15
|
+
readonly redundantReadCount: number;
|
|
16
|
+
readonly repeatedFailureCount: number;
|
|
17
|
+
readonly unusedOutputCount: number;
|
|
18
|
+
}
|
|
19
|
+
export interface ToolSelectionScorerOptions {
|
|
20
|
+
readonly redundantReadPenalty?: number;
|
|
21
|
+
readonly repeatedFailurePenalty?: number;
|
|
22
|
+
readonly unusedOutputPenalty?: number;
|
|
23
|
+
readonly unusedOutputSizeThreshold?: number;
|
|
24
|
+
readonly worstOffenderCount?: number;
|
|
25
|
+
}
|
|
26
|
+
export declare class ToolSelectionScorer {
|
|
27
|
+
private readonly redundantReadPenalty;
|
|
28
|
+
private readonly repeatedFailurePenalty;
|
|
29
|
+
private readonly unusedOutputPenalty;
|
|
30
|
+
private readonly unusedOutputSizeThreshold;
|
|
31
|
+
private readonly worstOffenderCount;
|
|
32
|
+
constructor(options?: ToolSelectionScorerOptions);
|
|
33
|
+
scoreSession(toolCalls: readonly ToolCallRecord[]): ToolSelectionMetrics;
|
|
34
|
+
private findRedundantReads;
|
|
35
|
+
private findRepeatedFailures;
|
|
36
|
+
private findUnusedOutputs;
|
|
37
|
+
private isOutputReferenced;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=tool-selection-scorer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-selection-scorer.d.ts","sourceRoot":"","sources":["../../src/metrics/tool-selection-scorer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAM1D,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,kBAAkB,GAAG,eAAe,CAAC;IACzE,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAChC,QAAQ,CAAC,SAAS,EAAE,SAAS,oBAAoB,EAAE,CAAC;IACpD,QAAQ,CAAC,cAAc,EAAE,SAAS,oBAAoB,EAAE,CAAC;IACzD,QAAQ,CAAC,kBAAkB,EAAE,MAAM,CAAC;IACpC,QAAQ,CAAC,oBAAoB,EAAE,MAAM,CAAC;IACtC,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC;CACpC;AAED,MAAM,WAAW,0BAA0B;IACzC,QAAQ,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IACvC,QAAQ,CAAC,sBAAsB,CAAC,EAAE,MAAM,CAAC;IACzC,QAAQ,CAAC,mBAAmB,CAAC,EAAE,MAAM,CAAC;IACtC,QAAQ,CAAC,yBAAyB,CAAC,EAAE,MAAM,CAAC;IAC5C,QAAQ,CAAC,kBAAkB,CAAC,EAAE,MAAM,CAAC;CACtC;AAkCD,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAS;IAC9C,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAS;IAChD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAS;IAC7C,OAAO,CAAC,QAAQ,CAAC,yBAAyB,CAAS;IACnD,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAS;gBAEhC,OAAO,CAAC,EAAE,0BAA0B;IAUhD,YAAY,CAAC,SAAS,EAAE,SAAS,cAAc,EAAE,GAAG,oBAAoB;IA4CxE,OAAO,CAAC,kBAAkB;IAiD1B,OAAO,CAAC,oBAAoB;IA2B5B,OAAO,CAAC,iBAAiB;IA0BzB,OAAO,CAAC,kBAAkB;CAqB3B"}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
// ---------------------------------------------------------------------------
|
|
2
|
+
// Defaults
|
|
3
|
+
// ---------------------------------------------------------------------------
|
|
4
|
+
const DEFAULT_REDUNDANT_READ_PENALTY = 0.03;
|
|
5
|
+
const DEFAULT_REPEATED_FAILURE_PENALTY = 0.08;
|
|
6
|
+
const DEFAULT_UNUSED_OUTPUT_PENALTY = 0.04;
|
|
7
|
+
const DEFAULT_UNUSED_OUTPUT_SIZE_THRESHOLD = 4000;
|
|
8
|
+
const DEFAULT_WORST_OFFENDER_COUNT = 10;
|
|
9
|
+
// Tools whose output is terminal — they perform an action and their output is
|
|
10
|
+
// a confirmation or result, not raw data to be consumed by later tool calls.
|
|
11
|
+
// Penalizing these for "unused output" is nonsensical.
|
|
12
|
+
const TERMINAL_OUTPUT_TOOLS = new Set([
|
|
13
|
+
'Edit',
|
|
14
|
+
'Write',
|
|
15
|
+
'Agent',
|
|
16
|
+
'NotebookEdit',
|
|
17
|
+
'Bash',
|
|
18
|
+
'TaskCreate',
|
|
19
|
+
'TaskUpdate',
|
|
20
|
+
'TaskList',
|
|
21
|
+
'TaskGet',
|
|
22
|
+
'SendMessage',
|
|
23
|
+
'EnterPlanMode',
|
|
24
|
+
'ExitPlanMode',
|
|
25
|
+
]);
|
|
26
|
+
// ---------------------------------------------------------------------------
|
|
27
|
+
// ToolSelectionScorer
|
|
28
|
+
// ---------------------------------------------------------------------------
|
|
29
|
+
export class ToolSelectionScorer {
|
|
30
|
+
redundantReadPenalty;
|
|
31
|
+
repeatedFailurePenalty;
|
|
32
|
+
unusedOutputPenalty;
|
|
33
|
+
unusedOutputSizeThreshold;
|
|
34
|
+
worstOffenderCount;
|
|
35
|
+
constructor(options) {
|
|
36
|
+
this.redundantReadPenalty = options?.redundantReadPenalty ?? DEFAULT_REDUNDANT_READ_PENALTY;
|
|
37
|
+
this.repeatedFailurePenalty =
|
|
38
|
+
options?.repeatedFailurePenalty ?? DEFAULT_REPEATED_FAILURE_PENALTY;
|
|
39
|
+
this.unusedOutputPenalty = options?.unusedOutputPenalty ?? DEFAULT_UNUSED_OUTPUT_PENALTY;
|
|
40
|
+
this.unusedOutputSizeThreshold =
|
|
41
|
+
options?.unusedOutputSizeThreshold ?? DEFAULT_UNUSED_OUTPUT_SIZE_THRESHOLD;
|
|
42
|
+
this.worstOffenderCount = options?.worstOffenderCount ?? DEFAULT_WORST_OFFENDER_COUNT;
|
|
43
|
+
}
|
|
44
|
+
scoreSession(toolCalls) {
|
|
45
|
+
if (toolCalls.length === 0) {
|
|
46
|
+
return {
|
|
47
|
+
score: 1,
|
|
48
|
+
totalCalls: 0,
|
|
49
|
+
penalizedCalls: 0,
|
|
50
|
+
penalties: [],
|
|
51
|
+
worstOffenders: [],
|
|
52
|
+
redundantReadCount: 0,
|
|
53
|
+
repeatedFailureCount: 0,
|
|
54
|
+
unusedOutputCount: 0,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const penalties = [];
|
|
58
|
+
penalties.push(...this.findRedundantReads(toolCalls));
|
|
59
|
+
penalties.push(...this.findRepeatedFailures(toolCalls));
|
|
60
|
+
penalties.push(...this.findUnusedOutputs(toolCalls));
|
|
61
|
+
const rawPenalty = penalties.reduce((sum, p) => sum + p.penaltyScore, 0);
|
|
62
|
+
// Normalize: cap penalty contribution relative to session size so that a
|
|
63
|
+
// 1000-call session with 10 redundant reads isn't unfairly punished the
|
|
64
|
+
// same as a 15-call session with 10 redundant reads. Effective penalty is
|
|
65
|
+
// at most 70% (floor of 0.3 ensures even bad sessions aren't demoralizingly low).
|
|
66
|
+
const totalPenalty = Math.min(rawPenalty, 0.7);
|
|
67
|
+
const score = Math.max(0, Math.round((1 - totalPenalty) * 1000) / 1000);
|
|
68
|
+
const worstOffenders = [...penalties]
|
|
69
|
+
.sort((a, b) => b.penaltyScore - a.penaltyScore)
|
|
70
|
+
.slice(0, this.worstOffenderCount);
|
|
71
|
+
return {
|
|
72
|
+
score,
|
|
73
|
+
totalCalls: toolCalls.length,
|
|
74
|
+
penalizedCalls: penalties.length,
|
|
75
|
+
penalties,
|
|
76
|
+
worstOffenders,
|
|
77
|
+
redundantReadCount: penalties.filter((p) => p.reason === 'redundant_read').length,
|
|
78
|
+
repeatedFailureCount: penalties.filter((p) => p.reason === 'repeated_failure').length,
|
|
79
|
+
unusedOutputCount: penalties.filter((p) => p.reason === 'unused_output').length,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
findRedundantReads(toolCalls) {
|
|
83
|
+
const penalties = [];
|
|
84
|
+
const readFiles = new Map();
|
|
85
|
+
for (let i = 0; i < toolCalls.length; i++) {
|
|
86
|
+
const call = toolCalls[i];
|
|
87
|
+
if (call.toolName !== 'Read')
|
|
88
|
+
continue;
|
|
89
|
+
const file = call.filePath;
|
|
90
|
+
if (!file)
|
|
91
|
+
continue;
|
|
92
|
+
const entry = readFiles.get(file) ?? { count: 0, ids: [], indices: [] };
|
|
93
|
+
entry.count++;
|
|
94
|
+
entry.ids.push(call.id);
|
|
95
|
+
entry.indices.push(i);
|
|
96
|
+
readFiles.set(file, entry);
|
|
97
|
+
}
|
|
98
|
+
for (const [file, entry] of readFiles) {
|
|
99
|
+
if (entry.count <= 1)
|
|
100
|
+
continue;
|
|
101
|
+
// Only penalize reads beyond the 2nd — one re-read after editing is
|
|
102
|
+
// normal verification; 3+ reads of the same file suggests lost context.
|
|
103
|
+
for (let i = 2; i < entry.ids.length; i++) {
|
|
104
|
+
// Skip if there was an Edit/Write to this file between reads (re-read
|
|
105
|
+
// after modification is intentional, not redundant).
|
|
106
|
+
const prevIdx = entry.indices[i - 1];
|
|
107
|
+
const currIdx = entry.indices[i];
|
|
108
|
+
let editBetween = false;
|
|
109
|
+
for (let j = prevIdx + 1; j < currIdx; j++) {
|
|
110
|
+
const tc = toolCalls[j];
|
|
111
|
+
if ((tc.toolName === 'Edit' || tc.toolName === 'Write') && tc.filePath === file) {
|
|
112
|
+
editBetween = true;
|
|
113
|
+
break;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
if (editBetween)
|
|
117
|
+
continue;
|
|
118
|
+
penalties.push({
|
|
119
|
+
callId: entry.ids[i],
|
|
120
|
+
toolName: 'Read',
|
|
121
|
+
reason: 'redundant_read',
|
|
122
|
+
penaltyScore: this.redundantReadPenalty,
|
|
123
|
+
detail: `Redundant read of ${file} (read #${i + 1} of ${entry.count})`,
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
return penalties;
|
|
128
|
+
}
|
|
129
|
+
findRepeatedFailures(toolCalls) {
|
|
130
|
+
const penalties = [];
|
|
131
|
+
// Track consecutive failures: reset streak when the tool succeeds or a
|
|
132
|
+
// different tool is called. Only penalize back-to-back failures.
|
|
133
|
+
const consecutiveFailures = new Map();
|
|
134
|
+
for (const call of toolCalls) {
|
|
135
|
+
if (call.success) {
|
|
136
|
+
consecutiveFailures.set(call.toolName, 0);
|
|
137
|
+
continue;
|
|
138
|
+
}
|
|
139
|
+
const streak = (consecutiveFailures.get(call.toolName) ?? 0) + 1;
|
|
140
|
+
consecutiveFailures.set(call.toolName, streak);
|
|
141
|
+
if (streak > 1) {
|
|
142
|
+
penalties.push({
|
|
143
|
+
callId: call.id,
|
|
144
|
+
toolName: call.toolName,
|
|
145
|
+
reason: 'repeated_failure',
|
|
146
|
+
penaltyScore: this.repeatedFailurePenalty,
|
|
147
|
+
detail: `Consecutive failure of ${call.toolName} (${streak} in a row)`,
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
return penalties;
|
|
152
|
+
}
|
|
153
|
+
findUnusedOutputs(toolCalls) {
|
|
154
|
+
const penalties = [];
|
|
155
|
+
for (let i = 0; i < toolCalls.length; i++) {
|
|
156
|
+
const call = toolCalls[i];
|
|
157
|
+
if (TERMINAL_OUTPUT_TOOLS.has(call.toolName))
|
|
158
|
+
continue;
|
|
159
|
+
const outputSize = call.outputSizeBytes ?? 0;
|
|
160
|
+
if (outputSize < this.unusedOutputSizeThreshold)
|
|
161
|
+
continue;
|
|
162
|
+
if (!call.success)
|
|
163
|
+
continue;
|
|
164
|
+
const isReferenced = this.isOutputReferenced(call, toolCalls.slice(i + 1));
|
|
165
|
+
if (!isReferenced) {
|
|
166
|
+
penalties.push({
|
|
167
|
+
callId: call.id,
|
|
168
|
+
toolName: call.toolName,
|
|
169
|
+
reason: 'unused_output',
|
|
170
|
+
penaltyScore: this.unusedOutputPenalty,
|
|
171
|
+
detail: `Large output (${outputSize} bytes) from ${call.toolName} not referenced in subsequent turns`,
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return penalties;
|
|
176
|
+
}
|
|
177
|
+
isOutputReferenced(sourceCall, subsequentCalls) {
|
|
178
|
+
// If the source was a Read, check if the file is referenced in subsequent Edits/Writes
|
|
179
|
+
if (sourceCall.toolName === 'Read') {
|
|
180
|
+
const filePath = sourceCall.filePath;
|
|
181
|
+
if (filePath) {
|
|
182
|
+
for (const call of subsequentCalls) {
|
|
183
|
+
if ((call.toolName === 'Edit' || call.toolName === 'Write') &&
|
|
184
|
+
call.filePath === filePath) {
|
|
185
|
+
return true;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
//# sourceMappingURL=tool-selection-scorer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-selection-scorer.js","sourceRoot":"","sources":["../../src/metrics/tool-selection-scorer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cross-Session Trend Analysis — computes longitudinal metrics from stored
|
|
3
|
+
* session data for weekly trends, comparisons, and text summaries.
|
|
4
|
+
*
|
|
5
|
+
* Operates on `FullSessionSummary[]` loaded from `SessionStore`, grouping
|
|
6
|
+
* by ISO week to compute efficiency, cost, task success, tool call, and
|
|
7
|
+
* anti-pattern trends over time.
|
|
8
|
+
*/
|
|
9
|
+
import type { MetricAggregator } from '../shared/index.js';
|
|
10
|
+
import type { SessionStore } from '../storage/session-store.js';
|
|
11
|
+
export interface WeeklyDataPoint {
|
|
12
|
+
readonly week: string;
|
|
13
|
+
readonly value: number;
|
|
14
|
+
}
|
|
15
|
+
export interface AntiPatternWeeklyPoint {
|
|
16
|
+
readonly week: string;
|
|
17
|
+
readonly counts: Record<string, number>;
|
|
18
|
+
}
|
|
19
|
+
export interface TrendData {
|
|
20
|
+
readonly weeklyEfficiencyTrend: WeeklyDataPoint[];
|
|
21
|
+
readonly weeklyCostTrend: WeeklyDataPoint[];
|
|
22
|
+
readonly weeklyTaskSuccessTrend: WeeklyDataPoint[];
|
|
23
|
+
readonly weeklyToolCallTrend: WeeklyDataPoint[];
|
|
24
|
+
readonly weeklyAntiPatternTrend: AntiPatternWeeklyPoint[];
|
|
25
|
+
}
|
|
26
|
+
export interface WeekComparison {
|
|
27
|
+
readonly weekA: string;
|
|
28
|
+
readonly weekB: string;
|
|
29
|
+
readonly efficiencyDelta: number | null;
|
|
30
|
+
readonly efficiencyPctChange: number | null;
|
|
31
|
+
readonly costDelta: number;
|
|
32
|
+
readonly costPctChange: number | null;
|
|
33
|
+
readonly taskSuccessDelta: number;
|
|
34
|
+
readonly taskSuccessPctChange: number | null;
|
|
35
|
+
readonly toolCallDelta: number;
|
|
36
|
+
readonly toolCallPctChange: number | null;
|
|
37
|
+
}
|
|
38
|
+
export interface DeveloperComparison {
|
|
39
|
+
readonly developer: string;
|
|
40
|
+
readonly week: string;
|
|
41
|
+
readonly developerEfficiency: number | null;
|
|
42
|
+
readonly teamEfficiency: number | null;
|
|
43
|
+
readonly developerCost: number;
|
|
44
|
+
readonly teamCost: number;
|
|
45
|
+
readonly developerTaskSuccess: number;
|
|
46
|
+
readonly teamTaskSuccess: number;
|
|
47
|
+
}
|
|
48
|
+
export interface ModelComparison {
|
|
49
|
+
readonly modelA: string;
|
|
50
|
+
readonly modelB: string;
|
|
51
|
+
readonly modelACost: number;
|
|
52
|
+
readonly modelBCost: number;
|
|
53
|
+
readonly modelAEfficiency: number | null;
|
|
54
|
+
readonly modelBEfficiency: number | null;
|
|
55
|
+
readonly modelASessionCount: number;
|
|
56
|
+
readonly modelBSessionCount: number;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Simple moving average over a series of values.
|
|
60
|
+
* For indices where the full window is not available, uses whatever
|
|
61
|
+
* values are available (partial window at the start).
|
|
62
|
+
*/
|
|
63
|
+
export declare function movingAverage(values: number[], windowSize: number): number[];
|
|
64
|
+
/**
|
|
65
|
+
* Percentage change from old to new value.
|
|
66
|
+
* Returns null when oldValue is 0 and newValue is non-zero (undefined growth from zero baseline).
|
|
67
|
+
* Returns 0 when both are 0.
|
|
68
|
+
*/
|
|
69
|
+
export declare function percentChange(oldValue: number, newValue: number): number | null;
|
|
70
|
+
/**
|
|
71
|
+
* Detects whether the last value in the array is a significant outlier.
|
|
72
|
+
* Uses z-score: computes mean and std of all values except the last,
|
|
73
|
+
* then checks if the last value is beyond `threshold` standard deviations.
|
|
74
|
+
*/
|
|
75
|
+
export declare function significantChange(values: number[], threshold?: number): boolean;
|
|
76
|
+
export declare class TrendAnalyzer {
|
|
77
|
+
private readonly sessionStore;
|
|
78
|
+
constructor(options: {
|
|
79
|
+
sessionStore: SessionStore;
|
|
80
|
+
});
|
|
81
|
+
computeTrends(options?: {
|
|
82
|
+
since?: Date;
|
|
83
|
+
developer?: string;
|
|
84
|
+
}): TrendData;
|
|
85
|
+
compareWeeks(weekA: string, weekB: string): WeekComparison;
|
|
86
|
+
compareDeveloperToTeam(developer: string, weekId: string): DeveloperComparison;
|
|
87
|
+
detectModelMigrationImpact(modelA: string, modelB: string): ModelComparison;
|
|
88
|
+
generateWeekSummary(weekId: string): string;
|
|
89
|
+
emitWeeklySummaryEvent(weekId: string, aggregator: MetricAggregator): void;
|
|
90
|
+
private loadWeekAggregate;
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=trend-analyzer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trend-analyzer.d.ts","sourceRoot":"","sources":["../../src/metrics/trend-analyzer.ts"],"names":[],"mappings":"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"}
|