claude-flow-novice 1.6.1 → 1.6.3
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/.claude/agents/cfn-loop/product-owner.md +54 -4
- package/.claude/commands/cfn-claude-sync.md +303 -0
- package/.claude/commands/cfn-loop-epic.md +290 -0
- package/.claude/commands/cfn-loop-single.md +168 -0
- package/.claude/commands/cfn-loop-sprints.md +384 -0
- package/.claude/commands/cfn-loop.md +180 -0
- package/.claude/commands/metrics-summary.md +58 -0
- package/.claude/commands/parse-epic.md +357 -0
- package/.claude/settings.json +5 -4
- package/.claude/settings.local.json +9 -2
- package/.claude-flow-novice/.claude/agents/cfn-loop/product-owner.md +792 -0
- package/.claude-flow-novice/dist/mcp/server.js +21 -2
- package/.claude-flow-novice/dist/src/api/auth-service.js +84 -38
- package/.claude-flow-novice/dist/src/api/auth-service.js.map +1 -1
- package/.claude-flow-novice/dist/src/api/claude-client.js +138 -3
- package/.claude-flow-novice/dist/src/api/claude-client.js.map +1 -1
- package/.claude-flow-novice/dist/src/cfn-loop/phase-orchestrator-example.js +1 -1
- package/.claude-flow-novice/dist/src/cfn-loop/scope-control.js +247 -0
- package/.claude-flow-novice/dist/src/cfn-loop/scope-control.js.map +1 -0
- package/.claude-flow-novice/dist/src/cli/commands/swarm.js +32 -15
- package/.claude-flow-novice/dist/src/cli/commands/swarm.js.map +1 -1
- package/.claude-flow-novice/dist/src/cli/commands/transparency.js +455 -0
- package/.claude-flow-novice/dist/src/cli/commands/transparency.js.map +1 -0
- package/.claude-flow-novice/dist/src/cli/simple-commands/init/templates/CLAUDE.md +129 -13
- package/.claude-flow-novice/dist/src/components/visualizations/index.js +9 -0
- package/.claude-flow-novice/dist/src/components/visualizations/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/adapters/v1-coordinator-adapter.js +462 -0
- package/.claude-flow-novice/dist/src/coordination/adapters/v1-coordinator-adapter.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/config-translator.js +248 -0
- package/.claude-flow-novice/dist/src/coordination/config-translator.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/coordination-toggle.js +287 -0
- package/.claude-flow-novice/dist/src/coordination/coordination-toggle.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/distributed-consensus.js +68 -9
- package/.claude-flow-novice/dist/src/coordination/distributed-consensus.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/feature-flags.js +166 -0
- package/.claude-flow-novice/dist/src/coordination/feature-flags.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/queen-agent.js +18 -4
- package/.claude-flow-novice/dist/src/coordination/queen-agent.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/role-assignment.js +6 -110
- package/.claude-flow-novice/dist/src/coordination/role-assignment.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/cache/artifact-cache-optimizer.js +632 -0
- package/.claude-flow-novice/dist/src/coordination/v2/cache/artifact-cache-optimizer.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/cache/index.js +11 -0
- package/.claude-flow-novice/dist/src/coordination/v2/cache/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/checkpoints/checkpoint-compressor.js +318 -0
- package/.claude-flow-novice/dist/src/coordination/v2/checkpoints/checkpoint-compressor.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.example.js +364 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.example.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.js +492 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/hierarchical-coordinator.js +786 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/hierarchical-coordinator.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/index.js +16 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/parent-child-manager.js +342 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/parent-child-manager.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/swarm-coordinator-v2.js +601 -0
- package/.claude-flow-novice/dist/src/coordination/v2/coordinators/swarm-coordinator-v2.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/help-request-metrics.js +211 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/help-request-metrics.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/index.js +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/index.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/core/message-broker.js +365 -6
- package/.claude-flow-novice/dist/src/coordination/v2/core/message-broker.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/core/resource-manager-safe.js +478 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/resource-manager-safe.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine-config.js +5 -2
- package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine-config.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine.js +189 -0
- package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/deadlock-detector.js +424 -0
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/deadlock-detector.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/index.js +9 -0
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/resource-manager.js +669 -0
- package/.claude-flow-novice/dist/src/coordination/v2/deadlock/resource-manager.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/artifact-storage.js +451 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/artifact-storage.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/cycle-detector.js +271 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/cycle-detector.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-graph.js +335 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-graph.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-manager.js +439 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-manager.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-request.js +92 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-request.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/index.js +21 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/topological-sort.js +223 -0
- package/.claude-flow-novice/dist/src/coordination/v2/dependency/topological-sort.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-coordinator.js +436 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-coordinator.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-matcher.js +278 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-matcher.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request-handler.js +317 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request-handler.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request.js +273 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/index.js +15 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/waiting-agent-pool.js +512 -0
- package/.claude-flow-novice/dist/src/coordination/v2/help-system/waiting-agent-pool.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/index.js +6 -0
- package/.claude-flow-novice/dist/src/coordination/v2/index.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/integration/help-deadlock-integration.js +557 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/help-deadlock-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/index.js +14 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.example.js +212 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.example.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.js +552 -0
- package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/memory/dependency-storage.js +367 -0
- package/.claude-flow-novice/dist/src/coordination/v2/memory/dependency-storage.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/memory/index.js +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/memory/index.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channel.js +371 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channel.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/dependency-channel.js +355 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/dependency-channel.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/help-channel.js +424 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/help-channel.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/index.js +16 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/state-channel.js +295 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/state-channel.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/task-channel.js +411 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/task-channel.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/index.js +14 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-bus.js +387 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-bus.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-persistence.js +589 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-persistence.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-router.js +444 -0
- package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-router.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/checkpoint-manager.js +29 -8
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/checkpoint-manager.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/help-coordinator.js +470 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/help-coordinator.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/hierarchical-background-integration.js +450 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/hierarchical-background-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/index.js +5 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/index.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/multi-level-control.js +545 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/multi-level-control.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-controller.js +44 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-controller.js.map +1 -1
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-message-integration.js +415 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-message-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/session-pool-optimizer.js +615 -0
- package/.claude-flow-novice/dist/src/coordination/v2/sdk/session-pool-optimizer.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/security/payload-validator.js +259 -0
- package/.claude-flow-novice/dist/src/coordination/v2/security/payload-validator.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/index.js +17 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-integration.js +357 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-system.js +679 -0
- package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-system.js.map +1 -0
- package/.claude-flow-novice/dist/src/core/agent-manager.js +30 -0
- package/.claude-flow-novice/dist/src/core/agent-manager.js.map +1 -1
- package/.claude-flow-novice/dist/src/mcp/server.js +21 -2
- package/.claude-flow-novice/dist/src/mcp/server.js.map +1 -1
- package/.claude-flow-novice/dist/src/monitoring/apm/apm-integration.js +719 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/apm-integration.js.map +1 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/datadog-collector.js +363 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/datadog-collector.js.map +1 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/index.js +97 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/newrelic-collector.js +384 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/newrelic-collector.js.map +1 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/performance-optimizer.js +612 -0
- package/.claude-flow-novice/dist/src/monitoring/apm/performance-optimizer.js.map +1 -0
- package/.claude-flow-novice/dist/src/monitoring/metrics-collector.js +282 -0
- package/.claude-flow-novice/dist/src/monitoring/metrics-collector.js.map +1 -0
- package/.claude-flow-novice/dist/src/observability/metrics-counter.js +268 -0
- package/.claude-flow-novice/dist/src/observability/metrics-counter.js.map +1 -0
- package/.claude-flow-novice/dist/src/observability/metrics-storage.js +265 -0
- package/.claude-flow-novice/dist/src/observability/metrics-storage.js.map +1 -0
- package/.claude-flow-novice/dist/src/observability/telemetry.js +26 -0
- package/.claude-flow-novice/dist/src/observability/telemetry.js.map +1 -1
- package/.claude-flow-novice/dist/src/providers/tiered-router.js +64 -10
- package/.claude-flow-novice/dist/src/providers/tiered-router.js.map +1 -1
- package/.claude-flow-novice/dist/src/providers/zai-provider.js +196 -97
- package/.claude-flow-novice/dist/src/providers/zai-provider.js.map +1 -1
- package/.claude-flow-novice/dist/src/slash-commands/cfn-claude-sync.js +533 -0
- package/.claude-flow-novice/dist/src/slash-commands/index.js +5 -0
- package/.claude-flow-novice/dist/src/slash-commands/metrics-summary-class.js +74 -0
- package/.claude-flow-novice/dist/src/slash-commands/metrics-summary.js +335 -0
- package/.claude-flow-novice/dist/src/slash-commands/register-all-commands.js +12 -0
- package/.claude-flow-novice/dist/src/verification/checkpoint-compression-demo.js +96 -0
- package/.claude-flow-novice/dist/src/verification/checkpoint-compression-demo.js.map +1 -0
- package/.claude-flow-novice/dist/src/verification/checkpoint-compression.js +406 -0
- package/.claude-flow-novice/dist/src/verification/checkpoint-compression.js.map +1 -0
- package/.claude-flow-novice/dist/src/verification/checkpoint-manager.js +35 -5
- package/.claude-flow-novice/dist/src/verification/checkpoint-manager.js.map +1 -1
- package/.claude-flow-novice/dist/src/web/api/apm-routes.js +355 -0
- package/.claude-flow-novice/dist/src/web/api/apm-routes.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/config/api-config.js +186 -0
- package/.claude-flow-novice/dist/src/web/api/config/api-config.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/auth.js +205 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/auth.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/cache.js +262 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/cache.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/error-handler.js +250 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/error-handler.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/request-logger.js +217 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/request-logger.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/validation.js +325 -0
- package/.claude-flow-novice/dist/src/web/api/middleware/validation.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/routes/events.js +465 -0
- package/.claude-flow-novice/dist/src/web/api/routes/events.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/routes/hierarchy.js +302 -0
- package/.claude-flow-novice/dist/src/web/api/routes/hierarchy.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/routes/index.js +14 -0
- package/.claude-flow-novice/dist/src/web/api/routes/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/routes/metrics.js +561 -0
- package/.claude-flow-novice/dist/src/web/api/routes/metrics.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/routes/status.js +450 -0
- package/.claude-flow-novice/dist/src/web/api/routes/status.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/api/server.js +451 -0
- package/.claude-flow-novice/dist/src/web/api/server.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/dashboard/hooks/useWebSocket.js +385 -0
- package/.claude-flow-novice/dist/src/web/dashboard/hooks/useWebSocket.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/dashboard/index.js +87 -0
- package/.claude-flow-novice/dist/src/web/dashboard/index.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/dashboard/types.js +6 -0
- package/.claude-flow-novice/dist/src/web/dashboard/types.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/frontend/src/utils/security.js +425 -0
- package/.claude-flow-novice/dist/src/web/frontend/src/utils/security.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/security/security-middleware.js +379 -0
- package/.claude-flow-novice/dist/src/web/security/security-middleware.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/websocket/apm-websocket-handler.js +441 -0
- package/.claude-flow-novice/dist/src/web/websocket/apm-websocket-handler.js.map +1 -0
- package/.claude-flow-novice/dist/src/web/websocket/websocket-manager.js +255 -1
- package/.claude-flow-novice/dist/src/web/websocket/websocket-manager.js.map +1 -1
- package/.claude-flow-novice/metrics.db +0 -0
- package/.claude-flow-novice/metrics.db-shm +0 -0
- package/.claude-flow-novice/metrics.db-wal +0 -0
- package/AGENT_PERFORMANCE_GUIDELINES.md +88 -0
- package/CLAUDE.md +60 -3
- package/MEMORY_LEAK_ROOT_CAUSE.md +149 -0
- package/README.md +27 -0
- package/config/hooks/post-edit-pipeline.js +36 -2
- package/examples/metrics-counter-demo.ts +106 -0
- package/examples/persistent-metrics-demo.ts +83 -0
- package/examples/phase-5-multi-level-control.ts +282 -0
- package/examples/session-pool-optimizer-example.ts +311 -0
- package/package.json +18 -4
- package/scripts/check-routing-stats.cjs +122 -0
- package/scripts/monitor-loop.sh +65 -0
- package/scripts/monitor-memory.sh +47 -0
- package/scripts/monitor.py +43 -0
- package/scripts/pre-publish-validation.cjs +212 -0
- package/scripts/test-provider-routing.cjs +228 -0
- package/scripts/test-routing-telemetry.cjs +147 -0
- package/scripts/test-zai-10k.cjs +81 -0
- package/scripts/test-zai-api.cjs +191 -0
- package/scripts/test-zai-diagnostic.cjs +151 -0
- package/scripts/test-zai-final.cjs +128 -0
- package/scripts/test-zai-with-env.cjs +85 -0
- package/scripts/validate-coordination-cli.js +69 -0
- package/scripts/validate-coordination-toggle-integration.cjs +501 -0
- package/src/cli/simple-commands/init/templates/CLAUDE.md +29 -0
- package/src/observability/metrics-counter.ts +347 -0
- package/src/observability/metrics-storage.ts +356 -0
- package/src/observability/telemetry.ts +658 -0
- package/src/slash-commands/cfn-claude-sync.js +533 -0
- package/src/slash-commands/index.js +5 -0
- package/src/slash-commands/metrics-summary-class.js +74 -0
- package/src/slash-commands/metrics-summary.js +335 -0
- package/src/slash-commands/register-all-commands.js +12 -0
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Persistent Metrics Storage using SQLite
|
|
3
|
+
*
|
|
4
|
+
* Stores all metrics to a local SQLite database for:
|
|
5
|
+
* - Cross-process metric aggregation
|
|
6
|
+
* - Historical analysis
|
|
7
|
+
* - Metrics that survive restarts
|
|
8
|
+
* - Query capabilities across time ranges
|
|
9
|
+
*/ import Database from 'better-sqlite3';
|
|
10
|
+
import { existsSync, mkdirSync } from 'fs';
|
|
11
|
+
import { dirname } from 'path';
|
|
12
|
+
export class MetricsStorage {
|
|
13
|
+
db;
|
|
14
|
+
insertStmt;
|
|
15
|
+
dbPath;
|
|
16
|
+
constructor(dbPath = '.claude-flow-novice/metrics.db'){
|
|
17
|
+
this.dbPath = dbPath;
|
|
18
|
+
// Ensure directory exists
|
|
19
|
+
const dir = dirname(dbPath);
|
|
20
|
+
if (!existsSync(dir)) {
|
|
21
|
+
mkdirSync(dir, {
|
|
22
|
+
recursive: true
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
// Initialize database
|
|
26
|
+
this.db = new Database(dbPath);
|
|
27
|
+
this.db.pragma('journal_mode = WAL'); // Write-Ahead Logging for better concurrency
|
|
28
|
+
// Create schema
|
|
29
|
+
this.createSchema();
|
|
30
|
+
// Prepare insert statement for performance
|
|
31
|
+
this.insertStmt = this.db.prepare(`
|
|
32
|
+
INSERT INTO metrics (name, value, type, timestamp, tags)
|
|
33
|
+
VALUES (?, ?, ?, ?, ?)
|
|
34
|
+
`);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Create database schema
|
|
38
|
+
*/ createSchema() {
|
|
39
|
+
this.db.exec(`
|
|
40
|
+
CREATE TABLE IF NOT EXISTS metrics (
|
|
41
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
42
|
+
name TEXT NOT NULL,
|
|
43
|
+
value REAL NOT NULL,
|
|
44
|
+
type TEXT NOT NULL CHECK(type IN ('counter', 'gauge', 'timer', 'histogram')),
|
|
45
|
+
timestamp TEXT NOT NULL,
|
|
46
|
+
tags TEXT NOT NULL DEFAULT '{}',
|
|
47
|
+
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
|
|
48
|
+
);
|
|
49
|
+
|
|
50
|
+
-- Indexes for fast queries
|
|
51
|
+
CREATE INDEX IF NOT EXISTS idx_metrics_name ON metrics(name);
|
|
52
|
+
CREATE INDEX IF NOT EXISTS idx_metrics_timestamp ON metrics(timestamp);
|
|
53
|
+
CREATE INDEX IF NOT EXISTS idx_metrics_type ON metrics(type);
|
|
54
|
+
CREATE INDEX IF NOT EXISTS idx_metrics_name_timestamp ON metrics(name, timestamp);
|
|
55
|
+
`);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Store a metric point
|
|
59
|
+
*/ store(metric) {
|
|
60
|
+
this.insertStmt.run(metric.name, metric.value, metric.type, metric.timestamp.toISOString(), JSON.stringify(metric.tags));
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Store multiple metrics in a transaction (faster)
|
|
64
|
+
*/ storeBatch(metrics) {
|
|
65
|
+
const insertMany = this.db.transaction((metricsArray)=>{
|
|
66
|
+
for (const metric of metricsArray){
|
|
67
|
+
this.insertStmt.run(metric.name, metric.value, metric.type, metric.timestamp.toISOString(), JSON.stringify(metric.tags));
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
insertMany(metrics);
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Query metrics with filters
|
|
74
|
+
*/ query(filter = {}) {
|
|
75
|
+
let sql = 'SELECT * FROM metrics WHERE 1=1';
|
|
76
|
+
const params = [];
|
|
77
|
+
if (filter.name) {
|
|
78
|
+
sql += ' AND name = ?';
|
|
79
|
+
params.push(filter.name);
|
|
80
|
+
}
|
|
81
|
+
if (filter.type) {
|
|
82
|
+
sql += ' AND type = ?';
|
|
83
|
+
params.push(filter.type);
|
|
84
|
+
}
|
|
85
|
+
if (filter.startTime) {
|
|
86
|
+
sql += ' AND timestamp >= ?';
|
|
87
|
+
params.push(filter.startTime.toISOString());
|
|
88
|
+
}
|
|
89
|
+
if (filter.endTime) {
|
|
90
|
+
sql += ' AND timestamp <= ?';
|
|
91
|
+
params.push(filter.endTime.toISOString());
|
|
92
|
+
}
|
|
93
|
+
sql += ' ORDER BY timestamp DESC';
|
|
94
|
+
if (filter.limit) {
|
|
95
|
+
sql += ' LIMIT ?';
|
|
96
|
+
params.push(filter.limit);
|
|
97
|
+
}
|
|
98
|
+
const stmt = this.db.prepare(sql);
|
|
99
|
+
const rows = stmt.all(...params);
|
|
100
|
+
// Filter by tags if specified
|
|
101
|
+
if (filter.tags) {
|
|
102
|
+
return rows.filter((row)=>{
|
|
103
|
+
const rowTags = JSON.parse(row.tags);
|
|
104
|
+
return Object.entries(filter.tags).every(([key, value])=>rowTags[key] === value);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
return rows;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Get total count for a counter metric
|
|
111
|
+
*/ getCounterTotal(name, tags) {
|
|
112
|
+
const metrics = this.query({
|
|
113
|
+
name,
|
|
114
|
+
type: 'counter',
|
|
115
|
+
tags
|
|
116
|
+
});
|
|
117
|
+
return metrics.reduce((sum, m)=>sum + m.value, 0);
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Get latest gauge value
|
|
121
|
+
*/ getLatestGauge(name, tags) {
|
|
122
|
+
const metrics = this.query({
|
|
123
|
+
name,
|
|
124
|
+
type: 'gauge',
|
|
125
|
+
tags,
|
|
126
|
+
limit: 1
|
|
127
|
+
});
|
|
128
|
+
return metrics.length > 0 ? metrics[0].value : null;
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Get metric summary with aggregations
|
|
132
|
+
*/ getSummary(name, startTime, endTime) {
|
|
133
|
+
const metrics = this.query({
|
|
134
|
+
name,
|
|
135
|
+
startTime,
|
|
136
|
+
endTime
|
|
137
|
+
});
|
|
138
|
+
if (metrics.length === 0) {
|
|
139
|
+
return null;
|
|
140
|
+
}
|
|
141
|
+
const values = metrics.map((m)=>m.value);
|
|
142
|
+
const tagBreakdown = {};
|
|
143
|
+
// Aggregate tags
|
|
144
|
+
metrics.forEach((metric)=>{
|
|
145
|
+
const tags = JSON.parse(metric.tags);
|
|
146
|
+
Object.entries(tags).forEach(([key, value])=>{
|
|
147
|
+
if (!tagBreakdown[key]) {
|
|
148
|
+
tagBreakdown[key] = {};
|
|
149
|
+
}
|
|
150
|
+
tagBreakdown[key][value] = (tagBreakdown[key][value] || 0) + metric.value;
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
return {
|
|
154
|
+
name,
|
|
155
|
+
type: metrics[0].type,
|
|
156
|
+
count: metrics.length,
|
|
157
|
+
sum: values.reduce((a, b)=>a + b, 0),
|
|
158
|
+
avg: values.reduce((a, b)=>a + b, 0) / values.length,
|
|
159
|
+
min: Math.min(...values),
|
|
160
|
+
max: Math.max(...values),
|
|
161
|
+
tags: tagBreakdown
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Get breakdown by tag value
|
|
166
|
+
*/ getBreakdown(name, tagKey, startTime, endTime) {
|
|
167
|
+
const metrics = this.query({
|
|
168
|
+
name,
|
|
169
|
+
startTime,
|
|
170
|
+
endTime
|
|
171
|
+
});
|
|
172
|
+
const breakdown = {};
|
|
173
|
+
metrics.forEach((metric)=>{
|
|
174
|
+
const tags = JSON.parse(metric.tags);
|
|
175
|
+
const tagValue = tags[tagKey] || 'unknown';
|
|
176
|
+
breakdown[tagValue] = (breakdown[tagValue] || 0) + metric.value;
|
|
177
|
+
});
|
|
178
|
+
return breakdown;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Get time-series data (metrics grouped by time buckets)
|
|
182
|
+
*/ getTimeSeries(name, bucketSize = '5min', startTime, endTime) {
|
|
183
|
+
const bucketSeconds = {
|
|
184
|
+
'1min': 60,
|
|
185
|
+
'5min': 300,
|
|
186
|
+
'1hour': 3600,
|
|
187
|
+
'1day': 86400
|
|
188
|
+
};
|
|
189
|
+
const seconds = bucketSeconds[bucketSize];
|
|
190
|
+
const sql = `
|
|
191
|
+
SELECT
|
|
192
|
+
strftime('%Y-%m-%d %H:%M:%S',
|
|
193
|
+
datetime((strftime('%s', timestamp) / ${seconds}) * ${seconds}, 'unixepoch')
|
|
194
|
+
) as bucket,
|
|
195
|
+
SUM(value) as value,
|
|
196
|
+
COUNT(*) as count
|
|
197
|
+
FROM metrics
|
|
198
|
+
WHERE name = ?
|
|
199
|
+
${startTime ? 'AND timestamp >= ?' : ''}
|
|
200
|
+
${endTime ? 'AND timestamp <= ?' : ''}
|
|
201
|
+
GROUP BY bucket
|
|
202
|
+
ORDER BY bucket ASC
|
|
203
|
+
`;
|
|
204
|
+
const params = [
|
|
205
|
+
name
|
|
206
|
+
];
|
|
207
|
+
if (startTime) params.push(startTime.toISOString());
|
|
208
|
+
if (endTime) params.push(endTime.toISOString());
|
|
209
|
+
const stmt = this.db.prepare(sql);
|
|
210
|
+
return stmt.all(...params);
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Clean up old metrics (retention policy)
|
|
214
|
+
*/ cleanup(retentionDays = 30) {
|
|
215
|
+
const cutoffDate = new Date();
|
|
216
|
+
cutoffDate.setDate(cutoffDate.getDate() - retentionDays);
|
|
217
|
+
const stmt = this.db.prepare('DELETE FROM metrics WHERE timestamp < ?');
|
|
218
|
+
const result = stmt.run(cutoffDate.toISOString());
|
|
219
|
+
return result.changes;
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Get database statistics
|
|
223
|
+
*/ getStats() {
|
|
224
|
+
const totalMetrics = this.db.prepare('SELECT COUNT(*) as count FROM metrics').get();
|
|
225
|
+
const uniqueNames = this.db.prepare('SELECT COUNT(DISTINCT name) as count FROM metrics').get();
|
|
226
|
+
const oldest = this.db.prepare('SELECT MIN(timestamp) as ts FROM metrics').get();
|
|
227
|
+
const newest = this.db.prepare('SELECT MAX(timestamp) as ts FROM metrics').get();
|
|
228
|
+
// Get database file size
|
|
229
|
+
let dbSizeMB = 0;
|
|
230
|
+
try {
|
|
231
|
+
const fs = require('fs');
|
|
232
|
+
const stats = fs.statSync(this.dbPath);
|
|
233
|
+
dbSizeMB = stats.size / (1024 * 1024);
|
|
234
|
+
} catch (err) {
|
|
235
|
+
// Ignore if can't get file size
|
|
236
|
+
}
|
|
237
|
+
return {
|
|
238
|
+
totalMetrics: totalMetrics.count,
|
|
239
|
+
uniqueNames: uniqueNames.count,
|
|
240
|
+
oldestMetric: oldest.ts,
|
|
241
|
+
newestMetric: newest.ts,
|
|
242
|
+
dbSizeMB: Math.round(dbSizeMB * 100) / 100
|
|
243
|
+
};
|
|
244
|
+
}
|
|
245
|
+
/**
|
|
246
|
+
* Close database connection
|
|
247
|
+
*/ close() {
|
|
248
|
+
this.db.close();
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
// ============================================================================
|
|
252
|
+
// Singleton Instance
|
|
253
|
+
// ============================================================================
|
|
254
|
+
let globalStorage;
|
|
255
|
+
export function getGlobalMetricsStorage() {
|
|
256
|
+
if (!globalStorage) {
|
|
257
|
+
globalStorage = new MetricsStorage();
|
|
258
|
+
}
|
|
259
|
+
return globalStorage;
|
|
260
|
+
}
|
|
261
|
+
export function setGlobalMetricsStorage(storage) {
|
|
262
|
+
globalStorage = storage;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
//# sourceMappingURL=metrics-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/observability/metrics-storage.ts"],"names":["Database","existsSync","mkdirSync","dirname","MetricsStorage","db","insertStmt","dbPath","dir","recursive","pragma","createSchema","prepare","exec","store","metric","run","name","value","type","timestamp","toISOString","JSON","stringify","tags","storeBatch","metrics","insertMany","transaction","metricsArray","query","filter","sql","params","push","startTime","endTime","limit","stmt","rows","all","row","rowTags","parse","Object","entries","every","key","getCounterTotal","reduce","sum","m","getLatestGauge","length","getSummary","values","map","tagBreakdown","forEach","count","a","b","avg","min","Math","max","getBreakdown","tagKey","breakdown","tagValue","getTimeSeries","bucketSize","bucketSeconds","seconds","cleanup","retentionDays","cutoffDate","Date","setDate","getDate","result","changes","getStats","totalMetrics","get","uniqueNames","oldest","newest","dbSizeMB","fs","require","stats","statSync","size","err","oldestMetric","ts","newestMetric","round","close","globalStorage","getGlobalMetricsStorage","setGlobalMetricsStorage","storage"],"mappings":"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"}
|
|
@@ -8,12 +8,14 @@
|
|
|
8
8
|
*/ import { EventEmitter } from 'node:events';
|
|
9
9
|
import { Logger } from '../core/logger.js';
|
|
10
10
|
import { generateId } from '../utils/helpers.js';
|
|
11
|
+
import { getGlobalMetricsStorage } from './metrics-storage.js';
|
|
11
12
|
// ============================================================================
|
|
12
13
|
// Telemetry System
|
|
13
14
|
// ============================================================================
|
|
14
15
|
export class TelemetrySystem extends EventEmitter {
|
|
15
16
|
logger;
|
|
16
17
|
config;
|
|
18
|
+
storage;
|
|
17
19
|
// Tracing
|
|
18
20
|
activeTraces = new Map();
|
|
19
21
|
completedTraces = [];
|
|
@@ -30,6 +32,7 @@ export class TelemetrySystem extends EventEmitter {
|
|
|
30
32
|
enableTracing: config.enableTracing ?? true,
|
|
31
33
|
enableMetrics: config.enableMetrics ?? true,
|
|
32
34
|
enableStructuredLogging: config.enableStructuredLogging ?? true,
|
|
35
|
+
enablePersistence: config.enablePersistence ?? true,
|
|
33
36
|
metricsFlushInterval: config.metricsFlushInterval ?? 60000,
|
|
34
37
|
traceSamplingRate: config.traceSamplingRate ?? 1.0,
|
|
35
38
|
maxTraceHistory: config.maxTraceHistory ?? 100,
|
|
@@ -42,6 +45,17 @@ export class TelemetrySystem extends EventEmitter {
|
|
|
42
45
|
}, {
|
|
43
46
|
component: 'TelemetrySystem'
|
|
44
47
|
});
|
|
48
|
+
// Initialize persistent storage if enabled
|
|
49
|
+
if (this.config.enablePersistence) {
|
|
50
|
+
try {
|
|
51
|
+
this.storage = getGlobalMetricsStorage();
|
|
52
|
+
} catch (error) {
|
|
53
|
+
this.logger.warn('Failed to initialize metrics storage, persistence disabled', {
|
|
54
|
+
error
|
|
55
|
+
});
|
|
56
|
+
this.config.enablePersistence = false;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
45
59
|
}
|
|
46
60
|
// ============================================================================
|
|
47
61
|
// Distributed Tracing
|
|
@@ -357,6 +371,7 @@ export class TelemetrySystem extends EventEmitter {
|
|
|
357
371
|
// Internal Helpers
|
|
358
372
|
// ============================================================================
|
|
359
373
|
storeMetric(name, metric) {
|
|
374
|
+
// Store in memory buffer
|
|
360
375
|
if (!this.metrics.has(name)) {
|
|
361
376
|
this.metrics.set(name, []);
|
|
362
377
|
}
|
|
@@ -366,6 +381,17 @@ export class TelemetrySystem extends EventEmitter {
|
|
|
366
381
|
if (metricsList.length > this.config.maxMetricHistory) {
|
|
367
382
|
metricsList.shift();
|
|
368
383
|
}
|
|
384
|
+
// Persist to SQLite if enabled
|
|
385
|
+
if (this.config.enablePersistence && this.storage) {
|
|
386
|
+
try {
|
|
387
|
+
this.storage.store(metric);
|
|
388
|
+
} catch (error) {
|
|
389
|
+
this.logger.error('Failed to persist metric', {
|
|
390
|
+
metric: name,
|
|
391
|
+
error
|
|
392
|
+
});
|
|
393
|
+
}
|
|
394
|
+
}
|
|
369
395
|
}
|
|
370
396
|
startMetricsFlush() {
|
|
371
397
|
this.metricsFlushTimer = setInterval(()=>{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/observability/telemetry.ts"],"names":["EventEmitter","Logger","generateId","TelemetrySystem","logger","config","activeTraces","Map","completedTraces","metrics","latencyBuffer","metricsFlushTimer","logBuffer","maxLogBuffer","enableTracing","enableMetrics","enableStructuredLogging","metricsFlushInterval","traceSamplingRate","maxTraceHistory","maxMetricHistory","level","format","destination","component","startSpan","operation","parentSpanId","tags","createNoOpTrace","Math","random","traceId","spanId","trace","startTime","Date","logs","status","set","emit","debug","endSpan","get","warn","endTime","duration","getTime","delete","push","length","shift","addTraceLog","message","fields","timestamp","addTraceTags","Object","assign","getTrace","values","find","t","getTracesByCorrelation","correlationId","filter","recordCounter","name","value","metric","type","storeMetric","recordGauge","recordTimer","durationMs","has","recordHistogram","getLatencyMetrics","operationName","latencies","sorted","sort","a","b","count","p50","percentile","p90","p95","p99","mean","reduce","sum","val","min","max","getThroughputMetrics","windowMs","now","windowStart","recentMetrics","m","totalRequests","successfulRequests","failedRequests","requestsPerSecond","successRate","failureRate","getMetrics","log","entry","workerId","taskId","getRecentLogs","l","slice","getLogsByCorrelation","initialize","info","startMetricsFlush","shutdown","clearInterval","undefined","flushMetrics","clear","removeAllListeners","metricsList","setInterval","summary","getMetricsSummary","totalMetrics","metricNames","byType","counter","gauge","timer","histogram","Array","from","keys","p","index","ceil","globalTelemetry","getGlobalTelemetry","setGlobalTelemetry","telemetry"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../../src/observability/telemetry.ts"],"names":["EventEmitter","Logger","generateId","getGlobalMetricsStorage","TelemetrySystem","logger","config","storage","activeTraces","Map","completedTraces","metrics","latencyBuffer","metricsFlushTimer","logBuffer","maxLogBuffer","enableTracing","enableMetrics","enableStructuredLogging","enablePersistence","metricsFlushInterval","traceSamplingRate","maxTraceHistory","maxMetricHistory","level","format","destination","component","error","warn","startSpan","operation","parentSpanId","tags","createNoOpTrace","Math","random","traceId","spanId","trace","startTime","Date","logs","status","set","emit","debug","endSpan","get","endTime","duration","getTime","delete","push","length","shift","addTraceLog","message","fields","timestamp","addTraceTags","Object","assign","getTrace","values","find","t","getTracesByCorrelation","correlationId","filter","recordCounter","name","value","metric","type","storeMetric","recordGauge","recordTimer","durationMs","has","recordHistogram","getLatencyMetrics","operationName","latencies","sorted","sort","a","b","count","p50","percentile","p90","p95","p99","mean","reduce","sum","val","min","max","getThroughputMetrics","windowMs","now","windowStart","recentMetrics","m","totalRequests","successfulRequests","failedRequests","requestsPerSecond","successRate","failureRate","getMetrics","log","entry","workerId","taskId","getRecentLogs","l","slice","getLogsByCorrelation","initialize","info","startMetricsFlush","shutdown","clearInterval","undefined","flushMetrics","clear","removeAllListeners","metricsList","store","setInterval","summary","getMetricsSummary","totalMetrics","metricNames","byType","counter","gauge","timer","histogram","Array","from","keys","p","index","ceil","globalTelemetry","getGlobalTelemetry","setGlobalTelemetry","telemetry"],"mappings":"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"}
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
* Routes agents to appropriate LLM providers based on tier configuration
|
|
4
4
|
* and agent profile preferences
|
|
5
5
|
*/ import { AgentProfileLoader } from "./agent-profile-loader.js";
|
|
6
|
+
import { getGlobalTelemetry } from "../observability/telemetry.js";
|
|
6
7
|
// ===== TIER DEFINITIONS =====
|
|
7
8
|
const TIER_CONFIGS = [
|
|
8
9
|
{
|
|
@@ -18,7 +19,7 @@ const TIER_CONFIGS = [
|
|
|
18
19
|
},
|
|
19
20
|
{
|
|
20
21
|
name: "Tier 2: Z.ai Default",
|
|
21
|
-
provider: "
|
|
22
|
+
provider: "zai",
|
|
22
23
|
agentTypes: [],
|
|
23
24
|
priority: 2
|
|
24
25
|
},
|
|
@@ -34,7 +35,8 @@ export class TieredProviderRouter {
|
|
|
34
35
|
subscriptionUsage;
|
|
35
36
|
tierConfigs;
|
|
36
37
|
profileLoader;
|
|
37
|
-
|
|
38
|
+
telemetry;
|
|
39
|
+
constructor(tierConfigs = TIER_CONFIGS, initialUsage = {}, agentsDir, telemetry){
|
|
38
40
|
this.tierConfigs = tierConfigs.sort((a, b)=>a.priority - b.priority);
|
|
39
41
|
this.subscriptionUsage = {
|
|
40
42
|
used: initialUsage.used || 0,
|
|
@@ -42,20 +44,37 @@ export class TieredProviderRouter {
|
|
|
42
44
|
resetDate: initialUsage.resetDate || this.getNextResetDate()
|
|
43
45
|
};
|
|
44
46
|
this.profileLoader = new AgentProfileLoader(agentsDir);
|
|
47
|
+
this.telemetry = telemetry || getGlobalTelemetry();
|
|
45
48
|
}
|
|
46
49
|
/**
|
|
47
50
|
* Select provider based on agent type, profile preferences, and tier rules
|
|
48
51
|
*/ async selectProvider(agentType) {
|
|
52
|
+
let selectedProvider;
|
|
53
|
+
let tierName;
|
|
54
|
+
let source;
|
|
49
55
|
// Step 1: Check agent profile for explicit provider preference
|
|
50
56
|
const profilePreference = this.profileLoader.getProviderPreference(agentType);
|
|
51
57
|
if (profilePreference) {
|
|
52
58
|
// If profile specifies anthropic and subscription has capacity, use it
|
|
53
59
|
if (profilePreference === "anthropic" && this.hasSubscriptionCapacity()) {
|
|
54
60
|
this.consumeSubscription();
|
|
55
|
-
|
|
61
|
+
selectedProvider = "anthropic";
|
|
62
|
+
tierName = "Tier 1: Subscription";
|
|
63
|
+
source = "profile-override-subscription";
|
|
64
|
+
} else {
|
|
65
|
+
// Otherwise respect the profile preference
|
|
66
|
+
selectedProvider = profilePreference;
|
|
67
|
+
tierName = profilePreference === "anthropic" ? "Tier 3: Anthropic Explicit" : "Profile Override";
|
|
68
|
+
source = "profile-override";
|
|
56
69
|
}
|
|
57
|
-
//
|
|
58
|
-
|
|
70
|
+
// Record telemetry
|
|
71
|
+
this.telemetry.recordCounter("provider.request", 1, {
|
|
72
|
+
provider: selectedProvider,
|
|
73
|
+
tier: tierName,
|
|
74
|
+
agentType,
|
|
75
|
+
source
|
|
76
|
+
});
|
|
77
|
+
return selectedProvider;
|
|
59
78
|
}
|
|
60
79
|
// Step 2: Check tier configuration for agent type
|
|
61
80
|
for (const tier of this.tierConfigs){
|
|
@@ -64,16 +83,51 @@ export class TieredProviderRouter {
|
|
|
64
83
|
if (tier.priority === 1 && tier.subscriptionLimit) {
|
|
65
84
|
if (this.hasSubscriptionCapacity()) {
|
|
66
85
|
this.consumeSubscription();
|
|
67
|
-
|
|
86
|
+
selectedProvider = tier.provider;
|
|
87
|
+
tierName = tier.name;
|
|
88
|
+
source = "tier-config-subscription";
|
|
89
|
+
// Record subscription usage gauge
|
|
90
|
+
this.telemetry.recordGauge("subscription.usage", this.subscriptionUsage.used, {
|
|
91
|
+
limit: this.subscriptionUsage.limit.toString(),
|
|
92
|
+
remaining: (this.subscriptionUsage.limit - this.subscriptionUsage.used).toString()
|
|
93
|
+
});
|
|
94
|
+
// Record telemetry
|
|
95
|
+
this.telemetry.recordCounter("provider.request", 1, {
|
|
96
|
+
provider: selectedProvider,
|
|
97
|
+
tier: tierName,
|
|
98
|
+
agentType,
|
|
99
|
+
source
|
|
100
|
+
});
|
|
101
|
+
return selectedProvider;
|
|
68
102
|
}
|
|
69
103
|
continue;
|
|
70
104
|
}
|
|
71
|
-
|
|
105
|
+
selectedProvider = tier.provider;
|
|
106
|
+
tierName = tier.name;
|
|
107
|
+
source = "tier-config";
|
|
108
|
+
// Record telemetry
|
|
109
|
+
this.telemetry.recordCounter("provider.request", 1, {
|
|
110
|
+
provider: selectedProvider,
|
|
111
|
+
tier: tierName,
|
|
112
|
+
agentType,
|
|
113
|
+
source
|
|
114
|
+
});
|
|
115
|
+
return selectedProvider;
|
|
72
116
|
}
|
|
73
117
|
}
|
|
74
118
|
// Step 3: Default fallback to Tier 2 (Z.ai)
|
|
75
119
|
const fallbackTier = this.tierConfigs.find((t)=>t.priority === 2);
|
|
76
|
-
|
|
120
|
+
selectedProvider = fallbackTier?.provider || "zai";
|
|
121
|
+
tierName = fallbackTier?.name || "Tier 2: Z.ai Default";
|
|
122
|
+
source = "fallback";
|
|
123
|
+
// Record telemetry
|
|
124
|
+
this.telemetry.recordCounter("provider.request", 1, {
|
|
125
|
+
provider: selectedProvider,
|
|
126
|
+
tier: tierName,
|
|
127
|
+
agentType,
|
|
128
|
+
source
|
|
129
|
+
});
|
|
130
|
+
return selectedProvider;
|
|
77
131
|
}
|
|
78
132
|
/**
|
|
79
133
|
* Check if subscription has capacity
|
|
@@ -122,8 +176,8 @@ export class TieredProviderRouter {
|
|
|
122
176
|
}
|
|
123
177
|
}
|
|
124
178
|
// ===== FACTORY =====
|
|
125
|
-
export function createTieredRouter(customTiers, initialUsage, agentsDir) {
|
|
126
|
-
return new TieredProviderRouter(customTiers, initialUsage, agentsDir);
|
|
179
|
+
export function createTieredRouter(customTiers, initialUsage, agentsDir, telemetry) {
|
|
180
|
+
return new TieredProviderRouter(customTiers, initialUsage, agentsDir, telemetry);
|
|
127
181
|
}
|
|
128
182
|
|
|
129
183
|
//# sourceMappingURL=tiered-router.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/providers/tiered-router.ts"],"names":["AgentProfileLoader","TIER_CONFIGS","name","provider","agentTypes","priority","subscriptionLimit","TieredProviderRouter","subscriptionUsage","tierConfigs","profileLoader","initialUsage","agentsDir","sort","a","b","used","limit","resetDate","getNextResetDate","selectProvider","agentType","profilePreference","getProviderPreference","hasSubscriptionCapacity","consumeSubscription","tier","includes","fallbackTier","find","t","Date","resetSubscriptionUsage","now","getFullYear","getMonth","getDate","getSubscriptionUsage","getTierForAgentType","getTierConfigs","createTieredRouter","customTiers"],"mappings":"AAAA;;;;CAIC,GAGD,SAASA,kBAAkB,QAAQ,4BAA4B;
|
|
1
|
+
{"version":3,"sources":["../../../../src/providers/tiered-router.ts"],"names":["AgentProfileLoader","getGlobalTelemetry","TIER_CONFIGS","name","provider","agentTypes","priority","subscriptionLimit","TieredProviderRouter","subscriptionUsage","tierConfigs","profileLoader","telemetry","initialUsage","agentsDir","sort","a","b","used","limit","resetDate","getNextResetDate","selectProvider","agentType","selectedProvider","tierName","source","profilePreference","getProviderPreference","hasSubscriptionCapacity","consumeSubscription","recordCounter","tier","includes","recordGauge","toString","remaining","fallbackTier","find","t","Date","resetSubscriptionUsage","now","getFullYear","getMonth","getDate","getSubscriptionUsage","getTierForAgentType","getTierConfigs","createTieredRouter","customTiers"],"mappings":"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"}
|