claude-flow-novice 2.10.5 → 2.10.7

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 (694) hide show
  1. package/.claude/hooks/cfn-invoke-security-validation.sh +70 -0
  2. package/.claude/skills/cfn-hybrid-routing/spawn-worker.sh +43 -43
  3. package/claude-assets/agents/AGENT_LIFECYCLE.md +530 -0
  4. package/claude-assets/agents/README-VALIDATION.md +243 -0
  5. package/claude-assets/agents/cfn-dev-team/dev-ops/docker-specialist.md +692 -0
  6. package/claude-assets/agents/cfn-dev-team/dev-ops/monitoring-specialist.md +739 -0
  7. package/claude-assets/agents/cfn-dev-team/developers/api-gateway-specialist.md +905 -0
  8. package/claude-assets/agents/cfn-dev-team/testers/api-testing-specialist.md +707 -0
  9. package/claude-assets/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +901 -0
  10. package/claude-assets/agents/cfn-dev-team/utility/memory-leak-specialist.md +757 -0
  11. package/claude-assets/agents/cfn-dev-team/utility/z-ai-specialist.md +630 -0
  12. package/claude-assets/agents/custom/claude-code-expert.md +144 -0
  13. package/claude-assets/agents/custom/test-mcp-access.md +26 -0
  14. package/claude-assets/agents/docker-team/csuite/c-suite-template.md +529 -0
  15. package/claude-assets/agents/docker-team/infrastructure/team-coordinator-template.md +467 -0
  16. package/claude-assets/agents/project-only-agents/npm-package-specialist.md +347 -0
  17. package/claude-assets/agents/validate-agent.js +841 -0
  18. package/claude-assets/commands/agents/README.md +10 -0
  19. package/claude-assets/commands/agents/agent-capabilities.md +21 -0
  20. package/claude-assets/commands/agents/agent-coordination.md +28 -0
  21. package/claude-assets/commands/agents/agent-spawning.md +28 -0
  22. package/claude-assets/commands/agents/agent-types.md +26 -0
  23. package/claude-assets/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
  24. package/claude-assets/commands/analysis/README.md +9 -0
  25. package/claude-assets/commands/analysis/bottleneck-detect.md +162 -0
  26. package/claude-assets/commands/analysis/performance-bottlenecks.md +59 -0
  27. package/claude-assets/commands/analysis/performance-report.md +25 -0
  28. package/claude-assets/commands/analysis/token-efficiency.md +45 -0
  29. package/claude-assets/commands/analysis/token-usage.md +25 -0
  30. package/claude-assets/commands/automation/README.md +9 -0
  31. package/claude-assets/commands/automation/auto-agent.md +122 -0
  32. package/claude-assets/commands/automation/self-healing.md +106 -0
  33. package/claude-assets/commands/automation/session-memory.md +90 -0
  34. package/claude-assets/commands/automation/smart-agents.md +73 -0
  35. package/claude-assets/commands/automation/smart-spawn.md +25 -0
  36. package/claude-assets/commands/automation/workflow-select.md +25 -0
  37. package/claude-assets/commands/cfn/CFN_COORDINATOR_PARAMETERS.md +660 -0
  38. package/claude-assets/commands/cfn/CFN_LOOP_FRONTEND.md +741 -0
  39. package/claude-assets/commands/cfn/CFN_LOOP_TASK_MODE.md +353 -0
  40. package/claude-assets/commands/cfn/README.md +157 -0
  41. package/claude-assets/commands/cfn/auto-compact.md +80 -0
  42. package/claude-assets/commands/cfn/cfn-claude-sync.md +303 -0
  43. package/claude-assets/commands/cfn/cfn-loop-document.md +480 -0
  44. package/claude-assets/commands/cfn/cfn-loop-epic.md +478 -0
  45. package/claude-assets/commands/cfn/cfn-loop-frontend.md +555 -0
  46. package/claude-assets/commands/cfn/cfn-loop-single.md +256 -0
  47. package/claude-assets/commands/cfn/cfn-loop-sprints.md +396 -0
  48. package/claude-assets/commands/cfn/cfn-loop.md +517 -0
  49. package/claude-assets/commands/cfn/cfn-mode.md +20 -0
  50. package/claude-assets/commands/cfn/cfn-optimize-agents.md +103 -0
  51. package/claude-assets/commands/cfn/claude-md.md +64 -0
  52. package/claude-assets/commands/cfn/claude-soul.md +22 -0
  53. package/claude-assets/commands/cfn/context-curate.md +211 -0
  54. package/claude-assets/commands/cfn/context-inject.md +262 -0
  55. package/claude-assets/commands/cfn/context-query.md +215 -0
  56. package/claude-assets/commands/cfn/context-reflect.md +165 -0
  57. package/claude-assets/commands/cfn/context-stats.md +294 -0
  58. package/claude-assets/commands/cfn/cost-savings-off.md +35 -0
  59. package/claude-assets/commands/cfn/cost-savings-on.md +35 -0
  60. package/claude-assets/commands/cfn/cost-savings-status.md +34 -0
  61. package/claude-assets/commands/cfn/custom-routing-activate.md +55 -0
  62. package/claude-assets/commands/cfn/custom-routing-deactivate.md +46 -0
  63. package/claude-assets/commands/cfn/dependency-recommendations.md +171 -0
  64. package/claude-assets/commands/cfn/fullstack.md +179 -0
  65. package/claude-assets/commands/cfn/github-commit.md +289 -0
  66. package/claude-assets/commands/cfn/github.md +221 -0
  67. package/claude-assets/commands/cfn/hello-world-tests.md +381 -0
  68. package/claude-assets/commands/cfn/hooks.md +38 -0
  69. package/claude-assets/commands/cfn/launch-web-dashboard.md +295 -0
  70. package/claude-assets/commands/cfn/list-agents-rebuild.md +205 -0
  71. package/claude-assets/commands/cfn/metrics-summary.md +58 -0
  72. package/claude-assets/commands/cfn/neural.md +39 -0
  73. package/claude-assets/commands/cfn/parse-epic.md +357 -0
  74. package/claude-assets/commands/cfn/performance.md +41 -0
  75. package/claude-assets/commands/cfn/sparc.md +46 -0
  76. package/claude-assets/commands/cfn/suggest-improvements.md +95 -0
  77. package/claude-assets/commands/cfn/suggest-templates.md +147 -0
  78. package/claude-assets/commands/cfn/swarm.md +24 -0
  79. package/claude-assets/commands/cfn/switch-api.md +53 -0
  80. package/claude-assets/commands/cfn/workflow.md +295 -0
  81. package/claude-assets/commands/cfn/write-plan.md +104 -0
  82. package/claude-assets/commands/claude-md.js +237 -0
  83. package/claude-assets/commands/claude-soul.js +28 -0
  84. package/claude-assets/commands/cli-integration.js +216 -0
  85. package/claude-assets/commands/coordination/README.md +9 -0
  86. package/claude-assets/commands/coordination/agent-spawn.md +25 -0
  87. package/claude-assets/commands/coordination/coordination-system.md +88 -0
  88. package/claude-assets/commands/coordination/init.md +44 -0
  89. package/claude-assets/commands/coordination/orchestrate.md +43 -0
  90. package/claude-assets/commands/coordination/spawn.md +45 -0
  91. package/claude-assets/commands/coordination/swarm-init.md +85 -0
  92. package/claude-assets/commands/coordination/task-orchestrate.md +25 -0
  93. package/claude-assets/commands/github/README.md +11 -0
  94. package/claude-assets/commands/github/code-review-swarm.md +514 -0
  95. package/claude-assets/commands/github/code-review.md +25 -0
  96. package/claude-assets/commands/github/github-modes.md +147 -0
  97. package/claude-assets/commands/github/github-swarm.md +121 -0
  98. package/claude-assets/commands/github/issue-tracker.md +292 -0
  99. package/claude-assets/commands/github/issue-triage.md +25 -0
  100. package/claude-assets/commands/github/multi-repo-swarm.md +519 -0
  101. package/claude-assets/commands/github/pr-enhance.md +26 -0
  102. package/claude-assets/commands/github/pr-manager.md +170 -0
  103. package/claude-assets/commands/github/project-board-sync.md +471 -0
  104. package/claude-assets/commands/github/release-manager.md +338 -0
  105. package/claude-assets/commands/github/release-swarm.md +544 -0
  106. package/claude-assets/commands/github/repo-analyze.md +25 -0
  107. package/claude-assets/commands/github/repo-architect.md +367 -0
  108. package/claude-assets/commands/github/swarm-issue.md +482 -0
  109. package/claude-assets/commands/github/swarm-pr.md +285 -0
  110. package/claude-assets/commands/github/sync-coordinator.md +301 -0
  111. package/claude-assets/commands/github/workflow-automation.md +442 -0
  112. package/claude-assets/commands/github.js +638 -0
  113. package/claude-assets/commands/hive-mind/README.md +17 -0
  114. package/claude-assets/commands/hive-mind/hive-mind-consensus.md +8 -0
  115. package/claude-assets/commands/hive-mind/hive-mind-init.md +18 -0
  116. package/claude-assets/commands/hive-mind/hive-mind-memory.md +8 -0
  117. package/claude-assets/commands/hive-mind/hive-mind-metrics.md +8 -0
  118. package/claude-assets/commands/hive-mind/hive-mind-resume.md +8 -0
  119. package/claude-assets/commands/hive-mind/hive-mind-sessions.md +8 -0
  120. package/claude-assets/commands/hive-mind/hive-mind-spawn.md +21 -0
  121. package/claude-assets/commands/hive-mind/hive-mind-status.md +8 -0
  122. package/claude-assets/commands/hive-mind/hive-mind-stop.md +8 -0
  123. package/claude-assets/commands/hive-mind/hive-mind-wizard.md +8 -0
  124. package/claude-assets/commands/hive-mind/hive-mind.md +27 -0
  125. package/claude-assets/commands/hooks/README.md +11 -0
  126. package/claude-assets/commands/hooks/overview.md +58 -0
  127. package/claude-assets/commands/hooks/post-edit.md +117 -0
  128. package/claude-assets/commands/hooks/post-task.md +112 -0
  129. package/claude-assets/commands/hooks/pre-edit.md +113 -0
  130. package/claude-assets/commands/hooks/pre-task.md +111 -0
  131. package/claude-assets/commands/hooks/session-end.md +118 -0
  132. package/claude-assets/commands/hooks/session-start.md +9 -0
  133. package/claude-assets/commands/hooks/setup.md +103 -0
  134. package/claude-assets/commands/hooks.js +651 -0
  135. package/claude-assets/commands/index.js +119 -0
  136. package/claude-assets/commands/memory/README.md +9 -0
  137. package/claude-assets/commands/memory/memory-bank.md +58 -0
  138. package/claude-assets/commands/memory/memory-persist.md +25 -0
  139. package/claude-assets/commands/memory/memory-search.md +25 -0
  140. package/claude-assets/commands/memory/memory-usage.md +25 -0
  141. package/claude-assets/commands/memory/neural.md +47 -0
  142. package/claude-assets/commands/memory/usage.md +46 -0
  143. package/claude-assets/commands/monitoring/README.md +9 -0
  144. package/claude-assets/commands/monitoring/agent-metrics.md +25 -0
  145. package/claude-assets/commands/monitoring/agents.md +44 -0
  146. package/claude-assets/commands/monitoring/real-time-view.md +25 -0
  147. package/claude-assets/commands/monitoring/status.md +46 -0
  148. package/claude-assets/commands/monitoring/swarm-monitor.md +25 -0
  149. package/claude-assets/commands/neural.js +572 -0
  150. package/claude-assets/commands/optimization/README.md +9 -0
  151. package/claude-assets/commands/optimization/auto-topology.md +62 -0
  152. package/claude-assets/commands/optimization/cache-manage.md +25 -0
  153. package/claude-assets/commands/optimization/parallel-execute.md +25 -0
  154. package/claude-assets/commands/optimization/parallel-execution.md +50 -0
  155. package/claude-assets/commands/optimization/topology-optimize.md +25 -0
  156. package/claude-assets/commands/pair/README.md +261 -0
  157. package/claude-assets/commands/pair/commands.md +546 -0
  158. package/claude-assets/commands/pair/config.md +510 -0
  159. package/claude-assets/commands/pair/examples.md +512 -0
  160. package/claude-assets/commands/pair/modes.md +348 -0
  161. package/claude-assets/commands/pair/session.md +407 -0
  162. package/claude-assets/commands/pair/start.md +209 -0
  163. package/claude-assets/commands/parse-epic.js +180 -0
  164. package/claude-assets/commands/performance.js +582 -0
  165. package/claude-assets/commands/register-all-commands.js +320 -0
  166. package/claude-assets/commands/register-claude-md.js +82 -0
  167. package/claude-assets/commands/register-claude-soul.js +80 -0
  168. package/claude-assets/commands/sparc/analyzer.md +52 -0
  169. package/claude-assets/commands/sparc/architect.md +53 -0
  170. package/claude-assets/commands/sparc/batch-executor.md +54 -0
  171. package/claude-assets/commands/sparc/coder.md +54 -0
  172. package/claude-assets/commands/sparc/debugger.md +54 -0
  173. package/claude-assets/commands/sparc/designer.md +53 -0
  174. package/claude-assets/commands/sparc/documenter.md +54 -0
  175. package/claude-assets/commands/sparc/innovator.md +54 -0
  176. package/claude-assets/commands/sparc/memory-manager.md +54 -0
  177. package/claude-assets/commands/sparc/optimizer.md +54 -0
  178. package/claude-assets/commands/sparc/orchestrator.md +132 -0
  179. package/claude-assets/commands/sparc/researcher.md +54 -0
  180. package/claude-assets/commands/sparc/reviewer.md +54 -0
  181. package/claude-assets/commands/sparc/sparc-modes.md +174 -0
  182. package/claude-assets/commands/sparc/swarm-coordinator.md +54 -0
  183. package/claude-assets/commands/sparc/tdd.md +54 -0
  184. package/claude-assets/commands/sparc/tester.md +54 -0
  185. package/claude-assets/commands/sparc/workflow-manager.md +54 -0
  186. package/claude-assets/commands/sparc.js +110 -0
  187. package/claude-assets/commands/stream-chain/pipeline.md +121 -0
  188. package/claude-assets/commands/stream-chain/run.md +70 -0
  189. package/claude-assets/commands/swarm/README.md +15 -0
  190. package/claude-assets/commands/swarm/analysis.md +95 -0
  191. package/claude-assets/commands/swarm/development.md +96 -0
  192. package/claude-assets/commands/swarm/examples.md +168 -0
  193. package/claude-assets/commands/swarm/maintenance.md +102 -0
  194. package/claude-assets/commands/swarm/optimization.md +117 -0
  195. package/claude-assets/commands/swarm/research.md +136 -0
  196. package/claude-assets/commands/swarm/swarm-analysis.md +8 -0
  197. package/claude-assets/commands/swarm/swarm-background.md +8 -0
  198. package/claude-assets/commands/swarm/swarm-init.md +19 -0
  199. package/claude-assets/commands/swarm/swarm-modes.md +8 -0
  200. package/claude-assets/commands/swarm/swarm-monitor.md +8 -0
  201. package/claude-assets/commands/swarm/swarm-spawn.md +19 -0
  202. package/claude-assets/commands/swarm/swarm-status.md +8 -0
  203. package/claude-assets/commands/swarm/swarm-strategies.md +8 -0
  204. package/claude-assets/commands/swarm/swarm.md +27 -0
  205. package/claude-assets/commands/swarm/testing.md +131 -0
  206. package/claude-assets/commands/swarm.js +423 -0
  207. package/claude-assets/commands/testing/playwright-e2e.md +288 -0
  208. package/claude-assets/commands/training/README.md +9 -0
  209. package/claude-assets/commands/training/model-update.md +25 -0
  210. package/claude-assets/commands/training/neural-patterns.md +74 -0
  211. package/claude-assets/commands/training/neural-train.md +25 -0
  212. package/claude-assets/commands/training/pattern-learn.md +25 -0
  213. package/claude-assets/commands/training/specialization.md +63 -0
  214. package/claude-assets/commands/truth/start.md +143 -0
  215. package/claude-assets/commands/validate-commands.js +223 -0
  216. package/claude-assets/commands/verify/check.md +50 -0
  217. package/claude-assets/commands/verify/start.md +128 -0
  218. package/claude-assets/commands/workflow.js +606 -0
  219. package/claude-assets/commands/workflows/README.md +9 -0
  220. package/claude-assets/commands/workflows/development.md +78 -0
  221. package/claude-assets/commands/workflows/research.md +63 -0
  222. package/claude-assets/commands/workflows/workflow-create.md +25 -0
  223. package/claude-assets/commands/workflows/workflow-execute.md +25 -0
  224. package/claude-assets/commands/workflows/workflow-export.md +25 -0
  225. package/claude-assets/hooks/cfn-BACKUP_USAGE.md +243 -0
  226. package/claude-assets/hooks/cfn-invoke-post-edit.sh +87 -0
  227. package/claude-assets/hooks/cfn-invoke-security-validation.sh +70 -0
  228. package/claude-assets/hooks/cfn-post-edit-cfn-retrospective.sh +79 -0
  229. package/claude-assets/hooks/cfn-post-edit.config.json +37 -0
  230. package/claude-assets/hooks/cfn-post-edit.sh +21 -0
  231. package/claude-assets/hooks/cfn-pre-edit-backup.sh +71 -0
  232. package/claude-assets/hooks/cfn-restore-from-backup.sh +37 -0
  233. package/claude-assets/hooks/post-edit.config.json +12 -0
  234. package/claude-assets/root-claude-distribute/CFN-CLAUDE.md +796 -0
  235. package/claude-assets/skills/CFN-LOOP-VALIDATION.md +202 -0
  236. package/claude-assets/skills/REDIS-COORDINATION.md +187 -0
  237. package/claude-assets/skills/SKILL.md +229 -0
  238. package/claude-assets/skills/agent-discovery/agents-registry.json +484 -0
  239. package/claude-assets/skills/cfn-ace-system/SKILL.md +364 -0
  240. package/claude-assets/skills/cfn-ace-system/add-bullet.sh +145 -0
  241. package/claude-assets/skills/cfn-ace-system/analyze-anti-pattern-effectiveness.sh +56 -0
  242. package/claude-assets/skills/cfn-ace-system/classify-task.sh +18 -0
  243. package/claude-assets/skills/cfn-ace-system/export-ace-metrics.sh +48 -0
  244. package/claude-assets/skills/cfn-ace-system/extract-tags.sh +385 -0
  245. package/claude-assets/skills/cfn-ace-system/format-negative-context.sh +180 -0
  246. package/claude-assets/skills/cfn-ace-system/init-indexes.sql +160 -0
  247. package/claude-assets/skills/cfn-ace-system/invoke-context-curate.sh +192 -0
  248. package/claude-assets/skills/cfn-ace-system/invoke-context-inject.sh +361 -0
  249. package/claude-assets/skills/cfn-ace-system/invoke-context-query.sh +139 -0
  250. package/claude-assets/skills/cfn-ace-system/invoke-context-reflect.sh +343 -0
  251. package/claude-assets/skills/cfn-ace-system/invoke-context-stats.sh +227 -0
  252. package/claude-assets/skills/cfn-ace-system/log-merge.sh +67 -0
  253. package/claude-assets/skills/cfn-ace-system/monitor-injection-performance.sh +138 -0
  254. package/claude-assets/skills/cfn-ace-system/optimize-injection-pipeline.sh +169 -0
  255. package/claude-assets/skills/cfn-ace-system/query-anti-patterns.sh +276 -0
  256. package/claude-assets/skills/cfn-ace-system/query-contexts.sh +150 -0
  257. package/claude-assets/skills/cfn-ace-system/query-reflections.sh +35 -0
  258. package/claude-assets/skills/cfn-ace-system/schema/001-create-context-reflections.sql +237 -0
  259. package/claude-assets/skills/cfn-ace-system/schema/README.md +723 -0
  260. package/claude-assets/skills/cfn-ace-system/schema/SCHEMA_DESIGN_SUMMARY.md +564 -0
  261. package/claude-assets/skills/cfn-ace-system/schema/populate-test-data-simple.sh +62 -0
  262. package/claude-assets/skills/cfn-ace-system/schema/populate-test-data.sh +247 -0
  263. package/claude-assets/skills/cfn-ace-system/schema/run-migration.sh +231 -0
  264. package/claude-assets/skills/cfn-ace-system/schema/validate-schema.sql +280 -0
  265. package/claude-assets/skills/cfn-ace-system/score-relevance-adapter.sh +138 -0
  266. package/claude-assets/skills/cfn-ace-system/score-relevance.sh +253 -0
  267. package/claude-assets/skills/cfn-ace-system/sprint-7-lessons.json +46 -0
  268. package/claude-assets/skills/cfn-ace-system/store-reflection.sh +46 -0
  269. package/claude-assets/skills/cfn-ace-system/test-ace-skill.sh +312 -0
  270. package/claude-assets/skills/cfn-ace-system/track-ab-test.sh +42 -0
  271. package/claude-assets/skills/cfn-ace-system/update-reflection.sh +41 -0
  272. package/claude-assets/skills/cfn-agent-discovery/SKILL.md +40 -0
  273. package/claude-assets/skills/cfn-agent-discovery/agents-registry-clean.json +0 -0
  274. package/claude-assets/skills/cfn-agent-discovery/agents-registry-fixed.json +19 -0
  275. package/claude-assets/skills/cfn-agent-discovery/agents-registry.json +718 -0
  276. package/claude-assets/skills/cfn-agent-discovery/discover-agents.py +184 -0
  277. package/claude-assets/skills/cfn-agent-discovery/discover-agents.sh +87 -0
  278. package/claude-assets/skills/cfn-agent-discovery/invoke-registry.sh +11 -0
  279. package/claude-assets/skills/cfn-agent-discovery/temp_script.py +0 -0
  280. package/claude-assets/skills/cfn-agent-execution/execute-agent.sh +126 -0
  281. package/claude-assets/skills/cfn-agent-output-processing/SKILL.md +359 -0
  282. package/claude-assets/skills/cfn-agent-selector/SKILL.md +90 -0
  283. package/claude-assets/skills/cfn-agent-selector/select-agents.sh +112 -0
  284. package/claude-assets/skills/cfn-agent-spawning/README.md +140 -0
  285. package/claude-assets/skills/cfn-agent-spawning/SKILL.md +135 -0
  286. package/claude-assets/skills/cfn-agent-spawning/agent-selection-guide.md +814 -0
  287. package/claude-assets/skills/cfn-agent-spawning/check-dependencies.sh +30 -0
  288. package/claude-assets/skills/cfn-agent-spawning/spawn-agent.sh +263 -0
  289. package/claude-assets/skills/cfn-agent-spawning/spawn-templates.sh +613 -0
  290. package/claude-assets/skills/cfn-agent-swap/SKILL.md +36 -0
  291. package/claude-assets/skills/cfn-agent-swap/recommend-swap.sh +60 -0
  292. package/claude-assets/skills/cfn-analytics/README.md +58 -0
  293. package/claude-assets/skills/cfn-analytics/description-refinement-guide.md +164 -0
  294. package/claude-assets/skills/cfn-analytics/log-skill-invocation.js +122 -0
  295. package/claude-assets/skills/cfn-analytics/run-production-criteria-tests.sh +126 -0
  296. package/claude-assets/skills/cfn-analytics/skill-analytics-dashboard.js +113 -0
  297. package/claude-assets/skills/cfn-analytics/skill-invocation-hook.sh +28 -0
  298. package/claude-assets/skills/cfn-analytics/skill-invocations.sql +58 -0
  299. package/claude-assets/skills/cfn-analytics/test-corpus.json +32 -0
  300. package/claude-assets/skills/cfn-analytics/test-data-generator.js +115 -0
  301. package/claude-assets/skills/cfn-analytics/test-manual-override-rate.js +285 -0
  302. package/claude-assets/skills/cfn-analytics/validate-skill-selection.js +188 -0
  303. package/claude-assets/skills/cfn-api-validation/test-endpoints.sh +54 -0
  304. package/claude-assets/skills/cfn-automatic-memory-persistence/SKILL.md +73 -0
  305. package/claude-assets/skills/cfn-automatic-memory-persistence/persist-agent-output.sh +49 -0
  306. package/claude-assets/skills/cfn-automatic-memory-persistence/query-agent-history.sh +35 -0
  307. package/claude-assets/skills/cfn-automatic-memory-persistence/test-memory-persistence.sh +235 -0
  308. package/claude-assets/skills/cfn-complexity-estimator/SKILL.md +96 -0
  309. package/claude-assets/skills/cfn-complexity-estimator/estimate-complexity.sh +144 -0
  310. package/claude-assets/skills/cfn-config-management/README.md +42 -0
  311. package/claude-assets/skills/cfn-config-management/SKILL.md +34 -0
  312. package/claude-assets/skills/cfn-config-management/check-dependencies.sh +56 -0
  313. package/claude-assets/skills/cfn-config-management/config.json +32 -0
  314. package/claude-assets/skills/cfn-config-management/manage-config.sh +113 -0
  315. package/claude-assets/skills/cfn-context-pruner/SKILL.md +75 -0
  316. package/claude-assets/skills/cfn-context-pruner/prune-context.sh +73 -0
  317. package/claude-assets/skills/cfn-defense-in-depth/SKILL.md +133 -0
  318. package/claude-assets/skills/cfn-dependency-extractor/SKILL.md +35 -0
  319. package/claude-assets/skills/cfn-dependency-extractor/extract-dependencies.sh +66 -0
  320. package/claude-assets/skills/cfn-epic-decomposer/SKILL.md +44 -0
  321. package/claude-assets/skills/cfn-epic-decomposer/decompose-epic.sh +104 -0
  322. package/claude-assets/skills/cfn-event-bus/README.md +299 -0
  323. package/claude-assets/skills/cfn-event-bus/SKILL.md +412 -0
  324. package/claude-assets/skills/cfn-event-bus/config.json +111 -0
  325. package/claude-assets/skills/cfn-event-bus/eventbus-wrapper.cjs +69 -0
  326. package/claude-assets/skills/cfn-event-bus/invoke-event-publish.sh +147 -0
  327. package/claude-assets/skills/cfn-event-bus/invoke-event-subscribe.sh +171 -0
  328. package/claude-assets/skills/cfn-event-bus/invoke-lifecycle-track.sh +201 -0
  329. package/claude-assets/skills/cfn-event-bus/test-event-bus.sh +280 -0
  330. package/claude-assets/skills/cfn-fleet-manager/README.md +74 -0
  331. package/claude-assets/skills/cfn-fleet-manager/SKILL.md +412 -0
  332. package/claude-assets/skills/cfn-fleet-manager/config.json +60 -0
  333. package/claude-assets/skills/cfn-fleet-manager/invoke-fleet-allocate.sh +182 -0
  334. package/claude-assets/skills/cfn-fleet-manager/invoke-fleet-balance.sh +239 -0
  335. package/claude-assets/skills/cfn-fleet-manager/invoke-fleet-metrics.sh +193 -0
  336. package/claude-assets/skills/cfn-fleet-manager/invoke-fleet-register.sh +124 -0
  337. package/claude-assets/skills/cfn-fleet-manager/test-fleet-manager.sh +345 -0
  338. package/claude-assets/skills/cfn-hook-pipeline/README.md +74 -0
  339. package/claude-assets/skills/cfn-hook-pipeline/SKILL.md +148 -0
  340. package/claude-assets/skills/cfn-hook-pipeline/auto-resolve.sh +66 -0
  341. package/claude-assets/skills/cfn-hook-pipeline/check-dependencies.sh +40 -0
  342. package/claude-assets/skills/cfn-hook-pipeline/feedback-resolver.sh +452 -0
  343. package/claude-assets/skills/cfn-hook-pipeline/post-edit-handler.sh +154 -0
  344. package/claude-assets/skills/cfn-hook-pipeline/security-scan.json +60 -0
  345. package/claude-assets/skills/cfn-hook-pipeline/security-scanner.sh +121 -0
  346. package/claude-assets/skills/cfn-hook-pipeline/test-root-warning-resolution.sh +148 -0
  347. package/claude-assets/skills/cfn-hybrid-routing/README.md +50 -0
  348. package/claude-assets/skills/cfn-hybrid-routing/SKILL.md +46 -0
  349. package/claude-assets/skills/cfn-hybrid-routing/check-dependencies.sh +52 -0
  350. package/claude-assets/skills/cfn-hybrid-routing/config.json +26 -0
  351. package/claude-assets/skills/cfn-hybrid-routing/spawn-worker.sh +44 -0
  352. package/claude-assets/skills/cfn-improvement-recommender/SKILL.md +33 -0
  353. package/claude-assets/skills/cfn-improvement-recommender/recommend-improvements.sh +92 -0
  354. package/claude-assets/skills/cfn-intervention-detector/SKILL.md +39 -0
  355. package/claude-assets/skills/cfn-intervention-detector/detect-intervention.sh +111 -0
  356. package/claude-assets/skills/cfn-intervention-orchestrator/SKILL.md +43 -0
  357. package/claude-assets/skills/cfn-intervention-orchestrator/execute-intervention.sh +59 -0
  358. package/claude-assets/skills/cfn-loop-orchestration/README.md +41 -0
  359. package/claude-assets/skills/cfn-loop-orchestration/SKILL.md +299 -0
  360. package/claude-assets/skills/cfn-loop-orchestration/helpers/auto-tune-timeouts.sh +228 -0
  361. package/claude-assets/skills/cfn-loop-orchestration/helpers/consensus.sh +84 -0
  362. package/claude-assets/skills/cfn-loop-orchestration/helpers/context-injection.sh +142 -0
  363. package/claude-assets/skills/cfn-loop-orchestration/helpers/context-lookup.sh +359 -0
  364. package/claude-assets/skills/cfn-loop-orchestration/helpers/deliverable-verifier.sh +71 -0
  365. package/claude-assets/skills/cfn-loop-orchestration/helpers/gate-check.sh +90 -0
  366. package/claude-assets/skills/cfn-loop-orchestration/helpers/iteration-manager.sh +87 -0
  367. package/claude-assets/skills/cfn-loop-orchestration/helpers/spawn-agents.sh +271 -0
  368. package/claude-assets/skills/cfn-loop-orchestration/helpers/timeout-calculator.sh +51 -0
  369. package/claude-assets/skills/cfn-loop-orchestration/inject-loop-context.sh +41 -0
  370. package/claude-assets/skills/cfn-loop-orchestration/monitor-execution.sh +156 -0
  371. package/claude-assets/skills/cfn-loop-orchestration/orchestrate.sh +884 -0
  372. package/claude-assets/skills/cfn-loop-orchestration/orchestrate.sh.backup +840 -0
  373. package/claude-assets/skills/cfn-loop-orchestration/security_utils.sh +99 -0
  374. package/claude-assets/skills/cfn-loop-orchestration/test-cfn-orchestration.sh +281 -0
  375. package/claude-assets/skills/cfn-loop-orchestration/test-edge-cases.sh +188 -0
  376. package/claude-assets/skills/cfn-loop-validation/README.md +256 -0
  377. package/claude-assets/skills/cfn-loop-validation/SKILL.md +353 -0
  378. package/claude-assets/skills/cfn-loop-validation/check-dependencies.sh +31 -0
  379. package/claude-assets/skills/cfn-loop-validation/config.json +161 -0
  380. package/claude-assets/skills/cfn-loop-validation/consensus-calculator.js +477 -0
  381. package/claude-assets/skills/cfn-loop-validation/evidence-chain.sql +163 -0
  382. package/claude-assets/skills/cfn-loop-validation/examples/README.md +453 -0
  383. package/claude-assets/skills/cfn-loop-validation/examples/coordinator-full-cfn-loop.sh +234 -0
  384. package/claude-assets/skills/cfn-loop-validation/examples/coordinator-loop2-consensus.sh +132 -0
  385. package/claude-assets/skills/cfn-loop-validation/examples/coordinator-loop3-gate.sh +115 -0
  386. package/claude-assets/skills/cfn-loop-validation/examples/coordinator-redis-integration.sh +186 -0
  387. package/claude-assets/skills/cfn-loop-validation/orchestrate-cfn-loop.sh +252 -0
  388. package/claude-assets/skills/cfn-loop-validation/validate-iteration.sh +134 -0
  389. package/claude-assets/skills/cfn-loop-validation.sh +70 -0
  390. package/claude-assets/skills/cfn-loop2-output-processing/SKILL.md +163 -0
  391. package/claude-assets/skills/cfn-loop2-output-processing/execute-and-extract.sh +77 -0
  392. package/claude-assets/skills/cfn-loop2-output-processing/execute-and-extract.sh.backup +36 -0
  393. package/claude-assets/skills/cfn-loop2-output-processing/parse-feedback.sh +147 -0
  394. package/claude-assets/skills/cfn-loop2-output-processing/process-validator-output.sh +275 -0
  395. package/claude-assets/skills/cfn-loop2-output-processing/test-bug27-fix.sh +200 -0
  396. package/claude-assets/skills/cfn-loop2-output-processing/test-loop2-processing.sh +113 -0
  397. package/claude-assets/skills/cfn-loop3-output-processing/AGENT_COMPLETION_PROTOCOL.md +206 -0
  398. package/claude-assets/skills/cfn-loop3-output-processing/SKILL.md +421 -0
  399. package/claude-assets/skills/cfn-loop3-output-processing/calculate-confidence.sh +28 -0
  400. package/claude-assets/skills/cfn-loop3-output-processing/execute-and-extract.sh +85 -0
  401. package/claude-assets/skills/cfn-loop3-output-processing/parse-confidence.sh +31 -0
  402. package/claude-assets/skills/cfn-loop3-output-processing/test-agent-timeout.sh +327 -0
  403. package/claude-assets/skills/cfn-loop3-output-processing/test-loop3-processing.sh +155 -0
  404. package/claude-assets/skills/cfn-loop3-output-processing/verify-deliverables.sh +42 -0
  405. package/claude-assets/skills/cfn-marketing-ad-campaigns/SKILL.md +392 -0
  406. package/claude-assets/skills/cfn-marketing-ad-campaigns/operations/create-campaign.sh +231 -0
  407. package/claude-assets/skills/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +190 -0
  408. package/claude-assets/skills/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +142 -0
  409. package/claude-assets/skills/cfn-marketing-ad-campaigns/operations/set-budget.sh +181 -0
  410. package/claude-assets/skills/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +133 -0
  411. package/claude-assets/skills/cfn-marketing-analytics-data/SKILL.md +124 -0
  412. package/claude-assets/skills/cfn-marketing-analytics-data/operations/get-ad-performance.sh +105 -0
  413. package/claude-assets/skills/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +102 -0
  414. package/claude-assets/skills/cfn-marketing-analytics-data/operations/get-email-performance.sh +105 -0
  415. package/claude-assets/skills/cfn-marketing-analytics-data/operations/get-social-engagement.sh +105 -0
  416. package/claude-assets/skills/cfn-marketing-analytics-data/operations/get-website-traffic.sh +107 -0
  417. package/claude-assets/skills/cfn-marketing-chatbot-conversations/SKILL.md +340 -0
  418. package/claude-assets/skills/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +121 -0
  419. package/claude-assets/skills/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +156 -0
  420. package/claude-assets/skills/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +181 -0
  421. package/claude-assets/skills/cfn-marketing-chatbot-conversations/operations/send-message.sh +137 -0
  422. package/claude-assets/skills/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +179 -0
  423. package/claude-assets/skills/cfn-marketing-competitive-intel/SKILL.md +350 -0
  424. package/claude-assets/skills/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +154 -0
  425. package/claude-assets/skills/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +173 -0
  426. package/claude-assets/skills/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +147 -0
  427. package/claude-assets/skills/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +146 -0
  428. package/claude-assets/skills/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +167 -0
  429. package/claude-assets/skills/cfn-marketing-crm-contacts/SKILL.md +116 -0
  430. package/claude-assets/skills/cfn-marketing-crm-contacts/operations/add-to-segment.sh +78 -0
  431. package/claude-assets/skills/cfn-marketing-crm-contacts/operations/create-contact.sh +113 -0
  432. package/claude-assets/skills/cfn-marketing-crm-contacts/operations/get-contact.sh +86 -0
  433. package/claude-assets/skills/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +78 -0
  434. package/claude-assets/skills/cfn-marketing-crm-contacts/operations/update-contact.sh +120 -0
  435. package/claude-assets/skills/cfn-marketing-email-campaigns/SKILL.md +106 -0
  436. package/claude-assets/skills/cfn-marketing-email-campaigns/operations/create-campaign.sh +123 -0
  437. package/claude-assets/skills/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +66 -0
  438. package/claude-assets/skills/cfn-marketing-email-campaigns/operations/list-templates.sh +68 -0
  439. package/claude-assets/skills/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +85 -0
  440. package/claude-assets/skills/cfn-marketing-email-campaigns/operations/send-test-email.sh +81 -0
  441. package/claude-assets/skills/cfn-marketing-landing-pages/SKILL.md +366 -0
  442. package/claude-assets/skills/cfn-marketing-landing-pages/operations/create-ab-test.sh +231 -0
  443. package/claude-assets/skills/cfn-marketing-landing-pages/operations/create-landing-page.sh +190 -0
  444. package/claude-assets/skills/cfn-marketing-landing-pages/operations/get-page-performance.sh +137 -0
  445. package/claude-assets/skills/cfn-marketing-landing-pages/operations/publish-page.sh +120 -0
  446. package/claude-assets/skills/cfn-marketing-landing-pages/operations/unpublish-page.sh +108 -0
  447. package/claude-assets/skills/cfn-marketing-media-monitoring/SKILL.md +202 -0
  448. package/claude-assets/skills/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +104 -0
  449. package/claude-assets/skills/cfn-marketing-media-monitoring/operations/export-report.sh +92 -0
  450. package/claude-assets/skills/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +85 -0
  451. package/claude-assets/skills/cfn-marketing-media-monitoring/operations/search-mentions.sh +86 -0
  452. package/claude-assets/skills/cfn-marketing-media-outreach/SKILL.md +168 -0
  453. package/claude-assets/skills/cfn-marketing-media-outreach/operations/search-journalists.sh +74 -0
  454. package/claude-assets/skills/cfn-marketing-media-outreach/operations/send-pitch.sh +80 -0
  455. package/claude-assets/skills/cfn-marketing-media-outreach/operations/submit-haro-response.sh +88 -0
  456. package/claude-assets/skills/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +66 -0
  457. package/claude-assets/skills/cfn-marketing-press-distribution/SKILL.md +159 -0
  458. package/claude-assets/skills/cfn-marketing-press-distribution/operations/distribute-press-release.sh +94 -0
  459. package/claude-assets/skills/cfn-marketing-press-distribution/operations/get-distribution-status.sh +59 -0
  460. package/claude-assets/skills/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +72 -0
  461. package/claude-assets/skills/cfn-marketing-press-distribution/operations/list-templates.sh +53 -0
  462. package/claude-assets/skills/cfn-marketing-sms-campaigns/SKILL.md +429 -0
  463. package/claude-assets/skills/cfn-marketing-sms-campaigns/operations/create-campaign.sh +183 -0
  464. package/claude-assets/skills/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +139 -0
  465. package/claude-assets/skills/cfn-marketing-sms-campaigns/operations/opt-out.sh +150 -0
  466. package/claude-assets/skills/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +187 -0
  467. package/claude-assets/skills/cfn-marketing-sms-campaigns/operations/send-sms.sh +181 -0
  468. package/claude-assets/skills/cfn-marketing-social-publishing/SKILL.md +108 -0
  469. package/claude-assets/skills/cfn-marketing-social-publishing/operations/create-post.sh +104 -0
  470. package/claude-assets/skills/cfn-marketing-social-publishing/operations/delete-post.sh +76 -0
  471. package/claude-assets/skills/cfn-marketing-social-publishing/operations/get-post-stats.sh +66 -0
  472. package/claude-assets/skills/cfn-marketing-social-publishing/operations/schedule-post.sh +85 -0
  473. package/claude-assets/skills/cfn-marketing-social-publishing/operations/upload-media.sh +88 -0
  474. package/claude-assets/skills/cfn-pattern-extraction/SKILL.md +30 -0
  475. package/claude-assets/skills/cfn-pattern-extraction/extract-patterns.sh +80 -0
  476. package/claude-assets/skills/cfn-playbook/SKILL.md +113 -0
  477. package/claude-assets/skills/cfn-playbook/init-playbook.sh +54 -0
  478. package/claude-assets/skills/cfn-playbook/playbook.db +0 -0
  479. package/claude-assets/skills/cfn-playbook/query-playbook.sh +79 -0
  480. package/claude-assets/skills/cfn-playbook/update-playbook.sh +69 -0
  481. package/claude-assets/skills/cfn-playbook-auto-update/SKILL.md +29 -0
  482. package/claude-assets/skills/cfn-playbook-auto-update/auto-update-playbook.sh +86 -0
  483. package/claude-assets/skills/cfn-process-lifecycle/README.md +43 -0
  484. package/claude-assets/skills/cfn-process-lifecycle/SKILL.md +39 -0
  485. package/claude-assets/skills/cfn-process-lifecycle/check-dependencies.sh +58 -0
  486. package/claude-assets/skills/cfn-process-lifecycle/config.json +39 -0
  487. package/claude-assets/skills/cfn-process-lifecycle/process-manager.sh +144 -0
  488. package/claude-assets/skills/cfn-product-owner-decision/SKILL.md +332 -0
  489. package/claude-assets/skills/cfn-product-owner-decision/execute-decision.sh +176 -0
  490. package/claude-assets/skills/cfn-product-owner-decision/parse-decision.sh +66 -0
  491. package/claude-assets/skills/cfn-product-owner-decision/validate-deliverables.sh +82 -0
  492. package/claude-assets/skills/cfn-redis-coordination/AGENT_LOGGING.md +280 -0
  493. package/claude-assets/skills/cfn-redis-coordination/BZPOPMIN_FIX_SUMMARY.md +209 -0
  494. package/claude-assets/skills/cfn-redis-coordination/HEARTBEAT.md +57 -0
  495. package/claude-assets/skills/cfn-redis-coordination/HEARTBEAT_MONITORING.md +267 -0
  496. package/claude-assets/skills/cfn-redis-coordination/LOGGING.md +260 -0
  497. package/claude-assets/skills/cfn-redis-coordination/README.md +65 -0
  498. package/claude-assets/skills/cfn-redis-coordination/SECURITY_REVIEW.md +25 -0
  499. package/claude-assets/skills/cfn-redis-coordination/SHUTDOWN_HANDLING.md +164 -0
  500. package/claude-assets/skills/cfn-redis-coordination/SKILL.md +720 -0
  501. package/claude-assets/skills/cfn-redis-coordination/agent-log.sh +124 -0
  502. package/claude-assets/skills/cfn-redis-coordination/agent-recovery.sh +75 -0
  503. package/claude-assets/skills/cfn-redis-coordination/analyze-task-complexity.sh +277 -0
  504. package/claude-assets/skills/cfn-redis-coordination/cancel-swarm.sh +221 -0
  505. package/claude-assets/skills/cfn-redis-coordination/cfn-loop-exec.sh +468 -0
  506. package/claude-assets/skills/cfn-redis-coordination/cfn-loop-relaunch.sh +29 -0
  507. package/claude-assets/skills/cfn-redis-coordination/check-dependencies.sh +32 -0
  508. package/claude-assets/skills/cfn-redis-coordination/collect-confidence-scores.sh +179 -0
  509. package/claude-assets/skills/cfn-redis-coordination/collect-results.sh +75 -0
  510. package/claude-assets/skills/cfn-redis-coordination/complete-swarm.sh +75 -0
  511. package/claude-assets/skills/cfn-redis-coordination/config.json +61 -0
  512. package/claude-assets/skills/cfn-redis-coordination/data/cfn-loop.db +0 -0
  513. package/claude-assets/skills/cfn-redis-coordination/demos/phase4-wake-queue-test-report.md +82 -0
  514. package/claude-assets/skills/cfn-redis-coordination/demos/test-bzpopmin-fix.sh +274 -0
  515. package/claude-assets/skills/cfn-redis-coordination/demos/test-cancel-swarm.sh +276 -0
  516. package/claude-assets/skills/cfn-redis-coordination/demos/test-dlq.sh +129 -0
  517. package/claude-assets/skills/cfn-redis-coordination/demos/test-iteration-feedback.sh +320 -0
  518. package/claude-assets/skills/cfn-redis-coordination/demos/test-orchestrator.sh +249 -0
  519. package/claude-assets/skills/cfn-redis-coordination/demos/test-priority-wake-phase4-unix.sh +148 -0
  520. package/claude-assets/skills/cfn-redis-coordination/demos/test-priority-wake-phase4.sh +163 -0
  521. package/claude-assets/skills/cfn-redis-coordination/demos/test-priority-wake.sh +138 -0
  522. package/claude-assets/skills/cfn-redis-coordination/demos/test-quick-fix.sh +81 -0
  523. package/claude-assets/skills/cfn-redis-coordination/demos/test-quorum-absolute.sh +45 -0
  524. package/claude-assets/skills/cfn-redis-coordination/demos/test-quorum-fallback.sh +68 -0
  525. package/claude-assets/skills/cfn-redis-coordination/demos/test-quorum-percentage.sh +56 -0
  526. package/claude-assets/skills/cfn-redis-coordination/demos/test-quorum-with-retry.sh +81 -0
  527. package/claude-assets/skills/cfn-redis-coordination/demos/test-quorum.sh +57 -0
  528. package/claude-assets/skills/cfn-redis-coordination/demos/test-shutdown-handling.sh +187 -0
  529. package/claude-assets/skills/cfn-redis-coordination/demos/test-shutdown.sh +160 -0
  530. package/claude-assets/skills/cfn-redis-coordination/demos/test-utils-unix.sh +97 -0
  531. package/claude-assets/skills/cfn-redis-coordination/demos/test-utils.sh +97 -0
  532. package/claude-assets/skills/cfn-redis-coordination/demos/test-waiting-mode.sh +59 -0
  533. package/claude-assets/skills/cfn-redis-coordination/examples/README.md +73 -0
  534. package/claude-assets/skills/cfn-redis-coordination/examples/grafana-dashboard.json +352 -0
  535. package/claude-assets/skills/cfn-redis-coordination/examples/hierarchical-pattern.sh +127 -0
  536. package/claude-assets/skills/cfn-redis-coordination/examples/mesh-pattern.sh +171 -0
  537. package/claude-assets/skills/cfn-redis-coordination/examples/timeout-handling.sh +227 -0
  538. package/claude-assets/skills/cfn-redis-coordination/examples/waiting-mode-pattern.sh +239 -0
  539. package/claude-assets/skills/cfn-redis-coordination/execute-product-owner-decision.sh +258 -0
  540. package/claude-assets/skills/cfn-redis-coordination/get-agent-timeout.sh +177 -0
  541. package/claude-assets/skills/cfn-redis-coordination/heartbeat-functions.sh +137 -0
  542. package/claude-assets/skills/cfn-redis-coordination/heartbeat-protocol.md +106 -0
  543. package/claude-assets/skills/cfn-redis-coordination/heartbeat.sh +126 -0
  544. package/claude-assets/skills/cfn-redis-coordination/init-swarm.sh +148 -0
  545. package/claude-assets/skills/cfn-redis-coordination/invoke-redis-pattern.sh +220 -0
  546. package/claude-assets/skills/cfn-redis-coordination/invoke-waiting-mode.sh +283 -0
  547. package/claude-assets/skills/cfn-redis-coordination/invoke-waiting-mode.sh.backup-p7 +423 -0
  548. package/claude-assets/skills/cfn-redis-coordination/list-active-swarms.sh +147 -0
  549. package/claude-assets/skills/cfn-redis-coordination/log-event.sh +109 -0
  550. package/claude-assets/skills/cfn-redis-coordination/metrics-export.sh +674 -0
  551. package/claude-assets/skills/cfn-redis-coordination/metrics-schema.json +66 -0
  552. package/claude-assets/skills/cfn-redis-coordination/metrics-storage.md +31 -0
  553. package/claude-assets/skills/cfn-redis-coordination/monitor-cfn-violations.sh +391 -0
  554. package/claude-assets/skills/cfn-redis-coordination/monitor-heartbeats.sh +101 -0
  555. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop-v3.sh +141 -0
  556. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh +31 -0
  557. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup +38 -0
  558. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup-1761167675 +1672 -0
  559. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup-p5 +1604 -0
  560. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup-phase1 +1550 -0
  561. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup-phase2 +1621 -0
  562. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.backup-phase3 +1621 -0
  563. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.bak +0 -0
  564. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.broken +1627 -0
  565. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.corrupted +80 -0
  566. package/claude-assets/skills/cfn-redis-coordination/orchestrate-cfn-loop.sh.deprecated +1864 -0
  567. package/claude-assets/skills/cfn-redis-coordination/priority-wake-mechanism.md +75 -0
  568. package/claude-assets/skills/cfn-redis-coordination/priority_wake.py +134 -0
  569. package/claude-assets/skills/cfn-redis-coordination/query-dlq.sh +162 -0
  570. package/claude-assets/skills/cfn-redis-coordination/query-logs.sh +103 -0
  571. package/claude-assets/skills/cfn-redis-coordination/redis-pattern.sh +619 -0
  572. package/claude-assets/skills/cfn-redis-coordination/retrieve-context.sh +58 -0
  573. package/claude-assets/skills/cfn-redis-coordination/select-specialist-agent.sh +371 -0
  574. package/claude-assets/skills/cfn-redis-coordination/semantic-match-tfidf.py +252 -0
  575. package/claude-assets/skills/cfn-redis-coordination/send-heartbeat.sh +165 -0
  576. package/claude-assets/skills/cfn-redis-coordination/signal.sh +38 -0
  577. package/claude-assets/skills/cfn-redis-coordination/store-context.sh +86 -0
  578. package/claude-assets/skills/cfn-redis-coordination/store-epic-context.sh +123 -0
  579. package/claude-assets/skills/cfn-redis-coordination/test-context-injection.sh +354 -0
  580. package/claude-assets/skills/cfn-redis-coordination/test-timeout-enforcement.sh +513 -0
  581. package/claude-assets/skills/cfn-redis-coordination/tests/convert-line-endings.sh +15 -0
  582. package/claude-assets/skills/cfn-redis-coordination/tests/dlq-functionality-test.sh +102 -0
  583. package/claude-assets/skills/cfn-redis-coordination/tests/edge-cases-test.sh +99 -0
  584. package/claude-assets/skills/cfn-redis-coordination/tests/integration-test.sh +170 -0
  585. package/claude-assets/skills/cfn-redis-coordination/tests/retry-mechanism-test.sh +82 -0
  586. package/claude-assets/skills/cfn-redis-coordination/tests/run-test-suite.sh +92 -0
  587. package/claude-assets/skills/cfn-redis-coordination/tests/run-tests.sh +4 -0
  588. package/claude-assets/skills/cfn-redis-coordination/tests/test-heartbeat-monitoring.sh +418 -0
  589. package/claude-assets/skills/cfn-redis-coordination/tests/test-heartbeat-simple.sh +124 -0
  590. package/claude-assets/skills/cfn-redis-coordination/tests/test-primitives.sh +166 -0
  591. package/claude-assets/skills/cfn-redis-coordination/tests/test-utils.sh +54 -0
  592. package/claude-assets/skills/cfn-redis-coordination/tests/test_coordination_primitives.sh.deprecated +20 -0
  593. package/claude-assets/skills/cfn-redis-coordination/tests/test_utils.sh +49 -0
  594. package/claude-assets/skills/cfn-redis-coordination/v2_modularization/core_orchestration.sh +76 -0
  595. package/claude-assets/skills/cfn-redis-coordination/validate-parameters.sh +492 -0
  596. package/claude-assets/skills/cfn-retrospective-report/SKILL.md +31 -0
  597. package/claude-assets/skills/cfn-retrospective-report/generate-report.sh +101 -0
  598. package/claude-assets/skills/cfn-scope-simplifier/SKILL.md +37 -0
  599. package/claude-assets/skills/cfn-scope-simplifier/simplify-scope.sh +68 -0
  600. package/claude-assets/skills/cfn-simplified-agent-lifecycle/COST_ANALYSIS.md +49 -0
  601. package/claude-assets/skills/cfn-simplified-agent-lifecycle/DESIGN.md +98 -0
  602. package/claude-assets/skills/cfn-simplified-agent-lifecycle/MIGRATION_PLAN.md +74 -0
  603. package/claude-assets/skills/cfn-skill-builder/SKILL.md +910 -0
  604. package/claude-assets/skills/cfn-specialist-injection/SKILL.md +41 -0
  605. package/claude-assets/skills/cfn-specialist-injection/recommend-specialist.sh +57 -0
  606. package/claude-assets/skills/cfn-sprint-execution/SKILL.md +27 -0
  607. package/claude-assets/skills/cfn-sprint-execution/execute-sprint-task.sh +59 -0
  608. package/claude-assets/skills/cfn-sprint-execution/execute-sprint.sh +65 -0
  609. package/claude-assets/skills/cfn-sprint-planner/SKILL.md +37 -0
  610. package/claude-assets/skills/cfn-sprint-planner/plan-sprint.sh +85 -0
  611. package/claude-assets/skills/cfn-sqlite-memory/IMPLEMENTATION_REPORT.md +393 -0
  612. package/claude-assets/skills/cfn-sqlite-memory/QUICK_REFERENCE.md +204 -0
  613. package/claude-assets/skills/cfn-sqlite-memory/README.md +65 -0
  614. package/claude-assets/skills/cfn-sqlite-memory/SKILL.md +415 -0
  615. package/claude-assets/skills/cfn-sqlite-memory/acl-queries.sql +452 -0
  616. package/claude-assets/skills/cfn-sqlite-memory/check-dependencies.sh +36 -0
  617. package/claude-assets/skills/cfn-sqlite-memory/config.json +45 -0
  618. package/claude-assets/skills/cfn-sqlite-memory/memory-cli.sh +88 -0
  619. package/claude-assets/skills/cfn-sqlite-memory/test-state-persistence.js +187 -0
  620. package/claude-assets/skills/cfn-sqlite-memory/ttl-cleanup.sh +274 -0
  621. package/claude-assets/skills/cfn-standardized-error-handling/SKILL.md +56 -0
  622. package/claude-assets/skills/cfn-standardized-error-handling/capture-agent-error.sh +87 -0
  623. package/claude-assets/skills/cfn-standardized-error-handling/test-error-handling.sh +166 -0
  624. package/claude-assets/skills/cfn-task-classifier/SKILL.md +94 -0
  625. package/claude-assets/skills/cfn-task-classifier/USAGE.md +248 -0
  626. package/claude-assets/skills/cfn-task-classifier/classify-task.sh +291 -0
  627. package/claude-assets/skills/cfn-test-execution/README.md +129 -0
  628. package/claude-assets/skills/cfn-test-execution/SKILL.md +128 -0
  629. package/claude-assets/skills/cfn-test-execution/check-dependencies.sh +36 -0
  630. package/claude-assets/skills/cfn-test-execution/test-cache-reader.sh +134 -0
  631. package/claude-assets/skills/cfn-test-execution/test-concurrent-conflicts.sh +115 -0
  632. package/claude-assets/skills/cfn-test-execution/test-coordinator-pattern.sh +109 -0
  633. package/claude-assets/skills/cfn-transparency-middleware/Cargo.toml +18 -0
  634. package/claude-assets/skills/cfn-transparency-middleware/README.md +74 -0
  635. package/claude-assets/skills/cfn-transparency-middleware/SECURITY.md +41 -0
  636. package/claude-assets/skills/cfn-transparency-middleware/SKILL.md +91 -0
  637. package/claude-assets/skills/cfn-transparency-middleware/TEST_RESULTS.md +174 -0
  638. package/claude-assets/skills/cfn-transparency-middleware/config.json +31 -0
  639. package/claude-assets/skills/cfn-transparency-middleware/examples/basic-usage.ts +39 -0
  640. package/claude-assets/skills/cfn-transparency-middleware/examples/batch-processing.ts +52 -0
  641. package/claude-assets/skills/cfn-transparency-middleware/examples/custom-filtering.ts +61 -0
  642. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +98 -0
  643. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-init.sh +224 -0
  644. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-level.sh +333 -0
  645. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +345 -0
  646. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +140 -0
  647. package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +235 -0
  648. package/claude-assets/skills/cfn-transparency-middleware/memory_query.rs +85 -0
  649. package/claude-assets/skills/cfn-transparency-middleware/memory_repository.rs +140 -0
  650. package/claude-assets/skills/cfn-transparency-middleware/memory_schema.rs +64 -0
  651. package/claude-assets/skills/cfn-transparency-middleware/middleware-config.sh +29 -0
  652. package/claude-assets/skills/cfn-transparency-middleware/performance-benchmark.sh +79 -0
  653. package/claude-assets/skills/cfn-transparency-middleware/test-e2e.sh +406 -0
  654. package/claude-assets/skills/cfn-transparency-middleware/test-integration.sh +162 -0
  655. package/claude-assets/skills/cfn-transparency-middleware/test-transparency-skill.sh +368 -0
  656. package/claude-assets/skills/cfn-transparency-middleware/test-transparency-skill.sh.unix +126 -0
  657. package/claude-assets/skills/cfn-transparency-middleware/tests/input-validation.sh +93 -0
  658. package/claude-assets/skills/cfn-transparency-middleware/wrap-agent.sh +132 -0
  659. package/claude-assets/skills/cfn-validation-templates/SKILL.md +47 -0
  660. package/claude-assets/skills/cfn-validation-templates/content.json +38 -0
  661. package/claude-assets/skills/cfn-validation-templates/data.json +38 -0
  662. package/claude-assets/skills/cfn-validation-templates/design.json +38 -0
  663. package/claude-assets/skills/cfn-validation-templates/infrastructure.json +38 -0
  664. package/claude-assets/skills/cfn-validation-templates/research.json +38 -0
  665. package/claude-assets/skills/cfn-validation-templates/software.json +38 -0
  666. package/claude-assets/skills/cfn-web-portal/DESIGN.md +117 -0
  667. package/claude-assets/skills/cfn-web-portal/SKILL.md +679 -0
  668. package/claude-assets/skills/cfn-web-portal/invoke-portal-agents.sh +129 -0
  669. package/claude-assets/skills/cfn-web-portal/invoke-portal-dashboard.sh +85 -0
  670. package/claude-assets/skills/cfn-web-portal/invoke-portal-events.sh +125 -0
  671. package/claude-assets/skills/cfn-web-portal/invoke-portal-metrics.sh +112 -0
  672. package/claude-assets/skills/cfn-web-portal/invoke-portal-start.sh +135 -0
  673. package/claude-assets/skills/cfn-web-portal/invoke-portal-stop.sh +121 -0
  674. package/claude-assets/skills/cfn-web-portal/test-web-portal-skill.sh +51 -0
  675. package/claude-assets/skills/cfn-web-portal/validate-deployment.sh +85 -0
  676. package/claude-assets/skills/cfn-webapp-testing/README.md +142 -0
  677. package/claude-assets/skills/cfn-webapp-testing/SCREENSHOT_NAMING_CONVENTION.md +547 -0
  678. package/claude-assets/skills/cfn-webapp-testing/SKILL.md +877 -0
  679. package/claude-assets/skills/cfn-webapp-testing/capture-screenshot.sh +238 -0
  680. package/claude-assets/skills/cfn-webapp-testing/cfn-loop-integration.sh +265 -0
  681. package/claude-assets/skills/cfn-webapp-testing/compare-screenshots.sh +199 -0
  682. package/claude-assets/skills/cfn-webapp-testing/init-storage.sh +150 -0
  683. package/claude-assets/skills/cfn-webapp-testing/set-baseline.sh +196 -0
  684. package/claude-assets/skills/cfn-webapp-testing/test-webapp-testing.sh +233 -0
  685. package/claude-assets/skills/consensus-calculator.js +45 -0
  686. package/claude-assets/skills/evidence-chain.sql +66 -0
  687. package/claude-assets/skills/run-all-skill-tests.sh +124 -0
  688. package/claude-assets/skills/team-provider-routing/execute-agent.sh +76 -0
  689. package/claude-assets/skills/team-provider-routing/spawn-worker.sh +91 -0
  690. package/claude-assets/skills/test-execution-coordinator-pattern.md +228 -0
  691. package/dist/agents/agent-loader.js +165 -146
  692. package/dist/agents/agent-loader.js.map +1 -1
  693. package/package.json +3 -3
  694. package/scripts/init-project.js +7 -7
