@newrelic/preflight 0.0.1-pre.1 → 1.0.0
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 +860 -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 +103 -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 +125 -1
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { SpanStatusCode, trace } from '@opentelemetry/api';
|
|
2
|
+
import { getMcpTracer } from './mcp-tracer.js';
|
|
3
|
+
import { createLogger } from '../shared/index.js';
|
|
4
|
+
const logger = createLogger('task-span-tracker');
|
|
5
|
+
export class TaskSpanTracker {
|
|
6
|
+
activeTasks = new Map();
|
|
7
|
+
taskContexts = new Map();
|
|
8
|
+
openTask(taskId, label, parentContext) {
|
|
9
|
+
if (this.activeTasks.has(taskId))
|
|
10
|
+
return;
|
|
11
|
+
const span = getMcpTracer().startSpan(`ai.task ${label}`, {
|
|
12
|
+
attributes: {
|
|
13
|
+
'ai.task.id': taskId,
|
|
14
|
+
'ai.task.label': label,
|
|
15
|
+
},
|
|
16
|
+
}, parentContext);
|
|
17
|
+
this.activeTasks.set(taskId, span);
|
|
18
|
+
this.taskContexts.set(taskId, parentContext);
|
|
19
|
+
logger.debug('Task span opened', { taskId, label });
|
|
20
|
+
}
|
|
21
|
+
closeTask(taskId, toolCallCount) {
|
|
22
|
+
const span = this.activeTasks.get(taskId);
|
|
23
|
+
if (!span)
|
|
24
|
+
return;
|
|
25
|
+
span.setAttributes({ 'ai.task.tool_call_count': toolCallCount });
|
|
26
|
+
span.setStatus({ code: SpanStatusCode.OK });
|
|
27
|
+
span.end();
|
|
28
|
+
this.activeTasks.delete(taskId);
|
|
29
|
+
this.taskContexts.delete(taskId);
|
|
30
|
+
logger.debug('Task span closed', { taskId });
|
|
31
|
+
}
|
|
32
|
+
getContext(taskId, fallback) {
|
|
33
|
+
if (!taskId)
|
|
34
|
+
return fallback;
|
|
35
|
+
const span = this.activeTasks.get(taskId);
|
|
36
|
+
if (!span)
|
|
37
|
+
return fallback;
|
|
38
|
+
// Use the stored parent context from openTask() rather than context.active() to
|
|
39
|
+
// avoid attaching the span to an unrelated async frame's context.
|
|
40
|
+
const parentCtx = this.taskContexts.get(taskId) ?? fallback;
|
|
41
|
+
return trace.setSpan(parentCtx, span);
|
|
42
|
+
}
|
|
43
|
+
closeAll() {
|
|
44
|
+
for (const [taskId, span] of this.activeTasks) {
|
|
45
|
+
span.setStatus({
|
|
46
|
+
code: SpanStatusCode.ERROR,
|
|
47
|
+
message: 'session ended with task in progress',
|
|
48
|
+
});
|
|
49
|
+
span.end();
|
|
50
|
+
logger.debug('Force-closed task span', { taskId });
|
|
51
|
+
}
|
|
52
|
+
this.activeTasks.clear();
|
|
53
|
+
this.taskContexts.clear();
|
|
54
|
+
}
|
|
55
|
+
get size() {
|
|
56
|
+
return this.activeTasks.size;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=task-span-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-span-tracker.js","sourceRoot":"","sources":["../../src/tracing/task-span-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { context } from '@opentelemetry/api';
|
|
2
|
+
import type { ToolCallRecord } from '../storage/types.js';
|
|
3
|
+
export declare function emitToolCallSpan(record: ToolCallRecord, parentContext: ReturnType<typeof context.active>, taskId?: string): void;
|
|
4
|
+
//# sourceMappingURL=tool-call-span.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-call-span.d.ts","sourceRoot":"","sources":["../../src/tracing/tool-call-span.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAM1D,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,cAAc,EACtB,aAAa,EAAE,UAAU,CAAC,OAAO,OAAO,CAAC,MAAM,CAAC,EAChD,MAAM,CAAC,EAAE,MAAM,GACd,IAAI,CA6DN"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { SpanStatusCode } from '@opentelemetry/api';
|
|
2
|
+
import { getMcpTracer } from './mcp-tracer.js';
|
|
3
|
+
import { createLogger } from '../shared/index.js';
|
|
4
|
+
const logger = createLogger('tool-call-span');
|
|
5
|
+
export function emitToolCallSpan(record, parentContext, taskId) {
|
|
6
|
+
const tracer = getMcpTracer();
|
|
7
|
+
const spanName = `mcp.tool.${record.toolName}`;
|
|
8
|
+
const isBash = record.toolName === 'Bash';
|
|
9
|
+
const bashCategory = typeof record.bashCategory === 'string' ? record.bashCategory : undefined;
|
|
10
|
+
const bashLeading = typeof record.bashLeading === 'string' ? record.bashLeading : undefined;
|
|
11
|
+
const bashDestructive = typeof record.bashDestructive === 'boolean' ? record.bashDestructive : undefined;
|
|
12
|
+
const bashNetwork = typeof record.bashNetwork === 'boolean' ? record.bashNetwork : undefined;
|
|
13
|
+
const span = tracer.startSpan(spanName, {
|
|
14
|
+
startTime: record.timestamp,
|
|
15
|
+
attributes: {
|
|
16
|
+
'mcp.tool.name': record.toolName,
|
|
17
|
+
'mcp.tool.use_id': record.toolUseId,
|
|
18
|
+
'ai.session.id': record.sessionId ?? '',
|
|
19
|
+
'mcp.tool.success': record.success,
|
|
20
|
+
...(record.inputSizeBytes !== undefined && {
|
|
21
|
+
'mcp.tool.input_size_bytes': record.inputSizeBytes,
|
|
22
|
+
}),
|
|
23
|
+
...(record.outputSizeBytes !== undefined && {
|
|
24
|
+
'mcp.tool.output_size_bytes': record.outputSizeBytes,
|
|
25
|
+
}),
|
|
26
|
+
...(taskId && { 'ai.task.id': taskId }),
|
|
27
|
+
...(isBash && bashCategory !== undefined && { 'bash.category': bashCategory }),
|
|
28
|
+
...(isBash && bashLeading !== undefined && { 'bash.leading': bashLeading }),
|
|
29
|
+
...(isBash && bashDestructive !== undefined && { 'bash.destructive': bashDestructive }),
|
|
30
|
+
...(isBash && bashNetwork !== undefined && { 'bash.network': bashNetwork }),
|
|
31
|
+
},
|
|
32
|
+
}, parentContext);
|
|
33
|
+
let ended = false;
|
|
34
|
+
if (record.durationMs != null && Number.isFinite(record.durationMs)) {
|
|
35
|
+
const endTime = record.timestamp + record.durationMs;
|
|
36
|
+
if (!record.success) {
|
|
37
|
+
span.setStatus({
|
|
38
|
+
code: SpanStatusCode.ERROR,
|
|
39
|
+
message: record.error ?? record.errorType ?? 'tool call failed',
|
|
40
|
+
});
|
|
41
|
+
if (record.error)
|
|
42
|
+
span.recordException(new Error(record.error));
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
span.setStatus({ code: SpanStatusCode.OK });
|
|
46
|
+
}
|
|
47
|
+
if (!ended) {
|
|
48
|
+
span.end(endTime);
|
|
49
|
+
ended = true;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
else if (!ended) {
|
|
53
|
+
// Orphaned/timeout record — end immediately
|
|
54
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: 'orphaned tool call (no post event)' });
|
|
55
|
+
span.end();
|
|
56
|
+
ended = true;
|
|
57
|
+
}
|
|
58
|
+
logger.debug('Tool call span emitted', { tool: record.toolName, success: record.success });
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=tool-call-span.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-call-span.js","sourceRoot":"","sources":["../../src/tracing/tool-call-span.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACpE,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/transport/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log Ingest — converts AuditRecords into NR Log entries and ships them
|
|
3
|
+
* via the shared Logs API transport on a harvest interval.
|
|
4
|
+
*/
|
|
5
|
+
import type { NrLogEntry, TransportOptions, TransportResult } from '../shared/index.js';
|
|
6
|
+
import type { AuditRecord } from '../security/audit-trail.js';
|
|
7
|
+
type SendLogsFn = (logs: NrLogEntry[], licenseKey: string, options: TransportOptions) => Promise<TransportResult>;
|
|
8
|
+
export interface LogIngestOptions {
|
|
9
|
+
licenseKey: string;
|
|
10
|
+
transportOptions: TransportOptions;
|
|
11
|
+
developer: string;
|
|
12
|
+
appName: string;
|
|
13
|
+
logHarvestIntervalMs?: number;
|
|
14
|
+
/** Override for testing; defaults to the shared sendLogs transport. */
|
|
15
|
+
sendLogsFn?: SendLogsFn;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Convert an AuditRecord into a structured NR Log entry.
|
|
19
|
+
*/
|
|
20
|
+
export declare function auditRecordToLogEntry(record: AuditRecord, appName: string): NrLogEntry;
|
|
21
|
+
export declare class LogIngestManager {
|
|
22
|
+
private buffer;
|
|
23
|
+
private readonly maxBufferSize;
|
|
24
|
+
private readonly licenseKey;
|
|
25
|
+
private readonly transportOptions;
|
|
26
|
+
private readonly developer;
|
|
27
|
+
private readonly appName;
|
|
28
|
+
private readonly sendLogsFn;
|
|
29
|
+
private readonly harvestIntervalMs;
|
|
30
|
+
private intervalId;
|
|
31
|
+
private running;
|
|
32
|
+
private inFlightFlush;
|
|
33
|
+
constructor(options: LogIngestOptions);
|
|
34
|
+
addLog(entry: NrLogEntry): void;
|
|
35
|
+
addAuditRecord(record: AuditRecord): void;
|
|
36
|
+
start(): void;
|
|
37
|
+
stop(): Promise<void>;
|
|
38
|
+
flush(): Promise<void>;
|
|
39
|
+
private requeueBatch;
|
|
40
|
+
}
|
|
41
|
+
export {};
|
|
42
|
+
//# sourceMappingURL=log-ingest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-ingest.d.ts","sourceRoot":"","sources":["../../src/transport/log-ingest.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGxF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAQ9D,KAAK,UAAU,GAAG,CAChB,IAAI,EAAE,UAAU,EAAE,EAClB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,gBAAgB,KACtB,OAAO,CAAC,eAAe,CAAC,CAAC;AAE9B,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,gBAAgB,EAAE,gBAAgB,CAAC;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,uEAAuE;IACvE,UAAU,CAAC,EAAE,UAAU,CAAC;CACzB;AAMD;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,GAAG,UAAU,CA2BtF;AAQD,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAoB;IAClC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAmB;IACpD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAS;IAC3C,OAAO,CAAC,UAAU,CAA+C;IACjE,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,aAAa,CAA8B;gBAEvC,OAAO,EAAE,gBAAgB;IASrC,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAI/B,cAAc,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAIzC,KAAK,IAAI,IAAI;IAYP,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAerB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAwC5B,OAAO,CAAC,YAAY;CAarB"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log Ingest — converts AuditRecords into NR Log entries and ships them
|
|
3
|
+
* via the shared Logs API transport on a harvest interval.
|
|
4
|
+
*/
|
|
5
|
+
import { createLogger } from '../shared/index.js';
|
|
6
|
+
import { sendLogs } from '../shared/index.js';
|
|
7
|
+
import { redactSensitive } from '../config.js';
|
|
8
|
+
const logger = createLogger('log-ingest');
|
|
9
|
+
// ---------------------------------------------------------------------------
|
|
10
|
+
// Conversion
|
|
11
|
+
// ---------------------------------------------------------------------------
|
|
12
|
+
/**
|
|
13
|
+
* Convert an AuditRecord into a structured NR Log entry.
|
|
14
|
+
*/
|
|
15
|
+
export function auditRecordToLogEntry(record, appName) {
|
|
16
|
+
const attributes = {
|
|
17
|
+
tool: record.tool,
|
|
18
|
+
developer: record.developer,
|
|
19
|
+
app_name: appName,
|
|
20
|
+
'audit.action': record.action,
|
|
21
|
+
'audit.security_alert': !!record.securityAlert,
|
|
22
|
+
};
|
|
23
|
+
if (record.sessionId != null)
|
|
24
|
+
attributes.session_id = record.sessionId;
|
|
25
|
+
// Defense-in-depth: AuditRecord is already constructed with redacted
|
|
26
|
+
// filePath/command/detail (see audit-trail.ts), but apply redactSensitive
|
|
27
|
+
// again here so a future caller that bypasses the AuditTrailManager
|
|
28
|
+
// constructor cannot leak secrets via the NR Logs egress channel.
|
|
29
|
+
if (record.filePath != null)
|
|
30
|
+
attributes['audit.file_path'] = redactSensitive(record.filePath);
|
|
31
|
+
if (record.command != null)
|
|
32
|
+
attributes['audit.command'] = redactSensitive(record.command);
|
|
33
|
+
if (record.securityAlert) {
|
|
34
|
+
attributes['audit.severity'] = record.securityAlert.severity;
|
|
35
|
+
attributes['audit.alert_type'] = record.securityAlert.alertType;
|
|
36
|
+
}
|
|
37
|
+
return {
|
|
38
|
+
timestamp: record.timestamp,
|
|
39
|
+
message: redactSensitive(record.detail),
|
|
40
|
+
attributes,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
// ---------------------------------------------------------------------------
|
|
44
|
+
// LogIngestManager
|
|
45
|
+
// ---------------------------------------------------------------------------
|
|
46
|
+
const DEFAULT_LOG_HARVEST_MS = 5_000;
|
|
47
|
+
export class LogIngestManager {
|
|
48
|
+
buffer = [];
|
|
49
|
+
maxBufferSize = 1_000;
|
|
50
|
+
licenseKey;
|
|
51
|
+
transportOptions;
|
|
52
|
+
developer;
|
|
53
|
+
appName;
|
|
54
|
+
sendLogsFn;
|
|
55
|
+
harvestIntervalMs;
|
|
56
|
+
intervalId = null;
|
|
57
|
+
running = false;
|
|
58
|
+
inFlightFlush = null;
|
|
59
|
+
constructor(options) {
|
|
60
|
+
this.licenseKey = options.licenseKey;
|
|
61
|
+
this.transportOptions = options.transportOptions;
|
|
62
|
+
this.developer = options.developer;
|
|
63
|
+
this.appName = options.appName;
|
|
64
|
+
this.sendLogsFn = options.sendLogsFn ?? sendLogs;
|
|
65
|
+
this.harvestIntervalMs = options.logHarvestIntervalMs ?? DEFAULT_LOG_HARVEST_MS;
|
|
66
|
+
}
|
|
67
|
+
addLog(entry) {
|
|
68
|
+
this.buffer.push(entry);
|
|
69
|
+
}
|
|
70
|
+
addAuditRecord(record) {
|
|
71
|
+
this.addLog(auditRecordToLogEntry(record, this.appName));
|
|
72
|
+
}
|
|
73
|
+
start() {
|
|
74
|
+
if (this.running)
|
|
75
|
+
return;
|
|
76
|
+
this.running = true;
|
|
77
|
+
this.intervalId = setInterval(() => {
|
|
78
|
+
this.inFlightFlush = this.flush().finally(() => {
|
|
79
|
+
this.inFlightFlush = null;
|
|
80
|
+
});
|
|
81
|
+
}, this.harvestIntervalMs);
|
|
82
|
+
this.intervalId.unref();
|
|
83
|
+
}
|
|
84
|
+
async stop() {
|
|
85
|
+
if (!this.running)
|
|
86
|
+
return;
|
|
87
|
+
this.running = false;
|
|
88
|
+
if (this.intervalId !== null) {
|
|
89
|
+
clearInterval(this.intervalId);
|
|
90
|
+
this.intervalId = null;
|
|
91
|
+
}
|
|
92
|
+
// Wait for any in-flight periodic flush to finish before draining the
|
|
93
|
+
// final batch, so a concurrent requeueBatch() doesn't lose entries.
|
|
94
|
+
if (this.inFlightFlush)
|
|
95
|
+
await this.inFlightFlush.catch(() => { });
|
|
96
|
+
await this.flush();
|
|
97
|
+
}
|
|
98
|
+
async flush() {
|
|
99
|
+
if (this.buffer.length === 0)
|
|
100
|
+
return;
|
|
101
|
+
const batch = this.buffer;
|
|
102
|
+
this.buffer = [];
|
|
103
|
+
try {
|
|
104
|
+
const result = await this.sendLogsFn(batch, this.licenseKey, this.transportOptions);
|
|
105
|
+
if (!result.success) {
|
|
106
|
+
// Drop non-retryable 4xx (auth failure, bad payload) — re-queuing
|
|
107
|
+
// would fill the buffer indefinitely with entries that will never succeed.
|
|
108
|
+
const isNonRetryable = result.statusCode !== null &&
|
|
109
|
+
result.statusCode >= 400 &&
|
|
110
|
+
result.statusCode < 500 &&
|
|
111
|
+
result.statusCode !== 408 &&
|
|
112
|
+
result.statusCode !== 429;
|
|
113
|
+
if (isNonRetryable) {
|
|
114
|
+
logger.warn('Dropping non-retryable log batch', {
|
|
115
|
+
statusCode: result.statusCode,
|
|
116
|
+
batchSize: batch.length,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
logger.warn('Failed to send logs — re-queuing batch for retry', {
|
|
121
|
+
batchSize: batch.length,
|
|
122
|
+
error: result.error,
|
|
123
|
+
});
|
|
124
|
+
this.requeueBatch(batch);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
catch (err) {
|
|
129
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
130
|
+
logger.warn('Unexpected error sending logs — re-queuing batch for retry', {
|
|
131
|
+
batchSize: batch.length,
|
|
132
|
+
error: message,
|
|
133
|
+
});
|
|
134
|
+
this.requeueBatch(batch);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
requeueBatch(batch) {
|
|
138
|
+
// Trim new entries first so the failed batch (higher retry priority) is preserved.
|
|
139
|
+
// If the batch itself exceeds the cap, keep its most-recent entries.
|
|
140
|
+
const maxNew = Math.max(0, this.maxBufferSize - batch.length);
|
|
141
|
+
// Guard: slice(-0) === slice(0) returns the full array in JS; use [] when maxNew is 0.
|
|
142
|
+
const trimmedNew = maxNew === 0 ? [] : this.buffer.slice(-maxNew);
|
|
143
|
+
const trimmedBatch = batch.slice(-this.maxBufferSize);
|
|
144
|
+
const dropped = this.buffer.length - trimmedNew.length + (batch.length - trimmedBatch.length);
|
|
145
|
+
this.buffer = [...trimmedBatch, ...trimmedNew];
|
|
146
|
+
if (dropped > 0) {
|
|
147
|
+
logger.warn('Log buffer overflow — entries dropped', { dropped });
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=log-ingest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-ingest.js","sourceRoot":"","sources":["../../src/transport/log-ingest.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* New Relic Event Ingestion — converts ToolCallRecords into NR events and
|
|
3
|
+
* metrics, then ships them via the shared HarvestScheduler.
|
|
4
|
+
*/
|
|
5
|
+
import type { NrEventData, NrMetric, NrLogEntry, TransportOptions, TransportResult } from '../shared/index.js';
|
|
6
|
+
import type { ToolCallRecord } from '../storage/types.js';
|
|
7
|
+
import type { ProxyToolCallRecord, ProxyRequestRecord } from '../proxy/types.js';
|
|
8
|
+
import type { AiCodingTask } from '../metrics/task-detector.js';
|
|
9
|
+
import type { AntiPattern } from '../metrics/anti-patterns.js';
|
|
10
|
+
import type { SessionTracker } from '../metrics/session-tracker.js';
|
|
11
|
+
import type { CostTracker } from '../metrics/cost-tracker.js';
|
|
12
|
+
import type { EfficiencyScorer } from '../metrics/efficiency-score.js';
|
|
13
|
+
import type { BudgetThresholdEvent } from '../metrics/budget-tracker.js';
|
|
14
|
+
import type { ContextTurnSnapshot, ToolContextContribution } from '../metrics/context-tracker.js';
|
|
15
|
+
import { AuditTrailManager } from '../security/index.js';
|
|
16
|
+
import type { AuditRecord } from '../security/index.js';
|
|
17
|
+
import type { TurnCostAttributor } from '../metrics/turn-cost-attributor.js';
|
|
18
|
+
import type { LocalStore } from '../storage/index.js';
|
|
19
|
+
type SendEventsFn = (events: NrEventData[], licenseKey: string, options: TransportOptions) => Promise<TransportResult>;
|
|
20
|
+
type SendMetricsFn = (metrics: NrMetric[], licenseKey: string, options: TransportOptions) => Promise<TransportResult>;
|
|
21
|
+
type SendLogsFn = (logs: NrLogEntry[], licenseKey: string, options: TransportOptions) => Promise<TransportResult>;
|
|
22
|
+
export interface NrIngestOptions {
|
|
23
|
+
licenseKey: string;
|
|
24
|
+
transportOptions: TransportOptions;
|
|
25
|
+
developer: string;
|
|
26
|
+
appName: string;
|
|
27
|
+
sessionTracker: SessionTracker;
|
|
28
|
+
eventHarvestIntervalMs?: number;
|
|
29
|
+
metricHarvestIntervalMs?: number;
|
|
30
|
+
/** Session ID for audit trail context. */
|
|
31
|
+
sessionId?: string | null;
|
|
32
|
+
/** Trace ID generated at server startup — threaded through all NR events and metrics. */
|
|
33
|
+
sessionTraceId?: string;
|
|
34
|
+
/** LocalStore for persisting audit entries to disk. */
|
|
35
|
+
localStore?: LocalStore;
|
|
36
|
+
/**
|
|
37
|
+
* Optional pre-constructed AuditTrailManager. When provided, NrIngestManager
|
|
38
|
+
* uses it instead of constructing its own — lets the dashboard share the
|
|
39
|
+
* same audit log instance in both `local` and `cloud`/`both` modes.
|
|
40
|
+
*/
|
|
41
|
+
auditTrail?: AuditTrailManager;
|
|
42
|
+
/** Override for testing; defaults to the shared sendEvents transport. */
|
|
43
|
+
sendEventsFn?: SendEventsFn;
|
|
44
|
+
/** Override for testing; defaults to the shared sendMetrics transport. */
|
|
45
|
+
sendMetricsFn?: SendMetricsFn;
|
|
46
|
+
/** Harvest interval for NR Logs API delivery. Default: 5000ms. */
|
|
47
|
+
logHarvestIntervalMs?: number;
|
|
48
|
+
/** Override for testing; defaults to the shared sendLogs transport. */
|
|
49
|
+
sendLogsFn?: SendLogsFn;
|
|
50
|
+
/** Cost tracker for emitting ai.cost.* metrics. */
|
|
51
|
+
costTracker?: CostTracker;
|
|
52
|
+
/** Efficiency scorer for emitting ai.efficiency.* metrics. */
|
|
53
|
+
efficiencyScorer?: EfficiencyScorer;
|
|
54
|
+
teamId?: string | null;
|
|
55
|
+
projectId?: string | null;
|
|
56
|
+
orgId?: string | null;
|
|
57
|
+
/** OTLP/HTTP endpoint URL. When set, telemetry is also exported via OTLP. */
|
|
58
|
+
otlpEndpoint?: string | null;
|
|
59
|
+
/** Additional HTTP headers for the OTLP exporter. */
|
|
60
|
+
otlpHeaders?: Record<string, string>;
|
|
61
|
+
/** Transport mode: 'nr-events-api', 'otlp', or 'both'. */
|
|
62
|
+
transport?: 'nr-events-api' | 'otlp' | 'both';
|
|
63
|
+
/** Turn cost attributor for enriching AiToolCall events with cost data. */
|
|
64
|
+
turnCostAttributor?: TurnCostAttributor;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Convert a ToolCallRecord into a flat NR event object.
|
|
68
|
+
*
|
|
69
|
+
* Standard fields are mapped to snake_case NR attributes; any extra
|
|
70
|
+
* tool-specific fields (string | number | boolean) are included as-is.
|
|
71
|
+
*/
|
|
72
|
+
export declare function toolCallToNrEvent(record: ToolCallRecord, attrs: {
|
|
73
|
+
developer: string;
|
|
74
|
+
appName: string;
|
|
75
|
+
sessionTraceId?: string;
|
|
76
|
+
teamId?: string | null;
|
|
77
|
+
projectId?: string | null;
|
|
78
|
+
orgId?: string | null;
|
|
79
|
+
}): NrEventData;
|
|
80
|
+
/** Type guard for ProxyToolCallRecord (has serverName and upstreamLatencyMs with correct types). */
|
|
81
|
+
export declare function isProxyToolCall(record: ToolCallRecord): record is ProxyToolCallRecord;
|
|
82
|
+
/**
|
|
83
|
+
* Convert a ProxyToolCallRecord into an NR event with proxy-specific attributes.
|
|
84
|
+
*/
|
|
85
|
+
export declare function proxyToolCallToNrEvent(record: ProxyToolCallRecord, attrs: {
|
|
86
|
+
developer: string;
|
|
87
|
+
appName: string;
|
|
88
|
+
sessionTraceId?: string;
|
|
89
|
+
teamId?: string | null;
|
|
90
|
+
projectId?: string | null;
|
|
91
|
+
orgId?: string | null;
|
|
92
|
+
}): NrEventData;
|
|
93
|
+
/**
|
|
94
|
+
* Convert a ProxyRequestRecord (discovery methods like tools/list) into an NR event.
|
|
95
|
+
*/
|
|
96
|
+
export declare function proxyRequestToNrEvent(record: ProxyRequestRecord, attrs: {
|
|
97
|
+
developer: string;
|
|
98
|
+
appName: string;
|
|
99
|
+
teamId?: string | null;
|
|
100
|
+
projectId?: string | null;
|
|
101
|
+
orgId?: string | null;
|
|
102
|
+
}): NrEventData;
|
|
103
|
+
/**
|
|
104
|
+
* Convert an AiCodingTask into a flat NR event object.
|
|
105
|
+
*
|
|
106
|
+
* All fields use snake_case to match the convention of AiToolCall/AiAuditEvent.
|
|
107
|
+
* File path arrays are emitted as counts to keep event size small.
|
|
108
|
+
*/
|
|
109
|
+
export declare function codingTaskToNrEvent(task: AiCodingTask, attrs: {
|
|
110
|
+
developer: string;
|
|
111
|
+
appName: string;
|
|
112
|
+
sessionTraceId?: string;
|
|
113
|
+
teamId?: string | null;
|
|
114
|
+
projectId?: string | null;
|
|
115
|
+
orgId?: string | null;
|
|
116
|
+
}): NrEventData;
|
|
117
|
+
/**
|
|
118
|
+
* Convert an AntiPattern into a flat NR event object.
|
|
119
|
+
*
|
|
120
|
+
* Optional fields are only included when defined on the source pattern.
|
|
121
|
+
*/
|
|
122
|
+
export declare function antiPatternToNrEvent(pattern: AntiPattern, attrs: {
|
|
123
|
+
developer: string;
|
|
124
|
+
appName: string;
|
|
125
|
+
sessionId?: string;
|
|
126
|
+
platform?: string;
|
|
127
|
+
taskId: string;
|
|
128
|
+
teamId?: string | null;
|
|
129
|
+
projectId?: string | null;
|
|
130
|
+
orgId?: string | null;
|
|
131
|
+
/** Detection wall-clock time in ms. Defaults to now if not provided. */
|
|
132
|
+
detectedAt?: number;
|
|
133
|
+
}): NrEventData;
|
|
134
|
+
export declare class NrIngestManager {
|
|
135
|
+
private readonly scheduler;
|
|
136
|
+
private readonly logIngest;
|
|
137
|
+
private readonly sessionTracker;
|
|
138
|
+
private readonly proxyMetrics;
|
|
139
|
+
private readonly costTracker?;
|
|
140
|
+
private readonly efficiencyScorer?;
|
|
141
|
+
readonly auditTrail: AuditTrailManager;
|
|
142
|
+
private readonly developer;
|
|
143
|
+
private readonly appName;
|
|
144
|
+
private readonly sessionTraceId;
|
|
145
|
+
private readonly teamId;
|
|
146
|
+
private readonly projectId;
|
|
147
|
+
private readonly orgId;
|
|
148
|
+
private readonly metricHarvestIntervalMs;
|
|
149
|
+
private readonly turnCostAttributor?;
|
|
150
|
+
private readonly otlpTransport;
|
|
151
|
+
private readonly otlpEventBridge;
|
|
152
|
+
private sessionGaugeIntervalId;
|
|
153
|
+
private running;
|
|
154
|
+
constructor(options: NrIngestOptions);
|
|
155
|
+
ingestProxyRequest(record: ProxyRequestRecord): void;
|
|
156
|
+
ingestToolCall(record: ToolCallRecord, auditRecord?: AuditRecord): void;
|
|
157
|
+
ingestCodingTask(task: AiCodingTask): void;
|
|
158
|
+
ingestAntiPattern(pattern: AntiPattern, context: {
|
|
159
|
+
sessionId?: string;
|
|
160
|
+
platform?: string;
|
|
161
|
+
taskId: string;
|
|
162
|
+
detectedAt?: number;
|
|
163
|
+
}): void;
|
|
164
|
+
ingestContextSnapshot(snapshot: ContextTurnSnapshot, topTools: readonly ToolContextContribution[]): void;
|
|
165
|
+
ingestBudgetWarning(event: BudgetThresholdEvent): void;
|
|
166
|
+
start(): void;
|
|
167
|
+
stop(): Promise<void>;
|
|
168
|
+
private emitSessionGauges;
|
|
169
|
+
}
|
|
170
|
+
export {};
|
|
171
|
+
//# sourceMappingURL=nr-ingest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nr-ingest.d.ts","sourceRoot":"","sources":["../../src/transport/nr-ingest.ts"],"names":[],"mappings":"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"}
|