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.
Files changed (273) hide show
  1. package/.claude/agents/cfn-loop/product-owner.md +54 -4
  2. package/.claude/commands/cfn-claude-sync.md +303 -0
  3. package/.claude/commands/cfn-loop-epic.md +290 -0
  4. package/.claude/commands/cfn-loop-single.md +168 -0
  5. package/.claude/commands/cfn-loop-sprints.md +384 -0
  6. package/.claude/commands/cfn-loop.md +180 -0
  7. package/.claude/commands/metrics-summary.md +58 -0
  8. package/.claude/commands/parse-epic.md +357 -0
  9. package/.claude/settings.json +5 -4
  10. package/.claude/settings.local.json +9 -2
  11. package/.claude-flow-novice/.claude/agents/cfn-loop/product-owner.md +792 -0
  12. package/.claude-flow-novice/dist/mcp/server.js +21 -2
  13. package/.claude-flow-novice/dist/src/api/auth-service.js +84 -38
  14. package/.claude-flow-novice/dist/src/api/auth-service.js.map +1 -1
  15. package/.claude-flow-novice/dist/src/api/claude-client.js +138 -3
  16. package/.claude-flow-novice/dist/src/api/claude-client.js.map +1 -1
  17. package/.claude-flow-novice/dist/src/cfn-loop/phase-orchestrator-example.js +1 -1
  18. package/.claude-flow-novice/dist/src/cfn-loop/scope-control.js +247 -0
  19. package/.claude-flow-novice/dist/src/cfn-loop/scope-control.js.map +1 -0
  20. package/.claude-flow-novice/dist/src/cli/commands/swarm.js +32 -15
  21. package/.claude-flow-novice/dist/src/cli/commands/swarm.js.map +1 -1
  22. package/.claude-flow-novice/dist/src/cli/commands/transparency.js +455 -0
  23. package/.claude-flow-novice/dist/src/cli/commands/transparency.js.map +1 -0
  24. package/.claude-flow-novice/dist/src/cli/simple-commands/init/templates/CLAUDE.md +129 -13
  25. package/.claude-flow-novice/dist/src/components/visualizations/index.js +9 -0
  26. package/.claude-flow-novice/dist/src/components/visualizations/index.js.map +1 -0
  27. package/.claude-flow-novice/dist/src/coordination/adapters/v1-coordinator-adapter.js +462 -0
  28. package/.claude-flow-novice/dist/src/coordination/adapters/v1-coordinator-adapter.js.map +1 -0
  29. package/.claude-flow-novice/dist/src/coordination/config-translator.js +248 -0
  30. package/.claude-flow-novice/dist/src/coordination/config-translator.js.map +1 -0
  31. package/.claude-flow-novice/dist/src/coordination/coordination-toggle.js +287 -0
  32. package/.claude-flow-novice/dist/src/coordination/coordination-toggle.js.map +1 -0
  33. package/.claude-flow-novice/dist/src/coordination/distributed-consensus.js +68 -9
  34. package/.claude-flow-novice/dist/src/coordination/distributed-consensus.js.map +1 -1
  35. package/.claude-flow-novice/dist/src/coordination/feature-flags.js +166 -0
  36. package/.claude-flow-novice/dist/src/coordination/feature-flags.js.map +1 -0
  37. package/.claude-flow-novice/dist/src/coordination/queen-agent.js +18 -4
  38. package/.claude-flow-novice/dist/src/coordination/queen-agent.js.map +1 -1
  39. package/.claude-flow-novice/dist/src/coordination/role-assignment.js +6 -110
  40. package/.claude-flow-novice/dist/src/coordination/role-assignment.js.map +1 -1
  41. package/.claude-flow-novice/dist/src/coordination/v2/cache/artifact-cache-optimizer.js +632 -0
  42. package/.claude-flow-novice/dist/src/coordination/v2/cache/artifact-cache-optimizer.js.map +1 -0
  43. package/.claude-flow-novice/dist/src/coordination/v2/cache/index.js +11 -0
  44. package/.claude-flow-novice/dist/src/coordination/v2/cache/index.js.map +1 -0
  45. package/.claude-flow-novice/dist/src/coordination/v2/checkpoints/checkpoint-compressor.js +318 -0
  46. package/.claude-flow-novice/dist/src/coordination/v2/checkpoints/checkpoint-compressor.js.map +1 -0
  47. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.example.js +364 -0
  48. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.example.js.map +1 -0
  49. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.js +492 -0
  50. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/cascading-shutdown.js.map +1 -0
  51. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/hierarchical-coordinator.js +786 -0
  52. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/hierarchical-coordinator.js.map +1 -0
  53. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/index.js +16 -0
  54. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/index.js.map +1 -0
  55. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/parent-child-manager.js +342 -0
  56. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/parent-child-manager.js.map +1 -0
  57. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/swarm-coordinator-v2.js +601 -0
  58. package/.claude-flow-novice/dist/src/coordination/v2/coordinators/swarm-coordinator-v2.js.map +1 -0
  59. package/.claude-flow-novice/dist/src/coordination/v2/core/help-request-metrics.js +211 -0
  60. package/.claude-flow-novice/dist/src/coordination/v2/core/help-request-metrics.js.map +1 -0
  61. package/.claude-flow-novice/dist/src/coordination/v2/core/index.js +1 -0
  62. package/.claude-flow-novice/dist/src/coordination/v2/core/index.js.map +1 -1
  63. package/.claude-flow-novice/dist/src/coordination/v2/core/message-broker.js +365 -6
  64. package/.claude-flow-novice/dist/src/coordination/v2/core/message-broker.js.map +1 -1
  65. package/.claude-flow-novice/dist/src/coordination/v2/core/resource-manager-safe.js +478 -0
  66. package/.claude-flow-novice/dist/src/coordination/v2/core/resource-manager-safe.js.map +1 -0
  67. package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine-config.js +5 -2
  68. package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine-config.js.map +1 -1
  69. package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine.js +189 -0
  70. package/.claude-flow-novice/dist/src/coordination/v2/core/state-machine.js.map +1 -1
  71. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/deadlock-detector.js +424 -0
  72. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/deadlock-detector.js.map +1 -0
  73. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/index.js +9 -0
  74. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/index.js.map +1 -0
  75. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/resource-manager.js +669 -0
  76. package/.claude-flow-novice/dist/src/coordination/v2/deadlock/resource-manager.js.map +1 -0
  77. package/.claude-flow-novice/dist/src/coordination/v2/dependency/artifact-storage.js +451 -0
  78. package/.claude-flow-novice/dist/src/coordination/v2/dependency/artifact-storage.js.map +1 -0
  79. package/.claude-flow-novice/dist/src/coordination/v2/dependency/cycle-detector.js +271 -0
  80. package/.claude-flow-novice/dist/src/coordination/v2/dependency/cycle-detector.js.map +1 -0
  81. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-graph.js +335 -0
  82. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-graph.js.map +1 -0
  83. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-manager.js +439 -0
  84. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-manager.js.map +1 -0
  85. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-request.js +92 -0
  86. package/.claude-flow-novice/dist/src/coordination/v2/dependency/dependency-request.js.map +1 -0
  87. package/.claude-flow-novice/dist/src/coordination/v2/dependency/index.js +21 -0
  88. package/.claude-flow-novice/dist/src/coordination/v2/dependency/index.js.map +1 -0
  89. package/.claude-flow-novice/dist/src/coordination/v2/dependency/topological-sort.js +223 -0
  90. package/.claude-flow-novice/dist/src/coordination/v2/dependency/topological-sort.js.map +1 -0
  91. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-coordinator.js +436 -0
  92. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-coordinator.js.map +1 -0
  93. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-matcher.js +278 -0
  94. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-matcher.js.map +1 -0
  95. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request-handler.js +317 -0
  96. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request-handler.js.map +1 -0
  97. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request.js +273 -0
  98. package/.claude-flow-novice/dist/src/coordination/v2/help-system/help-request.js.map +1 -0
  99. package/.claude-flow-novice/dist/src/coordination/v2/help-system/index.js +15 -0
  100. package/.claude-flow-novice/dist/src/coordination/v2/help-system/index.js.map +1 -0
  101. package/.claude-flow-novice/dist/src/coordination/v2/help-system/waiting-agent-pool.js +512 -0
  102. package/.claude-flow-novice/dist/src/coordination/v2/help-system/waiting-agent-pool.js.map +1 -0
  103. package/.claude-flow-novice/dist/src/coordination/v2/index.js +6 -0
  104. package/.claude-flow-novice/dist/src/coordination/v2/index.js.map +1 -1
  105. package/.claude-flow-novice/dist/src/coordination/v2/integration/help-deadlock-integration.js +557 -0
  106. package/.claude-flow-novice/dist/src/coordination/v2/integration/help-deadlock-integration.js.map +1 -0
  107. package/.claude-flow-novice/dist/src/coordination/v2/integration/index.js +14 -0
  108. package/.claude-flow-novice/dist/src/coordination/v2/integration/index.js.map +1 -0
  109. package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.example.js +212 -0
  110. package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.example.js.map +1 -0
  111. package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.js +552 -0
  112. package/.claude-flow-novice/dist/src/coordination/v2/integration/message-bus-completion-integration.js.map +1 -0
  113. package/.claude-flow-novice/dist/src/coordination/v2/memory/dependency-storage.js +367 -0
  114. package/.claude-flow-novice/dist/src/coordination/v2/memory/dependency-storage.js.map +1 -0
  115. package/.claude-flow-novice/dist/src/coordination/v2/memory/index.js +1 -0
  116. package/.claude-flow-novice/dist/src/coordination/v2/memory/index.js.map +1 -1
  117. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channel.js +371 -0
  118. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channel.js.map +1 -0
  119. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/dependency-channel.js +355 -0
  120. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/dependency-channel.js.map +1 -0
  121. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/help-channel.js +424 -0
  122. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/help-channel.js.map +1 -0
  123. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/index.js +16 -0
  124. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/index.js.map +1 -0
  125. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/state-channel.js +295 -0
  126. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/state-channel.js.map +1 -0
  127. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/task-channel.js +411 -0
  128. package/.claude-flow-novice/dist/src/coordination/v2/messaging/channels/task-channel.js.map +1 -0
  129. package/.claude-flow-novice/dist/src/coordination/v2/messaging/index.js +14 -0
  130. package/.claude-flow-novice/dist/src/coordination/v2/messaging/index.js.map +1 -0
  131. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-bus.js +387 -0
  132. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-bus.js.map +1 -0
  133. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-persistence.js +589 -0
  134. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-persistence.js.map +1 -0
  135. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-router.js +444 -0
  136. package/.claude-flow-novice/dist/src/coordination/v2/messaging/message-router.js.map +1 -0
  137. package/.claude-flow-novice/dist/src/coordination/v2/sdk/checkpoint-manager.js +29 -8
  138. package/.claude-flow-novice/dist/src/coordination/v2/sdk/checkpoint-manager.js.map +1 -1
  139. package/.claude-flow-novice/dist/src/coordination/v2/sdk/help-coordinator.js +470 -0
  140. package/.claude-flow-novice/dist/src/coordination/v2/sdk/help-coordinator.js.map +1 -0
  141. package/.claude-flow-novice/dist/src/coordination/v2/sdk/hierarchical-background-integration.js +450 -0
  142. package/.claude-flow-novice/dist/src/coordination/v2/sdk/hierarchical-background-integration.js.map +1 -0
  143. package/.claude-flow-novice/dist/src/coordination/v2/sdk/index.js +5 -0
  144. package/.claude-flow-novice/dist/src/coordination/v2/sdk/index.js.map +1 -1
  145. package/.claude-flow-novice/dist/src/coordination/v2/sdk/multi-level-control.js +545 -0
  146. package/.claude-flow-novice/dist/src/coordination/v2/sdk/multi-level-control.js.map +1 -0
  147. package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-controller.js +44 -0
  148. package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-controller.js.map +1 -1
  149. package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-message-integration.js +415 -0
  150. package/.claude-flow-novice/dist/src/coordination/v2/sdk/query-message-integration.js.map +1 -0
  151. package/.claude-flow-novice/dist/src/coordination/v2/sdk/session-pool-optimizer.js +615 -0
  152. package/.claude-flow-novice/dist/src/coordination/v2/sdk/session-pool-optimizer.js.map +1 -0
  153. package/.claude-flow-novice/dist/src/coordination/v2/security/payload-validator.js +259 -0
  154. package/.claude-flow-novice/dist/src/coordination/v2/security/payload-validator.js.map +1 -0
  155. package/.claude-flow-novice/dist/src/coordination/v2/transparency/index.js +17 -0
  156. package/.claude-flow-novice/dist/src/coordination/v2/transparency/index.js.map +1 -0
  157. package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-integration.js +357 -0
  158. package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-integration.js.map +1 -0
  159. package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-system.js +679 -0
  160. package/.claude-flow-novice/dist/src/coordination/v2/transparency/transparency-system.js.map +1 -0
  161. package/.claude-flow-novice/dist/src/core/agent-manager.js +30 -0
  162. package/.claude-flow-novice/dist/src/core/agent-manager.js.map +1 -1
  163. package/.claude-flow-novice/dist/src/mcp/server.js +21 -2
  164. package/.claude-flow-novice/dist/src/mcp/server.js.map +1 -1
  165. package/.claude-flow-novice/dist/src/monitoring/apm/apm-integration.js +719 -0
  166. package/.claude-flow-novice/dist/src/monitoring/apm/apm-integration.js.map +1 -0
  167. package/.claude-flow-novice/dist/src/monitoring/apm/datadog-collector.js +363 -0
  168. package/.claude-flow-novice/dist/src/monitoring/apm/datadog-collector.js.map +1 -0
  169. package/.claude-flow-novice/dist/src/monitoring/apm/index.js +97 -0
  170. package/.claude-flow-novice/dist/src/monitoring/apm/index.js.map +1 -0
  171. package/.claude-flow-novice/dist/src/monitoring/apm/newrelic-collector.js +384 -0
  172. package/.claude-flow-novice/dist/src/monitoring/apm/newrelic-collector.js.map +1 -0
  173. package/.claude-flow-novice/dist/src/monitoring/apm/performance-optimizer.js +612 -0
  174. package/.claude-flow-novice/dist/src/monitoring/apm/performance-optimizer.js.map +1 -0
  175. package/.claude-flow-novice/dist/src/monitoring/metrics-collector.js +282 -0
  176. package/.claude-flow-novice/dist/src/monitoring/metrics-collector.js.map +1 -0
  177. package/.claude-flow-novice/dist/src/observability/metrics-counter.js +268 -0
  178. package/.claude-flow-novice/dist/src/observability/metrics-counter.js.map +1 -0
  179. package/.claude-flow-novice/dist/src/observability/metrics-storage.js +265 -0
  180. package/.claude-flow-novice/dist/src/observability/metrics-storage.js.map +1 -0
  181. package/.claude-flow-novice/dist/src/observability/telemetry.js +26 -0
  182. package/.claude-flow-novice/dist/src/observability/telemetry.js.map +1 -1
  183. package/.claude-flow-novice/dist/src/providers/tiered-router.js +64 -10
  184. package/.claude-flow-novice/dist/src/providers/tiered-router.js.map +1 -1
  185. package/.claude-flow-novice/dist/src/providers/zai-provider.js +196 -97
  186. package/.claude-flow-novice/dist/src/providers/zai-provider.js.map +1 -1
  187. package/.claude-flow-novice/dist/src/slash-commands/cfn-claude-sync.js +533 -0
  188. package/.claude-flow-novice/dist/src/slash-commands/index.js +5 -0
  189. package/.claude-flow-novice/dist/src/slash-commands/metrics-summary-class.js +74 -0
  190. package/.claude-flow-novice/dist/src/slash-commands/metrics-summary.js +335 -0
  191. package/.claude-flow-novice/dist/src/slash-commands/register-all-commands.js +12 -0
  192. package/.claude-flow-novice/dist/src/verification/checkpoint-compression-demo.js +96 -0
  193. package/.claude-flow-novice/dist/src/verification/checkpoint-compression-demo.js.map +1 -0
  194. package/.claude-flow-novice/dist/src/verification/checkpoint-compression.js +406 -0
  195. package/.claude-flow-novice/dist/src/verification/checkpoint-compression.js.map +1 -0
  196. package/.claude-flow-novice/dist/src/verification/checkpoint-manager.js +35 -5
  197. package/.claude-flow-novice/dist/src/verification/checkpoint-manager.js.map +1 -1
  198. package/.claude-flow-novice/dist/src/web/api/apm-routes.js +355 -0
  199. package/.claude-flow-novice/dist/src/web/api/apm-routes.js.map +1 -0
  200. package/.claude-flow-novice/dist/src/web/api/config/api-config.js +186 -0
  201. package/.claude-flow-novice/dist/src/web/api/config/api-config.js.map +1 -0
  202. package/.claude-flow-novice/dist/src/web/api/middleware/auth.js +205 -0
  203. package/.claude-flow-novice/dist/src/web/api/middleware/auth.js.map +1 -0
  204. package/.claude-flow-novice/dist/src/web/api/middleware/cache.js +262 -0
  205. package/.claude-flow-novice/dist/src/web/api/middleware/cache.js.map +1 -0
  206. package/.claude-flow-novice/dist/src/web/api/middleware/error-handler.js +250 -0
  207. package/.claude-flow-novice/dist/src/web/api/middleware/error-handler.js.map +1 -0
  208. package/.claude-flow-novice/dist/src/web/api/middleware/request-logger.js +217 -0
  209. package/.claude-flow-novice/dist/src/web/api/middleware/request-logger.js.map +1 -0
  210. package/.claude-flow-novice/dist/src/web/api/middleware/validation.js +325 -0
  211. package/.claude-flow-novice/dist/src/web/api/middleware/validation.js.map +1 -0
  212. package/.claude-flow-novice/dist/src/web/api/routes/events.js +465 -0
  213. package/.claude-flow-novice/dist/src/web/api/routes/events.js.map +1 -0
  214. package/.claude-flow-novice/dist/src/web/api/routes/hierarchy.js +302 -0
  215. package/.claude-flow-novice/dist/src/web/api/routes/hierarchy.js.map +1 -0
  216. package/.claude-flow-novice/dist/src/web/api/routes/index.js +14 -0
  217. package/.claude-flow-novice/dist/src/web/api/routes/index.js.map +1 -0
  218. package/.claude-flow-novice/dist/src/web/api/routes/metrics.js +561 -0
  219. package/.claude-flow-novice/dist/src/web/api/routes/metrics.js.map +1 -0
  220. package/.claude-flow-novice/dist/src/web/api/routes/status.js +450 -0
  221. package/.claude-flow-novice/dist/src/web/api/routes/status.js.map +1 -0
  222. package/.claude-flow-novice/dist/src/web/api/server.js +451 -0
  223. package/.claude-flow-novice/dist/src/web/api/server.js.map +1 -0
  224. package/.claude-flow-novice/dist/src/web/dashboard/hooks/useWebSocket.js +385 -0
  225. package/.claude-flow-novice/dist/src/web/dashboard/hooks/useWebSocket.js.map +1 -0
  226. package/.claude-flow-novice/dist/src/web/dashboard/index.js +87 -0
  227. package/.claude-flow-novice/dist/src/web/dashboard/index.js.map +1 -0
  228. package/.claude-flow-novice/dist/src/web/dashboard/types.js +6 -0
  229. package/.claude-flow-novice/dist/src/web/dashboard/types.js.map +1 -0
  230. package/.claude-flow-novice/dist/src/web/frontend/src/utils/security.js +425 -0
  231. package/.claude-flow-novice/dist/src/web/frontend/src/utils/security.js.map +1 -0
  232. package/.claude-flow-novice/dist/src/web/security/security-middleware.js +379 -0
  233. package/.claude-flow-novice/dist/src/web/security/security-middleware.js.map +1 -0
  234. package/.claude-flow-novice/dist/src/web/websocket/apm-websocket-handler.js +441 -0
  235. package/.claude-flow-novice/dist/src/web/websocket/apm-websocket-handler.js.map +1 -0
  236. package/.claude-flow-novice/dist/src/web/websocket/websocket-manager.js +255 -1
  237. package/.claude-flow-novice/dist/src/web/websocket/websocket-manager.js.map +1 -1
  238. package/.claude-flow-novice/metrics.db +0 -0
  239. package/.claude-flow-novice/metrics.db-shm +0 -0
  240. package/.claude-flow-novice/metrics.db-wal +0 -0
  241. package/AGENT_PERFORMANCE_GUIDELINES.md +88 -0
  242. package/CLAUDE.md +60 -3
  243. package/MEMORY_LEAK_ROOT_CAUSE.md +149 -0
  244. package/README.md +27 -0
  245. package/config/hooks/post-edit-pipeline.js +36 -2
  246. package/examples/metrics-counter-demo.ts +106 -0
  247. package/examples/persistent-metrics-demo.ts +83 -0
  248. package/examples/phase-5-multi-level-control.ts +282 -0
  249. package/examples/session-pool-optimizer-example.ts +311 -0
  250. package/package.json +18 -4
  251. package/scripts/check-routing-stats.cjs +122 -0
  252. package/scripts/monitor-loop.sh +65 -0
  253. package/scripts/monitor-memory.sh +47 -0
  254. package/scripts/monitor.py +43 -0
  255. package/scripts/pre-publish-validation.cjs +212 -0
  256. package/scripts/test-provider-routing.cjs +228 -0
  257. package/scripts/test-routing-telemetry.cjs +147 -0
  258. package/scripts/test-zai-10k.cjs +81 -0
  259. package/scripts/test-zai-api.cjs +191 -0
  260. package/scripts/test-zai-diagnostic.cjs +151 -0
  261. package/scripts/test-zai-final.cjs +128 -0
  262. package/scripts/test-zai-with-env.cjs +85 -0
  263. package/scripts/validate-coordination-cli.js +69 -0
  264. package/scripts/validate-coordination-toggle-integration.cjs +501 -0
  265. package/src/cli/simple-commands/init/templates/CLAUDE.md +29 -0
  266. package/src/observability/metrics-counter.ts +347 -0
  267. package/src/observability/metrics-storage.ts +356 -0
  268. package/src/observability/telemetry.ts +658 -0
  269. package/src/slash-commands/cfn-claude-sync.js +533 -0
  270. package/src/slash-commands/index.js +5 -0
  271. package/src/slash-commands/metrics-summary-class.js +74 -0
  272. package/src/slash-commands/metrics-summary.js +335 -0
  273. 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: "custom",
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
- constructor(tierConfigs = TIER_CONFIGS, initialUsage = {}, agentsDir){
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
- return "anthropic";
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
- // Otherwise respect the profile preference
58
- return profilePreference;
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
- return tier.provider;
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
- return tier.provider;
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
- return fallbackTier?.provider || "custom"; // "custom" maps to Z.ai
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":"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"}
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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"}