claude-flow-novice 2.18.5 → 2.18.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/FILE_MANIFEST.md +50 -0
- package/.claude/MANIFEST_INDEX.md +224 -0
- package/.claude/MANIFEST_README.md +308 -0
- package/.claude/TRIGGER_TASKS_MANIFEST.md +11 -0
- package/.claude/WORKING-SETUP.md +67 -0
- package/.claude/adaptive-context/cfn-v3-reflection.json +21 -0
- package/.claude/agent-principles/SPARSE_LANGUAGE_FINDINGS.md +991 -0
- package/.claude/agent-principles/agent-template.md +96 -0
- package/.claude/agent-principles/prompt-engineering.md +501 -0
- package/.claude/agents/cfn-dev-team/analysts/analyst.md +120 -0
- package/.claude/agents/cfn-dev-team/analysts/root-cause-analyst.md +264 -0
- package/.claude/agents/cfn-dev-team/architecture/api-designer-persona.md +152 -0
- package/.claude/agents/cfn-dev-team/architecture/base-template-generator.md +157 -0
- package/.claude/agents/cfn-dev-team/architecture/goal-planner.md +180 -0
- package/.claude/agents/cfn-dev-team/architecture/planner.md +139 -0
- package/.claude/agents/cfn-dev-team/architecture/system-architect.md +132 -0
- package/.claude/agents/cfn-dev-team/coordinators/cfn-frontend-coordinator.md +893 -0
- package/.claude/agents/cfn-dev-team/coordinators/consensus-builder.md +480 -0
- package/.claude/agents/cfn-dev-team/coordinators/handoff-coordinator.md +747 -0
- package/.claude/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +510 -0
- package/.claude/agents/cfn-dev-team/dev-ops/devops-engineer.md +157 -0
- package/.claude/agents/cfn-dev-team/dev-ops/docker-specialist.md +671 -0
- package/.claude/agents/cfn-dev-team/dev-ops/github-commit-agent.md +123 -0
- package/.claude/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +624 -0
- package/.claude/agents/cfn-dev-team/developers/api-gateway-specialist.md +977 -0
- package/.claude/agents/cfn-dev-team/developers/backend-developer-cerebras.md +210 -0
- package/.claude/agents/cfn-dev-team/developers/backend-developer.md +206 -0
- package/.claude/agents/cfn-dev-team/developers/data/data-engineer.md +672 -0
- package/.claude/agents/cfn-dev-team/developers/database/database-architect.md +376 -0
- package/.claude/agents/cfn-dev-team/developers/database/supabase-specialist.md +746 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/mobile-dev.md +247 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/react-frontend-engineer.md +272 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/typescript-specialist.md +396 -0
- package/.claude/agents/cfn-dev-team/developers/frontend/ui-designer.md +221 -0
- package/.claude/agents/cfn-dev-team/developers/graphql-specialist.md +707 -0
- package/.claude/agents/cfn-dev-team/developers/rust-developer.md +228 -0
- package/.claude/agents/cfn-dev-team/documentation/agent-type-guidelines.md +476 -0
- package/.claude/agents/cfn-dev-team/documentation/api-documentation.md +111 -0
- package/.claude/agents/cfn-dev-team/documentation/pseudocode.md +144 -0
- package/.claude/agents/cfn-dev-team/documentation/specification-agent.md +152 -0
- package/.claude/agents/cfn-dev-team/product-owners/accessibility-advocate-persona.md +119 -0
- package/.claude/agents/cfn-dev-team/product-owners/cto-agent.md +138 -0
- package/.claude/agents/cfn-dev-team/product-owners/power-user-persona.md +151 -0
- package/.claude/agents/cfn-dev-team/product-owners/product-owner.md +483 -0
- package/.claude/agents/cfn-dev-team/reviewers/code-reviewer.md +303 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +220 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/cyclomatic-complexity-reducer.md +334 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +257 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +160 -0
- package/.claude/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +386 -0
- package/.claude/agents/cfn-dev-team/testers/api-testing-specialist.md +757 -0
- package/.claude/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +944 -0
- package/.claude/agents/cfn-dev-team/testers/contract-tester.md +687 -0
- package/.claude/agents/cfn-dev-team/testers/e2e/playwright-tester.md +124 -0
- package/.claude/agents/cfn-dev-team/testers/integration-tester.md +785 -0
- package/.claude/agents/cfn-dev-team/testers/interaction-tester.md +188 -0
- package/.claude/agents/cfn-dev-team/testers/load-testing-specialist.md +505 -0
- package/.claude/agents/cfn-dev-team/testers/mutation-testing-specialist.md +643 -0
- package/.claude/agents/cfn-dev-team/testers/playwright-tester.md +253 -0
- package/.claude/agents/cfn-dev-team/testers/tester.md +224 -0
- package/.claude/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +37 -0
- package/.claude/agents/cfn-dev-team/testers/validation/validation-production-validator.md +27 -0
- package/.claude/agents/cfn-dev-team/testing/test-validation-agent.md +280 -0
- package/.claude/agents/cfn-dev-team/utility/agent-builder.md +487 -0
- package/.claude/agents/cfn-dev-team/utility/context-curator.md +69 -0
- package/.claude/agents/cfn-dev-team/utility/epic-creator-v2.md +2 -0
- package/.claude/agents/cfn-dev-team/utility/epic-creator.md +7 -0
- package/.claude/agents/cfn-dev-team/utility/memory-leak-specialist.md +177 -0
- package/.claude/agents/cfn-dev-team/utility/researcher.md +116 -0
- package/.claude/agents/cfn-dev-team/utility/z-ai-specialist.md +218 -0
- package/.claude/agents/custom/cfn-docker-expert.md +132 -0
- package/.claude/agents/custom/cfn-loops-cli-expert.md +9 -0
- package/.claude/agents/custom/cfn-redis-operations.md +538 -0
- package/.claude/agents/custom/cfn-system-expert.md +489 -0
- package/.claude/agents/custom/claude-code-expert.md +298 -0
- package/.claude/agents/custom/mdap-trigger-specialist.md +82 -0
- package/.claude/agents/custom/trigger-dev-expert.md +386 -0
- package/.claude/agents/docker-coordinators/cfn-docker-v3-coordinator.md +1101 -0
- package/.claude/agents/docker-ts-fixer.md +65 -0
- package/.claude/agents/project-only-agents/npm-package-specialist.md +334 -0
- package/.claude/cfn-config/team-providers.json +102 -0
- package/.claude/commands/README.md +204 -0
- package/.claude/commands/cfn-check-errors.md +34 -0
- package/.claude/commands/cfn-detect-stale-docs.md +26 -0
- package/.claude/commands/cfn-epic-creator-v2.md +10 -0
- package/.claude/commands/cfn-loop/CFN_LOOP_FRONTEND.md +741 -0
- package/.claude/commands/cfn-loop/cfn-loop-cli.md +273 -0
- package/.claude/commands/cfn-loop/cfn-loop-task.md +490 -0
- package/.claude/commands/cfn-loop/cfn-loop-trigger.md +56 -0
- package/.claude/commands/cfn-ruvector-search.md +46 -0
- package/.claude/commands/cfn-test-framework +5 -0
- package/.claude/commands/cfn-update-search-index.md +31 -0
- package/.claude/coordinator-feedback-pattern.md +326 -0
- package/.claude/coordinator-patterns.md +126 -0
- package/.claude/core/agent-manager.js +80 -0
- package/.claude/core/agent-manager.js.map +1 -0
- package/.claude/core/cfn-agent-manager.js +80 -0
- package/.claude/core/cfn-agent-manager.js.map +1 -0
- package/.claude/core/cfn-config.js +1241 -0
- package/.claude/core/cfn-config.js.map +1 -0
- package/.claude/core/cfn-event-bus.js +136 -0
- package/.claude/core/cfn-event-bus.js.map +1 -0
- package/.claude/core/cfn-index.js +6 -0
- package/.claude/core/cfn-index.js.map +1 -0
- package/.claude/core/cfn-json-persistence.js +112 -0
- package/.claude/core/cfn-json-persistence.js.map +1 -0
- package/.claude/core/cfn-logger.js +245 -0
- package/.claude/core/cfn-logger.js.map +1 -0
- package/.claude/core/cfn-orchestrator-fixed.js +236 -0
- package/.claude/core/cfn-orchestrator-fixed.js.map +1 -0
- package/.claude/core/cfn-orchestrator.js +1136 -0
- package/.claude/core/cfn-orchestrator.js.map +1 -0
- package/.claude/core/cfn-persistence.js +185 -0
- package/.claude/core/cfn-persistence.js.map +1 -0
- package/.claude/core/cfn-project-manager.js +80 -0
- package/.claude/core/cfn-project-manager.js.map +1 -0
- package/.claude/core/cfn-slash-command.js +24 -0
- package/.claude/core/cfn-version.js +35 -0
- package/.claude/core/cfn-version.js.map +1 -0
- package/.claude/core/config.js +1241 -0
- package/.claude/core/config.js.map +1 -0
- package/.claude/core/event-bus.js +136 -0
- package/.claude/core/event-bus.js.map +1 -0
- package/.claude/core/index.js +6 -0
- package/.claude/core/index.js.map +1 -0
- package/.claude/core/json-persistence.js +112 -0
- package/.claude/core/json-persistence.js.map +1 -0
- package/.claude/core/logger.js +245 -0
- package/.claude/core/logger.js.map +1 -0
- package/.claude/core/orchestrator-fixed.js +236 -0
- package/.claude/core/orchestrator-fixed.js.map +1 -0
- package/.claude/core/orchestrator.js +1136 -0
- package/.claude/core/orchestrator.js.map +1 -0
- package/.claude/core/persistence.js +185 -0
- package/.claude/core/persistence.js.map +1 -0
- package/.claude/core/project-manager.js +80 -0
- package/.claude/core/project-manager.js.map +1 -0
- package/.claude/core/slash-command.js +24 -0
- package/.claude/core/version.js +35 -0
- package/.claude/core/version.js.map +1 -0
- package/.claude/helpers/cfn-checkpoint-manager.sh +251 -0
- package/.claude/helpers/cfn-github-safe.js +106 -0
- package/.claude/helpers/cfn-github-setup.sh +28 -0
- package/.claude/helpers/cfn-quick-start.sh +19 -0
- package/.claude/helpers/cfn-setup-mcp.sh +18 -0
- package/.claude/helpers/cfn-standard-checkpoint-hooks.sh +179 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +179 -0
- package/.claude/hooks/SKILL.md +518 -0
- package/.claude/hooks/cfn-post-edit.config.json +51 -0
- package/.claude/hooks/cfn-pre-edit-security-warning.sh +40 -0
- package/.claude/hooks/cfn-subagent-start.sh +98 -0
- package/.claude/hooks/cfn-subagent-stop.sh +129 -0
- package/.claude/hooks.json +33 -0
- package/.claude/logs/sprint1-hybrid-routing-v2-decision.json +18 -0
- package/.claude/prompts/cfn-loop-context.md +115 -0
- package/.claude/prompts/loop-specific/loop2.md +50 -0
- package/.claude/prompts/loop-specific/loop3.md +43 -0
- package/.claude/prompts/loop-specific/loop4.md +54 -0
- package/.claude/settings.json +172 -0
- package/.claude/settings.local.json +41 -0
- package/.claude/settings.playwright.json +198 -0
- package/.claude/skills/.cfn/task-configs/task-test-123.json +48 -0
- package/.claude/skills/bulk-add-ruvector-instructions.sh +89 -0
- package/.claude/skills/cfn-agent-lifecycle/SKILL.md +290 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/lifecycle-hook.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/select-agents.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/cli/spawn-agent.sh +5 -0
- package/.claude/skills/cfn-agent-lifecycle/execute.sh +355 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/audit/execute-lifecycle-hook.sh +544 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/agent-selector.ts +350 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/selection/src/cli.ts +74 -0
- package/.claude/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent-wrapper.sh +63 -0
- package/.claude/skills/cfn-agent-selector +1 -0
- package/.claude/skills/cfn-agent-spawning +1 -0
- package/.claude/skills/cfn-cerebras-code-generator/SKILL.md +53 -0
- package/.claude/skills/cfn-cerebras-code-generator/context-analyzer.sh +96 -0
- package/.claude/skills/cfn-cerebras-code-generator/generate-code.sh +205 -0
- package/.claude/skills/cfn-cerebras-coordinator/SKILL.md +103 -0
- package/.claude/skills/cfn-cerebras-coordinator/TEST_RESULTS.md +98 -0
- package/.claude/skills/cfn-cerebras-coordinator/coordinate-generation.sh +381 -0
- package/.claude/skills/cfn-cerebras-coordinator/example-fix-scenario.md +254 -0
- package/.claude/skills/cfn-cerebras-coordinator/example-workflow.md +142 -0
- package/.claude/skills/cfn-cerebras-coordinator/feedback-logger.sh +254 -0
- package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code-v2.sh +443 -0
- package/.claude/skills/cfn-cerebras-coordinator/fix-existing-code.sh +519 -0
- package/.claude/skills/cfn-cerebras-coordinator/pattern-examples.md +317 -0
- package/.claude/skills/cfn-cerebras-coordinator/query-patterns.sh +182 -0
- package/.claude/skills/cfn-cerebras-coordinator/tdd-coordinator.sh +638 -0
- package/.claude/skills/cfn-cerebras-coordinator/test-runner.sh +335 -0
- package/.claude/skills/cfn-cerebras-mcp/SKILL.md +64 -0
- package/.claude/skills/cfn-compilation-error-fixer/HANDOFF.md +29 -0
- package/.claude/skills/cfn-compilation-error-fixer/README.md +202 -0
- package/.claude/skills/cfn-compilation-error-fixer/SKILL.md +426 -0
- package/.claude/skills/cfn-compilation-error-fixer/bin/fix-errors.sh +75 -0
- package/.claude/skills/cfn-compilation-error-fixer/index.js +81 -0
- package/.claude/skills/cfn-compilation-error-fixer/install.sh +60 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/README-TypeScript.md +164 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1475 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts.bak +1475 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-sdk.d.ts +30 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/cerebras-wrapper.ts +93 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json +30 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/package.json.bak +23 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/fixer/typescript-gated-fixer-v2.ts +977 -0
- package/.claude/skills/cfn-compilation-error-fixer/lib/gates/typescript-gates.ts +704 -0
- package/.claude/skills/cfn-compilation-error-fixer/package.json +47 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-fixer-logic.sh +96 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-installation.sh +97 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer-validation.sh +54 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-rust-fixer.sh +380 -0
- package/.claude/skills/cfn-compilation-error-fixer/test-typescript-fixer.sh +278 -0
- package/.claude/skills/cfn-compilation-error-fixer/validate-setup.md +70 -0
- package/.claude/skills/cfn-config/lib/management/manage-config.sh +115 -0
- package/.claude/skills/cfn-dependency-management/SKILL.md +118 -0
- package/.claude/skills/cfn-dependency-management/cfn-dependency-management.sh +18 -0
- package/.claude/skills/cfn-dependency-management/execute.sh +306 -0
- package/.claude/skills/cfn-dependency-management/lib/ingestion/src/ingest-dependencies.ts +563 -0
- package/.claude/skills/cfn-docker-runtime/execute.sh +386 -0
- package/.claude/skills/cfn-docker-wave-execution +1 -0
- package/.claude/skills/cfn-edit-safety/README.md +160 -0
- package/.claude/skills/cfn-edit-safety/cli/edit-safety-cli.sh +337 -0
- package/.claude/skills/cfn-edit-safety/edit-safety.sh +375 -0
- package/.claude/skills/cfn-edit-safety/lib/hooks/post-edit-handler.sh +155 -0
- package/.claude/skills/cfn-epic-parser/SKILL.md +220 -0
- package/.claude/skills/cfn-epic-parser/example-epic.md +49 -0
- package/.claude/skills/cfn-epic-parser/parse.sh +517 -0
- package/.claude/skills/cfn-epic-parser/test-parser.sh +299 -0
- package/.claude/skills/cfn-error-management/cli/batch-errors.sh +4 -0
- package/.claude/skills/cfn-error-management/cli/capture-error.sh +4 -0
- package/.claude/skills/cfn-error-management/cli/log-error.sh +4 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/error-logger.ts +1042 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/index.ts +12 -0
- package/.claude/skills/cfn-error-management/lib/logging/src/types.ts +456 -0
- package/.claude/skills/cfn-expert-update/SKILL.md +149 -0
- package/.claude/skills/cfn-expert-update/test-expert-update.sh +254 -0
- package/.claude/skills/cfn-expert-update/update-expert.sh +484 -0
- package/.claude/skills/cfn-hybrid-routing +1 -0
- package/.claude/skills/cfn-intervention-system/lib/detector/detect-intervention.sh +106 -0
- package/.claude/skills/cfn-knowledge-base/SKILL.md +109 -0
- package/.claude/skills/cfn-knowledge-base/cli/knowledge-base.sh +435 -0
- package/.claude/skills/cfn-knowledge-base/execute.sh +163 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/SKILL.md +153 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/init-playbook.sh +54 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/query-playbook.sh +89 -0
- package/.claude/skills/cfn-knowledge-base/lib/playbook/update-playbook.sh +67 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/COST_TRACKING.md +637 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/EDGE_CASE_TRACKING.md +404 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/README_PHASE4.md +457 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/SKILL.md +110 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/generate-skill-update.sh +525 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh +654 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/index.ts +24 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/pattern-analyzer.ts +537 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/src/types.ts +180 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh +486 -0
- package/.claude/skills/cfn-knowledge-base/lib/workflow/track-edge-case.sh +290 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/AGENT_LIFECYCLE_INTEGRATION.md +341 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/Cargo.toml +40 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/README.md +563 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/SKILL.md +343 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/analyze-agent-failures.sh +275 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/cfn-integration.sh +179 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/embeddings_manager.py +289 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/index-code.sh +234 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/ingest-agent-transcript.sh +255 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/init-local-ruvector.sh +112 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/project-structure.md +53 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/query-agent-patterns.sh +197 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/query-local.sh +169 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/requirements.txt +2 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/search_engine.py +200 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/search_engine_v2.py +238 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/sqlite_store.py +220 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/cleanup.rs +134 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/export.rs +40 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/index.rs +301 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/init.rs +127 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/migration.rs +74 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/mod.rs +18 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/query.rs +222 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/reset.rs +37 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/cli/stats.rs +133 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/embeddings.rs +121 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/main.rs +359 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/migration.rs +318 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/search_engine.rs +281 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/src/sqlite_store.rs +211 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/test-agent-lifecycle-integration.sh +254 -0
- package/.claude/skills/cfn-local-ruvector-accelerator/test-local-ruvector.sh +250 -0
- package/.claude/skills/cfn-loop-orchestration +1 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/cfn-orchestrator.cjs +49 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/orchestrate.sh +21 -0
- package/.claude/skills/cfn-loop-orchestration-v2/cli/resolve-provider-model.cjs +69 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/agent-spawner/agent-spawner.ts +34 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/cli/orchestrator-cli.ts +396 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/gate-checker/gate-checker.ts +36 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR.md +564 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONFIDENCE_AGGREGATOR_QUICK_REF.md +241 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_QUICK_REFERENCE.md +362 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_README.md +307 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/CONTEXT_INJECTOR_USAGE_GUIDE.md +508 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/confidence-aggregator.ts +473 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/consensus.ts +87 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-injector.ts +349 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/context-lookup.ts +486 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/deliverable-verifier.ts +107 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/gate-check.ts +115 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/iteration-manager.ts +45 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/parse-test-results.ts +372 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/product-owner-decision.ts +316 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/spawn-agents.ts +357 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/timeout-calculator.ts +41 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/helpers/validator.ts +276 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/index.ts +16 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrate.ts +1389 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/orchestrator/orchestrator.ts +31 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/redis/redis-coordinator.ts +72 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/types.ts +244 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/orchestrator/src/utils/logger.ts +32 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/index.ts +6 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/output-processor.ts +183 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop2.ts +195 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/cli/process-loop3.ts +157 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/output/src/output-processor.ts +632 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh +59 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/index.ts +12 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/detect-vapor.ts +177 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-deliverables.ts +161 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/cli/validate-gate.ts +139 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/types.ts +215 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/src/validator.ts +503 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh +59 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh +63 -0
- package/.claude/skills/cfn-loop-orchestration-v2/lib/validation/validation-framework.ts +237 -0
- package/.claude/skills/cfn-mdap-context-injection/SKILL.md +14 -0
- package/.claude/skills/cfn-mdap-context-injection/inject.sh +348 -0
- package/.claude/skills/cfn-mdap-error-fixer/HANDOFF.md +383 -0
- package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/cerebras-gated-fixer-v2.ts +1500 -0
- package/.claude/skills/cfn-mdap-error-fixer/lib/fixer/package.json +20 -0
- package/.claude/skills/cfn-mdap-error-fixer/skill.md +205 -0
- package/.claude/skills/cfn-memory-persistence/lib/auto/test-memory-persistence.sh +230 -0
- package/.claude/skills/cfn-memory-persistence/lib/sqlite/memory-cli.sh +74 -0
- package/.claude/skills/cfn-memory-persistence/lib/sqlite/ttl-cleanup.sh +266 -0
- package/.claude/skills/cfn-node-heap-sizer/SKILL.md +313 -0
- package/.claude/skills/cfn-node-heap-sizer/task-mode-heap-limiter.sh +326 -0
- package/.claude/skills/cfn-operations/execute.sh +175 -0
- package/.claude/skills/cfn-operations/lib/file/lib/lock.sh +361 -0
- package/.claude/skills/cfn-operations/lib/file/test.sh +373 -0
- package/.claude/skills/cfn-operations/lib/log/test.sh +400 -0
- package/.claude/skills/cfn-parameterized-queries/SKILL.md +368 -0
- package/.claude/skills/cfn-parameterized-queries/parameterized-queries.sh +249 -0
- package/.claude/skills/cfn-parameterized-queries/test-implementation.sh +237 -0
- package/.claude/skills/cfn-planning/execute.sh +159 -0
- package/.claude/skills/cfn-process-management/cfn-process +16 -0
- package/.claude/skills/cfn-process-management/cli/process-manager +186 -0
- package/.claude/skills/cfn-process-management/lib/lifecycle/process-manager.sh +334 -0
- package/.claude/skills/cfn-project-management/SKILL.md +60 -0
- package/.claude/skills/cfn-provider-routing +1 -0
- package/.claude/skills/cfn-redis-coordination +1 -0
- package/.claude/skills/cfn-routing-config/lib/provider/resolve-provider-model.ts +252 -0
- package/.claude/skills/cfn-session-handoff/SKILL.md +53 -0
- package/.claude/skills/cfn-skill-management/FIXES_APPLIED.md +80 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/package.json +56 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/cli.ts +75 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/database-adapter.ts +239 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/file-system-adapter.ts +113 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/index.ts +72 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/logger.ts +43 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/metadata-parser.ts +154 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-propagator.ts +274 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/skill-validator.ts +179 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/types.ts +143 -0
- package/.claude/skills/cfn-skill-management/lib/propagation/src/version-manager.ts +118 -0
- package/.claude/skills/cfn-skill-management/src/cli/skill-loader.ts +364 -0
- package/.claude/skills/cfn-skill-management/src/lib/database-service.ts +313 -0
- package/.claude/skills/cfn-sprint-execution/execute.sh +257 -0
- package/.claude/skills/cfn-sprint-execution/lib/execution/execute-sprint-task.sh +68 -0
- package/.claude/skills/cfn-task-decomposition/explore-123-subtasks.json +27 -0
- package/.claude/skills/cfn-task-decomposition/prompts/explore-123-analyze-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/explore-123-scan-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-fix-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-pattern-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-recon-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/prompts/test-final-validate-prompt.md +36 -0
- package/.claude/skills/cfn-task-decomposition/test-456-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-789-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-999-subtasks.json +27 -0
- package/.claude/skills/cfn-task-decomposition/test-debug-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-debug2-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-final-subtasks.json +60 -0
- package/.claude/skills/cfn-task-decomposition/test-simple-subtasks.json +60 -0
- package/.claude/skills/cfn-task-intelligence/SKILL.md +18 -0
- package/.claude/skills/cfn-task-intelligence/cfn-task-intelligence.sh +158 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/SKILL.md +339 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/learning-loop.sh +127 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/post-feedback-hook.sh +124 -0
- package/.claude/skills/cfn-task-intelligence/lib/integration/pre-execution-hook.sh +59 -0
- package/.claude/skills/cfn-task-planning/SKILL.md +15 -0
- package/.claude/skills/cfn-task-planning/cli/classify-task.sh +4 -0
- package/.claude/skills/cfn-task-planning/cli/decompose-task.sh +4 -0
- package/.claude/skills/cfn-task-planning/cli/init-config.sh +4 -0
- package/.claude/skills/cfn-task-planning/lib/audit/get-audit-data.sh +397 -0
- package/.claude/skills/cfn-task-planning/lib/audit/store-task-audit.sh +191 -0
- package/.claude/skills/cfn-task-planning/lib/decomposition/task-decomposer.sh +415 -0
- package/.claude/skills/cfn-test-framework/CLI.md +191 -0
- package/.claude/skills/cfn-test-framework/execute.sh +386 -0
- package/.claude/skills/cfn-transparency-middleware/CACHE_MANAGER.md +98 -0
- package/.claude/skills/cfn-transparency-middleware/Cargo.lock +2358 -0
- package/.claude/skills/cfn-transparency-middleware/Cargo.toml +20 -0
- package/.claude/skills/cfn-transparency-middleware/README.md +327 -0
- package/.claude/skills/cfn-transparency-middleware/SKILL.md +327 -0
- package/.claude/skills/cfn-transparency-middleware/config.json +23 -0
- package/.claude/skills/cfn-transparency-middleware/fix_redact.sh +12 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +98 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-init.sh +224 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-level.sh +333 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +345 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +140 -0
- package/.claude/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +235 -0
- package/.claude/skills/cfn-transparency-middleware/src/agent_metrics.rs +480 -0
- package/.claude/skills/cfn-transparency-middleware/src/api_handler.rs +318 -0
- package/.claude/skills/cfn-transparency-middleware/src/cache_manager.rs +219 -0
- package/.claude/skills/cfn-transparency-middleware/src/fix_regex.rs +9 -0
- package/.claude/skills/cfn-transparency-middleware/src/lib.rs +391 -0
- package/.claude/skills/cfn-transparency-middleware/src/main.rs +205 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_query.rs +93 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_repository.rs +169 -0
- package/.claude/skills/cfn-transparency-middleware/src/memory_schema.rs +154 -0
- package/.claude/skills/cfn-transparency-middleware/src/test_fix.txt +2 -0
- package/.claude/skills/cfn-transparency-middleware/test-integration.sh +162 -0
- package/.claude/skills/cfn-utilities/lib/logging.sh +77 -0
- package/.claude/skills/cfn-validation-framework/execute.sh +223 -0
- package/.claude/skills/equation-solver/solve.sh +352 -0
- package/.claude/skills/equation-solver/test.cjs +25 -0
- package/.claude/skills/shared/bootstrap/sqlite-params.sh +156 -0
- package/.claude/skills/shared/lib/path-utils.sh +139 -0
- package/.claude/skills-database/APPROVAL_CRITERIA.md +925 -0
- package/.claude/skills-database/APPROVAL_WORKFLOW.md +1482 -0
- package/.claude/skills-database/ARCHITECTURE_DECISIONS.md +456 -0
- package/.claude/skills-database/IMPLEMENTATION_GUIDE.md +763 -0
- package/.claude/skills-database/README.md +564 -0
- package/.claude/skills-database/TDD_SKILLS_DB_INTEGRATION.md +2286 -0
- package/.claude/skills-database/schema-v2.sql +587 -0
- package/.claude/slash-commands.json +92 -0
- package/.claude/spawn-pattern-examples.md +500 -0
- package/.claude/sprint-configs/cfn-naming-standardization.json +729 -0
- package/.claude/state/cfn-expert-last-commit +2 -0
- package/.claude/tooling/jq +0 -0
- package/fix-node_modules.md +68 -0
- package/package.json +44 -40
- package/readme/COMPONENT_NPM_STATUS.md +1 -1
- package/readme/installation-process.md +1 -1
- package/scripts/cfn-init.js +377 -0
- package/scripts/postinstall.js +144 -0
- package/trigger.config.ts +9 -0
- package/claude-assets/agents/cfn-dev-team/analysts/analyst.md +0 -113
- package/claude-assets/agents/cfn-dev-team/analysts/root-cause-analyst.md +0 -257
- package/claude-assets/agents/cfn-dev-team/architecture/api-designer-persona.md +0 -145
- package/claude-assets/agents/cfn-dev-team/architecture/base-template-generator.md +0 -150
- package/claude-assets/agents/cfn-dev-team/architecture/goal-planner.md +0 -173
- package/claude-assets/agents/cfn-dev-team/architecture/planner.md +0 -132
- package/claude-assets/agents/cfn-dev-team/architecture/system-architect.md +0 -125
- package/claude-assets/agents/cfn-dev-team/coordinators/cfn-frontend-coordinator.md +0 -886
- package/claude-assets/agents/cfn-dev-team/coordinators/consensus-builder.md +0 -473
- package/claude-assets/agents/cfn-dev-team/coordinators/handoff-coordinator.md +0 -740
- package/claude-assets/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +0 -503
- package/claude-assets/agents/cfn-dev-team/dev-ops/devops-engineer.md +0 -150
- package/claude-assets/agents/cfn-dev-team/dev-ops/docker-specialist.md +0 -664
- package/claude-assets/agents/cfn-dev-team/dev-ops/github-commit-agent.md +0 -116
- package/claude-assets/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +0 -617
- package/claude-assets/agents/cfn-dev-team/developers/api-gateway-specialist.md +0 -970
- package/claude-assets/agents/cfn-dev-team/developers/backend-developer.md +0 -192
- package/claude-assets/agents/cfn-dev-team/developers/data/data-engineer.md +0 -665
- package/claude-assets/agents/cfn-dev-team/developers/database/database-architect.md +0 -369
- package/claude-assets/agents/cfn-dev-team/developers/database/supabase-specialist.md +0 -739
- package/claude-assets/agents/cfn-dev-team/developers/frontend/mobile-dev.md +0 -240
- package/claude-assets/agents/cfn-dev-team/developers/frontend/react-frontend-engineer.md +0 -256
- package/claude-assets/agents/cfn-dev-team/developers/frontend/typescript-specialist.md +0 -389
- package/claude-assets/agents/cfn-dev-team/developers/frontend/ui-designer.md +0 -214
- package/claude-assets/agents/cfn-dev-team/developers/graphql-specialist.md +0 -700
- package/claude-assets/agents/cfn-dev-team/developers/rust-developer.md +0 -221
- package/claude-assets/agents/cfn-dev-team/documentation/agent-type-guidelines.md +0 -469
- package/claude-assets/agents/cfn-dev-team/documentation/api-documentation.md +0 -104
- package/claude-assets/agents/cfn-dev-team/documentation/pseudocode.md +0 -137
- package/claude-assets/agents/cfn-dev-team/documentation/specification-agent.md +0 -145
- package/claude-assets/agents/cfn-dev-team/product-owners/accessibility-advocate-persona.md +0 -112
- package/claude-assets/agents/cfn-dev-team/product-owners/cto-agent.md +0 -131
- package/claude-assets/agents/cfn-dev-team/product-owners/power-user-persona.md +0 -144
- package/claude-assets/agents/cfn-dev-team/product-owners/product-owner.md +0 -476
- package/claude-assets/agents/cfn-dev-team/reviewers/code-reviewer.md +0 -287
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +0 -213
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/cyclomatic-complexity-reducer.md +0 -327
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +0 -250
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +0 -153
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +0 -379
- package/claude-assets/agents/cfn-dev-team/testers/api-testing-specialist.md +0 -750
- package/claude-assets/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +0 -937
- package/claude-assets/agents/cfn-dev-team/testers/contract-tester.md +0 -680
- package/claude-assets/agents/cfn-dev-team/testers/e2e/playwright-tester.md +0 -117
- package/claude-assets/agents/cfn-dev-team/testers/integration-tester.md +0 -778
- package/claude-assets/agents/cfn-dev-team/testers/interaction-tester.md +0 -181
- package/claude-assets/agents/cfn-dev-team/testers/load-testing-specialist.md +0 -498
- package/claude-assets/agents/cfn-dev-team/testers/mutation-testing-specialist.md +0 -636
- package/claude-assets/agents/cfn-dev-team/testers/playwright-tester.md +0 -246
- package/claude-assets/agents/cfn-dev-team/testers/tester.md +0 -208
- package/claude-assets/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +0 -30
- package/claude-assets/agents/cfn-dev-team/testers/validation/validation-production-validator.md +0 -20
- package/claude-assets/agents/cfn-dev-team/testing/test-validation-agent.md +0 -273
- package/claude-assets/agents/cfn-dev-team/utility/agent-builder.md +0 -480
- package/claude-assets/agents/cfn-dev-team/utility/context-curator.md +0 -62
- package/claude-assets/agents/cfn-dev-team/utility/epic-creator.md +0 -132
- package/claude-assets/agents/cfn-dev-team/utility/memory-leak-specialist.md +0 -170
- package/claude-assets/agents/cfn-dev-team/utility/researcher.md +0 -109
- package/claude-assets/agents/cfn-dev-team/utility/z-ai-specialist.md +0 -211
- package/claude-assets/agents/custom/cfn-docker-expert.md +0 -104
- package/claude-assets/agents/custom/cfn-loops-cli-expert.md +0 -455
- package/claude-assets/agents/custom/cfn-redis-operations.md +0 -531
- package/claude-assets/agents/custom/cfn-system-expert.md +0 -337
- package/claude-assets/agents/custom/claude-code-expert.md +0 -291
- package/claude-assets/agents/custom/mdap-trigger-specialist.md +0 -437
- package/claude-assets/agents/custom/trigger-dev-expert.md +0 -370
- package/claude-assets/agents/docker-coordinators/cfn-docker-v3-coordinator.md +0 -1094
- package/claude-assets/agents/docker-ts-fixer.md +0 -58
- package/claude-assets/agents/project-only-agents/npm-package-specialist.md +0 -327
- package/claude-assets/commands/README.md +0 -205
- package/claude-assets/commands/cfn-loop/CFN_LOOP_FRONTEND.md +0 -741
- package/claude-assets/commands/cfn-loop/CFN_LOOP_TASK_MODE.md +0 -608
- package/claude-assets/commands/cfn-loop/cfn-loop-cli.md +0 -308
- package/claude-assets/commands/cfn-loop/cfn-loop-trigger.md +0 -132
- package/claude-assets/commands/deprecated/README.md +0 -24
- package/claude-assets/hooks/SKILL.md +0 -518
- package/claude-assets/hooks/SKILL.md.backup +0 -471
- package/claude-assets/hooks/cfn-invoke-post-edit-ts.sh.backup +0 -78
- package/claude-assets/hooks/cfn-invoke-post-edit.sh.backup +0 -87
- package/claude-assets/hooks/cfn-invoke-pre-edit-ts.sh.backup +0 -94
- package/claude-assets/hooks/cfn-invoke-pre-edit.sh.backup +0 -88
- package/claude-assets/hooks/cfn-post-edit.config.json +0 -51
- package/claude-assets/hooks/cfn-post-execution/memory-cleanup.sh +0 -20
- package/claude-assets/hooks/cfn-pre-edit-security-warning.sh +0 -40
- package/claude-assets/hooks/cfn-pre-execution/SESSION_START_README.md +0 -87
- package/claude-assets/hooks/cfn-pre-execution/TEST_SESSION_START.md +0 -128
- package/claude-assets/hooks/cfn-pre-execution/memory-check.sh +0 -20
- package/claude-assets/hooks/cfn-pre-execution/session-start-context.sh +0 -111
- package/claude-assets/hooks/subagent-start.sh +0 -98
- package/claude-assets/hooks/subagent-stop.sh +0 -93
- package/claude-assets/skills/cfn-agent-lifecycle/SKILL.md +0 -290
- package/claude-assets/skills/cfn-agent-lifecycle/cli/lifecycle-hook.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/cli/select-agents.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/cli/spawn-agent.sh +0 -5
- package/claude-assets/skills/cfn-agent-lifecycle/lib/audit/execute-lifecycle-hook.sh +0 -544
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/agent-selector.cjs +0 -297
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/agent-selector.js +0 -297
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/cli.cjs +0 -96
- package/claude-assets/skills/cfn-agent-lifecycle/lib/selection/dist/cli.js +0 -96
- package/claude-assets/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent-wrapper.sh +0 -63
- package/claude-assets/skills/cfn-cerebras-mcp/SKILL.md +0 -58
- package/claude-assets/skills/cfn-config/lib/management/manage-config.sh +0 -113
- package/claude-assets/skills/cfn-dependency-management/SKILL.md +0 -60
- package/claude-assets/skills/cfn-dependency-management/lib/ingestion/dist/ingest-dependencies.js +0 -478
- package/claude-assets/skills/cfn-docker-runtime/lib/build/SKILL.md +0 -96
- package/claude-assets/skills/cfn-docker-runtime/lib/build/build.sh +0 -73
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/README.md +0 -349
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/docker-helpers.sh +0 -433
- package/claude-assets/skills/cfn-docker-runtime/lib/coordination/package.json +0 -38
- package/claude-assets/skills/cfn-edit-safety/lib/backup/SKILL.md.backup +0 -277
- package/claude-assets/skills/cfn-edit-safety/lib/backup/backup.sh.backup +0 -107
- package/claude-assets/skills/cfn-edit-safety/lib/hooks/post-edit-handler.sh +0 -154
- package/claude-assets/skills/cfn-epic-parser/SKILL.md +0 -55
- package/claude-assets/skills/cfn-error-management/cli/batch-errors.sh +0 -4
- package/claude-assets/skills/cfn-error-management/cli/capture-error.sh +0 -4
- package/claude-assets/skills/cfn-error-management/cli/log-error.sh +0 -4
- package/claude-assets/skills/cfn-expert-update/SKILL.md +0 -24
- package/claude-assets/skills/cfn-expert-update/update-expert.sh +0 -346
- package/claude-assets/skills/cfn-github-workflow/SKILL.md +0 -70
- package/claude-assets/skills/cfn-intervention-system/lib/detector/detect-intervention.sh +0 -111
- package/claude-assets/skills/cfn-knowledge-base/SKILL.md +0 -61
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/SKILL.md +0 -153
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/init-playbook.sh +0 -54
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/query-playbook.sh +0 -83
- package/claude-assets/skills/cfn-knowledge-base/lib/playbook/update-playbook.sh +0 -80
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/COST_TRACKING.md +0 -637
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/EDGE_CASE_TRACKING.md +0 -404
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/README_PHASE4.md +0 -457
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/SKILL.md +0 -110
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/generate-skill-update.sh +0 -525
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh +0 -648
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh +0 -486
- package/claude-assets/skills/cfn-knowledge-base/lib/workflow/track-edge-case.sh +0 -290
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/agent-completion.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-signal.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/coordination/coordination-wait.sh.backup +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/agent-spawner/agent-spawner.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/agent-spawner/agent-spawner.js +0 -29
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/cli/orchestrator-cli.d.ts +0 -49
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/cli/orchestrator-cli.js +0 -339
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/gate-checker/gate-checker.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/gate-checker/gate-checker.js +0 -32
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/confidence-aggregator.d.ts +0 -115
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/confidence-aggregator.js +0 -359
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/consensus.d.ts +0 -36
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/consensus.js +0 -62
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-injector.d.ts +0 -135
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-injector.js +0 -257
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-lookup.d.ts +0 -179
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/context-lookup.js +0 -388
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/deliverable-verifier.d.ts +0 -26
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/deliverable-verifier.js +0 -116
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/gate-check.d.ts +0 -27
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/gate-check.js +0 -92
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/iteration-manager.d.ts +0 -28
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/iteration-manager.js +0 -34
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/parse-test-results.d.ts +0 -21
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/parse-test-results.js +0 -323
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/product-owner-decision.d.ts +0 -86
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/product-owner-decision.js +0 -272
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/spawn-agents.d.ts +0 -61
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/spawn-agents.js +0 -280
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/timeout-calculator.d.ts +0 -15
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/timeout-calculator.js +0 -34
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/validator.d.ts +0 -83
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/helpers/validator.js +0 -222
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/index.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/index.js +0 -32
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrate.d.ts +0 -325
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrate.js +0 -1083
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrator/orchestrator.d.ts +0 -17
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/orchestrator/orchestrator.js +0 -31
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/redis/redis-coordinator.d.ts +0 -46
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/redis/redis-coordinator.js +0 -68
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/types.d.ts +0 -166
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/types.js +0 -101
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/utils/logger.d.ts +0 -16
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/dist/utils/logger.js +0 -29
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/orchestrate.sh.backup2 +0 -959
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/orchestrator/orchestrate.sh.clean +0 -949
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md.backup +0 -353
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh.backup +0 -31
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh +0 -59
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/detect-vapor.sh.backup +0 -37
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/.tsbuildinfo +0 -1
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/detect-vapor.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/detect-vapor.js +0 -185
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-deliverables.d.ts +0 -14
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-deliverables.js +0 -176
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-gate.d.ts +0 -19
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/cli/validate-gate.js +0 -123
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/types.d.ts +0 -156
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/types.js +0 -66
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/validator.d.ts +0 -85
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/dist/validator.js +0 -411
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh.backup +0 -252
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh +0 -59
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-deliverables.sh.backup +0 -37
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh +0 -63
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-gate.sh.backup +0 -41
- package/claude-assets/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh.backup +0 -134
- package/claude-assets/skills/cfn-mdap-context-injection/SKILL.md +0 -176
- package/claude-assets/skills/cfn-mdap-context-injection/inject.sh +0 -284
- package/claude-assets/skills/cfn-memory-persistence/lib/auto/test-memory-persistence.sh +0 -236
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/agent-log.sh.backup +0 -128
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/agent-recovery.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/analyze-task-complexity.sh.backup +0 -277
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/bash-wrappers/store-context.sh.backup +0 -23
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cancel-swarm.sh.backup +0 -221
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cfn-loop-exec.sh.backup +0 -468
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/cfn-loop-relaunch.sh.backup +0 -29
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/collect-confidence-scores.sh.backup +0 -209
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/collect-results.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/complete-swarm.sh.backup +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-logger.d.ts +0 -92
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-logger.js +0 -329
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-recovery.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/agent-recovery.js +0 -302
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/completion-reporter.d.ts +0 -58
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/completion-reporter.js +0 -237
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/context-manager.d.ts +0 -63
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/context-manager.js +0 -230
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/index.d.ts +0 -45
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/index.js +0 -114
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/mode-detector.d.ts +0 -31
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/mode-detector.js +0 -185
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/redis-client.d.ts +0 -191
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/redis-client.js +0 -509
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/result-collector.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/result-collector.js +0 -281
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/swarm-manager.d.ts +0 -75
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/swarm-manager.js +0 -354
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-analyzer.d.ts +0 -62
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-analyzer.js +0 -305
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-executor.d.ts +0 -97
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/task-executor.js +0 -283
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/types.d.ts +0 -176
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/types.js +0 -81
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/waiting-coordinator.d.ts +0 -86
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/dist/waiting-coordinator.js +0 -419
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/get-context.sh.backup +0 -146
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/get-success-criteria.sh.backup +0 -54
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/invoke-waiting-mode.sh.backup +0 -225
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/redis-cli-wrapper.sh.backup +0 -43
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/redis-functions.sh.backup +0 -34
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/report-completion.sh.backup +0 -134
- package/claude-assets/skills/cfn-memory-persistence/lib/redis/store-context.sh.backup +0 -123
- package/claude-assets/skills/cfn-memory-persistence/lib/sqlite/memory-cli.sh +0 -88
- package/claude-assets/skills/cfn-memory-persistence/lib/sqlite/ttl-cleanup.sh +0 -266
- package/claude-assets/skills/cfn-node-heap-sizer/SKILL.md +0 -23
- package/claude-assets/skills/cfn-node-heap-sizer/task-mode-heap-limiter.sh +0 -326
- package/claude-assets/skills/cfn-operations/lib/file/lib/lock.sh +0 -361
- package/claude-assets/skills/cfn-operations/lib/file/test.sh +0 -369
- package/claude-assets/skills/cfn-operations/lib/log/test.sh +0 -394
- package/claude-assets/skills/cfn-parameterized-queries/SKILL.md +0 -347
- package/claude-assets/skills/cfn-process-management/lib/lifecycle/process-manager.sh +0 -144
- package/claude-assets/skills/cfn-project-analysis/SKILL.md +0 -113
- package/claude-assets/skills/cfn-project-management/SKILL.md +0 -52
- package/claude-assets/skills/cfn-routing-config/lib/provider/resolve-provider-model.ts +0 -223
- package/claude-assets/skills/cfn-ruvector-codebase-index/.cfn-manifest.json +0 -37
- package/claude-assets/skills/cfn-ruvector-codebase-index/SKILL.md +0 -830
- package/claude-assets/skills/cfn-ruvector-codebase-index/batch-indexer.js +0 -185
- package/claude-assets/skills/cfn-ruvector-codebase-index/check-db.js +0 -8
- package/claude-assets/skills/cfn-ruvector-codebase-index/clean-orphaned-entries.sh +0 -206
- package/claude-assets/skills/cfn-ruvector-codebase-index/config.json +0 -65
- package/claude-assets/skills/cfn-ruvector-codebase-index/debug-search.js +0 -19
- package/claude-assets/skills/cfn-ruvector-codebase-index/detect-stale-docs.sh +0 -325
- package/claude-assets/skills/cfn-ruvector-codebase-index/embeddings.js +0 -181
- package/claude-assets/skills/cfn-ruvector-codebase-index/get-embedding-text.js +0 -26
- package/claude-assets/skills/cfn-ruvector-codebase-index/handle-file-moves.sh +0 -147
- package/claude-assets/skills/cfn-ruvector-codebase-index/index.sh +0 -324
- package/claude-assets/skills/cfn-ruvector-codebase-index/indexer.js +0 -53
- package/claude-assets/skills/cfn-ruvector-codebase-index/init-db.js +0 -27
- package/claude-assets/skills/cfn-ruvector-codebase-index/install-hook.sh +0 -51
- package/claude-assets/skills/cfn-ruvector-codebase-index/package.json +0 -30
- package/claude-assets/skills/cfn-ruvector-codebase-index/parser.js +0 -264
- package/claude-assets/skills/cfn-ruvector-codebase-index/query-error-patterns.sh +0 -42
- package/claude-assets/skills/cfn-ruvector-codebase-index/query-learnings.sh +0 -44
- package/claude-assets/skills/cfn-ruvector-codebase-index/ruvector-learning.js +0 -316
- package/claude-assets/skills/cfn-ruvector-codebase-index/search.js +0 -55
- package/claude-assets/skills/cfn-ruvector-codebase-index/search.sh +0 -137
- package/claude-assets/skills/cfn-ruvector-codebase-index/standalone-indexer.js +0 -129
- package/claude-assets/skills/cfn-ruvector-codebase-index/store-error-pattern.sh +0 -54
- package/claude-assets/skills/cfn-ruvector-codebase-index/store-learning.sh +0 -64
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-comprehensive.js +0 -120
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-db-structure.js +0 -40
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-integration.js +0 -56
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-metadata-fetch.js +0 -57
- package/claude-assets/skills/cfn-ruvector-codebase-index/test-search-debug.js +0 -48
- package/claude-assets/skills/cfn-session-handoff/SKILL.md +0 -273
- package/claude-assets/skills/cfn-skill-management/lib/propagation/package.json +0 -52
- package/claude-assets/skills/cfn-sprint-execution/lib/execution/execute-sprint-task.sh +0 -59
- package/claude-assets/skills/cfn-task-intelligence/SKILL.md +0 -64
- package/claude-assets/skills/cfn-task-planning/SKILL.md +0 -193
- package/claude-assets/skills/cfn-task-planning/cli/classify-task.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/cli/decompose-task.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/cli/init-config.sh +0 -4
- package/claude-assets/skills/cfn-task-planning/lib/audit/get-audit-data.sh +0 -397
- package/claude-assets/skills/cfn-task-planning/lib/audit/store-task-audit.sh +0 -191
- package/claude-assets/skills/cfn-task-planning/lib/decomposition/task-decomposer.sh +0 -279
- package/claude-assets/skills/cfn-transparency-middleware/Cargo.toml +0 -18
- package/claude-assets/skills/cfn-transparency-middleware/README.md +0 -74
- package/claude-assets/skills/cfn-transparency-middleware/SKILL.md +0 -99
- package/claude-assets/skills/cfn-transparency-middleware/config.json +0 -31
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-filter.sh +0 -98
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-init.sh +0 -224
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-level.sh +0 -333
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-metrics.sh +0 -345
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-observe.sh +0 -140
- package/claude-assets/skills/cfn-transparency-middleware/invoke-transparency-stop.sh +0 -235
- package/claude-assets/skills/cfn-transparency-middleware/memory_query.rs +0 -85
- package/claude-assets/skills/cfn-transparency-middleware/memory_repository.rs +0 -140
- package/claude-assets/skills/cfn-transparency-middleware/memory_schema.rs +0 -64
- package/claude-assets/skills/cfn-transparency-middleware/test-integration.sh +0 -162
- package/claude-assets/skills/cfn-utilities/lib/logging.sh +0 -77
- package/claude-assets/skills/equation-solver/solve.sh +0 -348
- package/scripts/init-project.js +0 -455
- /package/{claude-assets → .claude}/agents/AGENT_LIFECYCLE.md +0 -0
- /package/{claude-assets → .claude}/agents/README-AGENT_LIFECYCLE.md +0 -0
- /package/{claude-assets → .claude}/agents/README-VALIDATION.md +0 -0
- /package/{claude-assets → .claude}/agents/SHARED_PROTOCOL.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/CLAUDE.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/coordinators/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/developers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/documentation/README-VALIDATION.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/reviewers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/cfn-dev-team/testers/README.md +0 -0
- /package/{claude-assets → .claude}/agents/csuite/cto-agent.md +0 -0
- /package/{claude-assets → .claude}/agents/validate-agent.js +0 -0
- /package/{claude-assets → .claude}/cfn-extras/.gs-api-quota.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/.gs-progress-state.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-enterprise.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-mvp.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-coordinator-standard.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-loop-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cfn-v3-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/code-booster.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cost-savings-cfn-loop-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/cost-savings-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator-enhanced.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/byzantine-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-enterprise.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-mvp.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-standard.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-unified.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/coordinator-hybrid.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/gossip-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/hierarchical-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/task-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/deprecated-coordinators/test-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/csuite/c-suite-template.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/infrastructure/team-coordinator-template.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/docker-team/micro-sprint-planner.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-advanced-analytics-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-api-integrator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-automation-scripting-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-business-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-collaboration-security-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-coordinator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-transformer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-validation-quality-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-data-visualization-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-design-layout-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-engineer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-engineering-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-formula-validator.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-generalist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-integration-api-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-performance-analyst.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-performance-optimization-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-schema-designer.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets/google-sheets-template-architecture-specialist.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/agents/google-sheets-specialist.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_CLI.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_LOOP.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_NATIVE.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/cfn-docker/CFN_DOCKER_TASK.md +0 -0
- /package/{claude-assets/commands/testing → .claude/cfn-extras/commands/cfn-docker}/cfn-docker-core-test-suite.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/CFN_EXPERT_UPDATE.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-epic.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-single.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cfn-loop-sprints.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-curate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-inject.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-query.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/context-stats.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cost-savings-off.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/cost-savings-on.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/custom-routing-activate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/custom-routing-deactivate.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/github-commit.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/github.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/hello-world-tests.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/parse-epic.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/deprecated/run-tests.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/commands/deprecated/suggest-improvements.md +0 -0
- /package/{claude-assets → .claude/cfn-extras}/commands/google-sheets/google-sheets-loop.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/docs/GOOGLE_SHEETS_CFN_LOOP.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/GOOGLE_SHEETS_SKILLS_README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-agent-swap/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-agent-swap/recommend-swap.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-api-validation/test-endpoints.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-context-pruner/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-context-pruner/prune-context.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/config.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/eventbus-wrapper.cjs +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-publish.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-event-subscribe.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/invoke-lifecycle-track.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-event-bus/test-event-bus.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/README.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/config.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-allocate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-balance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/invoke-fleet-register.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-fleet-manager/test-fleet-manager.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-safety/cli-coordination.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-safety/mode-detection.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/advanced-features/cfn-task-mode-sanitize/task-mode-env-sanitizer.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-clean.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry-fixed.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/agents-registry.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.py +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/discover-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/invoke-registry.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-discovery/temp_script.py +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-selector/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-agent-selector/select-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-cli-setup/validate-cli-environment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/DESIGN.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/api-call.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-api-coordinator/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-decomposition/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-decomposition/decompose.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/build-formula.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-formula-builder/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/track-progress.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-progress/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-sprint-order/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-sprint-order/order-sprints.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/validate-state.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/google-sheets-validation/validate.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/set-budget.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-ad-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-email-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-social-engagement.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-website-traffic.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/send-message.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/add-to-segment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/create-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/get-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/update-contact.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/list-templates.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/send-test-email.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-ab-test.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-landing-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/get-page-performance.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/publish-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/unpublish-page.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/export-report.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/search-mentions.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/search-journalists.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/send-pitch.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/submit-haro-response.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/distribute-press-release.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-distribution-status.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/list-templates.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/opt-out.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/send-sms.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/create-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/delete-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/get-post-stats.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/schedule-post.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/upload-media.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/DESIGN.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-agents.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-dashboard.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-events.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-metrics.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-start.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-stop.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/test-web-portal-skill.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/ui-portal/cfn-web-portal/validate-deployment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-environment-sanitization/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-environment-sanitization/sanitize-environment.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-process-instrumentation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/cfn-extras/skills/utility/cfn-process-instrumentation/instrument-process.sh +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-ad-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-analytics-data.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-chatbot-conversations.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-competitive-intel.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-crm-contacts.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-email-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-landing-pages.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-media-outreach.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-press-distribution.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-sms-campaigns.json +0 -0
- /package/{claude-assets → .claude}/cfn-extras/workflows/marketing-social-publishing.json +0 -0
- /package/{claude-assets/commands/cfn-loop/list-agents-rebuild.md → .claude/commands/cfn-loop/cfn-list-agents-rebuild.md} +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-loop-document.md +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-mode.md +0 -0
- /package/{claude-assets → .claude}/commands/cfn-loop/cfn-optimize-agents.md +0 -0
- /package/{claude-assets/commands/cfn-ruvector/codebase-reindex.md → .claude/commands/cfn-ruvector/cfn-codebase-reindex.md} +0 -0
- /package/{claude-assets/commands/cfn-ruvector/codebase-search.md → .claude/commands/cfn-ruvector/cfn-codebase-search.md} +0 -0
- /package/{claude-assets/commands/cfn-ruvector/detect-stale-docs.md → .claude/commands/cfn-ruvector/cfn-detect-stale-docs.md} +0 -0
- /package/{claude-assets/commands/cost-routing/switch-api.md → .claude/commands/cost-routing/cfn-switch-api.md} +0 -0
- /package/{claude-assets → .claude}/commands/sparc.md +0 -0
- /package/{claude-assets → .claude}/commands/workflow.md +0 -0
- /package/{claude-assets → .claude}/commands/write-plan.md +0 -0
- /package/{claude-assets → .claude}/hooks/GIT-HOOKS-USAGE-EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/hooks/README-GIT-HOOKS.md +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-BACKUP_USAGE.md +0 -0
- /package/{claude-assets/hooks/validators/credential-scanner.sh → .claude/hooks/cfn-credential-scanner.sh} +0 -0
- /package/{claude-assets/hooks/detect-hardcoded-credentials.sh → .claude/hooks/cfn-detect-hardcoded-credentials.sh} +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-post-edit-ts.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-post-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-pre-edit-ts.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-pre-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-invoke-security-validation.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-lint-sql-injection.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-post-edit-cfn-retrospective.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-post-edit.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-pre-edit-backup.sh +0 -0
- /package/{claude-assets → .claude}/hooks/cfn-restore-from-backup.sh +0 -0
- /package/{claude-assets → .claude}/hooks/install-git-hooks.sh +0 -0
- /package/{claude-assets → .claude}/hooks/post-commit-codebase-index +0 -0
- /package/{claude-assets → .claude}/root-claude-distribute/CFN-CLAUDE.md +0 -0
- /package/{claude-assets → .claude}/skills/SKILL_TEMPLATE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/audit/simple-audit.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/output/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/agent-mappings.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/select-agents-with-fallback.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/select-agents.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/selection/task-classifier.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/execute-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/get-agent-provider-env.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/parse-agent-provider.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-templates.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-lifecycle/lib/spawning/spawn-worker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/generator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/generator/generate-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/linter/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-agent-tooling/lib/linter/lint-agents.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/management/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-config/lib/sanitization/sanitize-environment.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-conversation-sync/sync-conversations.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/extractor/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/extractor/extract-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/build.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/ingest-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/ingest.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/cli-mode-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/shared-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-dev-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-dependency-management/lib/ingestion/manifests/trigger-mode-dependencies.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/deployment/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/deployment/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-deployment-lifecycle/lib/promotion/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/INTEGRATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/SAMPLE_OUTPUTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/capture-container-logs.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/enable-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/init-hybrid-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/analytics-summary.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-agent-timeline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-consensus-history.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-coordination-timeline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-failed-containers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/queries/query-gate-checks.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/schema.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/sqlite-helpers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/logging/test-hybrid-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/mcp/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/mcp/skill-mcp-selector.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/orchestration/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/orchestration/orchestrate.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/spawning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/spawning/spawn-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/cleanup-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/lib/docker-helpers.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/monitor-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-docker-runtime/lib/waves/spawn-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/backup/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/backup/backup.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/auto-resolve.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/feedback-resolver.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/security-scan.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/security-scanner.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-edit-safety/lib/hooks/test-root-warning-resolution.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/analyze-errors.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/calculate-waves.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/cluster-files.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/batching/create-batches.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/capture/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/capture/capture-agent-error.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/cleanup-error-logs.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/integrate-cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/integrate-docker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/invoke-error-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-error-management/lib/logging/test-error-logging.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/detector/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/orchestrator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-intervention-system/lib/orchestrator/execute-intervention.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/playbook/lib/auto-update/auto-update-playbook.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/APPROVAL_WORKFLOW.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/DEPLOY_QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/PROPAGATE_UPDATE_QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/approval-workflow.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/deploy-approved-skill.sh.backup-1763392820 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/lib/security-utils.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/propagate-skill-update.sh.backup-1763392820 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/review-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/test-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/test-metadata-update.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-knowledge-base/lib/workflow/track-cost-savings.sh.backup-1763392821 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/TYPESCRIPT_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/parse-decision.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/test-backlog-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/decision/validate-deliverables.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONFIGURATION_IMPROVEMENTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/CONTEXT_LOOKUP_QUICK_START.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/NORTH_STAR_INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/ORCHESTRATOR_QUICK_START.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/SPAWN_AGENTS_IMPLEMENTATION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATION_SUMMARY.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/VALIDATOR_MODULE_GUIDE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation-fixed.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/e2e-validation.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/run-north-star-e2e.ts +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/security_utils.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cfn-orchestration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-cli.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-edge-cases.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-iteration-context-injection.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/orchestrator/test-typescript-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/DELIVERY_SUMMARY.txt +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/output/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/INDEX.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/README_TYPESCRIPT.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/SKILL_TYPESCRIPT.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/VAPOR_DETECTION_EXAMPLES.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/consensus-calculator.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/evidence-chain.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/orchestrate-cfn-loop.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/package.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-loop-orchestration-v2/lib/validation/validate-iteration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/persist-agent-output.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/auto/query-agent-history.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/check-memory.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/management/cleanup-memory.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/redis/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/QUICK_REFERENCE.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/acl-queries.sql +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-memory-persistence/lib/sqlite/test-state-persistence.js +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/file/lib/atomic-write.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/lib/rotate.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-operations/lib/log/lib/search.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/map-dependencies-conflicts.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-coordinator-resources.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-multi-coordinator-work.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/plan-risk-rollout.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/test-multi-coordinator-planning.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/coordinator/validate-task-planning.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/epic/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/epic/decompose-epic.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/scope/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-planning/lib/scope/simplify-scope.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/instrumentation/instrument-process.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-process-management/lib/lifecycle/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/backlog/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/backlog/add-backlog-item.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/add-changelog-entry.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/bulk-import.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/lib/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-project-management/lib/changelog/lib/validation.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/config.json +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/hybrid/spawn-worker.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/provider/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-routing-config/lib/provider/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/builder/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/loader/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/loader/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/propagation/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-skill-management/lib/propagation/propagate-skill-update.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/cleanup-orphans.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/resume-wave.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/checkpoint/save-checkpoint.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-sprint-execution/lib/execution/execute-sprint.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/classifier/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/classifier/classify-task.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/complexity/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/complexity/estimate-complexity.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/specialist/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-intelligence/lib/specialist/recommend-specialist.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-planning/lib/classifier/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-task-planning/lib/classifier/classify-task.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/check-dependencies.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-cache-reader.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-concurrent-conflicts.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/execution/test-coordinator-pattern.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/detect-regressions.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/detect-regressions.sh.backup-1763392821 +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/init-benchmark-db.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/run-all-tests.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/store-benchmarks.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/runner/validate-redis-keys.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/README.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/SCREENSHOT_NAMING_CONVENTION.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/capture-screenshot.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/cfn-loop-integration.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/compare-screenshots.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/init-storage.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/set-baseline.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-test-framework/lib/webapp/test-webapp-testing.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/SECURITY.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/TEST_RESULTS.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/middleware-config.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/performance-benchmark.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-e2e.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-transparency-skill.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/test-transparency-skill.sh.unix +0 -0
- /package/{claude-assets → .claude}/skills/cfn-transparency-middleware/wrap-agent.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/execute.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/errors.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/file-ops.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/lib/retry.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-utilities/test.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/deliverables/confidence-calculator.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/instrumentation/wrapped-executor.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/test-validate-success-criteria.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/json/validate-success-criteria.sh +0 -0
- /package/{claude-assets → .claude}/skills/cfn-validation-framework/lib/layers/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/cfn-vision-analysis/SKILL.md +0 -0
- /package/{claude-assets/skills/cfn-knowledge-base/lib/workflow → .claude/skills/deprecated}/analyze-patterns.sh +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/README.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/SECURITY.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/SKILL.md +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/package.json +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/test-equation-solver-minimal.sh +0 -0
- /package/{claude-assets → .claude}/skills/equation-solver/test-equation-solver.sh +0 -0
|
@@ -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;
|