@@ -0,0 +1,841 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Agent Profile Validator
5
+ *
6
+ * Validates agent profiles against CLAUDE.md standards and design principles.
7
+ * Checks frontmatter, prompt format, quality, and provides actionable recommendations.
8
+ *
9
+ * Usage:
10
+ * node validate-agent.js <path-to-agent.md>
11
+ * node validate-agent.js --all
12
+ *
13
+ * @module validate-agent
14
+ */
15
+
16
+ import { readFile, readdir } from 'fs/promises';
17
+ import { resolve, dirname, basename, join } from 'path';
18
+ import { fileURLToPath } from 'url';
19
+
20
+ const __filename = fileURLToPath(import.meta.url);
21
+ const __dirname = dirname(__filename);
22
+
23
+ // ============================================================================
24
+ // Configuration
25
+ // ============================================================================
26
+
27
+ const APPROVED_TOOLS = [
28
+ 'Read', 'Write', 'Edit', 'MultiEdit', 'Bash', 'Glob', 'Grep', 'TodoWrite'
29
+ ];
30
+
31
+ const APPROVED_MODELS = [
32
+ 'sonnet', 'haiku', 'opus', 'sonnet-3-5', 'sonnet-4-5', 'haiku'
33
+ ];
34
+
35
+ const VALID_COLOR_FORMATS = [
36
+ /^[a-z]+$/i, // Named colors: "orange", "green"
37
+ /^#[0-9A-F]{6}$/i, // Hex colors: "#FF9800"
38
+ /^rgb\(\d+,\s*\d+,\s*\d+\)$/i // RGB colors: "rgb(255, 152, 0)"
39
+ ];
40
+
41
+ const AGENT_TYPES = [
42
+ 'coder', 'reviewer', 'tester', 'planner', 'researcher', 'coordinator',
43
+ 'backend-dev', 'api-docs', 'system-architect', 'code-analyzer',
44
+ 'mobile-dev', 'tdd-london-swarm', 'production-validator',
45
+ 'perf-analyzer', 'performance-benchmarker', 'task-orchestrator'
46
+ ];
47
+
48
+ // ============================================================================
49
+ // YAML Parser (Simplified - handles basic YAML)
50
+ // ============================================================================
51
+
52
+ function parseYAML(yamlString) {
53
+ const lines = yamlString.split('\n');
54
+ const result = {};
55
+ let currentKey = null;
56
+ let currentArray = null;
57
+ let inMultiline = false;
58
+ let multilineKey = null;
59
+ let multilineContent = [];
60
+
61
+ for (const line of lines) {
62
+ const trimmed = line.trim();
63
+
64
+ // Skip empty lines and comments
65
+ if (!trimmed || trimmed.startsWith('#')) continue;
66
+
67
+ // Handle multiline blocks
68
+ if (trimmed.endsWith('|') || trimmed.endsWith('>')) {
69
+ multilineKey = trimmed.slice(0, -1).replace(':', '').trim();
70
+ inMultiline = true;
71
+ multilineContent = [];
72
+ continue;
73
+ }
74
+
75
+ if (inMultiline) {
76
+ if (line.startsWith(' ')) {
77
+ multilineContent.push(line.slice(2));
78
+ } else {
79
+ result[multilineKey] = multilineContent.join('\n');
80
+ inMultiline = false;
81
+ multilineKey = null;
82
+ }
83
+ }
84
+
85
+ // Handle array items
86
+ if (trimmed.startsWith('- ')) {
87
+ const value = trimmed.slice(2).trim();
88
+ if (currentArray) {
89
+ currentArray.push(value);
90
+ }
91
+ continue;
92
+ }
93
+
94
+ // Handle key-value pairs
95
+ if (trimmed.includes(':')) {
96
+ const [key, ...valueParts] = trimmed.split(':');
97
+ const value = valueParts.join(':').trim();
98
+
99
+ currentKey = key.trim();
100
+
101
+ if (value === '') {
102
+ // Start of array or object
103
+ currentArray = [];
104
+ result[currentKey] = currentArray;
105
+ } else {
106
+ // Simple value
107
+ currentArray = null;
108
+ // Try to parse as number or boolean
109
+ if (value === 'true') result[currentKey] = true;
110
+ else if (value === 'false') result[currentKey] = false;
111
+ else if (!isNaN(value) && value !== '') result[currentKey] = Number(value);
112
+ else result[currentKey] = value.replace(/^['"]|['"]$/g, ''); // Remove quotes
113
+ }
114
+ }
115
+ }
116
+
117
+ // Close any remaining multiline
118
+ if (inMultiline && multilineKey) {
119
+ result[multilineKey] = multilineContent.join('\n');
120
+ }
121
+
122
+ return result;
123
+ }
124
+
125
+ // ============================================================================
126
+ // Format Detection & Classification
127
+ // ============================================================================
128
+
129
+ /**
130
+ * Classifies agent prompt format based on content analysis
131
+ */
132
+ function classifyFormat(content, frontmatter) {
133
+ const promptContent = content.split('---').slice(2).join('---');
134
+ const lines = promptContent.split('\n').filter(line => line.trim());
135
+ const wordCount = promptContent.split(/\s+/).length;
136
+
137
+ // Count code blocks
138
+ const codeBlockCount = (promptContent.match(/```/g) || []).length / 2;
139
+
140
+ // Count structured sections
141
+ const hasCapabilities = frontmatter.capabilities !== undefined;
142
+ const hasHooks = frontmatter.hooks !== undefined;
143
+ const hasLifecycle = frontmatter.lifecycle !== undefined;
144
+
145
+ // Classification logic based on empirical findings
146
+ const classification = {
147
+ format: 'unknown',
148
+ confidence: 0,
149
+ characteristics: {},
150
+ tokens: 0,
151
+ words: wordCount
152
+ };
153
+
154
+ // CODE-HEAVY: 2000+ tokens, multiple code examples, implementation patterns
155
+ if (codeBlockCount >= 3 && wordCount > 1500) {
156
+ classification.format = 'code-heavy';
157
+ classification.confidence = 0.9;
158
+ classification.tokens = 2000 + Math.floor(wordCount * 0.75);
159
+ classification.characteristics = {
160
+ codeBlocks: codeBlockCount,
161
+ hasExamples: true,
162
+ hasImplementationPatterns: true,
163
+ verbosity: 'high'
164
+ };
165
+ }
166
+ // METADATA: 1000-1500 tokens, structured frontmatter, YAML/TS blocks
167
+ else if ((hasCapabilities || hasHooks || hasLifecycle) && codeBlockCount >= 1) {
168
+ classification.format = 'metadata';
169
+ classification.confidence = 0.85;
170
+ classification.tokens = 1000 + Math.floor(wordCount * 0.5);
171
+ classification.characteristics = {
172
+ codeBlocks: codeBlockCount,
173
+ hasStructuredMetadata: true,
174
+ hasCapabilities,
175
+ hasHooks,
176
+ hasLifecycle,
177
+ verbosity: 'medium'
178
+ };
179
+ }
180
+ // MINIMAL: 500-800 tokens, lean prompts, reasoning-focused
181
+ else if (wordCount < 1000 && codeBlockCount <= 1) {
182
+ classification.format = 'minimal';
183
+ classification.confidence = 0.8;
184
+ classification.tokens = 500 + Math.floor(wordCount * 0.33);
185
+ classification.characteristics = {
186
+ codeBlocks: codeBlockCount,
187
+ reasoningFocused: true,
188
+ verbosity: 'low'
189
+ };
190
+ }
191
+ // METADATA as default middle ground
192
+ else {
193
+ classification.format = 'metadata';
194
+ classification.confidence = 0.6;
195
+ classification.tokens = 1000;
196
+ classification.characteristics = {
197
+ codeBlocks: codeBlockCount,
198
+ verbosity: 'medium'
199
+ };
200
+ }
201
+
202
+ return classification;
203
+ }
204
+
205
+ /**
206
+ * Estimates task complexity based on agent type and description
207
+ */
208
+ function estimateComplexity(frontmatter, content) {
209
+ const description = (frontmatter.description || '').toLowerCase();
210
+ const promptContent = content.toLowerCase();
211
+
212
+ const indicators = {
213
+ basic: ['simple', 'basic', 'string', 'array', 'validation', 'parse', 'format', 'convert'],
214
+ medium: ['multiple', 'integrate', 'refactor', 'concurrent', 'cache', 'queue', 'worker', 'pipeline'],
215
+ complex: ['architecture', 'system', 'distributed', 'scalable', 'design', 'trade-off', 'performance-critical', 'zero-copy']
216
+ };
217
+
218
+ const scores = {
219
+ basic: 0,
220
+ medium: 0,
221
+ complex: 0
222
+ };
223
+
224
+ // Score based on keywords
225
+ for (const [level, keywords] of Object.entries(indicators)) {
226
+ for (const keyword of keywords) {
227
+ if (description.includes(keyword)) scores[level]++;
228
+ if (promptContent.includes(keyword)) scores[level] += 0.5;
229
+ }
230
+ }
231
+
232
+ // Determine complexity
233
+ const maxScore = Math.max(...Object.values(scores));
234
+ if (maxScore === 0) return { complexity: 'medium', confidence: 'low', scores };
235
+
236
+ const complexity = Object.keys(scores).find(key => scores[key] === maxScore);
237
+ const confidence = maxScore >= 2 ? 'high' : maxScore >= 1 ? 'medium' : 'low';
238
+
239
+ return { complexity, confidence, scores };
240
+ }
241
+
242
+ /**
243
+ * Recommends optimal format based on agent type and complexity
244
+ */
245
+ function recommendFormat(agentType, complexity) {
246
+ // Always minimal for architectural reasoning
247
+ if (agentType === 'architect' || agentType === 'system-architect') {
248
+ return {
249
+ recommended: 'minimal',
250
+ reason: 'Architectural agents need reasoning freedom, not examples',
251
+ confidence: 'high'
252
+ };
253
+ }
254
+
255
+ // Always minimal for reviewers
256
+ if (agentType === 'reviewer' || agentType === 'code-analyzer') {
257
+ return {
258
+ recommended: 'minimal',
259
+ reason: 'Review agents need to reason about code, not follow patterns',
260
+ confidence: 'high'
261
+ };
262
+ }
263
+
264
+ // Always metadata for researchers
265
+ if (agentType === 'researcher') {
266
+ return {
267
+ recommended: 'metadata',
268
+ reason: 'Research needs structured output format',
269
+ confidence: 'high'
270
+ };
271
+ }
272
+
273
+ // Coder agents: complexity-based selection (validated)
274
+ if (agentType === 'coder' || agentType === 'backend-dev' || agentType === 'mobile-dev') {
275
+ if (complexity === 'basic') {
276
+ return {
277
+ recommended: 'code-heavy',
278
+ reason: 'Basic tasks benefit from examples (+43% quality boost validated)',
279
+ confidence: 'high',
280
+ evidence: 'Empirically validated on Rust benchmarks'
281
+ };
282
+ }
283
+ if (complexity === 'complex') {
284
+ return {
285
+ recommended: 'minimal',
286
+ reason: 'Complex tasks need reasoning, examples constrain solution space',
287
+ confidence: 'high',
288
+ evidence: 'Validated: 0% quality gap between formats on complex tasks'
289
+ };
290
+ }
291
+ return {
292
+ recommended: 'metadata',
293
+ reason: 'Medium complexity benefits from structure without over-constraining',
294
+ confidence: 'medium'
295
+ };
296
+ }
297
+
298
+ // Tester agents: similar to coders
299
+ if (agentType === 'tester' || agentType === 'tdd-london-swarm') {
300
+ if (complexity === 'basic') {
301
+ return {
302
+ recommended: 'code-heavy',
303
+ reason: 'Test structure and patterns benefit from examples',
304
+ confidence: 'medium'
305
+ };
306
+ }
307
+ return {
308
+ recommended: 'metadata',
309
+ reason: 'Test organization needs structure',
310
+ confidence: 'medium'
311
+ };
312
+ }
313
+
314
+ // Default: metadata as safe middle ground
315
+ return {
316
+ recommended: 'metadata',
317
+ reason: 'Balanced approach for general tasks',
318
+ confidence: 'medium'
319
+ };
320
+ }
321
+
322
+ // ============================================================================
323
+ // Validation Functions
324
+ // ============================================================================
325
+
326
+ /**
327
+ * Validates frontmatter structure and required fields
328
+ */
329
+ function validateFrontmatter(frontmatter) {
330
+ const issues = [];
331
+ const warnings = [];
332
+
333
+ // Required fields
334
+ if (!frontmatter.name) {
335
+ issues.push({
336
+ severity: 'error',
337
+ field: 'name',
338
+ message: 'Missing required field: name',
339
+ fix: 'Add "name: agent-name" to frontmatter'
340
+ });
341
+ }
342
+
343
+ if (!frontmatter.description) {
344
+ issues.push({
345
+ severity: 'error',
346
+ field: 'description',
347
+ message: 'Missing required field: description',
348
+ fix: 'Add "description: ..." to frontmatter'
349
+ });
350
+ } else if (frontmatter.description.length < 50) {
351
+ warnings.push({
352
+ severity: 'warning',
353
+ field: 'description',
354
+ message: 'Description is too short (< 50 chars)',
355
+ fix: 'Expand description to include key capabilities and use cases'
356
+ });
357
+ }
358
+
359
+ // Tools validation
360
+ if (!frontmatter.tools) {
361
+ warnings.push({
362
+ severity: 'warning',
363
+ field: 'tools',
364
+ message: 'Missing tools specification',
365
+ fix: 'Add "tools: Read, Write, Edit, ..." to frontmatter'
366
+ });
367
+ } else {
368
+ const tools = typeof frontmatter.tools === 'string'
369
+ ? frontmatter.tools.split(',').map(t => t.trim())
370
+ : frontmatter.tools;
371
+
372
+ const invalidTools = tools.filter(tool => !APPROVED_TOOLS.includes(tool));
373
+ if (invalidTools.length > 0) {
374
+ issues.push({
375
+ severity: 'error',
376
+ field: 'tools',
377
+ message: `Invalid tools: ${invalidTools.join(', ')}`,
378
+ fix: `Use only approved tools: ${APPROVED_TOOLS.join(', ')}`
379
+ });
380
+ }
381
+ }
382
+
383
+ // Model validation
384
+ if (!frontmatter.model) {
385
+ warnings.push({
386
+ severity: 'warning',
387
+ field: 'model',
388
+ message: 'Missing model specification',
389
+ fix: 'Add "model: sonnet" (or haiku, opus) to frontmatter'
390
+ });
391
+ } else if (!APPROVED_MODELS.includes(frontmatter.model)) {
392
+ warnings.push({
393
+ severity: 'warning',
394
+ field: 'model',
395
+ message: `Uncommon model: ${frontmatter.model}`,
396
+ fix: `Consider using: ${APPROVED_MODELS.slice(0, 3).join(', ')}`
397
+ });
398
+ }
399
+
400
+ // Color validation
401
+ if (!frontmatter.color) {
402
+ warnings.push({
403
+ severity: 'warning',
404
+ field: 'color',
405
+ message: 'Missing color specification',
406
+ fix: 'Add "color: blue" (or hex "#0000FF") to frontmatter'
407
+ });
408
+ } else {
409
+ const colorValid = VALID_COLOR_FORMATS.some(regex => regex.test(frontmatter.color));
410
+ if (!colorValid) {
411
+ issues.push({
412
+ severity: 'error',
413
+ field: 'color',
414
+ message: `Invalid color format: ${frontmatter.color}`,
415
+ fix: 'Use named color (e.g., "orange"), hex (e.g., "#FF9800"), or RGB (e.g., "rgb(255, 152, 0)")'
416
+ });
417
+ }
418
+ }
419
+
420
+ return { issues, warnings };
421
+ }
422
+
423
+ /**
424
+ * Analyzes prompt quality and structure
425
+ */
426
+ function analyzePromptQuality(content) {
427
+ const promptContent = content.split('---').slice(2).join('---');
428
+ const recommendations = [];
429
+
430
+ // Check for clear role definition
431
+ const hasRoleDefinition = /you are|your role|you specialize in/i.test(promptContent.slice(0, 500));
432
+ if (!hasRoleDefinition) {
433
+ recommendations.push({
434
+ category: 'role-clarity',
435
+ message: 'Add clear role definition in first paragraph',
436
+ example: 'Start with "You are a [Role] specialized in..."'
437
+ });
438
+ }
439
+
440
+ // Check for specific responsibilities
441
+ const hasResponsibilities = /responsibilities|duties|tasks|core functions/i.test(promptContent);
442
+ if (!hasResponsibilities) {
443
+ recommendations.push({
444
+ category: 'structure',
445
+ message: 'Add clear responsibilities section',
446
+ example: '## Core Responsibilities\n1. [Responsibility 1]\n2. [Responsibility 2]'
447
+ });
448
+ }
449
+
450
+ // Check for anti-patterns
451
+ const negativeCount = (promptContent.match(/don't|never|avoid(?!\s+memory leaks)/gi) || []).length;
452
+ if (negativeCount > 5) {
453
+ recommendations.push({
454
+ category: 'anti-pattern',
455
+ message: `Excessive negative instructions (${negativeCount} found)`,
456
+ fix: 'Rephrase as positive guidance: "Use X instead of Y"'
457
+ });
458
+ }
459
+
460
+ return { recommendations };
461
+ }
462
+
463
+ /**
464
+ * Checks format alignment with task complexity
465
+ */
466
+ function checkFormatAlignment(agentType, format, complexity) {
467
+ const recommendation = recommendFormat(agentType, complexity.complexity);
468
+ const alignment = {
469
+ aligned: format.format === recommendation.recommended,
470
+ currentFormat: format.format,
471
+ recommendedFormat: recommendation.recommended,
472
+ reason: recommendation.reason,
473
+ confidence: recommendation.confidence,
474
+ evidence: recommendation.evidence || 'Hypothesized from validated coder agent patterns'
475
+ };
476
+
477
+ if (!alignment.aligned) {
478
+ alignment.impact = estimateImpact(format.format, recommendation.recommended, complexity.complexity);
479
+ }
480
+
481
+ return alignment;
482
+ }
483
+
484
+ /**
485
+ * Estimates impact of format mismatch
486
+ */
487
+ function estimateImpact(currentFormat, recommendedFormat, complexity) {
488
+ const impacts = {
489
+ 'basic-minimal-to-code-heavy': '+43% quality boost (validated)',
490
+ 'basic-metadata-to-code-heavy': '+10-15% quality improvement',
491
+ 'complex-code-heavy-to-minimal': '0% quality gap, 10% faster response',
492
+ 'complex-metadata-to-minimal': '0-3% quality gap, 5% faster response'
493
+ };
494
+
495
+ const key = `${complexity}-${currentFormat}-to-${recommendedFormat}`;
496
+ return impacts[key] || 'Marginal impact expected';
497
+ }
498
+
499
+ // ============================================================================
500
+ // Validation Orchestration
501
+ // ============================================================================
502
+
503
+ /**
504
+ * Performs complete validation of an agent profile
505
+ */
506
+ async function validateAgent(filePath) {
507
+ const content = await readFile(filePath, 'utf-8');
508
+
509
+ // Parse frontmatter (handle both \n--- and ---\n endings)
510
+ const frontmatterMatch = content.match(/^---\r?\n([\s\S]*?)\r?\n---/);
511
+ if (!frontmatterMatch) {
512
+ return {
513
+ valid: false,
514
+ file: filePath,
515
+ agentType: 'unknown',
516
+ complianceScore: 0,
517
+ frontmatter: {
518
+ valid: false,
519
+ issues: [{
520
+ severity: 'error',
521
+ field: 'frontmatter',
522
+ message: 'No frontmatter found',
523
+ fix: 'Add YAML frontmatter at the beginning of the file'
524
+ }],
525
+ warnings: []
526
+ },
527
+ format: {
528
+ classification: { format: 'unknown', confidence: 0, characteristics: {}, tokens: 0, words: 0 },
529
+ complexity: { complexity: 'unknown', confidence: 'low', scores: { basic: 0, medium: 0, complex: 0 } },
530
+ alignment: { aligned: false, currentFormat: 'unknown', recommendedFormat: 'minimal', reason: 'No frontmatter', confidence: 'low', evidence: 'N/A' }
531
+ },
532
+ quality: { recommendations: [] },
533
+ summary: 'CRITICAL ERROR: No frontmatter found'
534
+ };
535
+ }
536
+
537
+ let frontmatter;
538
+ try {
539
+ frontmatter = parseYAML(frontmatterMatch[1]);
540
+ } catch (err) {
541
+ return {
542
+ valid: false,
543
+ file: filePath,
544
+ agentType: 'unknown',
545
+ complianceScore: 0,
546
+ frontmatter: {
547
+ valid: false,
548
+ issues: [{
549
+ severity: 'error',
550
+ field: 'frontmatter',
551
+ message: `Invalid YAML syntax: ${err.message}`,
552
+ fix: 'Fix YAML syntax errors in frontmatter'
553
+ }],
554
+ warnings: []
555
+ },
556
+ format: {
557
+ classification: { format: 'unknown', confidence: 0, characteristics: {}, tokens: 0, words: 0 },
558
+ complexity: { complexity: 'unknown', confidence: 'low', scores: { basic: 0, medium: 0, complex: 0 } },
559
+ alignment: { aligned: false, currentFormat: 'unknown', recommendedFormat: 'minimal', reason: 'Invalid YAML', confidence: 'low', evidence: 'N/A' }
560
+ },
561
+ quality: { recommendations: [] },
562
+ summary: `CRITICAL ERROR: Invalid YAML syntax`
563
+ };
564
+ }
565
+
566
+ // Run validations
567
+ const frontmatterValidation = validateFrontmatter(frontmatter);
568
+ const formatClassification = classifyFormat(content, frontmatter);
569
+ const complexityEstimate = estimateComplexity(frontmatter, content);
570
+ const qualityAnalysis = analyzePromptQuality(content);
571
+
572
+ // Determine agent type
573
+ const agentType = frontmatter.name || 'unknown';
574
+ const detectedType = AGENT_TYPES.find(type => agentType.toLowerCase().includes(type)) || 'unknown';
575
+
576
+ const formatAlignment = checkFormatAlignment(detectedType, formatClassification, complexityEstimate);
577
+
578
+ // Calculate compliance score
579
+ const totalIssues = frontmatterValidation.issues.length;
580
+ const totalWarnings = frontmatterValidation.warnings.length;
581
+ const totalRecommendations = qualityAnalysis.recommendations.length;
582
+
583
+ const complianceScore = Math.max(0, 100 - (totalIssues * 20) - (totalWarnings * 5) - (totalRecommendations * 2));
584
+
585
+ return {
586
+ valid: totalIssues === 0,
587
+ file: filePath,
588
+ agentType: detectedType || 'unknown',
589
+ complianceScore,
590
+ frontmatter: {
591
+ valid: frontmatterValidation.issues.length === 0,
592
+ issues: frontmatterValidation.issues,
593
+ warnings: frontmatterValidation.warnings
594
+ },
595
+ format: {
596
+ classification: formatClassification,
597
+ complexity: complexityEstimate,
598
+ alignment: formatAlignment
599
+ },
600
+ quality: qualityAnalysis,
601
+ summary: generateSummary(complianceScore, formatAlignment, frontmatterValidation, qualityAnalysis)
602
+ };
603
+ }
604
+
605
+ /**
606
+ * Generates human-readable summary
607
+ */
608
+ function generateSummary(score, alignment, frontmatter, quality) {
609
+ const status = score >= 90 ? 'Excellent' : score >= 75 ? 'Good' : score >= 60 ? 'Fair' : 'Needs Improvement';
610
+
611
+ const summary = [`Agent Profile Status: ${status} (${score}/100)`];
612
+
613
+ if (frontmatter.issues.length > 0) {
614
+ summary.push(`⚠️ ${frontmatter.issues.length} critical issue(s) found`);
615
+ }
616
+
617
+ if (!alignment.aligned) {
618
+ summary.push(`📊 Format mismatch: Using ${alignment.currentFormat}, recommend ${alignment.recommendedFormat}`);
619
+ summary.push(` Reason: ${alignment.reason}`);
620
+ summary.push(` Impact: ${alignment.impact || 'See recommendations'}`);
621
+ } else {
622
+ summary.push(`✅ Format aligned with best practices (${alignment.currentFormat})`);
623
+ }
624
+
625
+ if (quality.recommendations.length > 0) {
626
+ summary.push(`💡 ${quality.recommendations.length} improvement recommendation(s)`);
627
+ }
628
+
629
+ return summary.join('\n');
630
+ }
631
+
632
+ // ============================================================================
633
+ // CLI Interface
634
+ // ============================================================================
635
+
636
+ /**
637
+ * Formats validation results for console output
638
+ */
639
+ function formatOutput(result) {
640
+ const sections = [];
641
+
642
+ // Header
643
+ sections.push('═'.repeat(80));
644
+ sections.push(`AGENT VALIDATION REPORT: ${basename(result.file)}`);
645
+ sections.push('═'.repeat(80));
646
+ sections.push('');
647
+
648
+ // Summary
649
+ sections.push('SUMMARY');
650
+ sections.push('─'.repeat(80));
651
+ sections.push(result.summary);
652
+ sections.push('');
653
+
654
+ // Format Analysis
655
+ sections.push('FORMAT ANALYSIS');
656
+ sections.push('─'.repeat(80));
657
+ sections.push(`Detected Format: ${result.format.classification.format.toUpperCase()}`);
658
+ sections.push(`Confidence: ${(result.format.classification.confidence * 100).toFixed(0)}%`);
659
+ sections.push(`Estimated Tokens: ~${result.format.classification.tokens}`);
660
+ sections.push(`Word Count: ${result.format.classification.words}`);
661
+ sections.push('');
662
+ sections.push('Characteristics:');
663
+ for (const [key, value] of Object.entries(result.format.classification.characteristics)) {
664
+ sections.push(` • ${key}: ${value}`);
665
+ }
666
+ sections.push('');
667
+
668
+ // Complexity Estimate
669
+ sections.push('COMPLEXITY ANALYSIS');
670
+ sections.push('─'.repeat(80));
671
+ sections.push(`Estimated Complexity: ${result.format.complexity.complexity.toUpperCase()}`);
672
+ sections.push(`Confidence: ${result.format.complexity.confidence.toUpperCase()}`);
673
+ sections.push('Indicator Scores:');
674
+ for (const [level, score] of Object.entries(result.format.complexity.scores)) {
675
+ sections.push(` • ${level}: ${score.toFixed(1)}`);
676
+ }
677
+ sections.push('');
678
+
679
+ // Format Alignment
680
+ sections.push('FORMAT RECOMMENDATION');
681
+ sections.push('─'.repeat(80));
682
+ sections.push(`Current Format: ${result.format.alignment.currentFormat.toUpperCase()}`);
683
+ sections.push(`Recommended Format: ${result.format.alignment.recommendedFormat.toUpperCase()}`);
684
+ sections.push(`Alignment: ${result.format.alignment.aligned ? '✅ ALIGNED' : '⚠️ MISALIGNED'}`);
685
+ sections.push(`Confidence: ${result.format.alignment.confidence.toUpperCase()}`);
686
+ sections.push(`Reason: ${result.format.alignment.reason}`);
687
+ if (result.format.alignment.evidence) {
688
+ sections.push(`Evidence: ${result.format.alignment.evidence}`);
689
+ }
690
+ if (result.format.alignment.impact) {
691
+ sections.push(`Expected Impact: ${result.format.alignment.impact}`);
692
+ }
693
+ sections.push('');
694
+
695
+ // Issues
696
+ if (result.frontmatter.issues.length > 0) {
697
+ sections.push('CRITICAL ISSUES');
698
+ sections.push('─'.repeat(80));
699
+ result.frontmatter.issues.forEach((issue, i) => {
700
+ sections.push(`${i + 1}. [${issue.field}] ${issue.message}`);
701
+ sections.push(` Fix: ${issue.fix}`);
702
+ sections.push('');
703
+ });
704
+ }
705
+
706
+ // Warnings
707
+ if (result.frontmatter.warnings.length > 0) {
708
+ sections.push('WARNINGS');
709
+ sections.push('─'.repeat(80));
710
+ result.frontmatter.warnings.forEach((warning, i) => {
711
+ sections.push(`${i + 1}. [${warning.field}] ${warning.message}`);
712
+ sections.push(` Fix: ${warning.fix}`);
713
+ sections.push('');
714
+ });
715
+ }
716
+
717
+ // Recommendations
718
+ if (result.quality.recommendations.length > 0) {
719
+ sections.push('IMPROVEMENT RECOMMENDATIONS');
720
+ sections.push('─'.repeat(80));
721
+ result.quality.recommendations.forEach((rec, i) => {
722
+ sections.push(`${i + 1}. [${rec.category}] ${rec.message}`);
723
+ if (rec.impact) sections.push(` Impact: ${rec.impact}`);
724
+ if (rec.example) sections.push(` Example: ${rec.example}`);
725
+ if (rec.fix) sections.push(` Fix: ${rec.fix}`);
726
+ sections.push('');
727
+ });
728
+ }
729
+
730
+ // Footer
731
+ sections.push('═'.repeat(80));
732
+ sections.push(`Compliance Score: ${result.complianceScore}/100`);
733
+ sections.push('═'.repeat(80));
734
+
735
+ return sections.join('\n');
736
+ }
737
+
738
+ /**
739
+ * Find all agent markdown files recursively
740
+ */
741
+ async function findAgentFiles(dir, results = []) {
742
+ const entries = await readdir(dir, { withFileTypes: true });
743
+
744
+ for (const entry of entries) {
745
+ const fullPath = join(dir, entry.name);
746
+
747
+ if (entry.isDirectory() && entry.name !== 'node_modules') {
748
+ await findAgentFiles(fullPath, results);
749
+ } else if (entry.isFile() && entry.name.endsWith('.md')) {
750
+ // Skip certain files
751
+ if (!entry.name.includes('README') && !entry.name.includes('CLAUDE_AGENT_DESIGN_PRINCIPLES')) {
752
+ results.push(fullPath);
753
+ }
754
+ }
755
+ }
756
+
757
+ return results;
758
+ }
759
+
760
+ /**
761
+ * Main CLI entry point
762
+ */
763
+ async function main() {
764
+ const args = process.argv.slice(2);
765
+
766
+ if (args.length === 0) {
767
+ console.error('Usage: node validate-agent.js <path-to-agent.md>');
768
+ console.error(' node validate-agent.js --all');
769
+ process.exit(1);
770
+ }
771
+
772
+ if (args[0] === '--all') {
773
+ // Validate all agents
774
+ const agentsDir = resolve(__dirname);
775
+ const agentFiles = await findAgentFiles(agentsDir);
776
+
777
+ console.log(`Found ${agentFiles.length} agent files to validate\n`);
778
+
779
+ const results = [];
780
+ for (const file of agentFiles) {
781
+ try {
782
+ const result = await validateAgent(file);
783
+ results.push(result);
784
+
785
+ // Print summary for each
786
+ const relPath = file.replace(agentsDir + '/', '');
787
+ console.log(`${relPath}: ${result.valid ? '✅' : '❌'} Score: ${result.complianceScore}/100`);
788
+ } catch (err) {
789
+ console.error(`Error validating ${file}: ${err.message}`);
790
+ }
791
+ }
792
+
793
+ // Summary statistics
794
+ console.log('\n' + '═'.repeat(80));
795
+ console.log('VALIDATION SUMMARY');
796
+ console.log('═'.repeat(80));
797
+ console.log(`Total Agents: ${results.length}`);
798
+ console.log(`Passed: ${results.filter(r => r.valid).length}`);
799
+ console.log(`Failed: ${results.filter(r => !r.valid).length}`);
800
+ console.log(`Average Score: ${(results.reduce((sum, r) => sum + r.complianceScore, 0) / results.length).toFixed(1)}/100`);
801
+ console.log('');
802
+
803
+ // Top performers
804
+ const topPerformers = results.sort((a, b) => b.complianceScore - a.complianceScore).slice(0, 5);
805
+ console.log('Top 5 Performers:');
806
+ topPerformers.forEach((r, i) => {
807
+ console.log(` ${i + 1}. ${basename(r.file)}: ${r.complianceScore}/100`);
808
+ });
809
+ console.log('');
810
+
811
+ // Needs improvement
812
+ const needsImprovement = results.filter(r => r.complianceScore < 75).length;
813
+ if (needsImprovement > 0) {
814
+ console.log(`⚠️ ${needsImprovement} agent(s) need improvement (score < 75)`);
815
+ }
816
+
817
+ } else {
818
+ // Validate single agent
819
+ const filePath = resolve(process.cwd(), args[0]);
820
+
821
+ try {
822
+ const result = await validateAgent(filePath);
823
+ console.log(formatOutput(result));
824
+
825
+ // Exit code based on validation result
826
+ process.exit(result.valid ? 0 : 1);
827
+ } catch (err) {
828
+ console.error(`Error: ${err.message}`);
829
+ console.error('Stack:', err.stack);
830
+ process.exit(1);
831
+ }
832
+ }
833
+ }
834
+
835
+ // Run if called directly
836
+ main().catch(err => {
837
+ console.error('Fatal error:', err);
838
+ process.exit(1);
839
+ });
840
+
841
+ export { validateAgent, classifyFormat, estimateComplexity, recommendFormat };