claude-flow-novice 2.18.5 → 2.18.6

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 (1023) hide show
  1. package/.claude/.cfn-initialized +1 -0
  2. package/.claude/FILE_MANIFEST.md +50 -0
  3. package/.claude/MANIFEST_INDEX.md +224 -0
  4. package/.claude/MANIFEST_README.md +308 -0
  5. package/.claude/TRIGGER_TASKS_MANIFEST.md +11 -0
  6. package/.claude/WORKING-SETUP.md +67 -0
  7. package/.claude/adaptive-context/cfn-v3-reflection.json +21 -0
  8. package/.claude/agent-principles/SPARSE_LANGUAGE_FINDINGS.md +991 -0
  9. package/.claude/agent-principles/agent-template.md +96 -0
  10. package/.claude/agent-principles/prompt-engineering.md +501 -0
  11. package/.claude/agents/AGENT_LIFECYCLE.md +532 -0
  12. package/.claude/agents/README-AGENT_LIFECYCLE.md +522 -0
  13. package/.claude/agents/README-VALIDATION.md +243 -0
  14. package/.claude/agents/SHARED_PROTOCOL.md +64 -0
  15. package/.claude/agents/cfn-dev-team/CLAUDE.md +1000 -0
  16. package/.claude/agents/cfn-dev-team/README.md +219 -0
  17. package/.claude/agents/cfn-dev-team/analysts/analyst.md +120 -0
  18. package/.claude/agents/cfn-dev-team/analysts/root-cause-analyst.md +264 -0
  19. package/.claude/agents/cfn-dev-team/architecture/api-designer-persona.md +152 -0
  20. package/.claude/agents/cfn-dev-team/architecture/base-template-generator.md +157 -0
  21. package/.claude/agents/cfn-dev-team/architecture/goal-planner.md +180 -0
  22. package/.claude/agents/cfn-dev-team/architecture/planner.md +139 -0
  23. package/.claude/agents/cfn-dev-team/architecture/system-architect.md +132 -0
  24. package/.claude/agents/cfn-dev-team/coordinators/README.md +42 -0
  25. package/.claude/agents/cfn-dev-team/coordinators/cfn-frontend-coordinator.md +893 -0
  26. package/.claude/agents/cfn-dev-team/coordinators/consensus-builder.md +480 -0
  27. package/.claude/agents/cfn-dev-team/coordinators/handoff-coordinator.md +747 -0
  28. package/.claude/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +510 -0
  29. package/.claude/agents/cfn-dev-team/dev-ops/devops-engineer.md +157 -0
  30. package/.claude/agents/cfn-dev-team/dev-ops/docker-specialist.md +671 -0
  31. package/.claude/agents/cfn-dev-team/dev-ops/github-commit-agent.md +123 -0
  32. package/.claude/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +624 -0
  33. package/.claude/agents/cfn-dev-team/developers/README.md +69 -0
  34. package/.claude/agents/cfn-dev-team/developers/api-gateway-specialist.md +977 -0
  35. package/.claude/agents/cfn-dev-team/developers/backend-developer-cerebras.md +210 -0
  36. package/.claude/agents/cfn-dev-team/developers/backend-developer.md +206 -0
  37. package/.claude/agents/cfn-dev-team/developers/data/data-engineer.md +672 -0
  38. package/.claude/agents/cfn-dev-team/developers/database/database-architect.md +376 -0
  39. package/.claude/agents/cfn-dev-team/developers/database/supabase-specialist.md +746 -0
  40. package/.claude/agents/cfn-dev-team/developers/frontend/mobile-dev.md +247 -0
  41. package/.claude/agents/cfn-dev-team/developers/frontend/react-frontend-engineer.md +272 -0
  42. package/.claude/agents/cfn-dev-team/developers/frontend/typescript-specialist.md +396 -0
  43. package/.claude/agents/cfn-dev-team/developers/frontend/ui-designer.md +221 -0
  44. package/.claude/agents/cfn-dev-team/developers/graphql-specialist.md +707 -0
  45. package/.claude/agents/cfn-dev-team/developers/rust-developer.md +228 -0
  46. package/.claude/agents/cfn-dev-team/documentation/README-VALIDATION.md +245 -0
  47. package/.claude/agents/cfn-dev-team/documentation/agent-type-guidelines.md +476 -0
  48. package/.claude/agents/cfn-dev-team/documentation/api-documentation.md +111 -0
  49. package/.claude/agents/cfn-dev-team/documentation/pseudocode.md +144 -0
  50. package/.claude/agents/cfn-dev-team/documentation/specification-agent.md +152 -0
  51. package/.claude/agents/cfn-dev-team/product-owners/accessibility-advocate-persona.md +119 -0
  52. package/.claude/agents/cfn-dev-team/product-owners/cto-agent.md +138 -0
  53. package/.claude/agents/cfn-dev-team/product-owners/power-user-persona.md +151 -0
  54. package/.claude/agents/cfn-dev-team/product-owners/product-owner.md +483 -0
  55. package/.claude/agents/cfn-dev-team/reviewers/README.md +58 -0
  56. package/.claude/agents/cfn-dev-team/reviewers/code-reviewer.md +303 -0
  57. package/.claude/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +220 -0
  58. package/.claude/agents/cfn-dev-team/reviewers/quality/cyclomatic-complexity-reducer.md +334 -0
  59. package/.claude/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +257 -0
  60. package/.claude/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +160 -0
  61. package/.claude/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +386 -0
  62. package/.claude/agents/cfn-dev-team/testers/README.md +94 -0
  63. package/.claude/agents/cfn-dev-team/testers/api-testing-specialist.md +757 -0
  64. package/.claude/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +944 -0
  65. package/.claude/agents/cfn-dev-team/testers/contract-tester.md +687 -0
  66. package/.claude/agents/cfn-dev-team/testers/e2e/playwright-tester.md +124 -0
  67. package/.claude/agents/cfn-dev-team/testers/integration-tester.md +785 -0
  68. package/.claude/agents/cfn-dev-team/testers/interaction-tester.md +188 -0
  69. package/.claude/agents/cfn-dev-team/testers/load-testing-specialist.md +505 -0
  70. package/.claude/agents/cfn-dev-team/testers/mutation-testing-specialist.md +643 -0
  71. package/.claude/agents/cfn-dev-team/testers/playwright-tester.md +253 -0
  72. package/.claude/agents/cfn-dev-team/testers/tester.md +224 -0
  73. package/.claude/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +37 -0
  74. package/.claude/agents/cfn-dev-team/testers/validation/validation-production-validator.md +27 -0
  75. package/.claude/agents/cfn-dev-team/testing/test-validation-agent.md +280 -0
  76. package/.claude/agents/cfn-dev-team/utility/agent-builder.md +487 -0
  77. package/.claude/agents/cfn-dev-team/utility/context-curator.md +69 -0
  78. package/.claude/agents/cfn-dev-team/utility/epic-creator-v2.md +2 -0
  79. package/.claude/agents/cfn-dev-team/utility/epic-creator.md +7 -0
  80. package/.claude/agents/cfn-dev-team/utility/memory-leak-specialist.md +177 -0
  81. package/.claude/agents/cfn-dev-team/utility/researcher.md +116 -0
  82. package/.claude/agents/cfn-dev-team/utility/z-ai-specialist.md +218 -0
  83. package/.claude/agents/csuite/cto-agent.md +371 -0
  84. package/.claude/agents/custom/cfn-docker-expert.md +132 -0
  85. package/.claude/agents/custom/cfn-loops-cli-expert.md +9 -0
  86. package/.claude/agents/custom/cfn-redis-operations.md +538 -0
  87. package/.claude/agents/custom/cfn-system-expert.md +489 -0
  88. package/.claude/agents/custom/claude-code-expert.md +298 -0
  89. package/.claude/agents/custom/mdap-trigger-specialist.md +82 -0
  90. package/.claude/agents/custom/trigger-dev-expert.md +386 -0
  91. package/.claude/agents/docker-coordinators/cfn-docker-v3-coordinator.md +1101 -0
  92. package/.claude/agents/docker-ts-fixer.md +65 -0
  93. package/.claude/agents/project-only-agents/npm-package-specialist.md +334 -0
  94. package/.claude/agents/validate-agent.js +841 -0
  95. package/.claude/cfn-config/team-providers.json +102 -0
  96. package/.claude/cfn-extras/.gs-api-quota.json +16 -0
  97. package/.claude/cfn-extras/.gs-progress-state.json +22 -0
  98. package/.claude/cfn-extras/agents/cfn-coordinator-enterprise.md +1303 -0
  99. package/.claude/cfn-extras/agents/cfn-coordinator-mvp.md +942 -0
  100. package/.claude/cfn-extras/agents/cfn-coordinator-standard.md +1062 -0
  101. package/.claude/cfn-extras/agents/cfn-loop-coordinator.md +157 -0
  102. package/.claude/cfn-extras/agents/cfn-v3-coordinator.md +517 -0
  103. package/.claude/cfn-extras/agents/code-booster.md +67 -0
  104. package/.claude/cfn-extras/agents/coordinator.md +182 -0
  105. package/.claude/cfn-extras/agents/cost-savings-cfn-loop-coordinator.md +760 -0
  106. package/.claude/cfn-extras/agents/cost-savings-coordinator.md +173 -0
  107. package/.claude/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator-enhanced.md +147 -0
  108. package/.claude/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md +162 -0
  109. package/.claude/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md +729 -0
  110. package/.claude/cfn-extras/agents/deprecated-coordinators/byzantine-coordinator.md +100 -0
  111. package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-enterprise.md +323 -0
  112. package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-mvp.md +157 -0
  113. package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-standard.md +229 -0
  114. package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-unified.md +149 -0
  115. package/.claude/cfn-extras/agents/deprecated-coordinators/coordinator-hybrid.md +231 -0
  116. package/.claude/cfn-extras/agents/deprecated-coordinators/gossip-coordinator.md +165 -0
  117. package/.claude/cfn-extras/agents/deprecated-coordinators/hierarchical-coordinator.md +95 -0
  118. package/.claude/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md +132 -0
  119. package/.claude/cfn-extras/agents/deprecated-coordinators/task-coordinator.md +109 -0
  120. package/.claude/cfn-extras/agents/deprecated-coordinators/test-coordinator.md +142 -0
  121. package/.claude/cfn-extras/agents/docker-team/csuite/c-suite-template.md +529 -0
  122. package/.claude/cfn-extras/agents/docker-team/infrastructure/team-coordinator-template.md +467 -0
  123. package/.claude/cfn-extras/agents/docker-team/micro-sprint-planner.md +747 -0
  124. package/.claude/cfn-extras/agents/google-sheets/README.md +114 -0
  125. package/.claude/cfn-extras/agents/google-sheets/google-sheets-advanced-analytics-specialist.md +288 -0
  126. package/.claude/cfn-extras/agents/google-sheets/google-sheets-api-integrator.md +127 -0
  127. package/.claude/cfn-extras/agents/google-sheets/google-sheets-automation-scripting-specialist.md +195 -0
  128. package/.claude/cfn-extras/agents/google-sheets/google-sheets-business-validator.md +179 -0
  129. package/.claude/cfn-extras/agents/google-sheets/google-sheets-collaboration-security-specialist.md +240 -0
  130. package/.claude/cfn-extras/agents/google-sheets/google-sheets-coordinator.md +214 -0
  131. package/.claude/cfn-extras/agents/google-sheets/google-sheets-data-transformer.md +127 -0
  132. package/.claude/cfn-extras/agents/google-sheets/google-sheets-data-validation-quality-specialist.md +177 -0
  133. package/.claude/cfn-extras/agents/google-sheets/google-sheets-data-validator.md +119 -0
  134. package/.claude/cfn-extras/agents/google-sheets/google-sheets-data-visualization-specialist.md +135 -0
  135. package/.claude/cfn-extras/agents/google-sheets/google-sheets-design-layout-specialist.md +109 -0
  136. package/.claude/cfn-extras/agents/google-sheets/google-sheets-formula-engineer.md +127 -0
  137. package/.claude/cfn-extras/agents/google-sheets/google-sheets-formula-engineering-specialist.md +138 -0
  138. package/.claude/cfn-extras/agents/google-sheets/google-sheets-formula-validator.md +128 -0
  139. package/.claude/cfn-extras/agents/google-sheets/google-sheets-generalist.md +645 -0
  140. package/.claude/cfn-extras/agents/google-sheets/google-sheets-integration-api-specialist.md +258 -0
  141. package/.claude/cfn-extras/agents/google-sheets/google-sheets-performance-analyst.md +125 -0
  142. package/.claude/cfn-extras/agents/google-sheets/google-sheets-performance-optimization-specialist.md +211 -0
  143. package/.claude/cfn-extras/agents/google-sheets/google-sheets-schema-designer.md +130 -0
  144. package/.claude/cfn-extras/agents/google-sheets/google-sheets-template-architecture-specialist.md +259 -0
  145. package/.claude/cfn-extras/agents/google-sheets-specialist.md +614 -0
  146. package/.claude/cfn-extras/commands/cfn-docker/CFN_DOCKER_CLI.md +527 -0
  147. package/.claude/cfn-extras/commands/cfn-docker/CFN_DOCKER_LOOP.md +377 -0
  148. package/.claude/cfn-extras/commands/cfn-docker/CFN_DOCKER_NATIVE.md +295 -0
  149. package/.claude/cfn-extras/commands/cfn-docker/CFN_DOCKER_TASK.md +490 -0
  150. package/.claude/cfn-extras/commands/cfn-docker/cfn-docker-core-test-suite.md +326 -0
  151. package/.claude/cfn-extras/commands/deprecated/CFN_EXPERT_UPDATE.md +142 -0
  152. package/.claude/cfn-extras/commands/deprecated/README.md +55 -0
  153. package/.claude/cfn-extras/commands/deprecated/cfn-loop-epic.md +478 -0
  154. package/.claude/cfn-extras/commands/deprecated/cfn-loop-single.md +256 -0
  155. package/.claude/cfn-extras/commands/deprecated/cfn-loop-sprints.md +396 -0
  156. package/.claude/cfn-extras/commands/deprecated/context-curate.md +200 -0
  157. package/.claude/cfn-extras/commands/deprecated/context-inject.md +251 -0
  158. package/.claude/cfn-extras/commands/deprecated/context-query.md +210 -0
  159. package/.claude/cfn-extras/commands/deprecated/context-stats.md +269 -0
  160. package/.claude/cfn-extras/commands/deprecated/cost-savings-off.md +35 -0
  161. package/.claude/cfn-extras/commands/deprecated/cost-savings-on.md +35 -0
  162. package/.claude/cfn-extras/commands/deprecated/custom-routing-activate.md +55 -0
  163. package/.claude/cfn-extras/commands/deprecated/custom-routing-deactivate.md +46 -0
  164. package/.claude/cfn-extras/commands/deprecated/github-commit.md +289 -0
  165. package/.claude/cfn-extras/commands/deprecated/github.md +221 -0
  166. package/.claude/cfn-extras/commands/deprecated/hello-world-tests.md +381 -0
  167. package/.claude/cfn-extras/commands/deprecated/parse-epic.md +357 -0
  168. package/.claude/cfn-extras/commands/deprecated/run-tests.md +119 -0
  169. package/.claude/cfn-extras/commands/deprecated/suggest-improvements.md +95 -0
  170. package/.claude/cfn-extras/commands/google-sheets/google-sheets-loop.md +289 -0
  171. package/.claude/cfn-extras/docs/GOOGLE_SHEETS_CFN_LOOP.md +619 -0
  172. package/.claude/cfn-extras/skills/GOOGLE_SHEETS_SKILLS_README.md +453 -0
  173. package/.claude/cfn-extras/skills/advanced-features/cfn-agent-swap/SKILL.md +36 -0
  174. package/.claude/cfn-extras/skills/advanced-features/cfn-agent-swap/recommend-swap.sh +60 -0
  175. package/.claude/cfn-extras/skills/advanced-features/cfn-api-validation/test-endpoints.sh +54 -0
  176. package/.claude/cfn-extras/skills/advanced-features/cfn-context-pruner/SKILL.md +75 -0
  177. package/.claude/cfn-extras/skills/advanced-features/cfn-context-pruner/prune-context.sh +73 -0
  178. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/README.md +299 -0
  179. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/SKILL.md +412 -0
  180. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/config.json +111 -0
  181. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/eventbus-wrapper.cjs +69 -0
  182. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-publish.sh +147 -0
  183. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-subscribe.sh +171 -0
  184. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-lifecycle-track.sh +201 -0
  185. package/.claude/cfn-extras/skills/advanced-features/cfn-event-bus/test-event-bus.sh +280 -0
  186. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/README.md +74 -0
  187. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/SKILL.md +412 -0
  188. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/config.json +60 -0
  189. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-allocate.sh +182 -0
  190. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-balance.sh +239 -0
  191. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-metrics.sh +193 -0
  192. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-register.sh +124 -0
  193. package/.claude/cfn-extras/skills/advanced-features/cfn-fleet-manager/test-fleet-manager.sh +345 -0
  194. package/.claude/cfn-extras/skills/advanced-features/cfn-task-mode-safety/cli-coordination.sh +519 -0
  195. package/.claude/cfn-extras/skills/advanced-features/cfn-task-mode-safety/mode-detection.sh +326 -0
  196. package/.claude/cfn-extras/skills/advanced-features/cfn-task-mode-sanitize/task-mode-env-sanitizer.sh +267 -0
  197. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/SKILL.md +40 -0
  198. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-clean.json +0 -0
  199. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-fixed.json +19 -0
  200. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry.json +719 -0
  201. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.py +184 -0
  202. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.sh +87 -0
  203. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/invoke-registry.sh +11 -0
  204. package/.claude/cfn-extras/skills/deprecated/cfn-agent-discovery/temp_script.py +0 -0
  205. package/.claude/cfn-extras/skills/deprecated/cfn-agent-selector/SKILL.md +91 -0
  206. package/.claude/cfn-extras/skills/deprecated/cfn-agent-selector/select-agents.sh +112 -0
  207. package/.claude/cfn-extras/skills/deprecated/cfn-cli-setup/validate-cli-environment.sh +192 -0
  208. package/.claude/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/DESIGN.md +98 -0
  209. package/.claude/cfn-extras/skills/google-sheets-api-coordinator/SKILL.md +272 -0
  210. package/.claude/cfn-extras/skills/google-sheets-api-coordinator/api-call.sh +254 -0
  211. package/.claude/cfn-extras/skills/google-sheets-api-coordinator/test.sh +174 -0
  212. package/.claude/cfn-extras/skills/google-sheets-api-coordinator/validate.sh +98 -0
  213. package/.claude/cfn-extras/skills/google-sheets-decomposition/SKILL.md +269 -0
  214. package/.claude/cfn-extras/skills/google-sheets-decomposition/decompose.sh +313 -0
  215. package/.claude/cfn-extras/skills/google-sheets-formula-builder/SKILL.md +237 -0
  216. package/.claude/cfn-extras/skills/google-sheets-formula-builder/build-formula.sh +220 -0
  217. package/.claude/cfn-extras/skills/google-sheets-formula-builder/test.sh +172 -0
  218. package/.claude/cfn-extras/skills/google-sheets-formula-builder/validate.sh +98 -0
  219. package/.claude/cfn-extras/skills/google-sheets-progress/SKILL.md +287 -0
  220. package/.claude/cfn-extras/skills/google-sheets-progress/test.sh +385 -0
  221. package/.claude/cfn-extras/skills/google-sheets-progress/track-progress.sh +516 -0
  222. package/.claude/cfn-extras/skills/google-sheets-progress/validate.sh +119 -0
  223. package/.claude/cfn-extras/skills/google-sheets-sprint-order/SKILL.md +277 -0
  224. package/.claude/cfn-extras/skills/google-sheets-sprint-order/order-sprints.sh +233 -0
  225. package/.claude/cfn-extras/skills/google-sheets-validation/SKILL.md +352 -0
  226. package/.claude/cfn-extras/skills/google-sheets-validation/test.sh +355 -0
  227. package/.claude/cfn-extras/skills/google-sheets-validation/validate-state.sh +374 -0
  228. package/.claude/cfn-extras/skills/google-sheets-validation/validate.sh +128 -0
  229. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/SKILL.md +392 -0
  230. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/create-campaign.sh +231 -0
  231. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +190 -0
  232. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +142 -0
  233. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/set-budget.sh +181 -0
  234. package/.claude/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +133 -0
  235. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/SKILL.md +124 -0
  236. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-ad-performance.sh +105 -0
  237. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +102 -0
  238. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-email-performance.sh +105 -0
  239. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-social-engagement.sh +105 -0
  240. package/.claude/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-website-traffic.sh +107 -0
  241. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/SKILL.md +340 -0
  242. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +121 -0
  243. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +156 -0
  244. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +181 -0
  245. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/send-message.sh +137 -0
  246. package/.claude/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +179 -0
  247. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/SKILL.md +350 -0
  248. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +154 -0
  249. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +173 -0
  250. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +147 -0
  251. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +146 -0
  252. package/.claude/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +167 -0
  253. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/SKILL.md +116 -0
  254. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/add-to-segment.sh +78 -0
  255. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/create-contact.sh +113 -0
  256. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/get-contact.sh +86 -0
  257. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +78 -0
  258. package/.claude/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/update-contact.sh +120 -0
  259. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/SKILL.md +106 -0
  260. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/create-campaign.sh +123 -0
  261. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +66 -0
  262. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/list-templates.sh +68 -0
  263. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +85 -0
  264. package/.claude/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/send-test-email.sh +81 -0
  265. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/SKILL.md +366 -0
  266. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-ab-test.sh +231 -0
  267. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-landing-page.sh +190 -0
  268. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/get-page-performance.sh +137 -0
  269. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/publish-page.sh +120 -0
  270. package/.claude/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/unpublish-page.sh +108 -0
  271. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/SKILL.md +202 -0
  272. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +104 -0
  273. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/export-report.sh +92 -0
  274. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +85 -0
  275. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/search-mentions.sh +86 -0
  276. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-outreach/SKILL.md +168 -0
  277. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/search-journalists.sh +74 -0
  278. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/send-pitch.sh +80 -0
  279. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/submit-haro-response.sh +88 -0
  280. package/.claude/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +66 -0
  281. package/.claude/cfn-extras/skills/marketing/cfn-marketing-press-distribution/SKILL.md +159 -0
  282. package/.claude/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/distribute-press-release.sh +94 -0
  283. package/.claude/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-distribution-status.sh +59 -0
  284. package/.claude/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +72 -0
  285. package/.claude/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/list-templates.sh +53 -0
  286. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/SKILL.md +429 -0
  287. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/create-campaign.sh +183 -0
  288. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +139 -0
  289. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/opt-out.sh +150 -0
  290. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +187 -0
  291. package/.claude/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/send-sms.sh +181 -0
  292. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/SKILL.md +108 -0
  293. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/create-post.sh +104 -0
  294. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/delete-post.sh +76 -0
  295. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/get-post-stats.sh +66 -0
  296. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/schedule-post.sh +85 -0
  297. package/.claude/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/upload-media.sh +88 -0
  298. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/DESIGN.md +117 -0
  299. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/SKILL.md +679 -0
  300. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-agents.sh +129 -0
  301. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-dashboard.sh +85 -0
  302. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-events.sh +125 -0
  303. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-metrics.sh +112 -0
  304. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-start.sh +135 -0
  305. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-stop.sh +121 -0
  306. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/test-web-portal-skill.sh +51 -0
  307. package/.claude/cfn-extras/skills/ui-portal/cfn-web-portal/validate-deployment.sh +85 -0
  308. package/.claude/cfn-extras/skills/utility/cfn-environment-sanitization/SKILL.md +200 -0
  309. package/.claude/cfn-extras/skills/utility/cfn-environment-sanitization/sanitize-environment.sh +244 -0
  310. package/.claude/cfn-extras/skills/utility/cfn-process-instrumentation/SKILL.md +279 -0
  311. package/.claude/cfn-extras/skills/utility/cfn-process-instrumentation/instrument-process.sh +327 -0
  312. package/.claude/cfn-extras/workflows/marketing-ad-campaigns.json +125 -0
  313. package/.claude/cfn-extras/workflows/marketing-analytics-data.json +93 -0
  314. package/.claude/cfn-extras/workflows/marketing-chatbot-conversations.json +89 -0
  315. package/.claude/cfn-extras/workflows/marketing-competitive-intel.json +140 -0
  316. package/.claude/cfn-extras/workflows/marketing-crm-contacts.json +86 -0
  317. package/.claude/cfn-extras/workflows/marketing-email-campaigns.json +86 -0
  318. package/.claude/cfn-extras/workflows/marketing-landing-pages.json +137 -0
  319. package/.claude/cfn-extras/workflows/marketing-media-outreach.json +211 -0
  320. package/.claude/cfn-extras/workflows/marketing-press-distribution.json +224 -0
  321. package/.claude/cfn-extras/workflows/marketing-sms-campaigns.json +81 -0
  322. package/.claude/cfn-extras/workflows/marketing-social-publishing.json +86 -0
  323. package/.claude/commands/README.md +204 -0
  324. package/.claude/commands/cfn-loop/CFN_LOOP_FRONTEND.md +741 -0
  325. package/.claude/commands/cfn-loop/cfn-loop-cli.md +273 -0
  326. package/.claude/commands/cfn-loop/cfn-loop-document.md +499 -0
  327. package/.claude/commands/cfn-loop/cfn-loop-task.md +490 -0
  328. package/.claude/commands/cfn-loop/cfn-loop-trigger.md +56 -0
  329. package/.claude/commands/cfn-loop/cfn-mode.md +20 -0
  330. package/.claude/commands/cfn-loop/cfn-optimize-agents.md +103 -0
  331. package/.claude/commands/cfn-loop/list-agents-rebuild.md +205 -0
  332. package/.claude/commands/cfn-ruvector/codebase-reindex.md +37 -0
  333. package/.claude/commands/cfn-ruvector/codebase-search.md +38 -0
  334. package/.claude/commands/cfn-ruvector/detect-stale-docs.md +41 -0
  335. package/.claude/commands/cfn-test-framework +5 -0
  336. package/.claude/commands/check-errors.md +34 -0
  337. package/.claude/commands/cost-routing/switch-api.md +109 -0
  338. package/.claude/commands/detect-stale-docs.md +26 -0
  339. package/.claude/commands/epic-creator-v2.md +10 -0
  340. package/.claude/commands/ruvector-search.md +46 -0
  341. package/.claude/commands/sparc.md +46 -0
  342. package/.claude/commands/update-search-index.md +31 -0
  343. package/.claude/commands/workflow.md +295 -0
  344. package/.claude/commands/write-plan.md +275 -0
  345. package/.claude/coordinator-feedback-pattern.md +326 -0
  346. package/.claude/coordinator-patterns.md +126 -0
  347. package/.claude/core/agent-manager.js +80 -0
  348. package/.claude/core/agent-manager.js.map +1 -0
  349. package/.claude/core/config.js +1241 -0
  350. package/.claude/core/config.js.map +1 -0
  351. package/.claude/core/event-bus.js +136 -0
  352. package/.claude/core/event-bus.js.map +1 -0
  353. package/.claude/core/index.js +6 -0
  354. package/.claude/core/index.js.map +1 -0
  355. package/.claude/core/json-persistence.js +112 -0
  356. package/.claude/core/json-persistence.js.map +1 -0
  357. package/.claude/core/logger.js +245 -0
  358. package/.claude/core/logger.js.map +1 -0
  359. package/.claude/core/orchestrator-fixed.js +236 -0
  360. package/.claude/core/orchestrator-fixed.js.map +1 -0
  361. package/.claude/core/orchestrator.js +1136 -0
  362. package/.claude/core/orchestrator.js.map +1 -0
  363. package/.claude/core/persistence.js +185 -0
  364. package/.claude/core/persistence.js.map +1 -0
  365. package/.claude/core/project-manager.js +80 -0
  366. package/.claude/core/project-manager.js.map +1 -0
  367. package/.claude/core/slash-command.js +24 -0
  368. package/.claude/core/version.js +35 -0
  369. package/.claude/core/version.js.map +1 -0
  370. package/.claude/helpers/checkpoint-manager.sh +251 -0
  371. package/.claude/helpers/github-safe.js +106 -0
  372. package/.claude/helpers/github-setup.sh +28 -0
  373. package/.claude/helpers/quick-start.sh +19 -0
  374. package/.claude/helpers/setup-mcp.sh +18 -0
  375. package/.claude/helpers/standard-checkpoint-hooks.sh +179 -0
  376. package/.claude/hooks/GIT-HOOKS-USAGE-EXAMPLES.md +116 -0
  377. package/.claude/hooks/README-GIT-HOOKS.md +443 -0
  378. package/.claude/hooks/SKILL.md +518 -0
  379. package/.claude/hooks/SKILL.md.backup +471 -0
  380. package/.claude/hooks/cfn-BACKUP_USAGE.md +243 -0
  381. package/.claude/hooks/cfn-invoke-post-edit-ts.sh +100 -0
  382. package/.claude/hooks/cfn-invoke-post-edit.sh +135 -0
  383. package/.claude/hooks/cfn-invoke-pre-edit-ts.sh +116 -0
  384. package/.claude/hooks/cfn-invoke-pre-edit.sh +110 -0
  385. package/.claude/hooks/cfn-invoke-security-validation.sh +70 -0
  386. package/.claude/hooks/cfn-lint-sql-injection.sh +61 -0
  387. package/.claude/hooks/cfn-post-edit-cfn-retrospective.sh +110 -0
  388. package/.claude/hooks/cfn-post-edit.config.json +51 -0
  389. package/.claude/hooks/cfn-post-edit.sh +21 -0
  390. package/.claude/hooks/cfn-post-execution/memory-cleanup.sh +20 -0
  391. package/.claude/hooks/cfn-pre-edit-backup.sh +71 -0
  392. package/.claude/hooks/cfn-pre-edit-security-warning.sh +40 -0
  393. package/.claude/hooks/cfn-pre-execution/SESSION_START_README.md +87 -0
  394. package/.claude/hooks/cfn-pre-execution/TEST_SESSION_START.md +128 -0
  395. package/.claude/hooks/cfn-pre-execution/memory-check.sh +20 -0
  396. package/.claude/hooks/cfn-pre-execution/session-start-context.sh +111 -0
  397. package/.claude/hooks/cfn-restore-from-backup.sh +37 -0
  398. package/.claude/hooks/detect-hardcoded-credentials.sh +212 -0
  399. package/.claude/hooks/install-git-hooks.sh +243 -0
  400. package/.claude/hooks/post-commit-codebase-index +75 -0
  401. package/.claude/hooks/subagent-start.sh +98 -0
  402. package/.claude/hooks/subagent-stop.sh +93 -0
  403. package/.claude/hooks/validators/credential-scanner.sh +172 -0
  404. package/.claude/hooks.json +33 -0
  405. package/.claude/logs/sprint1-hybrid-routing-v2-decision.json +18 -0
  406. package/.claude/prompts/cfn-loop-context.md +115 -0
  407. package/.claude/prompts/loop-specific/loop2.md +50 -0
  408. package/.claude/prompts/loop-specific/loop3.md +43 -0
  409. package/.claude/prompts/loop-specific/loop4.md +54 -0
  410. package/.claude/root-claude-distribute/CFN-CLAUDE.md +513 -0
  411. package/.claude/settings.json +172 -0
  412. package/.claude/settings.local.json +41 -0
  413. package/.claude/settings.playwright.json +198 -0
  414. package/.claude/skills/.cfn/task-configs/task-test-123.json +48 -0
  415. package/.claude/skills/SKILL_TEMPLATE.md +774 -0
  416. package/.claude/skills/bulk-add-ruvector-instructions.sh +89 -0
  417. package/.claude/skills/cfn-agent-lifecycle/SKILL.md +290 -0
  418. package/.claude/skills/cfn-agent-lifecycle/cli/lifecycle-hook.sh +5 -0
  419. package/.claude/skills/cfn-agent-lifecycle/cli/select-agents.sh +5 -0
  420. package/.claude/skills/cfn-agent-lifecycle/cli/spawn-agent.sh +5 -0
  421. package/.claude/skills/cfn-agent-lifecycle/execute.sh +355 -0
  422. package/.claude/skills/cfn-agent-lifecycle/lib/audit/execute-lifecycle-hook.sh +544 -0
  423. package/.claude/skills/cfn-agent-lifecycle/lib/audit/simple-audit.sh +58 -0
  424. package/.claude/skills/cfn-agent-lifecycle/lib/output/README.md +359 -0
  425. package/.claude/skills/cfn-agent-lifecycle/lib/selection/SKILL.md +29 -0
  426. package/.claude/skills/cfn-agent-lifecycle/lib/selection/agent-mappings.json +142 -0
  427. package/.claude/skills/cfn-agent-lifecycle/lib/selection/select-agents-with-fallback.sh +195 -0
  428. package/.claude/skills/cfn-agent-lifecycle/lib/selection/select-agents.sh +94 -0
  429. package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/agent-selector.ts +350 -0
  430. package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/cli.ts +74 -0
  431. package/.claude/skills/cfn-agent-lifecycle/lib/selection/task-classifier.sh +93 -0
  432. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/SKILL.md +38 -0
  433. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/check-dependencies.sh +52 -0
  434. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/execute-agent.sh +126 -0
  435. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/get-agent-provider-env.sh +149 -0
  436. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/parse-agent-provider.sh +81 -0
  437. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent-wrapper.sh +63 -0
  438. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent.sh +308 -0
  439. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-templates.sh +635 -0
  440. package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-worker.sh +198 -0
  441. package/.claude/skills/cfn-agent-tooling/SKILL.md +52 -0
  442. package/.claude/skills/cfn-agent-tooling/lib/generator/SKILL.md +440 -0
  443. package/.claude/skills/cfn-agent-tooling/lib/generator/generate-agent.sh +405 -0
  444. package/.claude/skills/cfn-agent-tooling/lib/linter/SKILL.md +589 -0
  445. package/.claude/skills/cfn-agent-tooling/lib/linter/lint-agents.sh +271 -0
  446. package/.claude/skills/cfn-cerebras-code-generator/SKILL.md +53 -0
  447. package/.claude/skills/cfn-cerebras-code-generator/context-analyzer.sh +96 -0
  448. package/.claude/skills/cfn-cerebras-code-generator/generate-code.sh +205 -0
  449. package/.claude/skills/cfn-cerebras-coordinator/SKILL.md +103 -0
  450. package/.claude/skills/cfn-cerebras-coordinator/TEST_RESULTS.md +98 -0
  451. package/.claude/skills/cfn-cerebras-coordinator/coordinate-generation.sh +381 -0
  452. package/.claude/skills/cfn-cerebras-coordinator/example-fix-scenario.md +254 -0
  453. package/.claude/skills/cfn-cerebras-coordinator/example-workflow.md +142 -0
  454. package/.claude/skills/cfn-cerebras-coordinator/feedback-logger.sh +254 -0
  455. package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code-v2.sh +443 -0
  456. package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code.sh +519 -0
  457. package/.claude/skills/cfn-cerebras-coordinator/pattern-examples.md +317 -0
  458. package/.claude/skills/cfn-cerebras-coordinator/query-patterns.sh +182 -0
  459. package/.claude/skills/cfn-cerebras-coordinator/tdd-coordinator.sh +638 -0
  460. package/.claude/skills/cfn-cerebras-coordinator/test-runner.sh +335 -0
  461. package/.claude/skills/cfn-cerebras-mcp/SKILL.md +64 -0
  462. package/.claude/skills/cfn-compilation-error-fixer/HANDOFF.md +29 -0
  463. package/.claude/skills/cfn-compilation-error-fixer/README.md +202 -0
  464. package/.claude/skills/cfn-compilation-error-fixer/SKILL.md +426 -0
  465. package/.claude/skills/cfn-compilation-error-fixer/bin/fix-errors.sh +75 -0
  466. package/.claude/skills/cfn-compilation-error-fixer/index.js +81 -0
  467. package/.claude/skills/cfn-compilation-error-fixer/install.sh +60 -0
  468. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/README-TypeScript.md +164 -0
  469. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1475 -0
  470. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts.bak +1475 -0
  471. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-sdk.d.ts +30 -0
  472. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-wrapper.ts +93 -0
  473. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json +30 -0
  474. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json.bak +23 -0
  475. package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/typescript-gated-fixer-v2.ts +977 -0
  476. package/.claude/skills/cfn-compilation-error-fixer/lib/gates/typescript-gates.ts +704 -0
  477. package/.claude/skills/cfn-compilation-error-fixer/package.json +47 -0
  478. package/.claude/skills/cfn-compilation-error-fixer/test-fixer-logic.sh +96 -0
  479. package/.claude/skills/cfn-compilation-error-fixer/test-installation.sh +97 -0
  480. package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer-validation.sh +54 -0
  481. package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer.sh +380 -0
  482. package/.claude/skills/cfn-compilation-error-fixer/test-typescript-fixer.sh +278 -0
  483. package/.claude/skills/cfn-compilation-error-fixer/validate-setup.md +70 -0
  484. package/.claude/skills/cfn-config/SKILL.md +52 -0
  485. package/.claude/skills/cfn-config/lib/management/README.md +42 -0
  486. package/.claude/skills/cfn-config/lib/management/SKILL.md +34 -0
  487. package/.claude/skills/cfn-config/lib/management/check-dependencies.sh +56 -0
  488. package/.claude/skills/cfn-config/lib/management/config.json +32 -0
  489. package/.claude/skills/cfn-config/lib/management/manage-config.sh +115 -0
  490. package/.claude/skills/cfn-config/lib/sanitization/sanitize-environment.sh +48 -0
  491. package/.claude/skills/cfn-conversation-sync/README.md +133 -0
  492. package/.claude/skills/cfn-conversation-sync/SKILL.md +82 -0
  493. package/.claude/skills/cfn-conversation-sync/sync-conversations.sh +229 -0
  494. package/.claude/skills/cfn-dependency-management/SKILL.md +118 -0
  495. package/.claude/skills/cfn-dependency-management/cfn-dependency-management.sh +18 -0
  496. package/.claude/skills/cfn-dependency-management/execute.sh +306 -0
  497. package/.claude/skills/cfn-dependency-management/lib/extractor/SKILL.md +35 -0
  498. package/.claude/skills/cfn-dependency-management/lib/extractor/extract-dependencies.sh +66 -0
  499. package/.claude/skills/cfn-dependency-management/lib/ingestion/README.md +101 -0
  500. package/.claude/skills/cfn-dependency-management/lib/ingestion/SKILL.md +397 -0
  501. package/.claude/skills/cfn-dependency-management/lib/ingestion/build.sh +23 -0
  502. package/.claude/skills/cfn-dependency-management/lib/ingestion/ingest-dependencies.sh +295 -0
  503. package/.claude/skills/cfn-dependency-management/lib/ingestion/ingest.sh +237 -0
  504. package/.claude/skills/cfn-dependency-management/lib/ingestion/manifests/cli-mode-dependencies.txt +219 -0
  505. package/.claude/skills/cfn-dependency-management/lib/ingestion/manifests/shared-dependencies.txt +57 -0
  506. package/.claude/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-dev-dependencies.txt +82 -0
  507. package/.claude/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-mode-dependencies.txt +80 -0
  508. package/.claude/skills/cfn-dependency-management/lib/ingestion/src/ingest-dependencies.ts +563 -0
  509. package/.claude/skills/cfn-deployment-lifecycle/SKILL.md +53 -0
  510. package/.claude/skills/cfn-deployment-lifecycle/lib/deployment/SKILL.md +293 -0
  511. package/.claude/skills/cfn-deployment-lifecycle/lib/deployment/execute.sh +21 -0
  512. package/.claude/skills/cfn-deployment-lifecycle/lib/promotion/SKILL.md +305 -0
  513. package/.claude/skills/cfn-docker-runtime/SKILL.md +84 -0
  514. package/.claude/skills/cfn-docker-runtime/execute.sh +386 -0
  515. package/.claude/skills/cfn-docker-runtime/lib/coordination/README.md +349 -0
  516. package/.claude/skills/cfn-docker-runtime/lib/coordination/docker-helpers.sh +433 -0
  517. package/.claude/skills/cfn-docker-runtime/lib/coordination/package.json +38 -0
  518. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/agent-container.ts +471 -0
  519. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/docker-client.ts +483 -0
  520. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/health-checker.ts +418 -0
  521. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/index.ts +45 -0
  522. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/network-manager.ts +377 -0
  523. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/types.ts +412 -0
  524. package/.claude/skills/cfn-docker-runtime/lib/coordination/src/volume-manager.ts +389 -0
  525. package/.claude/skills/cfn-docker-runtime/lib/logging/INTEGRATION.md +268 -0
  526. package/.claude/skills/cfn-docker-runtime/lib/logging/SAMPLE_OUTPUTS.md +237 -0
  527. package/.claude/skills/cfn-docker-runtime/lib/logging/SKILL.md +442 -0
  528. package/.claude/skills/cfn-docker-runtime/lib/logging/capture-container-logs.sh +120 -0
  529. package/.claude/skills/cfn-docker-runtime/lib/logging/enable-logging.sh +430 -0
  530. package/.claude/skills/cfn-docker-runtime/lib/logging/init-hybrid-logging.sh +210 -0
  531. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/analytics-summary.sh +87 -0
  532. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/query-agent-timeline.sh +51 -0
  533. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/query-consensus-history.sh +56 -0
  534. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/query-coordination-timeline.sh +39 -0
  535. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/query-failed-containers.sh +40 -0
  536. package/.claude/skills/cfn-docker-runtime/lib/logging/queries/query-gate-checks.sh +39 -0
  537. package/.claude/skills/cfn-docker-runtime/lib/logging/schema.sql +111 -0
  538. package/.claude/skills/cfn-docker-runtime/lib/logging/sqlite-helpers.sh +240 -0
  539. package/.claude/skills/cfn-docker-runtime/lib/logging/test-hybrid-logging.sh +331 -0
  540. package/.claude/skills/cfn-docker-runtime/lib/mcp/SKILL.md +555 -0
  541. package/.claude/skills/cfn-docker-runtime/lib/mcp/skill-mcp-selector.js +472 -0
  542. package/.claude/skills/cfn-docker-runtime/lib/orchestration/SKILL.md +449 -0
  543. package/.claude/skills/cfn-docker-runtime/lib/orchestration/orchestrate.sh +1722 -0
  544. package/.claude/skills/cfn-docker-runtime/lib/spawning/SKILL.md +418 -0
  545. package/.claude/skills/cfn-docker-runtime/lib/spawning/spawn-agent.sh +569 -0
  546. package/.claude/skills/cfn-docker-runtime/lib/waves/SKILL.md +944 -0
  547. package/.claude/skills/cfn-docker-runtime/lib/waves/cleanup-wave.sh +445 -0
  548. package/.claude/skills/cfn-docker-runtime/lib/waves/lib/docker-helpers.sh +804 -0
  549. package/.claude/skills/cfn-docker-runtime/lib/waves/monitor-wave.sh +485 -0
  550. package/.claude/skills/cfn-docker-runtime/lib/waves/spawn-wave.sh +547 -0
  551. package/.claude/skills/cfn-edit-safety/README.md +160 -0
  552. package/.claude/skills/cfn-edit-safety/SKILL.md +62 -0
  553. package/.claude/skills/cfn-edit-safety/cli/edit-safety-cli.sh +337 -0
  554. package/.claude/skills/cfn-edit-safety/edit-safety.sh +375 -0
  555. package/.claude/skills/cfn-edit-safety/lib/backup/SKILL.md +324 -0
  556. package/.claude/skills/cfn-edit-safety/lib/backup/SKILL.md.backup +277 -0
  557. package/.claude/skills/cfn-edit-safety/lib/backup/backup.sh +129 -0
  558. package/.claude/skills/cfn-edit-safety/lib/backup/backup.sh.backup +107 -0
  559. package/.claude/skills/cfn-edit-safety/lib/hooks/README.md +74 -0
  560. package/.claude/skills/cfn-edit-safety/lib/hooks/SKILL.md +148 -0
  561. package/.claude/skills/cfn-edit-safety/lib/hooks/auto-resolve.sh +66 -0
  562. package/.claude/skills/cfn-edit-safety/lib/hooks/check-dependencies.sh +40 -0
  563. package/.claude/skills/cfn-edit-safety/lib/hooks/feedback-resolver.sh +452 -0
  564. package/.claude/skills/cfn-edit-safety/lib/hooks/post-edit-handler.sh +155 -0
  565. package/.claude/skills/cfn-edit-safety/lib/hooks/security-scan.json +60 -0
  566. package/.claude/skills/cfn-edit-safety/lib/hooks/security-scanner.sh +121 -0
  567. package/.claude/skills/cfn-edit-safety/lib/hooks/test-root-warning-resolution.sh +148 -0
  568. package/.claude/skills/cfn-epic-parser/SKILL.md +220 -0
  569. package/.claude/skills/cfn-epic-parser/example-epic.md +49 -0
  570. package/.claude/skills/cfn-epic-parser/parse.sh +517 -0
  571. package/.claude/skills/cfn-epic-parser/test-parser.sh +299 -0
  572. package/.claude/skills/cfn-error-management/SKILL.md +176 -0
  573. package/.claude/skills/cfn-error-management/cli/batch-errors.sh +4 -0
  574. package/.claude/skills/cfn-error-management/cli/capture-error.sh +4 -0
  575. package/.claude/skills/cfn-error-management/cli/log-error.sh +4 -0
  576. package/.claude/skills/cfn-error-management/lib/batching/README.md +1016 -0
  577. package/.claude/skills/cfn-error-management/lib/batching/analyze-errors.sh +327 -0
  578. package/.claude/skills/cfn-error-management/lib/batching/calculate-waves.sh +256 -0
  579. package/.claude/skills/cfn-error-management/lib/batching/cli.sh +523 -0
  580. package/.claude/skills/cfn-error-management/lib/batching/cluster-files.sh +196 -0
  581. package/.claude/skills/cfn-error-management/lib/batching/create-batches.sh +261 -0
  582. package/.claude/skills/cfn-error-management/lib/capture/README.md +56 -0
  583. package/.claude/skills/cfn-error-management/lib/capture/capture-agent-error.sh +87 -0
  584. package/.claude/skills/cfn-error-management/lib/logging/README.md +339 -0
  585. package/.claude/skills/cfn-error-management/lib/logging/cleanup-error-logs.sh +334 -0
  586. package/.claude/skills/cfn-error-management/lib/logging/integrate-cli.sh +232 -0
  587. package/.claude/skills/cfn-error-management/lib/logging/integrate-docker.sh +294 -0
  588. package/.claude/skills/cfn-error-management/lib/logging/invoke-error-logging.sh +839 -0
  589. package/.claude/skills/cfn-error-management/lib/logging/src/error-logger.ts +1042 -0
  590. package/.claude/skills/cfn-error-management/lib/logging/src/index.ts +12 -0
  591. package/.claude/skills/cfn-error-management/lib/logging/src/types.ts +456 -0
  592. package/.claude/skills/cfn-error-management/lib/logging/test-error-logging.sh +475 -0
  593. package/.claude/skills/cfn-expert-update/SKILL.md +149 -0
  594. package/.claude/skills/cfn-expert-update/test-expert-update.sh +254 -0
  595. package/.claude/skills/cfn-expert-update/update-expert.sh +484 -0
  596. package/.claude/skills/cfn-intervention-system/SKILL.md +52 -0
  597. package/.claude/skills/cfn-intervention-system/lib/detector/SKILL.md +39 -0
  598. package/.claude/skills/cfn-intervention-system/lib/detector/detect-intervention.sh +106 -0
  599. package/.claude/skills/cfn-intervention-system/lib/orchestrator/SKILL.md +43 -0
  600. package/.claude/skills/cfn-intervention-system/lib/orchestrator/execute-intervention.sh +59 -0
  601. package/.claude/skills/cfn-knowledge-base/SKILL.md +109 -0
  602. package/.claude/skills/cfn-knowledge-base/cli/knowledge-base.sh +435 -0
  603. package/.claude/skills/cfn-knowledge-base/execute.sh +163 -0
  604. package/.claude/skills/cfn-knowledge-base/lib/playbook/SKILL.md +153 -0
  605. package/.claude/skills/cfn-knowledge-base/lib/playbook/init-playbook.sh +54 -0
  606. package/.claude/skills/cfn-knowledge-base/lib/playbook/lib/auto-update/auto-update-playbook.sh +86 -0
  607. package/.claude/skills/cfn-knowledge-base/lib/playbook/query-playbook.sh +89 -0
  608. package/.claude/skills/cfn-knowledge-base/lib/playbook/update-playbook.sh +67 -0
  609. package/.claude/skills/cfn-knowledge-base/lib/workflow/APPROVAL_WORKFLOW.md +806 -0
  610. package/.claude/skills/cfn-knowledge-base/lib/workflow/COST_TRACKING.md +637 -0
  611. package/.claude/skills/cfn-knowledge-base/lib/workflow/DEPLOY_QUICK_REFERENCE.md +106 -0
  612. package/.claude/skills/cfn-knowledge-base/lib/workflow/EDGE_CASE_TRACKING.md +404 -0
  613. package/.claude/skills/cfn-knowledge-base/lib/workflow/PROPAGATE_UPDATE_QUICK_REFERENCE.md +366 -0
  614. package/.claude/skills/cfn-knowledge-base/lib/workflow/README_PHASE4.md +457 -0
  615. package/.claude/skills/cfn-knowledge-base/lib/workflow/SKILL.md +110 -0
  616. package/.claude/skills/cfn-knowledge-base/lib/workflow/approval-workflow.sh +514 -0
  617. package/.claude/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh +481 -0
  618. package/.claude/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh.backup-1763392820 +512 -0
  619. package/.claude/skills/cfn-knowledge-base/lib/workflow/generate-skill-update.sh +525 -0
  620. package/.claude/skills/cfn-knowledge-base/lib/workflow/lib/security-utils.sh +204 -0
  621. package/.claude/skills/cfn-knowledge-base/lib/workflow/package.json +30 -0
  622. package/.claude/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh +654 -0
  623. package/.claude/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh.backup-1763392820 +664 -0
  624. package/.claude/skills/cfn-knowledge-base/lib/workflow/review-skill.sh +643 -0
  625. package/.claude/skills/cfn-knowledge-base/lib/workflow/src/index.ts +24 -0
  626. package/.claude/skills/cfn-knowledge-base/lib/workflow/src/pattern-analyzer.ts +537 -0
  627. package/.claude/skills/cfn-knowledge-base/lib/workflow/src/types.ts +180 -0
  628. package/.claude/skills/cfn-knowledge-base/lib/workflow/test-integration.sh +296 -0
  629. package/.claude/skills/cfn-knowledge-base/lib/workflow/test-metadata-update.sh +350 -0
  630. package/.claude/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh +486 -0
  631. package/.claude/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh.backup-1763392821 +445 -0
  632. package/.claude/skills/cfn-knowledge-base/lib/workflow/track-edge-case.sh +290 -0
  633. package/.claude/skills/cfn-local-ruvector-accelerator/Cargo.toml +40 -0
  634. package/.claude/skills/cfn-local-ruvector-accelerator/README.md +563 -0
  635. package/.claude/skills/cfn-local-ruvector-accelerator/SKILL.md +343 -0
  636. package/.claude/skills/cfn-local-ruvector-accelerator/cfn-integration.sh +179 -0
  637. package/.claude/skills/cfn-local-ruvector-accelerator/embeddings_manager.py +289 -0
  638. package/.claude/skills/cfn-local-ruvector-accelerator/index-code.sh +234 -0
  639. package/.claude/skills/cfn-local-ruvector-accelerator/init-local-ruvector.sh +112 -0
  640. package/.claude/skills/cfn-local-ruvector-accelerator/project-structure.md +53 -0
  641. package/.claude/skills/cfn-local-ruvector-accelerator/query-local.sh +169 -0
  642. package/.claude/skills/cfn-local-ruvector-accelerator/requirements.txt +2 -0
  643. package/.claude/skills/cfn-local-ruvector-accelerator/search_engine.py +200 -0
  644. package/.claude/skills/cfn-local-ruvector-accelerator/search_engine_v2.py +238 -0
  645. package/.claude/skills/cfn-local-ruvector-accelerator/sqlite_store.py +220 -0
  646. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/cleanup.rs +134 -0
  647. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/export.rs +40 -0
  648. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/index.rs +301 -0
  649. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/init.rs +127 -0
  650. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/migration.rs +74 -0
  651. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/mod.rs +18 -0
  652. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/query.rs +222 -0
  653. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/reset.rs +37 -0
  654. package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/stats.rs +133 -0
  655. package/.claude/skills/cfn-local-ruvector-accelerator/src/embeddings.rs +121 -0
  656. package/.claude/skills/cfn-local-ruvector-accelerator/src/main.rs +359 -0
  657. package/.claude/skills/cfn-local-ruvector-accelerator/src/migration.rs +318 -0
  658. package/.claude/skills/cfn-local-ruvector-accelerator/src/search_engine.rs +281 -0
  659. package/.claude/skills/cfn-local-ruvector-accelerator/src/sqlite_store.rs +211 -0
  660. package/.claude/skills/cfn-local-ruvector-accelerator/test-local-ruvector.sh +250 -0
  661. package/.claude/skills/cfn-loop-orchestration-v2/SKILL.md +57 -0
  662. package/.claude/skills/cfn-loop-orchestration-v2/cli/cfn-orchestrator.cjs +49 -0
  663. package/.claude/skills/cfn-loop-orchestration-v2/cli/orchestrate.sh +21 -0
  664. package/.claude/skills/cfn-loop-orchestration-v2/cli/resolve-provider-model.cjs +69 -0
  665. package/.claude/skills/cfn-loop-orchestration-v2/lib/coordination/agent-completion.sh.backup +36 -0
  666. package/.claude/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-patterns.ts +194 -0
  667. package/.claude/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-signal.sh.backup +36 -0
  668. package/.claude/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-wait.sh.backup +36 -0
  669. package/.claude/skills/cfn-loop-orchestration-v2/lib/coordination/index.ts +25 -0
  670. package/.claude/skills/cfn-loop-orchestration-v2/lib/decision/SKILL.md +664 -0
  671. package/.claude/skills/cfn-loop-orchestration-v2/lib/decision/TYPESCRIPT_IMPLEMENTATION.md +653 -0
  672. package/.claude/skills/cfn-loop-orchestration-v2/lib/decision/parse-decision.sh +66 -0
  673. package/.claude/skills/cfn-loop-orchestration-v2/lib/decision/test-backlog-integration.sh +148 -0
  674. package/.claude/skills/cfn-loop-orchestration-v2/lib/decision/validate-deliverables.sh +82 -0
  675. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONFIGURATION_IMPROVEMENTS.md +318 -0
  676. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONTEXT_LOOKUP_QUICK_START.md +378 -0
  677. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/NORTH_STAR_INDEX.md +323 -0
  678. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_IMPLEMENTATION.md +493 -0
  679. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_QUICK_START.md +499 -0
  680. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/README.md +149 -0
  681. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/SKILL.md +418 -0
  682. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/SPAWN_AGENTS_IMPLEMENTATION.md +188 -0
  683. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATION_SUMMARY.txt +196 -0
  684. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATOR_MODULE_GUIDE.md +526 -0
  685. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation-fixed.js +240 -0
  686. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation.js +213 -0
  687. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/package.json +53 -0
  688. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/run-north-star-e2e.ts +210 -0
  689. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/security_utils.sh +123 -0
  690. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/agent-spawner/agent-spawner.ts +34 -0
  691. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/cli/orchestrator-cli.ts +396 -0
  692. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/gate-checker/gate-checker.ts +36 -0
  693. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR.md +564 -0
  694. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR_QUICK_REF.md +241 -0
  695. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_QUICK_REFERENCE.md +362 -0
  696. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_README.md +307 -0
  697. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_USAGE_GUIDE.md +508 -0
  698. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/confidence-aggregator.ts +473 -0
  699. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/consensus.ts +87 -0
  700. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-injector.ts +349 -0
  701. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-lookup.ts +486 -0
  702. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/deliverable-verifier.ts +107 -0
  703. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/gate-check.ts +115 -0
  704. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/iteration-manager.ts +45 -0
  705. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/parse-test-results.ts +372 -0
  706. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/product-owner-decision.ts +316 -0
  707. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/spawn-agents.ts +357 -0
  708. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/timeout-calculator.ts +41 -0
  709. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/validator.ts +276 -0
  710. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/index.ts +16 -0
  711. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrate.ts +1389 -0
  712. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrator/orchestrator.ts +31 -0
  713. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/redis/redis-coordinator.ts +72 -0
  714. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/types.ts +244 -0
  715. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/utils/logger.ts +32 -0
  716. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cfn-orchestration.sh +281 -0
  717. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cli.sh +92 -0
  718. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-edge-cases.sh +188 -0
  719. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-iteration-context-injection.sh +366 -0
  720. package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-typescript-integration.sh +442 -0
  721. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/DELIVERY_SUMMARY.txt +462 -0
  722. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/EXAMPLES.md +609 -0
  723. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/INDEX.md +531 -0
  724. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/README.md +114 -0
  725. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/SKILL.md +633 -0
  726. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/index.ts +6 -0
  727. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/output-processor.ts +183 -0
  728. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/package.json +50 -0
  729. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop2.ts +195 -0
  730. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop3.ts +157 -0
  731. package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/output-processor.ts +632 -0
  732. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/INDEX.md +531 -0
  733. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/README.md +256 -0
  734. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/README_TYPESCRIPT.md +454 -0
  735. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md +400 -0
  736. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md.backup +353 -0
  737. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/SKILL_TYPESCRIPT.md +782 -0
  738. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/VAPOR_DETECTION_EXAMPLES.md +598 -0
  739. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh +53 -0
  740. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh.backup +31 -0
  741. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/config.json +161 -0
  742. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/consensus-calculator.js +477 -0
  743. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh +59 -0
  744. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh.backup +37 -0
  745. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/evidence-chain.sql +163 -0
  746. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/index.ts +12 -0
  747. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh +274 -0
  748. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh.backup +252 -0
  749. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/package.json +93 -0
  750. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/detect-vapor.ts +177 -0
  751. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-deliverables.ts +161 -0
  752. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-gate.ts +139 -0
  753. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/types.ts +215 -0
  754. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/validator.ts +503 -0
  755. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh +59 -0
  756. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh.backup +37 -0
  757. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh +63 -0
  758. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh.backup +41 -0
  759. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh +156 -0
  760. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh.backup +134 -0
  761. package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validation-framework.ts +237 -0
  762. package/.claude/skills/cfn-mdap-context-injection/SKILL.md +21 -0
  763. package/.claude/skills/cfn-mdap-context-injection/inject.sh +348 -0
  764. package/.claude/skills/cfn-mdap-error-fixer/HANDOFF.md +383 -0
  765. package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1500 -0
  766. package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/package.json +20 -0
  767. package/.claude/skills/cfn-mdap-error-fixer/skill.md +205 -0
  768. package/.claude/skills/cfn-memory-persistence/SKILL.md +59 -0
  769. package/.claude/skills/cfn-memory-persistence/lib/auto/SKILL.md +73 -0
  770. package/.claude/skills/cfn-memory-persistence/lib/auto/persist-agent-output.sh +49 -0
  771. package/.claude/skills/cfn-memory-persistence/lib/auto/query-agent-history.sh +35 -0
  772. package/.claude/skills/cfn-memory-persistence/lib/auto/test-memory-persistence.sh +230 -0
  773. package/.claude/skills/cfn-memory-persistence/lib/management/SKILL.md +271 -0
  774. package/.claude/skills/cfn-memory-persistence/lib/management/check-memory.sh +160 -0
  775. package/.claude/skills/cfn-memory-persistence/lib/management/cleanup-memory.sh +197 -0
  776. package/.claude/skills/cfn-memory-persistence/lib/redis/SKILL.md +42 -0
  777. package/.claude/skills/cfn-memory-persistence/lib/redis/agent-log.sh.backup +128 -0
  778. package/.claude/skills/cfn-memory-persistence/lib/redis/agent-recovery.sh.backup +75 -0
  779. package/.claude/skills/cfn-memory-persistence/lib/redis/analyze-task-complexity.sh.backup +277 -0
  780. package/.claude/skills/cfn-memory-persistence/lib/redis/bash-wrappers/store-context.sh.backup +23 -0
  781. package/.claude/skills/cfn-memory-persistence/lib/redis/cancel-swarm.sh.backup +221 -0
  782. package/.claude/skills/cfn-memory-persistence/lib/redis/cfn-loop-exec.sh.backup +468 -0
  783. package/.claude/skills/cfn-memory-persistence/lib/redis/cfn-loop-relaunch.sh.backup +29 -0
  784. package/.claude/skills/cfn-memory-persistence/lib/redis/collect-confidence-scores.sh.backup +209 -0
  785. package/.claude/skills/cfn-memory-persistence/lib/redis/collect-results.sh.backup +75 -0
  786. package/.claude/skills/cfn-memory-persistence/lib/redis/complete-swarm.sh.backup +75 -0
  787. package/.claude/skills/cfn-memory-persistence/lib/redis/get-context.sh.backup +146 -0
  788. package/.claude/skills/cfn-memory-persistence/lib/redis/get-success-criteria.sh.backup +54 -0
  789. package/.claude/skills/cfn-memory-persistence/lib/redis/invoke-waiting-mode.sh.backup +225 -0
  790. package/.claude/skills/cfn-memory-persistence/lib/redis/redis-cli-wrapper.sh.backup +43 -0
  791. package/.claude/skills/cfn-memory-persistence/lib/redis/redis-functions.sh.backup +34 -0
  792. package/.claude/skills/cfn-memory-persistence/lib/redis/report-completion.sh.backup +134 -0
  793. package/.claude/skills/cfn-memory-persistence/lib/redis/store-context.sh.backup +123 -0
  794. package/.claude/skills/cfn-memory-persistence/lib/sqlite/QUICK_REFERENCE.md +204 -0
  795. package/.claude/skills/cfn-memory-persistence/lib/sqlite/README.md +65 -0
  796. package/.claude/skills/cfn-memory-persistence/lib/sqlite/SKILL.md +415 -0
  797. package/.claude/skills/cfn-memory-persistence/lib/sqlite/acl-queries.sql +452 -0
  798. package/.claude/skills/cfn-memory-persistence/lib/sqlite/check-dependencies.sh +36 -0
  799. package/.claude/skills/cfn-memory-persistence/lib/sqlite/config.json +45 -0
  800. package/.claude/skills/cfn-memory-persistence/lib/sqlite/memory-cli.sh +74 -0
  801. package/.claude/skills/cfn-memory-persistence/lib/sqlite/test-state-persistence.js +187 -0
  802. package/.claude/skills/cfn-memory-persistence/lib/sqlite/ttl-cleanup.sh +266 -0
  803. package/.claude/skills/cfn-node-heap-sizer/SKILL.md +313 -0
  804. package/.claude/skills/cfn-node-heap-sizer/task-mode-heap-limiter.sh +326 -0
  805. package/.claude/skills/cfn-operations/SKILL.md +52 -0
  806. package/.claude/skills/cfn-operations/execute.sh +175 -0
  807. package/.claude/skills/cfn-operations/lib/file/SKILL.md +290 -0
  808. package/.claude/skills/cfn-operations/lib/file/execute.sh +129 -0
  809. package/.claude/skills/cfn-operations/lib/file/lib/atomic-write.sh +294 -0
  810. package/.claude/skills/cfn-operations/lib/file/lib/lock.sh +361 -0
  811. package/.claude/skills/cfn-operations/lib/file/test.sh +373 -0
  812. package/.claude/skills/cfn-operations/lib/log/SKILL.md +308 -0
  813. package/.claude/skills/cfn-operations/lib/log/execute.sh +420 -0
  814. package/.claude/skills/cfn-operations/lib/log/lib/rotate.sh +406 -0
  815. package/.claude/skills/cfn-operations/lib/log/lib/search.sh +448 -0
  816. package/.claude/skills/cfn-operations/lib/log/test.sh +400 -0
  817. package/.claude/skills/cfn-parameterized-queries/SKILL.md +368 -0
  818. package/.claude/skills/cfn-parameterized-queries/parameterized-queries.sh +249 -0
  819. package/.claude/skills/cfn-parameterized-queries/test-implementation.sh +237 -0
  820. package/.claude/skills/cfn-planning/SKILL.md +55 -0
  821. package/.claude/skills/cfn-planning/execute.sh +159 -0
  822. package/.claude/skills/cfn-planning/lib/coordinator/README.md +256 -0
  823. package/.claude/skills/cfn-planning/lib/coordinator/SKILL.md +62 -0
  824. package/.claude/skills/cfn-planning/lib/coordinator/map-dependencies-conflicts.sh +376 -0
  825. package/.claude/skills/cfn-planning/lib/coordinator/plan-coordinator-resources.sh +258 -0
  826. package/.claude/skills/cfn-planning/lib/coordinator/plan-multi-coordinator-work.sh +267 -0
  827. package/.claude/skills/cfn-planning/lib/coordinator/plan-risk-rollout.sh +350 -0
  828. package/.claude/skills/cfn-planning/lib/coordinator/test-multi-coordinator-planning.sh +338 -0
  829. package/.claude/skills/cfn-planning/lib/coordinator/validate-task-planning.sh +189 -0
  830. package/.claude/skills/cfn-planning/lib/epic/SKILL.md +44 -0
  831. package/.claude/skills/cfn-planning/lib/epic/decompose-epic.sh +104 -0
  832. package/.claude/skills/cfn-planning/lib/scope/SKILL.md +37 -0
  833. package/.claude/skills/cfn-planning/lib/scope/simplify-scope.sh +68 -0
  834. package/.claude/skills/cfn-process-management/SKILL.md +52 -0
  835. package/.claude/skills/cfn-process-management/cfn-process +16 -0
  836. package/.claude/skills/cfn-process-management/cli/process-manager +186 -0
  837. package/.claude/skills/cfn-process-management/lib/instrumentation/instrument-process.sh +44 -0
  838. package/.claude/skills/cfn-process-management/lib/lifecycle/README.md +43 -0
  839. package/.claude/skills/cfn-process-management/lib/lifecycle/SKILL.md +39 -0
  840. package/.claude/skills/cfn-process-management/lib/lifecycle/check-dependencies.sh +58 -0
  841. package/.claude/skills/cfn-process-management/lib/lifecycle/config.json +39 -0
  842. package/.claude/skills/cfn-process-management/lib/lifecycle/process-manager.sh +334 -0
  843. package/.claude/skills/cfn-project-management/SKILL.md +60 -0
  844. package/.claude/skills/cfn-project-management/lib/backlog/SKILL.md +199 -0
  845. package/.claude/skills/cfn-project-management/lib/backlog/add-backlog-item.sh +208 -0
  846. package/.claude/skills/cfn-project-management/lib/changelog/SKILL.md +349 -0
  847. package/.claude/skills/cfn-project-management/lib/changelog/add-changelog-entry.sh +202 -0
  848. package/.claude/skills/cfn-project-management/lib/changelog/bulk-import.sh +268 -0
  849. package/.claude/skills/cfn-project-management/lib/changelog/lib/README.md +212 -0
  850. package/.claude/skills/cfn-project-management/lib/changelog/lib/validation.sh +72 -0
  851. package/.claude/skills/cfn-routing-config/SKILL.md +52 -0
  852. package/.claude/skills/cfn-routing-config/lib/hybrid/README.md +50 -0
  853. package/.claude/skills/cfn-routing-config/lib/hybrid/SKILL.md +54 -0
  854. package/.claude/skills/cfn-routing-config/lib/hybrid/check-dependencies.sh +52 -0
  855. package/.claude/skills/cfn-routing-config/lib/hybrid/config.json +26 -0
  856. package/.claude/skills/cfn-routing-config/lib/hybrid/spawn-worker.sh +44 -0
  857. package/.claude/skills/cfn-routing-config/lib/provider/README.md +129 -0
  858. package/.claude/skills/cfn-routing-config/lib/provider/SKILL.md +215 -0
  859. package/.claude/skills/cfn-routing-config/lib/provider/resolve-provider-model.ts +252 -0
  860. package/.claude/skills/cfn-session-handoff/SKILL.md +53 -0
  861. package/.claude/skills/cfn-skill-management/FIXES_APPLIED.md +80 -0
  862. package/.claude/skills/cfn-skill-management/SKILL.md +55 -0
  863. package/.claude/skills/cfn-skill-management/lib/builder/SKILL.md +910 -0
  864. package/.claude/skills/cfn-skill-management/lib/loader/SKILL.md +466 -0
  865. package/.claude/skills/cfn-skill-management/lib/loader/execute.sh +344 -0
  866. package/.claude/skills/cfn-skill-management/lib/propagation/README.md +233 -0
  867. package/.claude/skills/cfn-skill-management/lib/propagation/package.json +56 -0
  868. package/.claude/skills/cfn-skill-management/lib/propagation/propagate-skill-update.sh +32 -0
  869. package/.claude/skills/cfn-skill-management/lib/propagation/src/cli.ts +75 -0
  870. package/.claude/skills/cfn-skill-management/lib/propagation/src/database-adapter.ts +239 -0
  871. package/.claude/skills/cfn-skill-management/lib/propagation/src/file-system-adapter.ts +113 -0
  872. package/.claude/skills/cfn-skill-management/lib/propagation/src/index.ts +72 -0
  873. package/.claude/skills/cfn-skill-management/lib/propagation/src/logger.ts +43 -0
  874. package/.claude/skills/cfn-skill-management/lib/propagation/src/metadata-parser.ts +154 -0
  875. package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-propagator.ts +274 -0
  876. package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-validator.ts +179 -0
  877. package/.claude/skills/cfn-skill-management/lib/propagation/src/types.ts +143 -0
  878. package/.claude/skills/cfn-skill-management/lib/propagation/src/version-manager.ts +118 -0
  879. package/.claude/skills/cfn-skill-management/src/cli/skill-loader.ts +364 -0
  880. package/.claude/skills/cfn-skill-management/src/lib/database-service.ts +313 -0
  881. package/.claude/skills/cfn-sprint-execution/SKILL.md +55 -0
  882. package/.claude/skills/cfn-sprint-execution/execute.sh +257 -0
  883. package/.claude/skills/cfn-sprint-execution/lib/checkpoint/SKILL.md +333 -0
  884. package/.claude/skills/cfn-sprint-execution/lib/checkpoint/cleanup-orphans.sh +374 -0
  885. package/.claude/skills/cfn-sprint-execution/lib/checkpoint/resume-wave.sh +325 -0
  886. package/.claude/skills/cfn-sprint-execution/lib/checkpoint/save-checkpoint.sh +284 -0
  887. package/.claude/skills/cfn-sprint-execution/lib/execution/SKILL.md +27 -0
  888. package/.claude/skills/cfn-sprint-execution/lib/execution/execute-sprint-task.sh +68 -0
  889. package/.claude/skills/cfn-sprint-execution/lib/execution/execute-sprint.sh +65 -0
  890. package/.claude/skills/cfn-task-decomposition/explore-123-subtasks.json +27 -0
  891. package/.claude/skills/cfn-task-decomposition/prompts/explore-123-analyze-prompt.md +36 -0
  892. package/.claude/skills/cfn-task-decomposition/prompts/explore-123-scan-prompt.md +36 -0
  893. package/.claude/skills/cfn-task-decomposition/prompts/test-final-fix-prompt.md +36 -0
  894. package/.claude/skills/cfn-task-decomposition/prompts/test-final-pattern-prompt.md +36 -0
  895. package/.claude/skills/cfn-task-decomposition/prompts/test-final-recon-prompt.md +36 -0
  896. package/.claude/skills/cfn-task-decomposition/prompts/test-final-validate-prompt.md +36 -0
  897. package/.claude/skills/cfn-task-decomposition/test-456-subtasks.json +60 -0
  898. package/.claude/skills/cfn-task-decomposition/test-789-subtasks.json +60 -0
  899. package/.claude/skills/cfn-task-decomposition/test-999-subtasks.json +27 -0
  900. package/.claude/skills/cfn-task-decomposition/test-debug-subtasks.json +60 -0
  901. package/.claude/skills/cfn-task-decomposition/test-debug2-subtasks.json +60 -0
  902. package/.claude/skills/cfn-task-decomposition/test-final-subtasks.json +60 -0
  903. package/.claude/skills/cfn-task-decomposition/test-simple-subtasks.json +60 -0
  904. package/.claude/skills/cfn-task-intelligence/SKILL.md +18 -0
  905. package/.claude/skills/cfn-task-intelligence/cfn-task-intelligence.sh +158 -0
  906. package/.claude/skills/cfn-task-intelligence/lib/classifier/SKILL.md +81 -0
  907. package/.claude/skills/cfn-task-intelligence/lib/classifier/classify-task.sh +297 -0
  908. package/.claude/skills/cfn-task-intelligence/lib/complexity/SKILL.md +96 -0
  909. package/.claude/skills/cfn-task-intelligence/lib/complexity/estimate-complexity.sh +144 -0
  910. package/.claude/skills/cfn-task-intelligence/lib/integration/SKILL.md +339 -0
  911. package/.claude/skills/cfn-task-intelligence/lib/integration/learning-loop.sh +127 -0
  912. package/.claude/skills/cfn-task-intelligence/lib/integration/post-feedback-hook.sh +124 -0
  913. package/.claude/skills/cfn-task-intelligence/lib/integration/pre-execution-hook.sh +59 -0
  914. package/.claude/skills/cfn-task-intelligence/lib/specialist/SKILL.md +41 -0
  915. package/.claude/skills/cfn-task-intelligence/lib/specialist/recommend-specialist.sh +57 -0
  916. package/.claude/skills/cfn-task-planning/SKILL.md +15 -0
  917. package/.claude/skills/cfn-task-planning/cli/classify-task.sh +4 -0
  918. package/.claude/skills/cfn-task-planning/cli/decompose-task.sh +4 -0
  919. package/.claude/skills/cfn-task-planning/cli/init-config.sh +4 -0
  920. package/.claude/skills/cfn-task-planning/lib/audit/get-audit-data.sh +397 -0
  921. package/.claude/skills/cfn-task-planning/lib/audit/store-task-audit.sh +191 -0
  922. package/.claude/skills/cfn-task-planning/lib/classifier/README.md +81 -0
  923. package/.claude/skills/cfn-task-planning/lib/classifier/classify-task.sh +297 -0
  924. package/.claude/skills/cfn-task-planning/lib/decomposition/task-decomposer.sh +415 -0
  925. package/.claude/skills/cfn-test-framework/CLI.md +191 -0
  926. package/.claude/skills/cfn-test-framework/SKILL.md +55 -0
  927. package/.claude/skills/cfn-test-framework/execute.sh +386 -0
  928. package/.claude/skills/cfn-test-framework/lib/execution/README.md +129 -0
  929. package/.claude/skills/cfn-test-framework/lib/execution/SKILL.md +128 -0
  930. package/.claude/skills/cfn-test-framework/lib/execution/check-dependencies.sh +36 -0
  931. package/.claude/skills/cfn-test-framework/lib/execution/test-cache-reader.sh +134 -0
  932. package/.claude/skills/cfn-test-framework/lib/execution/test-concurrent-conflicts.sh +115 -0
  933. package/.claude/skills/cfn-test-framework/lib/execution/test-coordinator-pattern.sh +109 -0
  934. package/.claude/skills/cfn-test-framework/lib/runner/SKILL.md +288 -0
  935. package/.claude/skills/cfn-test-framework/lib/runner/detect-regressions.sh +58 -0
  936. package/.claude/skills/cfn-test-framework/lib/runner/detect-regressions.sh.backup-1763392821 +55 -0
  937. package/.claude/skills/cfn-test-framework/lib/runner/init-benchmark-db.sh +48 -0
  938. package/.claude/skills/cfn-test-framework/lib/runner/run-all-tests.sh +222 -0
  939. package/.claude/skills/cfn-test-framework/lib/runner/store-benchmarks.sh +53 -0
  940. package/.claude/skills/cfn-test-framework/lib/runner/validate-redis-keys.sh +143 -0
  941. package/.claude/skills/cfn-test-framework/lib/webapp/README.md +142 -0
  942. package/.claude/skills/cfn-test-framework/lib/webapp/SCREENSHOT_NAMING_CONVENTION.md +547 -0
  943. package/.claude/skills/cfn-test-framework/lib/webapp/SKILL.md +877 -0
  944. package/.claude/skills/cfn-test-framework/lib/webapp/capture-screenshot.sh +238 -0
  945. package/.claude/skills/cfn-test-framework/lib/webapp/cfn-loop-integration.sh +265 -0
  946. package/.claude/skills/cfn-test-framework/lib/webapp/compare-screenshots.sh +199 -0
  947. package/.claude/skills/cfn-test-framework/lib/webapp/init-storage.sh +150 -0
  948. package/.claude/skills/cfn-test-framework/lib/webapp/set-baseline.sh +196 -0
  949. package/.claude/skills/cfn-test-framework/lib/webapp/test-webapp-testing.sh +233 -0
  950. package/.claude/skills/cfn-transparency-middleware/CACHE_MANAGER.md +98 -0
  951. package/.claude/skills/cfn-transparency-middleware/Cargo.lock +2358 -0
  952. package/.claude/skills/cfn-transparency-middleware/Cargo.toml +20 -0
  953. package/.claude/skills/cfn-transparency-middleware/README.md +327 -0
  954. package/.claude/skills/cfn-transparency-middleware/SECURITY.md +41 -0
  955. package/.claude/skills/cfn-transparency-middleware/SKILL.md +327 -0
  956. package/.claude/skills/cfn-transparency-middleware/TEST_RESULTS.md +174 -0
  957. package/.claude/skills/cfn-transparency-middleware/config.json +23 -0
  958. package/.claude/skills/cfn-transparency-middleware/fix_redact.sh +12 -0
  959. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +98 -0
  960. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-init.sh +224 -0
  961. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-level.sh +333 -0
  962. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +345 -0
  963. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +140 -0
  964. package/.claude/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +235 -0
  965. package/.claude/skills/cfn-transparency-middleware/middleware-config.sh +29 -0
  966. package/.claude/skills/cfn-transparency-middleware/performance-benchmark.sh +79 -0
  967. package/.claude/skills/cfn-transparency-middleware/src/agent_metrics.rs +480 -0
  968. package/.claude/skills/cfn-transparency-middleware/src/api_handler.rs +318 -0
  969. package/.claude/skills/cfn-transparency-middleware/src/cache_manager.rs +219 -0
  970. package/.claude/skills/cfn-transparency-middleware/src/fix_regex.rs +9 -0
  971. package/.claude/skills/cfn-transparency-middleware/src/lib.rs +391 -0
  972. package/.claude/skills/cfn-transparency-middleware/src/lib.rs.backup +388 -0
  973. package/.claude/skills/cfn-transparency-middleware/src/main.rs +205 -0
  974. package/.claude/skills/cfn-transparency-middleware/src/memory_query.rs +93 -0
  975. package/.claude/skills/cfn-transparency-middleware/src/memory_repository.rs +169 -0
  976. package/.claude/skills/cfn-transparency-middleware/src/memory_schema.rs +154 -0
  977. package/.claude/skills/cfn-transparency-middleware/src/test_fix.txt +2 -0
  978. package/.claude/skills/cfn-transparency-middleware/test-e2e.sh +421 -0
  979. package/.claude/skills/cfn-transparency-middleware/test-integration.sh +162 -0
  980. package/.claude/skills/cfn-transparency-middleware/test-transparency-skill.sh +368 -0
  981. package/.claude/skills/cfn-transparency-middleware/test-transparency-skill.sh.unix +126 -0
  982. package/.claude/skills/cfn-transparency-middleware/wrap-agent.sh +132 -0
  983. package/.claude/skills/cfn-utilities/SKILL.md +239 -0
  984. package/.claude/skills/cfn-utilities/execute.sh +32 -0
  985. package/.claude/skills/cfn-utilities/lib/errors.sh +56 -0
  986. package/.claude/skills/cfn-utilities/lib/file-ops.sh +164 -0
  987. package/.claude/skills/cfn-utilities/lib/logging.sh +77 -0
  988. package/.claude/skills/cfn-utilities/lib/retry.sh +127 -0
  989. package/.claude/skills/cfn-utilities/test.sh +317 -0
  990. package/.claude/skills/cfn-validation-framework/SKILL.md +60 -0
  991. package/.claude/skills/cfn-validation-framework/execute.sh +223 -0
  992. package/.claude/skills/cfn-validation-framework/lib/deliverables/confidence-calculator.sh +262 -0
  993. package/.claude/skills/cfn-validation-framework/lib/instrumentation/wrapped-executor.sh +291 -0
  994. package/.claude/skills/cfn-validation-framework/lib/json/SKILL.md +431 -0
  995. package/.claude/skills/cfn-validation-framework/lib/json/test-validate-success-criteria.sh +421 -0
  996. package/.claude/skills/cfn-validation-framework/lib/json/validate-success-criteria.sh +197 -0
  997. package/.claude/skills/cfn-validation-framework/lib/layers/SKILL.md +133 -0
  998. package/.claude/skills/cfn-vision-analysis/SKILL.md +20 -0
  999. package/.claude/skills/deprecated/analyze-patterns.sh +899 -0
  1000. package/.claude/skills/equation-solver/README.md +327 -0
  1001. package/.claude/skills/equation-solver/SECURITY.md +306 -0
  1002. package/.claude/skills/equation-solver/SKILL.md +335 -0
  1003. package/.claude/skills/equation-solver/package.json +32 -0
  1004. package/.claude/skills/equation-solver/solve.sh +352 -0
  1005. package/.claude/skills/equation-solver/test-equation-solver-minimal.sh +103 -0
  1006. package/.claude/skills/equation-solver/test-equation-solver.sh +510 -0
  1007. package/.claude/skills/equation-solver/test.cjs +25 -0
  1008. package/.claude/skills/shared/bootstrap/sqlite-params.sh +156 -0
  1009. package/.claude/skills/shared/lib/path-utils.sh +139 -0
  1010. package/.claude/skills-database/APPROVAL_CRITERIA.md +925 -0
  1011. package/.claude/skills-database/APPROVAL_WORKFLOW.md +1482 -0
  1012. package/.claude/skills-database/ARCHITECTURE_DECISIONS.md +456 -0
  1013. package/.claude/skills-database/IMPLEMENTATION_GUIDE.md +763 -0
  1014. package/.claude/skills-database/README.md +564 -0
  1015. package/.claude/skills-database/TDD_SKILLS_DB_INTEGRATION.md +2286 -0
  1016. package/.claude/skills-database/schema-v2.sql +587 -0
  1017. package/.claude/slash-commands.json +92 -0
  1018. package/.claude/spawn-pattern-examples.md +500 -0
  1019. package/.claude/sprint-configs/cfn-naming-standardization.json +729 -0
  1020. package/.claude/state/cfn-expert-last-commit +2 -0
  1021. package/.claude/tooling/jq +0 -0
  1022. package/fix-node_modules.md +68 -0
  1023. package/package.json +2 -2
@@ -0,0 +1,1389 @@
1
+ /**
2
+ * CFN Loop Orchestrator - Complete TypeScript Implementation
3
+ * Orchestrates the Fail Never (CFN) Loop workflow with test-driven validation
4
+ * Supports MVP, Standard, and Enterprise execution modes
5
+ *
6
+ * Version: 3.0.0
7
+ */
8
+
9
+ import { gateCheck, GateCheckParams } from './helpers/gate-check';
10
+ import { collectConsensus, validateConsensus } from './helpers/consensus';
11
+ import { spawnLoop3Agents, spawnLoop2Agents, SpawnResult } from './helpers/spawn-agents';
12
+ import { TestResult, ExecutionMode } from './types';
13
+ import { execSync } from 'child_process';
14
+ import * as path from 'path';
15
+ import * as fs from 'fs/promises';
16
+
17
+ /**
18
+ * Execution phases in the CFN Loop
19
+ */
20
+ export type LoopPhase = 'loop3' | 'loop2' | 'product-owner' | 'complete';
21
+
22
+ /**
23
+ * Product owner decision outcomes
24
+ */
25
+ export type ProductOwnerDecision = 'PROCEED' | 'ITERATE' | 'ABORT' | null;
26
+
27
+ /**
28
+ * Timeout configuration for agent execution
29
+ */
30
+ export interface TimeoutConfig {
31
+ loop3Agent?: number;
32
+ loop2Agent?: number;
33
+ productOwner?: number;
34
+ }
35
+
36
+ /**
37
+ * Orchestration configuration
38
+ */
39
+ export interface OrchestrationConfig {
40
+ taskId: string;
41
+ mode: ExecutionMode;
42
+ maxIterations: number;
43
+ aceReflect?: boolean;
44
+ loop3Agents?: string[];
45
+ loop2Agents?: string[];
46
+ productOwner?: string;
47
+ successCriteriaEnabled?: boolean;
48
+ timeouts?: TimeoutConfig;
49
+ workspace?: string;
50
+ taskDescription?: string;
51
+ }
52
+
53
+ /**
54
+ * Agent execution context
55
+ */
56
+ export interface AgentExecutionContext {
57
+ agentId: string;
58
+ agentType: string;
59
+ loopType: 'loop3' | 'loop2';
60
+ iteration: number;
61
+ taskId: string;
62
+ timestamp: number;
63
+ }
64
+
65
+ /**
66
+ * Phase transition tracking
67
+ */
68
+ export interface PhaseTransition {
69
+ fromPhase: LoopPhase;
70
+ toPhase: LoopPhase;
71
+ timestamp: number;
72
+ iteration: number;
73
+ }
74
+
75
+ /**
76
+ * Gate check result
77
+ */
78
+ export interface GateCheckResult {
79
+ passed: boolean;
80
+ passRate: number;
81
+ threshold: number;
82
+ gap: number;
83
+ }
84
+
85
+ /**
86
+ * Consensus validation result
87
+ */
88
+ export interface ConsensusValidationResult {
89
+ passed: boolean;
90
+ average: number;
91
+ threshold: number;
92
+ gap: number;
93
+ }
94
+
95
+ /**
96
+ * Test result aggregation
97
+ */
98
+ export interface AggregatedTestResults {
99
+ totalPass: number;
100
+ totalFail: number;
101
+ totalSkip: number;
102
+ passRate: number;
103
+ agentCount: number;
104
+ }
105
+
106
+ /**
107
+ * Orchestration state tracking
108
+ */
109
+ export interface OrchestrationState {
110
+ taskId: string;
111
+ mode: ExecutionMode;
112
+ iteration: number;
113
+ currentPhase: LoopPhase;
114
+ completedAgents: Set<string>;
115
+ failedAgents: Set<string>;
116
+ startTime: number;
117
+ lastUpdateTime: number;
118
+ }
119
+
120
+ /**
121
+ * Feedback for next iteration
122
+ */
123
+ export interface IterationFeedback {
124
+ gatePassRate?: number;
125
+ consensusAverage?: number;
126
+ previousFailures?: string[];
127
+ reasons?: string[];
128
+ timestamp?: number;
129
+ }
130
+
131
+ /**
132
+ * Mode-specific configuration
133
+ */
134
+ interface ModeThresholds {
135
+ gateThreshold: number;
136
+ consensusThreshold: number;
137
+ maxIterations: number;
138
+ }
139
+
140
+ const MODE_CONFIG: Record<ExecutionMode, ModeThresholds> = {
141
+ mvp: {
142
+ gateThreshold: 0.70,
143
+ consensusThreshold: 0.80,
144
+ maxIterations: 5,
145
+ },
146
+ standard: {
147
+ gateThreshold: 0.95,
148
+ consensusThreshold: 0.90,
149
+ maxIterations: 10,
150
+ },
151
+ enterprise: {
152
+ gateThreshold: 0.98,
153
+ consensusThreshold: 0.95,
154
+ maxIterations: 15,
155
+ },
156
+ };
157
+
158
+ /**
159
+ * Shell escape utility for safe command execution
160
+ */
161
+ function escapeShellArg(arg: string): string {
162
+ // Use single quotes and escape any single quotes in the argument
163
+ return `'${arg.replace(/'/g, "'\\''")}'`;
164
+ }
165
+
166
+ /**
167
+ * Main orchestrator class
168
+ */
169
+ export class Orchestrator {
170
+ private config: OrchestrationConfig;
171
+ private state: OrchestrationState;
172
+ private testResults: Map<string, TestResult> = new Map();
173
+ private consensusScores: Map<string, number> = new Map();
174
+ private decision: ProductOwnerDecision = null;
175
+ private errors: Map<string, Error> = new Map();
176
+ private phaseHistory: PhaseTransition[] = [];
177
+
178
+ constructor(config: OrchestrationConfig) {
179
+ // Validate configuration
180
+ this.validateConfig(config);
181
+
182
+ this.config = config;
183
+ this.state = this.initializeState(config);
184
+ }
185
+
186
+ /**
187
+ * Validate configuration parameters
188
+ */
189
+ private validateConfig(config: OrchestrationConfig): void {
190
+ if (!config.taskId || config.taskId.trim() === '') {
191
+ throw new Error('Task ID cannot be empty');
192
+ }
193
+
194
+ const validModes: ExecutionMode[] = ['mvp', 'standard', 'enterprise'];
195
+ if (!validModes.includes(config.mode)) {
196
+ throw new Error(`Invalid execution mode: ${config.mode}`);
197
+ }
198
+
199
+ if (!Number.isInteger(config.maxIterations) || config.maxIterations < 1) {
200
+ throw new Error('Max iterations must be at least 1');
201
+ }
202
+
203
+ if (config.maxIterations > 100) {
204
+ throw new Error('Max iterations cannot exceed 100');
205
+ }
206
+
207
+ // Validate timeout configuration if provided
208
+ if (config.timeouts) {
209
+ const MIN_TIMEOUT = 10;
210
+ const MAX_TIMEOUT = 3600;
211
+
212
+ if (config.timeouts.loop3Agent !== undefined) {
213
+ if (config.timeouts.loop3Agent < MIN_TIMEOUT || config.timeouts.loop3Agent > MAX_TIMEOUT) {
214
+ throw new Error(`loop3Agent timeout must be between ${MIN_TIMEOUT}-${MAX_TIMEOUT}s, got ${config.timeouts.loop3Agent}s`);
215
+ }
216
+ }
217
+
218
+ if (config.timeouts.loop2Agent !== undefined) {
219
+ if (config.timeouts.loop2Agent < MIN_TIMEOUT || config.timeouts.loop2Agent > MAX_TIMEOUT) {
220
+ throw new Error(`loop2Agent timeout must be between ${MIN_TIMEOUT}-${MAX_TIMEOUT}s, got ${config.timeouts.loop2Agent}s`);
221
+ }
222
+ }
223
+
224
+ if (config.timeouts.productOwner !== undefined) {
225
+ if (config.timeouts.productOwner < MIN_TIMEOUT || config.timeouts.productOwner > MAX_TIMEOUT) {
226
+ throw new Error(`productOwner timeout must be between ${MIN_TIMEOUT}-${MAX_TIMEOUT}s, got ${config.timeouts.productOwner}s`);
227
+ }
228
+ }
229
+ }
230
+ }
231
+
232
+ /**
233
+ * Initialize orchestration state
234
+ */
235
+ private initializeState(config: OrchestrationConfig): OrchestrationState {
236
+ const now = Date.now();
237
+
238
+ return {
239
+ taskId: config.taskId,
240
+ mode: config.mode,
241
+ iteration: 0,
242
+ currentPhase: 'loop3',
243
+ completedAgents: new Set(),
244
+ failedAgents: new Set(),
245
+ startTime: now,
246
+ lastUpdateTime: now,
247
+ };
248
+ }
249
+
250
+ /**
251
+ * Get current orchestration state
252
+ */
253
+ public getState(): OrchestrationState {
254
+ return { ...this.state, completedAgents: new Set(this.state.completedAgents), failedAgents: new Set(this.state.failedAgents) };
255
+ }
256
+
257
+ /**
258
+ * Get task ID
259
+ */
260
+ public getTaskId(): string {
261
+ return this.config.taskId;
262
+ }
263
+
264
+ /**
265
+ * Get execution mode
266
+ */
267
+ public getMode(): ExecutionMode {
268
+ return this.config.mode;
269
+ }
270
+
271
+ /**
272
+ * Get maximum iterations for mode
273
+ */
274
+ public getMaxIterations(): number {
275
+ return this.config.maxIterations;
276
+ }
277
+
278
+ /**
279
+ * Get gate threshold for current mode
280
+ */
281
+ public getGateThreshold(): number {
282
+ return MODE_CONFIG[this.config.mode].gateThreshold;
283
+ }
284
+
285
+ /**
286
+ * Get consensus threshold for current mode
287
+ */
288
+ public getConsensusThreshold(): number {
289
+ return MODE_CONFIG[this.config.mode].consensusThreshold;
290
+ }
291
+
292
+ /**
293
+ * Get timeout configuration with defaults
294
+ * Defaults: Loop 3 = 300s, Loop 2 = 300s, Product Owner = 60s
295
+ */
296
+ public getTimeouts(): { loop3Agent: number; loop2Agent: number; productOwner: number } {
297
+ return {
298
+ loop3Agent: this.config.timeouts?.loop3Agent ?? 300,
299
+ loop2Agent: this.config.timeouts?.loop2Agent ?? 300,
300
+ productOwner: this.config.timeouts?.productOwner ?? 60,
301
+ };
302
+ }
303
+
304
+ /**
305
+ * Transition to next phase
306
+ */
307
+ public transitionPhase(newPhase: LoopPhase): void {
308
+ const transition: PhaseTransition = {
309
+ fromPhase: this.state.currentPhase,
310
+ toPhase: newPhase,
311
+ timestamp: Date.now(),
312
+ iteration: this.state.iteration,
313
+ };
314
+
315
+ this.phaseHistory.push(transition);
316
+ this.state.currentPhase = newPhase;
317
+ this.state.lastUpdateTime = Date.now();
318
+ }
319
+
320
+ /**
321
+ * Increment iteration counter
322
+ */
323
+ public incrementIteration(): void {
324
+ this.state.iteration++;
325
+ this.state.lastUpdateTime = Date.now();
326
+ }
327
+
328
+ /**
329
+ * Check if can continue iterating
330
+ */
331
+ public canContinueIterating(): boolean {
332
+ return this.state.iteration < this.config.maxIterations;
333
+ }
334
+
335
+ /**
336
+ * Check if orchestration should terminate
337
+ */
338
+ public shouldTerminate(): boolean {
339
+ if (this.decision === 'PROCEED' || this.decision === 'ABORT') {
340
+ return true;
341
+ }
342
+
343
+ if (this.decision === 'ITERATE' && !this.canContinueIterating()) {
344
+ return true;
345
+ }
346
+
347
+ return false;
348
+ }
349
+
350
+ /**
351
+ * Mark agent as completed
352
+ */
353
+ public markAgentComplete(agentId: string, _loopType: 'loop3' | 'loop2'): void {
354
+ this.state.completedAgents.add(agentId);
355
+ this.state.failedAgents.delete(agentId);
356
+ this.state.lastUpdateTime = Date.now();
357
+ }
358
+
359
+ /**
360
+ * Mark agent as failed
361
+ */
362
+ public markAgentFailed(agentId: string, _loopType: 'loop3' | 'loop2'): void {
363
+ this.state.failedAgents.add(agentId);
364
+ this.state.completedAgents.delete(agentId);
365
+ this.state.lastUpdateTime = Date.now();
366
+ }
367
+
368
+ /**
369
+ * Record execution error for agent
370
+ */
371
+ public recordExecutionError(agentId: string, error: Error): void {
372
+ this.errors.set(agentId, error);
373
+ this.markAgentFailed(agentId, 'loop3');
374
+ }
375
+
376
+ /**
377
+ * Record timeout for agent
378
+ */
379
+ public recordTimeout(agentId: string, timeoutSeconds: number): void {
380
+ const error = new Error(`Agent timeout after ${timeoutSeconds}s`);
381
+ this.recordExecutionError(agentId, error);
382
+ }
383
+
384
+ /**
385
+ * Record test results for agent
386
+ */
387
+ public recordTestResult(agentId: string, result: TestResult): void {
388
+ this.testResults.set(agentId, result);
389
+ this.state.lastUpdateTime = Date.now();
390
+ }
391
+
392
+ /**
393
+ * Get test result for agent
394
+ */
395
+ public getTestResult(agentId: string): TestResult | undefined {
396
+ return this.testResults.get(agentId);
397
+ }
398
+
399
+ /**
400
+ * Aggregate test results across all agents
401
+ */
402
+ public aggregateTestResults(): AggregatedTestResults {
403
+ let totalPass = 0;
404
+ let totalFail = 0;
405
+ let totalSkip = 0;
406
+
407
+ this.testResults.forEach((result) => {
408
+ totalPass += result.pass;
409
+ totalFail += result.fail;
410
+ totalSkip += result.skip ?? 0;
411
+ });
412
+
413
+ const total = totalPass + totalFail + totalSkip;
414
+ const passRate = total === 0 ? 0 : totalPass / total;
415
+
416
+ return {
417
+ totalPass,
418
+ totalFail,
419
+ totalSkip,
420
+ passRate,
421
+ agentCount: this.testResults.size,
422
+ };
423
+ }
424
+
425
+ /**
426
+ * Check gate (Loop 3 → Loop 2 transition)
427
+ */
428
+ public checkGate(passRate: number): GateCheckResult {
429
+ const threshold = this.getGateThreshold();
430
+
431
+ const params: GateCheckParams = {
432
+ passRate,
433
+ mode: this.config.mode,
434
+ threshold,
435
+ };
436
+
437
+ const result = gateCheck(params);
438
+
439
+ return {
440
+ passed: result.passed,
441
+ passRate: result.passRate,
442
+ threshold: result.threshold,
443
+ gap: result.gap,
444
+ };
445
+ }
446
+
447
+ /**
448
+ * Record consensus score from validator
449
+ */
450
+ public recordConsensusScore(validatorId: string, score: number): void {
451
+ if (score < 0 || score > 1) {
452
+ throw new Error(`Invalid consensus score: ${score} (must be 0.0-1.0)`);
453
+ }
454
+
455
+ this.consensusScores.set(validatorId, score);
456
+ this.state.lastUpdateTime = Date.now();
457
+ }
458
+
459
+ /**
460
+ * Get all consensus scores
461
+ */
462
+ public getConsensusScores(): number[] {
463
+ return Array.from(this.consensusScores.values());
464
+ }
465
+
466
+ /**
467
+ * Get consensus average
468
+ */
469
+ public getConsensusAverage(): number {
470
+ const scores = this.getConsensusScores();
471
+
472
+ if (scores.length === 0) {
473
+ throw new Error('No consensus scores recorded');
474
+ }
475
+
476
+ const sum = scores.reduce((a, b) => a + b, 0);
477
+ return sum / scores.length;
478
+ }
479
+
480
+ /**
481
+ * Validate consensus against threshold
482
+ */
483
+ public validateConsensus(): ConsensusValidationResult {
484
+ const scores = this.getConsensusScores();
485
+
486
+ if (scores.length === 0) {
487
+ throw new Error('No consensus scores recorded');
488
+ }
489
+
490
+ const result = collectConsensus(scores);
491
+ const validation = validateConsensus({
492
+ average: result.average,
493
+ mode: this.config.mode,
494
+ threshold: this.getConsensusThreshold(),
495
+ });
496
+
497
+ return {
498
+ passed: validation.passed,
499
+ average: validation.average,
500
+ threshold: validation.threshold,
501
+ gap: validation.gap,
502
+ };
503
+ }
504
+
505
+ /**
506
+ * Record product owner decision
507
+ */
508
+ public recordDecision(decision: ProductOwnerDecision): void {
509
+ this.decision = decision;
510
+ this.state.lastUpdateTime = Date.now();
511
+ }
512
+
513
+ /**
514
+ * Get recorded decision
515
+ */
516
+ public getDecision(): ProductOwnerDecision {
517
+ return this.decision;
518
+ }
519
+
520
+ /**
521
+ * Parse decision from agent output
522
+ */
523
+ public parseDecisionFromOutput(output: string): ProductOwnerDecision {
524
+ const normalizedOutput = output.toUpperCase();
525
+
526
+ if (normalizedOutput.includes('PROCEED')) {
527
+ return 'PROCEED';
528
+ }
529
+
530
+ if (normalizedOutput.includes('ITERATE')) {
531
+ return 'ITERATE';
532
+ }
533
+
534
+ if (normalizedOutput.includes('ABORT')) {
535
+ return 'ABORT';
536
+ }
537
+
538
+ return null;
539
+ }
540
+
541
+ /**
542
+ * Spawn Loop 3 (implementer) agents
543
+ */
544
+ public async spawnLoop3Agents(agentTypes: string[]): Promise<AgentExecutionContext[]> {
545
+ const agents: AgentExecutionContext[] = [];
546
+ const now = Date.now();
547
+
548
+ agentTypes.forEach((agentType, index) => {
549
+ agents.push({
550
+ agentId: `${agentType}-${this.state.iteration + 1}-${index + 1}`,
551
+ agentType,
552
+ loopType: 'loop3',
553
+ iteration: this.state.iteration + 1,
554
+ taskId: this.config.taskId,
555
+ timestamp: now,
556
+ });
557
+ });
558
+
559
+ return agents;
560
+ }
561
+
562
+ /**
563
+ * Spawn Loop 2 (validator) agents
564
+ */
565
+ public async spawnLoop2Validators(validatorTypes: string[]): Promise<AgentExecutionContext[]> {
566
+ const validators: AgentExecutionContext[] = [];
567
+ const now = Date.now();
568
+
569
+ validatorTypes.forEach((validatorType, index) => {
570
+ validators.push({
571
+ agentId: `${validatorType}-${this.state.iteration + 1}-${index + 1}`,
572
+ agentType: validatorType,
573
+ loopType: 'loop2',
574
+ iteration: this.state.iteration + 1,
575
+ taskId: this.config.taskId,
576
+ timestamp: now,
577
+ });
578
+ });
579
+
580
+ return validators;
581
+ }
582
+
583
+ /**
584
+ * Build task context string for agent spawning
585
+ */
586
+ private buildTaskContext(): string {
587
+ const context = {
588
+ taskId: this.config.taskId,
589
+ mode: this.config.mode,
590
+ iteration: this.state.iteration,
591
+ phase: this.state.currentPhase,
592
+ timestamp: Date.now(),
593
+ ...(this.config.workspace && { workspace: this.config.workspace }),
594
+ ...(this.config.taskDescription && { taskDescription: this.config.taskDescription }),
595
+ };
596
+ return JSON.stringify(context);
597
+ }
598
+
599
+ /**
600
+ * Wait for agents to complete via Redis coordination
601
+ * Blocks until all agents signal completion or timeout occurs
602
+ *
603
+ * @param spawnResults - Results from agent spawning
604
+ * @param timeoutSeconds - Maximum wait time (default: 300s)
605
+ * @returns Array of completed agent IDs
606
+ */
607
+ private async waitForAgentsToComplete(
608
+ spawnResults: SpawnResult[],
609
+ timeoutSeconds: number = 300
610
+ ): Promise<string[]> {
611
+ const completedAgents: string[] = [];
612
+ const startTime = Date.now();
613
+ const projectRoot = process.env.PROJECT_ROOT || process.cwd();
614
+
615
+ console.log(`Waiting for ${spawnResults.length} agents to complete (timeout: ${timeoutSeconds}s)...`);
616
+
617
+ for (const result of spawnResults) {
618
+ if (!result.success) {
619
+ console.warn(`Skipping failed agent: ${result.agentId}`);
620
+ continue;
621
+ }
622
+
623
+ const elapsedSeconds = Math.floor((Date.now() - startTime) / 1000);
624
+ const remainingTimeout = timeoutSeconds - elapsedSeconds;
625
+
626
+ if (remainingTimeout <= 0) {
627
+ console.error(`Global timeout reached. Remaining agents will not be waited for.`);
628
+ this.recordTimeout(result.agentId, timeoutSeconds);
629
+ break;
630
+ }
631
+
632
+ try {
633
+ // Agents push completion to legacy done list: swarm:{taskId}:{agentId}:done
634
+ const redisHost = process.env.CFN_REDIS_HOST || process.env.REDIS_HOST || 'localhost';
635
+ const redisPort = process.env.CFN_REDIS_PORT || process.env.REDIS_PORT || '6379';
636
+ const doneListKey = `swarm:${this.config.taskId}:${result.agentId}:done`;
637
+
638
+ const escapedHost = escapeShellArg(redisHost);
639
+ const escapedPort = escapeShellArg(redisPort);
640
+ const escapedDoneKey = escapeShellArg(doneListKey);
641
+
642
+ // Use short blocking chunks to stay under tool time limits
643
+ const chunkTimeout = Math.min(Math.max(remainingTimeout, 5), 60); // 5-60s
644
+
645
+ console.log(
646
+ `Waiting for agent ${result.agentId} via Redis BLPOP ${doneListKey} (chunk: ${chunkTimeout}s, remaining: ${remainingTimeout}s)...`
647
+ );
648
+
649
+ // First a quick length check to avoid blocking if already complete
650
+ try {
651
+ const len = parseInt(
652
+ execSync(`redis-cli -h ${escapedHost} -p ${escapedPort} LLEN ${escapedDoneKey}`, { encoding: 'utf8' }).trim(),
653
+ 10
654
+ );
655
+ if (!Number.isNaN(len) && len > 0) {
656
+ execSync(`redis-cli -h ${escapedHost} -p ${escapedPort} LPOP ${escapedDoneKey}`, { stdio: 'ignore' });
657
+ console.log(`✓ Agent ${result.agentId} completed (pre-existing done signal)`);
658
+ completedAgents.push(result.agentId);
659
+ this.markAgentComplete(result.agentId, 'loop3');
660
+ continue;
661
+ }
662
+ } catch {
663
+ // ignore LLEN errors and continue to BLPOP
664
+ }
665
+
666
+ // Blocking wait chunk
667
+ execSync(`redis-cli -h ${escapedHost} -p ${escapedPort} BLPOP ${escapedDoneKey} ${chunkTimeout}`, {
668
+ stdio: 'ignore',
669
+ timeout: chunkTimeout * 1000,
670
+ cwd: projectRoot,
671
+ });
672
+
673
+ console.log(`✓ Agent ${result.agentId} completed`);
674
+ completedAgents.push(result.agentId);
675
+ this.markAgentComplete(result.agentId, 'loop3');
676
+ } catch (error) {
677
+ const errorMsg = error instanceof Error ? error.message : String(error);
678
+ console.error(`✗ Agent ${result.agentId} failed or timed out: ${errorMsg}`);
679
+ this.recordExecutionError(result.agentId, new Error(errorMsg));
680
+ }
681
+ }
682
+
683
+ console.log(`Completed: ${completedAgents.length}/${spawnResults.length} agents`);
684
+ return completedAgents;
685
+ }
686
+
687
+ /**
688
+ * Collect agent outputs from Redis
689
+ * Retrieves test results, confidence scores, and deliverables
690
+ *
691
+ * @param agentIds - List of agent IDs to collect from
692
+ * @returns Map of agent outputs
693
+ */
694
+ private async collectAgentOutputs(
695
+ agentIds: string[]
696
+ ): Promise<Map<string, { testResult?: TestResult; confidence?: number; deliverables?: string[] }>> {
697
+ const outputs = new Map<string, { testResult?: TestResult; confidence?: number; deliverables?: string[] }>();
698
+
699
+ console.log(`Collecting outputs from ${agentIds.length} agents...`);
700
+
701
+ for (const agentId of agentIds) {
702
+ try {
703
+ // Retrieve agent output from Redis
704
+ const testResultJson = this.getRedisValue(`swarm:${this.config.taskId}:agent:${agentId}:test-result`);
705
+ const confidenceStr = this.getRedisValue(`swarm:${this.config.taskId}:agent:${agentId}:confidence`);
706
+ const deliverablesJson = this.getRedisValue(`swarm:${this.config.taskId}:agent:${agentId}:deliverables`);
707
+
708
+ const agentOutput: { testResult?: TestResult; confidence?: number; deliverables?: string[] } = {};
709
+
710
+ // Parse test results
711
+ if (testResultJson) {
712
+ try {
713
+ const testResult = JSON.parse(testResultJson) as TestResult;
714
+ agentOutput.testResult = testResult;
715
+ this.recordTestResult(agentId, testResult);
716
+ console.log(` ${agentId}: Test results collected (${testResult.pass} pass, ${testResult.fail} fail)`);
717
+ } catch (parseError) {
718
+ console.warn(` ${agentId}: Failed to parse test results: ${parseError}`);
719
+ }
720
+ }
721
+
722
+ // Parse confidence score
723
+ if (confidenceStr) {
724
+ const confidence = parseFloat(confidenceStr);
725
+ if (!isNaN(confidence) && confidence >= 0 && confidence <= 1) {
726
+ agentOutput.confidence = confidence;
727
+ console.log(` ${agentId}: Confidence score: ${(confidence * 100).toFixed(2)}%`);
728
+ }
729
+ }
730
+
731
+ // Parse deliverables
732
+ if (deliverablesJson) {
733
+ try {
734
+ const deliverables = JSON.parse(deliverablesJson) as string[];
735
+ agentOutput.deliverables = deliverables;
736
+ console.log(` ${agentId}: Deliverables: ${deliverables.length} files`);
737
+ } catch (parseError) {
738
+ console.warn(` ${agentId}: Failed to parse deliverables: ${parseError}`);
739
+ }
740
+ }
741
+
742
+ outputs.set(agentId, agentOutput);
743
+ } catch (error) {
744
+ const errorMsg = error instanceof Error ? error.message : String(error);
745
+ console.error(` ${agentId}: Failed to collect output: ${errorMsg}`);
746
+ }
747
+ }
748
+
749
+ console.log(`Successfully collected outputs from ${outputs.size}/${agentIds.length} agents`);
750
+ return outputs;
751
+ }
752
+
753
+ /**
754
+ * Get value from Redis using redis-cli
755
+ *
756
+ * @param key - Redis key
757
+ * @returns Value or null if not found
758
+ */
759
+ private getRedisValue(key: string): string | null {
760
+ try {
761
+ const redisHost = process.env.REDIS_HOST || 'localhost';
762
+ const redisPort = process.env.REDIS_PORT || '6379';
763
+
764
+ // Properly escape all user-controlled inputs to prevent shell injection
765
+ const escapedHost = escapeShellArg(redisHost);
766
+ const escapedPort = escapeShellArg(redisPort);
767
+ const escapedKey = escapeShellArg(key);
768
+
769
+ const result = execSync(`redis-cli -h ${escapedHost} -p ${escapedPort} GET ${escapedKey}`, {
770
+ encoding: 'utf8',
771
+ stdio: ['pipe', 'pipe', 'ignore'], // Suppress stderr
772
+ }).trim();
773
+
774
+ return result === '(nil)' ? null : result;
775
+ } catch (error) {
776
+ return null;
777
+ }
778
+ }
779
+
780
+ /**
781
+ * Execute tests against agent deliverables
782
+ * Runs test suite to validate actual agent work
783
+ *
784
+ * @param agentOutputs - Map of agent outputs with deliverables
785
+ * @returns Aggregated test results
786
+ */
787
+ private async executeTestsOnDeliverables(
788
+ agentOutputs: Map<string, { testResult?: TestResult; confidence?: number; deliverables?: string[] }>
789
+ ): Promise<AggregatedTestResults> {
790
+ console.log('Executing tests on agent deliverables...');
791
+
792
+ const projectRoot = process.env.PROJECT_ROOT || process.cwd();
793
+
794
+ // Validate TEST_COMMAND against allowlist to prevent shell injection (CVSS 8.5)
795
+ const ALLOWED_TEST_COMMANDS = ['npm test', 'npm run test', 'jest', 'mocha', 'yarn test'];
796
+ const ALLOWED_TEST_PATTERNS = [
797
+ /^npm run test:[a-z0-9-]+$/, // Namespaced npm scripts: npm run test:integration, test:security, etc.
798
+ /^jest [a-z0-9/_-]+\.test\.[jt]s$/, // Jest with specific test files (no path traversal)
799
+ /^mocha [a-z0-9/_-]+\.test\.[jt]s$/ // Mocha with specific test files (no path traversal)
800
+ ];
801
+ const testCommand = process.env.TEST_COMMAND || 'npm test';
802
+
803
+ // Security: Block path traversal attempts
804
+ if (testCommand.includes('..')) {
805
+ throw new Error(
806
+ `Security: Path traversal detected in TEST_COMMAND. Got: ${testCommand}`
807
+ );
808
+ }
809
+
810
+ // Check exact match first, then regex patterns
811
+ const isAllowed = ALLOWED_TEST_COMMANDS.includes(testCommand) ||
812
+ ALLOWED_TEST_PATTERNS.some(pattern => pattern.test(testCommand));
813
+
814
+ if (!isAllowed) {
815
+ throw new Error(
816
+ `Security: Invalid TEST_COMMAND value. Allowed commands: ${ALLOWED_TEST_COMMANDS.join(', ')}, ` +
817
+ `npm run test:*, jest <file>.test.[jt]s, mocha <file>.test.[jt]s. Got: ${testCommand}`
818
+ );
819
+ }
820
+
821
+ let totalPass = 0;
822
+ let totalFail = 0;
823
+ let totalSkip = 0;
824
+ let agentCount = 0;
825
+
826
+ for (const [agentId, output] of agentOutputs) {
827
+ // Verify deliverables exist
828
+ if (!output.deliverables || output.deliverables.length === 0) {
829
+ console.warn(` ${agentId}: No deliverables to test`);
830
+ continue;
831
+ }
832
+
833
+ // Validate deliverables exist on filesystem
834
+ const missingFiles: string[] = [];
835
+ for (const deliverable of output.deliverables) {
836
+ const filePath = path.join(projectRoot, deliverable);
837
+ try {
838
+ await fs.access(filePath);
839
+ } catch {
840
+ missingFiles.push(deliverable);
841
+ }
842
+ }
843
+
844
+ if (missingFiles.length > 0) {
845
+ console.warn(` ${agentId}: Missing deliverables: ${missingFiles.join(', ')}`);
846
+ const testResult: TestResult = {
847
+ pass: 0,
848
+ fail: missingFiles.length,
849
+ skip: 0,
850
+ };
851
+ this.recordTestResult(agentId, testResult);
852
+ totalFail += missingFiles.length;
853
+ agentCount++;
854
+ continue;
855
+ }
856
+
857
+ // Execute test suite
858
+ try {
859
+ console.log(` ${agentId}: Running tests on ${output.deliverables.length} deliverables...`);
860
+
861
+ const testOutput = execSync(testCommand, {
862
+ encoding: 'utf8',
863
+ cwd: projectRoot,
864
+ stdio: 'pipe',
865
+ });
866
+
867
+ // Parse test output (example for Jest format)
868
+ const passMatch = testOutput.match(/(\d+) passing/);
869
+ const failMatch = testOutput.match(/(\d+) failing/);
870
+ const skipMatch = testOutput.match(/(\d+) pending/);
871
+
872
+ const pass = passMatch && passMatch[1] ? parseInt(passMatch[1], 10) : 0;
873
+ const fail = failMatch && failMatch[1] ? parseInt(failMatch[1], 10) : 0;
874
+ const skip = skipMatch && skipMatch[1] ? parseInt(skipMatch[1], 10) : 0;
875
+
876
+ const testResult: TestResult = { pass, fail, skip };
877
+ this.recordTestResult(agentId, testResult);
878
+
879
+ totalPass += pass;
880
+ totalFail += fail;
881
+ totalSkip += skip;
882
+ agentCount++;
883
+
884
+ console.log(` ${agentId}: Tests completed (${pass} pass, ${fail} fail, ${skip} skip)`);
885
+ } catch (error) {
886
+ // Test execution failed
887
+ const errorMsg = error instanceof Error ? error.message : String(error);
888
+ console.error(` ${agentId}: Test execution failed: ${errorMsg}`);
889
+
890
+ const testResult: TestResult = {
891
+ pass: 0,
892
+ fail: output.deliverables.length,
893
+ skip: 0,
894
+ };
895
+ this.recordTestResult(agentId, testResult);
896
+ totalFail += output.deliverables.length;
897
+ agentCount++;
898
+ }
899
+ }
900
+
901
+ const total = totalPass + totalFail + totalSkip;
902
+ const passRate = total === 0 ? 0 : totalPass / total;
903
+
904
+ console.log(`Test execution complete: ${totalPass} pass, ${totalFail} fail, ${totalSkip} skip (${(passRate * 100).toFixed(2)}% pass rate)`);
905
+
906
+ return {
907
+ totalPass,
908
+ totalFail,
909
+ totalSkip,
910
+ passRate,
911
+ agentCount,
912
+ };
913
+ }
914
+
915
+ /**
916
+ * Build agent context for spawning
917
+ */
918
+ public buildAgentContext(
919
+ agentId: string,
920
+ loopType: 'loop3' | 'loop2',
921
+ iteration: number,
922
+ _feedback?: IterationFeedback
923
+ ): AgentExecutionContext {
924
+ return {
925
+ agentId,
926
+ agentType: 'unknown',
927
+ loopType,
928
+ iteration,
929
+ taskId: this.config.taskId,
930
+ timestamp: Date.now(),
931
+ };
932
+ }
933
+
934
+ /**
935
+ * Prepare feedback for next iteration
936
+ */
937
+ public prepareFeedback(feedback: IterationFeedback): IterationFeedback {
938
+ return {
939
+ ...feedback,
940
+ timestamp: Date.now(),
941
+ };
942
+ }
943
+
944
+ /**
945
+ * Get phase history
946
+ */
947
+ public getPhaseHistory(): PhaseTransition[] {
948
+ return [...this.phaseHistory];
949
+ }
950
+
951
+ /**
952
+ * Get execution errors
953
+ */
954
+ public getErrors(): Map<string, Error> {
955
+ return new Map(this.errors);
956
+ }
957
+
958
+ /**
959
+ * Reset state for new iteration
960
+ */
961
+ public resetForIteration(): void {
962
+ this.testResults.clear();
963
+ this.consensusScores.clear();
964
+ this.decision = null;
965
+ this.errors.clear();
966
+ this.state.completedAgents.clear();
967
+ this.state.failedAgents.clear();
968
+ }
969
+
970
+ /**
971
+ * Get orchestration summary
972
+ */
973
+ public getSummary(): {
974
+ taskId: string;
975
+ mode: ExecutionMode;
976
+ iteration: number;
977
+ totalAgentsCompleted: number;
978
+ totalAgentsFailed: number;
979
+ decision: ProductOwnerDecision;
980
+ duration: number;
981
+ } {
982
+ return {
983
+ taskId: this.config.taskId,
984
+ mode: this.config.mode,
985
+ iteration: this.state.iteration,
986
+ totalAgentsCompleted: this.state.completedAgents.size,
987
+ totalAgentsFailed: this.state.failedAgents.size,
988
+ decision: this.decision,
989
+ duration: Date.now() - this.state.startTime,
990
+ };
991
+ }
992
+
993
+ /**
994
+ * Execute the complete CFN Loop orchestration workflow
995
+ * Runs iterations with Loop 3 → Loop 2 → Product Owner progression
996
+ * Returns final decision (PROCEED/ITERATE/ABORT)
997
+ */
998
+ public async execute(): Promise<ProductOwnerDecision> {
999
+ const maxIterations = this.config.maxIterations;
1000
+
1001
+ // Main iteration loop
1002
+ for (let iteration = 1; iteration <= maxIterations; iteration++) {
1003
+ this.incrementIteration();
1004
+
1005
+ console.log(`\n${'='.repeat(60)}`);
1006
+ console.log(`=== ITERATION ${iteration}/${maxIterations} ===`);
1007
+ console.log(`${'='.repeat(60)}`);
1008
+
1009
+ // ===== LOOP 3: IMPLEMENTERS =====
1010
+ console.log('\nPhase: Loop 3 (Implementers)');
1011
+ this.transitionPhase('loop3');
1012
+
1013
+ const loop3AgentTypes = this.config.loop3Agents || ['backend-dev', 'coder'];
1014
+ const taskContext = this.buildTaskContext();
1015
+
1016
+ // Spawn real CLI agents
1017
+ console.log(`Spawning ${loop3AgentTypes.length} Loop 3 agents via CLI...`);
1018
+ const loop3SpawnResult = await spawnLoop3Agents(
1019
+ this.config.taskId,
1020
+ this.state.iteration,
1021
+ loop3AgentTypes,
1022
+ taskContext
1023
+ );
1024
+
1025
+ console.log(`Loop 3 spawn summary: ${loop3SpawnResult.successCount} successful, ${loop3SpawnResult.failureCount} failed`);
1026
+
1027
+ // Wait for agents to complete via Redis coordination
1028
+ const timeouts = this.getTimeouts();
1029
+ const completedAgentIds = await this.waitForAgentsToComplete(
1030
+ loop3SpawnResult.results,
1031
+ timeouts.loop3Agent
1032
+ );
1033
+
1034
+ if (completedAgentIds.length === 0) {
1035
+ console.error('No agents completed successfully. Aborting iteration.');
1036
+ this.recordDecision('ABORT');
1037
+ break;
1038
+ }
1039
+
1040
+ // Collect agent outputs (test results, confidence scores, deliverables)
1041
+ const agentOutputs = await this.collectAgentOutputs(completedAgentIds);
1042
+
1043
+ // Execute tests against actual agent deliverables
1044
+ const aggregated = await this.executeTestsOnDeliverables(agentOutputs);
1045
+ console.log(
1046
+ `Loop 3 Results: ${aggregated.totalPass} pass, ${aggregated.totalFail} fail (${aggregated.agentCount} agents, ${(aggregated.passRate * 100).toFixed(2)}% pass rate)`
1047
+ );
1048
+
1049
+ const gateResult = this.checkGate(aggregated.passRate);
1050
+ console.log(`Gate Check: ${gateResult.passed ? 'PASSED' : 'FAILED'} (threshold: ${(gateResult.threshold * 100).toFixed(2)}%)`);
1051
+
1052
+ if (!gateResult.passed) {
1053
+ console.log(`Gate failed. Iterating...`);
1054
+
1055
+ // Prepare feedback for next iteration
1056
+ this.prepareFeedback({
1057
+ gatePassRate: aggregated.passRate,
1058
+ previousFailures: Array.from(this.state.failedAgents),
1059
+ reasons: [`Gate check failed: ${(gateResult.gap * 100).toFixed(2)}% below threshold`],
1060
+ });
1061
+
1062
+ console.log(`Feedback prepared for iteration ${iteration + 1}`);
1063
+
1064
+ // Reset state for next iteration
1065
+ this.resetForIteration();
1066
+
1067
+ if (!this.canContinueIterating()) {
1068
+ console.log(`Max iterations (${maxIterations}) reached. ABORTING.`);
1069
+ this.recordDecision('ABORT');
1070
+ break;
1071
+ }
1072
+
1073
+ continue; // Go to next iteration
1074
+ }
1075
+
1076
+ // ===== LOOP 2: VALIDATORS =====
1077
+ console.log('\nPhase: Loop 2 (Validators)');
1078
+ this.transitionPhase('loop2');
1079
+
1080
+ const loop2AgentTypes = this.config.loop2Agents || ['code-reviewer', 'tester', 'security-specialist'];
1081
+
1082
+ // Spawn real CLI validators
1083
+ console.log(`Spawning ${loop2AgentTypes.length} Loop 2 validators via CLI...`);
1084
+ const loop2SpawnResult = await spawnLoop2Agents(
1085
+ this.config.taskId,
1086
+ this.state.iteration,
1087
+ loop2AgentTypes,
1088
+ taskContext
1089
+ );
1090
+
1091
+ console.log(`Loop 2 spawn summary: ${loop2SpawnResult.successCount} successful, ${loop2SpawnResult.failureCount} failed`);
1092
+
1093
+ // Wait for validators to complete via Redis coordination
1094
+ const completedValidatorIds = await this.waitForAgentsToComplete(
1095
+ loop2SpawnResult.results,
1096
+ timeouts.loop2Agent
1097
+ );
1098
+
1099
+ if (completedValidatorIds.length === 0) {
1100
+ console.error('No validators completed successfully. Iterating...');
1101
+ this.prepareFeedback({
1102
+ reasons: ['No Loop 2 validators completed'],
1103
+ });
1104
+ this.resetForIteration();
1105
+
1106
+ if (!this.canContinueIterating()) {
1107
+ console.log(`Max iterations (${maxIterations}) reached. ABORTING.`);
1108
+ this.recordDecision('ABORT');
1109
+ break;
1110
+ }
1111
+
1112
+ continue;
1113
+ }
1114
+
1115
+ // Collect validator outputs (consensus scores)
1116
+ const validatorOutputs = await this.collectAgentOutputs(completedValidatorIds);
1117
+
1118
+ // Record consensus scores from validators
1119
+ for (const [validatorId, output] of validatorOutputs) {
1120
+ if (output.confidence !== undefined) {
1121
+ this.recordConsensusScore(validatorId, output.confidence);
1122
+ }
1123
+ }
1124
+
1125
+ console.log(`Loop 2 validators completed: ${completedValidatorIds.length}/${loop2SpawnResult.totalSpawned}`);
1126
+
1127
+ // Validate consensus
1128
+ const consensusValidation = this.validateConsensus();
1129
+ console.log(
1130
+ `Loop 2 Consensus: ${(consensusValidation.average * 100).toFixed(2)}% (threshold: ${(consensusValidation.threshold * 100).toFixed(2)}%)`
1131
+ );
1132
+
1133
+ if (!consensusValidation.passed) {
1134
+ console.log(`Consensus failed. Iterating...`);
1135
+
1136
+ // Prepare feedback for next iteration
1137
+ this.prepareFeedback({
1138
+ consensusAverage: consensusValidation.average,
1139
+ reasons: [`Consensus below threshold: ${(consensusValidation.gap * 100).toFixed(2)}%`],
1140
+ });
1141
+
1142
+ console.log(`Feedback prepared for iteration ${iteration + 1}`);
1143
+
1144
+ // Reset state for next iteration
1145
+ this.resetForIteration();
1146
+
1147
+ if (!this.canContinueIterating()) {
1148
+ console.log(`Max iterations (${maxIterations}) reached. ABORTING.`);
1149
+ this.recordDecision('ABORT');
1150
+ break;
1151
+ }
1152
+
1153
+ continue; // Go to next iteration
1154
+ }
1155
+
1156
+ // ===== PRODUCT OWNER DECISION =====
1157
+ console.log('\nPhase: Product Owner Decision');
1158
+ this.transitionPhase('product-owner');
1159
+
1160
+ const ownerAgent = this.config.productOwner || 'product-owner-agent';
1161
+ console.log(`Consulting Product Owner (${ownerAgent})`);
1162
+
1163
+ // Execute Product Owner decision via skill
1164
+ let decision: ProductOwnerDecision = 'PROCEED';
1165
+ try {
1166
+ const projectRoot = path.resolve(__dirname, '../../../..');
1167
+ const skillPath = path.join(projectRoot, '.claude/skills/cfn-product-owner-decision/execute-decision.sh');
1168
+
1169
+ const poAgentId = `product-owner-${this.config.taskId}-${iteration}`;
1170
+ const poArgs = [
1171
+ '--task-id', this.config.taskId,
1172
+ '--agent-id', poAgentId,
1173
+ '--consensus', String(consensusValidation.average),
1174
+ '--threshold', String(consensusValidation.threshold),
1175
+ '--iteration', String(iteration),
1176
+ '--max-iterations', String(maxIterations),
1177
+ '--timeout', String(timeouts.productOwner),
1178
+ ];
1179
+
1180
+ if (this.config.successCriteriaEnabled) {
1181
+ poArgs.push('--success-criteria', 'enabled');
1182
+ }
1183
+
1184
+ console.log(`Executing Product Owner decision skill (timeout: ${timeouts.productOwner}s)...`);
1185
+
1186
+ const escapedArgs = [escapeShellArg(skillPath), ...poArgs.map(arg => escapeShellArg(arg))].join(' ');
1187
+ const poOutput = execSync(
1188
+ `bash ${escapedArgs}`,
1189
+ { encoding: 'utf-8', timeout: (timeouts.productOwner + 10) * 1000 }
1190
+ );
1191
+
1192
+ // Parse decision from JSON output
1193
+ const jsonMatch = poOutput.match(/\{[\s\S]*"decision":\s*"(PROCEED|ITERATE|ABORT)"[\s\S]*\}/);
1194
+ if (jsonMatch) {
1195
+ const poResult = JSON.parse(jsonMatch[0]);
1196
+ decision = poResult.decision as ProductOwnerDecision;
1197
+ console.log(`Product Owner reasoning: ${poResult.reasoning}`);
1198
+ console.log(`Product Owner confidence: ${poResult.confidence}`);
1199
+ } else {
1200
+ // Fallback: try to extract decision from plain text
1201
+ const decisionMatch = poOutput.match(/Decision:\s*(PROCEED|ITERATE|ABORT)/i);
1202
+ if (decisionMatch && decisionMatch[1]) {
1203
+ decision = decisionMatch[1].toUpperCase() as ProductOwnerDecision;
1204
+ } else {
1205
+ console.warn('Could not parse Product Owner decision, defaulting to PROCEED');
1206
+ decision = 'PROCEED';
1207
+ }
1208
+ }
1209
+ } catch (error: unknown) {
1210
+ console.error(`Product Owner execution failed: ${error instanceof Error ? error.message : String(error)}`);
1211
+ console.warn('Defaulting to PROCEED due to execution error');
1212
+ decision = 'PROCEED';
1213
+ }
1214
+
1215
+ this.recordDecision(decision);
1216
+ console.log(`Product Owner Decision: ${decision}`);
1217
+
1218
+ // ===== DECISION HANDLING =====
1219
+ if (decision === 'PROCEED') {
1220
+ console.log(`\n${'='.repeat(60)}`);
1221
+ console.log('SUCCESS: Product Owner approved. Orchestration complete.');
1222
+ console.log(`${'='.repeat(60)}`);
1223
+ break;
1224
+ } else if (decision === 'ITERATE') {
1225
+ console.log(`Product Owner requested iteration. Preparing feedback for iteration ${iteration + 1}...`);
1226
+
1227
+ // Prepare feedback for next iteration with Product Owner context
1228
+ const iterationFeedback = this.prepareFeedback({
1229
+ gatePassRate: gateResult.passRate,
1230
+ consensusAverage: consensusValidation.average,
1231
+ reasons: [
1232
+ `Product Owner requested iteration ${iteration + 1}`,
1233
+ `Gate pass rate: ${(gateResult.passRate * 100).toFixed(2)}%`,
1234
+ `Consensus: ${(consensusValidation.average * 100).toFixed(2)}%`,
1235
+ ],
1236
+ });
1237
+
1238
+ console.log('Feedback prepared:');
1239
+ console.log(` - Gate: ${(iterationFeedback.gatePassRate! * 100).toFixed(2)}%`);
1240
+ console.log(` - Consensus: ${(iterationFeedback.consensusAverage! * 100).toFixed(2)}%`);
1241
+ console.log(` - Reasons: ${iterationFeedback.reasons?.join(', ')}`);
1242
+
1243
+ // Store iteration feedback in Redis for next Loop 3 agents to access
1244
+ // Using proper escaping to prevent Redis command injection (CVSS 9.8)
1245
+ try {
1246
+ const feedbackKey = escapeShellArg(`swarm:${this.config.taskId}:iteration:${iteration + 1}:feedback`);
1247
+ const gatePassRateVal = escapeShellArg(String(iterationFeedback.gatePassRate));
1248
+ const consensusAverageVal = escapeShellArg(String(iterationFeedback.consensusAverage));
1249
+ const reasonsVal = escapeShellArg(iterationFeedback.reasons?.join('; ') || '');
1250
+
1251
+ const cmd = `redis-cli HSET ${feedbackKey} "gate_pass_rate" ${gatePassRateVal} "consensus_average" ${consensusAverageVal} "reasons" ${reasonsVal}`;
1252
+ execSync(cmd, { encoding: 'utf-8' });
1253
+
1254
+ console.log(`Iteration feedback stored in Redis for iteration ${iteration + 1}`);
1255
+ } catch (error: unknown) {
1256
+ console.warn(`Failed to store iteration feedback: ${error instanceof Error ? error.message : String(error)}`);
1257
+ }
1258
+
1259
+ // Reset state for next iteration
1260
+ this.resetForIteration();
1261
+
1262
+ if (!this.canContinueIterating()) {
1263
+ console.log(`Max iterations (${maxIterations}) reached. ABORTING.`);
1264
+ this.recordDecision('ABORT');
1265
+ break;
1266
+ }
1267
+
1268
+ console.log(`\nProceeding to iteration ${iteration + 1}...`);
1269
+ continue; // Go to next iteration
1270
+ } else if (decision === 'ABORT') {
1271
+ console.log(`\n${'='.repeat(60)}`);
1272
+ console.log('FAILURE: Product Owner rejected. Aborting orchestration.');
1273
+ console.log(`${'='.repeat(60)}`);
1274
+ break;
1275
+ }
1276
+ }
1277
+
1278
+ // Final status
1279
+ const finalDecision = this.getDecision() || 'ABORT';
1280
+ const summary = this.getSummary();
1281
+
1282
+ console.log(`\nFinal Summary:`);
1283
+ console.log(` Task ID: ${summary.taskId}`);
1284
+ console.log(` Mode: ${summary.mode}`);
1285
+ console.log(` Iterations: ${summary.iteration}/${this.config.maxIterations}`);
1286
+ console.log(` Completed Agents: ${this.state.completedAgents.size}`);
1287
+ console.log(` Failed Agents: ${this.state.failedAgents.size}`);
1288
+ console.log(` Decision: ${finalDecision}`);
1289
+ console.log(` Duration: ${(summary.duration / 1000).toFixed(2)}s`);
1290
+
1291
+ return finalDecision;
1292
+ }
1293
+ }
1294
+
1295
+ /**
1296
+ * CLI entry point for orchestrator
1297
+ */
1298
+ if (require.main === module) {
1299
+ const args = process.argv.slice(2);
1300
+
1301
+ // Parse command line arguments
1302
+ let taskId = '';
1303
+ let mode: ExecutionMode = 'standard';
1304
+ let maxIterations = 10;
1305
+ let loop3Agents: string[] = [];
1306
+ let loop2Agents: string[] = [];
1307
+ let productOwner = '';
1308
+ let successCriteriaEnabled = false;
1309
+
1310
+ for (let i = 0; i < args.length; i++) {
1311
+ const arg = args[i];
1312
+ if (!arg) continue;
1313
+
1314
+ switch (arg) {
1315
+ case '--task-id': {
1316
+ const nextArg = args[++i];
1317
+ if (nextArg) taskId = nextArg;
1318
+ break;
1319
+ }
1320
+ case '--mode': {
1321
+ const nextArg = args[++i];
1322
+ if (nextArg) mode = nextArg as ExecutionMode;
1323
+ break;
1324
+ }
1325
+ case '--max-iterations': {
1326
+ const nextArg = args[++i];
1327
+ if (nextArg) maxIterations = parseInt(nextArg, 10);
1328
+ break;
1329
+ }
1330
+ case '--loop3-agents': {
1331
+ const nextArg = args[++i];
1332
+ if (nextArg) {
1333
+ loop3Agents = nextArg.split(',').map((a) => a.trim()).filter((a) => a.length > 0);
1334
+ }
1335
+ break;
1336
+ }
1337
+ case '--loop2-agents': {
1338
+ const nextArg = args[++i];
1339
+ if (nextArg) {
1340
+ loop2Agents = nextArg.split(',').map((a) => a.trim()).filter((a) => a.length > 0);
1341
+ }
1342
+ break;
1343
+ }
1344
+ case '--product-owner': {
1345
+ const nextArg = args[++i];
1346
+ if (nextArg) productOwner = nextArg;
1347
+ break;
1348
+ }
1349
+ case '--success-criteria': {
1350
+ const nextArg = args[++i];
1351
+ if (nextArg) {
1352
+ successCriteriaEnabled = nextArg.toLowerCase() === 'enabled' || nextArg === 'true';
1353
+ }
1354
+ break;
1355
+ }
1356
+ }
1357
+ }
1358
+
1359
+ if (!taskId) {
1360
+ console.error('Error: --task-id is required');
1361
+ process.exit(1);
1362
+ }
1363
+
1364
+ const config: OrchestrationConfig = {
1365
+ taskId,
1366
+ mode,
1367
+ maxIterations,
1368
+ };
1369
+
1370
+ // Add optional parameters only if they have values
1371
+ if (loop3Agents.length > 0) {
1372
+ config.loop3Agents = loop3Agents;
1373
+ }
1374
+ if (loop2Agents.length > 0) {
1375
+ config.loop2Agents = loop2Agents;
1376
+ }
1377
+ if (productOwner) {
1378
+ config.productOwner = productOwner;
1379
+ }
1380
+ if (successCriteriaEnabled) {
1381
+ config.successCriteriaEnabled = successCriteriaEnabled;
1382
+ }
1383
+
1384
+ const orchestrator = new Orchestrator(config);
1385
+ console.log(JSON.stringify(orchestrator.getState(), null, 2));
1386
+ process.exit(0);
1387
+ }
1388
+
1389
+ export default Orchestrator;