claude-flow-novice 2.15.0 → 2.15.2
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/cfn-extras/agents/cfn-coordinator-enterprise.md +1303 -0
- package/.claude/cfn-extras/agents/cfn-coordinator-mvp.md +942 -0
- package/.claude/cfn-extras/agents/cfn-coordinator-standard.md +1062 -0
- package/.claude/cfn-extras/agents/cfn-loop-coordinator.md +157 -0
- package/.claude/cfn-extras/agents/coordinator.md +182 -0
- package/.claude/cfn-extras/agents/cost-savings-cfn-loop-coordinator.md +760 -0
- package/.claude/cfn-extras/agents/cost-savings-coordinator.md +173 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator-enhanced.md +147 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md +162 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md.backup +161 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md +729 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md.backup +728 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/byzantine-coordinator.md +100 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-enterprise.md +323 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-mvp.md +157 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-standard.md +229 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-unified.md +149 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/coordinator-hybrid.md +231 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/gossip-coordinator.md +165 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/hierarchical-coordinator.md +95 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md +132 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md.backup +131 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/task-coordinator.md +109 -0
- package/.claude/cfn-extras/agents/deprecated-coordinators/test-coordinator.md +142 -0
- package/.claude/cfn-extras/agents/google-sheets-specialist.md +614 -0
- package/.claude/commands/cfn/create-handoff.md +224 -0
- package/.claude/commands/cfn-docker/CFN_DOCKER_NATIVE.md +295 -0
- package/.claude/commands/cfn-docker-core-test-suite.md +326 -0
- package/.claude/commands/cfn-loop-cli.md +1 -1
- package/.claude/commands/switch-api.md +20 -6
- package/.claude/root-claude-distribute/CFN-CLAUDE.md +177 -426
- package/.claude/skills/cfn-docker-agent-spawning/spawn-agent.sh +27 -18
- package/.claude/skills/cfn-docker-loop-orchestration/orchestrate.sh +763 -38
- package/.claude/skills/cfn-docker-redis-coordination/coordinate.sh +25 -10
- package/.claude/skills/cfn-docker-redis-coordination/coordinate.sh.backup-1763145142 +641 -0
- package/.claude/skills/cfn-docker-skill-mcp-selection/skill-mcp-selector.js +471 -471
- package/.claude/skills/cfn-loop-orchestration/orchestrate.sh +52 -23
- package/.claude/skills/cfn-redis-coordination/complete-swarm.sh +3 -3
- package/.claude/skills/cfn-redis-coordination/data/cfn-loop.db +0 -0
- package/.claude/skills/cfn-redis-coordination/redis-cli-wrapper.sh +9 -0
- package/.claude/skills/cfn-redis-coordination/report-completion.sh +7 -7
- package/claude-assets/agents/cfn-dev-team/architecture/api-designer-persona.md +2 -0
- package/claude-assets/agents/cfn-dev-team/architecture/goal-planner.md +2 -0
- package/claude-assets/agents/cfn-dev-team/architecture/planner.md +2 -0
- package/claude-assets/agents/cfn-dev-team/architecture/system-architect.md +2 -0
- package/claude-assets/agents/cfn-dev-team/coordinators/handoff-coordinator.md +662 -0
- package/claude-assets/agents/cfn-dev-team/dev-ops/docker-specialist.md +448 -563
- package/claude-assets/agents/cfn-dev-team/dev-ops/kubernetes-specialist.md +2 -0
- package/claude-assets/agents/cfn-dev-team/developers/data/data-engineer.md +2 -0
- package/claude-assets/agents/cfn-dev-team/documentation/README-VALIDATION.md +2 -0
- package/claude-assets/agents/cfn-dev-team/documentation/agent-type-guidelines.md +2 -0
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/code-quality-validator.md +1 -1
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/perf-analyzer.md +1 -1
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/performance-benchmarker.md +2 -0
- package/claude-assets/agents/cfn-dev-team/reviewers/quality/quality-metrics.md +2 -0
- package/claude-assets/agents/cfn-dev-team/testers/api-testing-specialist.md +2 -0
- package/claude-assets/agents/cfn-dev-team/testers/chaos-engineering-specialist.md +1 -1
- package/claude-assets/agents/cfn-dev-team/testers/e2e/playwright-tester.md +1 -1
- package/claude-assets/agents/cfn-dev-team/testers/interaction-tester.md +2 -0
- package/claude-assets/agents/cfn-dev-team/testers/load-testing-specialist.md +2 -0
- package/claude-assets/agents/cfn-dev-team/testers/playwright-tester.md +2 -0
- package/claude-assets/agents/cfn-dev-team/testers/unit/tdd-london-unit-swarm.md +4 -0
- package/claude-assets/agents/cfn-dev-team/testers/validation/validation-production-validator.md +1 -1
- package/claude-assets/agents/docker-coordinators/cfn-docker-v3-coordinator.md +825 -17
- package/claude-assets/agents/docker-team/micro-sprint-planner.md +747 -0
- package/claude-assets/agents/docker-ts-fixer.md +56 -0
- package/claude-assets/agents/typescript-specialist.md +280 -0
- package/claude-assets/cfn-extras/agents/cfn-coordinator-enterprise.md +1303 -0
- package/claude-assets/cfn-extras/agents/cfn-coordinator-mvp.md +942 -0
- package/claude-assets/cfn-extras/agents/cfn-coordinator-standard.md +1062 -0
- package/claude-assets/cfn-extras/agents/cfn-loop-coordinator.md +157 -0
- package/claude-assets/cfn-extras/agents/coordinator.md +182 -0
- package/claude-assets/cfn-extras/agents/cost-savings-cfn-loop-coordinator.md +760 -0
- package/claude-assets/cfn-extras/agents/cost-savings-coordinator.md +173 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator-enhanced.md +147 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md +162 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/adaptive-coordinator.md.backup +161 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md +729 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/blocking-coordinator-example.md.backup +728 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/byzantine-coordinator.md +100 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-enterprise.md +323 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-mvp.md +157 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-standard.md +229 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/cfn-coordinator-unified.md +149 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/coordinator-hybrid.md +231 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/gossip-coordinator.md +165 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/hierarchical-coordinator.md +95 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md +132 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/mesh-coordinator.md.backup +131 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/task-coordinator.md +109 -0
- package/claude-assets/cfn-extras/agents/deprecated-coordinators/test-coordinator.md +142 -0
- package/claude-assets/cfn-extras/agents/google-sheets-specialist.md +614 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-agent-swap/SKILL.md +36 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-agent-swap/recommend-swap.sh +60 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-api-validation/test-endpoints.sh +54 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-context-pruner/SKILL.md +75 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-context-pruner/prune-context.sh +73 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-task-mode-safety/cli-coordination.sh +519 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-task-mode-safety/mode-detection.sh +326 -0
- package/claude-assets/cfn-extras/skills/advanced-features/cfn-task-mode-sanitize/task-mode-env-sanitizer.sh +267 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-improvement-recommender/SKILL.md +33 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-improvement-recommender/recommend-improvements.sh +92 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-memory-monitoring/SKILL.md +531 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-pattern-extraction/SKILL.md +30 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-pattern-extraction/extract-patterns.sh +80 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-retrospective-report/SKILL.md +31 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-retrospective-report/generate-report.sh +101 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-telemetry/collect-metrics.sh +249 -0
- package/claude-assets/cfn-extras/skills/analytics/cfn-telemetry/start-telemetry.sh +111 -0
- package/claude-assets/cfn-extras/skills/deprecated/cfn-cli-setup/validate-cli-environment.sh +192 -0
- package/claude-assets/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/COST_ANALYSIS.md +49 -0
- package/claude-assets/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/DESIGN.md +98 -0
- package/claude-assets/cfn-extras/skills/deprecated/cfn-simplified-agent-lifecycle/MIGRATION_PLAN.md +74 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/SKILL.md +392 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/create-campaign.sh +231 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +190 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +142 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/set-budget.sh +181 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +133 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/SKILL.md +124 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-ad-performance.sh +105 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +102 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-email-performance.sh +105 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-social-engagement.sh +105 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-analytics-data/operations/get-website-traffic.sh +107 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/SKILL.md +340 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +121 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +156 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +181 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/send-message.sh +137 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +179 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/SKILL.md +350 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +154 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +173 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +147 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +146 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +167 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/SKILL.md +116 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/add-to-segment.sh +78 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/create-contact.sh +113 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/get-contact.sh +86 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +78 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-crm-contacts/operations/update-contact.sh +120 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/SKILL.md +106 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/create-campaign.sh +123 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +66 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/list-templates.sh +68 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +85 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-email-campaigns/operations/send-test-email.sh +81 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/SKILL.md +366 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-ab-test.sh +231 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/create-landing-page.sh +190 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/get-page-performance.sh +137 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/publish-page.sh +120 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-landing-pages/operations/unpublish-page.sh +108 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/SKILL.md +202 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +104 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/export-report.sh +92 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +85 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-monitoring/operations/search-mentions.sh +86 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-outreach/SKILL.md +168 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/search-journalists.sh +74 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/send-pitch.sh +80 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/submit-haro-response.sh +88 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +66 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-press-distribution/SKILL.md +159 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/distribute-press-release.sh +94 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-distribution-status.sh +59 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +72 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-press-distribution/operations/list-templates.sh +53 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/SKILL.md +429 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/create-campaign.sh +183 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +139 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/opt-out.sh +150 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +187 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-sms-campaigns/operations/send-sms.sh +181 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/SKILL.md +108 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/create-post.sh +104 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/delete-post.sh +76 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/get-post-stats.sh +66 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/schedule-post.sh +85 -0
- package/claude-assets/cfn-extras/skills/marketing/cfn-marketing-social-publishing/operations/upload-media.sh +88 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/DESIGN.md +117 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/SKILL.md +679 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-agents.sh +129 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-dashboard.sh +85 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-events.sh +125 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-metrics.sh +112 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-start.sh +135 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/invoke-portal-stop.sh +121 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/test-web-portal-skill.sh +51 -0
- package/claude-assets/cfn-extras/skills/ui-portal/cfn-web-portal/validate-deployment.sh +85 -0
- package/claude-assets/cfn-extras/skills/utility/cfn-environment-sanitization/SKILL.md +200 -0
- package/claude-assets/cfn-extras/skills/utility/cfn-environment-sanitization/sanitize-environment.sh +244 -0
- package/claude-assets/cfn-extras/skills/utility/cfn-process-instrumentation/SKILL.md +279 -0
- package/claude-assets/cfn-extras/skills/utility/cfn-process-instrumentation/instrument-process.sh +327 -0
- package/claude-assets/commands/cfn/create-handoff.md +224 -0
- package/claude-assets/commands/cfn-docker/CFN_DOCKER_NATIVE.md +295 -0
- package/claude-assets/commands/cfn-docker-core-test-suite.md +326 -0
- package/claude-assets/commands/cfn-loop-cli.md +1 -1
- package/claude-assets/commands/switch-api.md +20 -6
- package/claude-assets/root-claude-distribute/CFN-CLAUDE.md +177 -426
- package/claude-assets/skills/cfn-docker-agent-spawning/spawn-agent.sh +27 -18
- package/claude-assets/skills/cfn-docker-loop-orchestration/orchestrate.sh +763 -38
- package/claude-assets/skills/cfn-docker-redis-coordination/coordinate.sh +25 -10
- package/claude-assets/skills/cfn-docker-redis-coordination/coordinate.sh.backup-1763145142 +641 -0
- package/claude-assets/skills/cfn-docker-skill-mcp-selection/skill-mcp-selector.js +471 -471
- package/claude-assets/skills/cfn-docker-wave-execution/SKILL.md +936 -0
- package/claude-assets/skills/cfn-docker-wave-execution/cleanup-wave.sh +445 -0
- package/claude-assets/skills/cfn-docker-wave-execution/lib/docker-helpers.sh +804 -0
- package/claude-assets/skills/cfn-docker-wave-execution/monitor-wave.sh +485 -0
- package/claude-assets/skills/cfn-docker-wave-execution/spawn-wave.sh +547 -0
- package/claude-assets/skills/cfn-error-batching-strategy/README.md +323 -0
- package/claude-assets/skills/cfn-error-batching-strategy/SKILL.md +1016 -0
- package/claude-assets/skills/cfn-error-batching-strategy/analyze-errors.sh +327 -0
- package/claude-assets/skills/cfn-error-batching-strategy/calculate-waves.sh +256 -0
- package/claude-assets/skills/cfn-error-batching-strategy/cli.sh +523 -0
- package/claude-assets/skills/cfn-error-batching-strategy/cluster-files.sh +196 -0
- package/claude-assets/skills/cfn-error-batching-strategy/create-batches.sh +261 -0
- package/claude-assets/skills/cfn-error-batching-strategy/lib/core-functions.sh +47 -0
- package/claude-assets/skills/cfn-error-batching-strategy/templates/default-tiers.json +22 -0
- package/claude-assets/skills/cfn-error-batching-strategy/tests/test-batching-strategy.sh +498 -0
- package/claude-assets/skills/cfn-loop-orchestration/orchestrate.sh +52 -23
- package/claude-assets/skills/cfn-redis-coordination/complete-swarm.sh +3 -3
- package/claude-assets/skills/cfn-redis-coordination/data/cfn-loop.db +0 -0
- package/claude-assets/skills/cfn-redis-coordination/redis-cli-wrapper.sh +9 -0
- package/claude-assets/skills/cfn-redis-coordination/report-completion.sh +7 -7
- package/claude-assets/skills/cfn-wave-checkpoint/SKILL.md +333 -0
- package/claude-assets/skills/cfn-wave-checkpoint/cleanup-orphans.sh +374 -0
- package/claude-assets/skills/cfn-wave-checkpoint/resume-wave.sh +325 -0
- package/claude-assets/skills/cfn-wave-checkpoint/save-checkpoint.sh +284 -0
- package/claude-assets/skills/docker-build/SKILL.md +203 -0
- package/claude-assets/skills/docker-build/build.sh +73 -0
- package/dist/agent/skill-mcp-selector.js +1 -1
- package/dist/agent/skill-mcp-selector.js.map +1 -1
- package/dist/cli/agent-definition-parser.js +36 -16
- package/dist/cli/agent-definition-parser.js.map +1 -1
- package/dist/cli/agent-executor.js +48 -13
- package/dist/cli/agent-executor.js.map +1 -1
- package/dist/cli/agent-prompt-builder.js +28 -2
- package/dist/cli/agent-prompt-builder.js.map +1 -1
- package/dist/cli/agent-spawn.js +57 -18
- package/dist/cli/agent-spawn.js.map +1 -1
- package/dist/cli/agent-token-manager.js +5 -1
- package/dist/cli/agent-token-manager.js.map +1 -1
- package/dist/cli/anthropic-client.js +35 -4
- package/dist/cli/anthropic-client.js.map +1 -1
- package/dist/cli/cfn-context.js +9 -6
- package/dist/cli/cfn-context.js.map +1 -1
- package/dist/cli/cfn-metrics.js +8 -1
- package/dist/cli/cfn-metrics.js.map +1 -1
- package/dist/cli/cfn-redis.js +7 -0
- package/dist/cli/cfn-redis.js.map +1 -1
- package/dist/cli/conversation-fork.js +14 -11
- package/dist/cli/conversation-fork.js.map +1 -1
- package/dist/cli/index.js +6 -1
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/iteration-history.js +8 -5
- package/dist/cli/iteration-history.js.map +1 -1
- package/dist/coordination/enhanced-progress-tracker.js +1 -1
- package/dist/coordination/enhanced-progress-tracker.js.map +1 -1
- package/dist/coordination/event-bus.js +1 -1
- package/dist/coordination/event-bus.js.map +1 -1
- package/dist/coordination/redis-messaging-infrastructure.js +1 -1
- package/dist/coordination/redis-messaging-infrastructure.js.map +1 -1
- package/dist/mcp/auth-middleware.js +1 -1
- package/dist/mcp/auth-middleware.js.map +1 -1
- package/dist/mcp/playwright-mcp-server-auth.js +1 -1
- package/dist/mcp/playwright-mcp-server-auth.js.map +1 -1
- package/dist/utils/secret-filter.js +145 -0
- package/dist/utils/secret-filter.js.map +1 -0
- package/package.json +5 -4
- package/scripts/build-linux.sh +78 -0
- package/scripts/docker-agent-init.sh +106 -0
- package/scripts/docker-rebuild-all-agents.sh +127 -0
- package/scripts/init-project.js +4 -4
- package/scripts/switch-api.sh +11 -4
- package/.claude/cfn-agents-ignore/cfn-seo-team/AGENT_CREATION_REPORT.md +0 -471
- package/.claude/cfn-agents-ignore/cfn-seo-team/AGENT_CREATION_REPORT.md.backup +0 -481
- package/.claude/cfn-agents-ignore/cfn-seo-team/DELEGATION_MATRIX.md.backup +0 -371
- package/.claude/cfn-agents-ignore/cfn-seo-team/INTEGRATION_REQUIREMENTS.md.backup +0 -637
- package/.claude/cfn-agents-ignore/cfn-seo-team/cfn-seo-coordinator.md.backup +0 -398
- package/.claude/cfn-agents-ignore/cfn-seo-team/competitive-seo-analyst.md.backup +0 -401
- package/.claude/cfn-agents-ignore/cfn-seo-team/content-atomization-specialist.md.backup +0 -552
- package/.claude/cfn-agents-ignore/cfn-seo-team/content-seo-strategist.md.backup +0 -223
- package/.claude/cfn-agents-ignore/cfn-seo-team/eeat-content-auditor.md.backup +0 -367
- package/.claude/cfn-agents-ignore/cfn-seo-team/geo-optimization-expert.md.backup +0 -247
- package/.claude/cfn-agents-ignore/cfn-seo-team/link-building-specialist.md.backup +0 -269
- package/.claude/cfn-agents-ignore/cfn-seo-team/local-seo-optimizer.md.backup +0 -311
- package/.claude/cfn-agents-ignore/cfn-seo-team/programmatic-seo-engineer.md.backup +0 -222
- package/.claude/cfn-agents-ignore/cfn-seo-team/schema-markup-engineer.md.backup +0 -408
- package/.claude/cfn-agents-ignore/cfn-seo-team/seo-analytics-specialist.md.backup +0 -354
- package/.claude/cfn-agents-ignore/cfn-seo-team/seo-validators/accessibility-validator.md.backup +0 -561
- package/.claude/cfn-agents-ignore/cfn-seo-team/seo-validators/audience-validator.md.backup +0 -480
- package/.claude/cfn-agents-ignore/cfn-seo-team/seo-validators/branding-validator.md.backup +0 -448
- package/.claude/cfn-agents-ignore/cfn-seo-team/seo-validators/humanizer-validator.md.backup +0 -329
- package/.claude/cfn-agents-ignore/cfn-seo-team/technical-seo-specialist.md.backup +0 -208
- package/claude-assets/agents/AGENT_LIFECYCLE.md.backup_before_replace +0 -530
- package/claude-assets/agents/README-AGENT_LIFECYCLE.md.backup_before_replace +0 -522
- package/claude-assets/agents/cfn-dev-team/test-agent.md +0 -141
- package/claude-assets/agents/marketing_hybrid/cost_tracker.md +0 -13
- package/claude-assets/agents/marketing_hybrid/docker_deployer.md +0 -13
- package/claude-assets/agents/marketing_hybrid/zai_worker_spawner.md +0 -13
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/AGENT_CREATION_REPORT.md +0 -471
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/AGENT_CREATION_REPORT.md.backup +0 -481
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/DELEGATION_MATRIX.md.backup +0 -371
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/INTEGRATION_REQUIREMENTS.md.backup +0 -637
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/cfn-seo-coordinator.md.backup +0 -398
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/competitive-seo-analyst.md.backup +0 -401
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/content-atomization-specialist.md.backup +0 -552
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/content-seo-strategist.md.backup +0 -223
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/eeat-content-auditor.md.backup +0 -367
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/geo-optimization-expert.md.backup +0 -247
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/link-building-specialist.md.backup +0 -269
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/local-seo-optimizer.md.backup +0 -311
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/programmatic-seo-engineer.md.backup +0 -222
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/schema-markup-engineer.md.backup +0 -408
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/seo-analytics-specialist.md.backup +0 -354
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/seo-validators/accessibility-validator.md.backup +0 -561
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/seo-validators/audience-validator.md.backup +0 -480
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/seo-validators/branding-validator.md.backup +0 -448
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/seo-validators/humanizer-validator.md.backup +0 -329
- package/claude-assets/cfn-agents-ignore/cfn-seo-team/technical-seo-specialist.md.backup +0 -208
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/DELEGATION_MATRIX.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/HUMANIZER_PROMPTS.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/INTEGRATION_REQUIREMENTS.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/cfn-seo-coordinator.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/competitive-seo-analyst.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/content-atomization-specialist.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/content-seo-strategist.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/eeat-content-auditor.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/geo-optimization-expert.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/link-building-specialist.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/local-seo-optimizer.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/programmatic-seo-engineer.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/schema-markup-engineer.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-analytics-specialist.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/accessibility-validator.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/audience-validator.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/branding-validator.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/humanizer-validator.md +0 -0
- /package/.claude/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/technical-seo-specialist.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-agent-swap/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-agent-swap/recommend-swap.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-api-validation/test-endpoints.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-context-pruner/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-context-pruner/prune-context.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/README.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/SKILL.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/config.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/eventbus-wrapper.cjs +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-event-publish.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-event-subscribe.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-lifecycle-track.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/test-event-bus.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/README.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/SKILL.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/config.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-allocate.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-balance.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-metrics.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-register.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/test-fleet-manager.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-task-mode-safety/cli-coordination.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-task-mode-safety/mode-detection.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/advanced-features}/cfn-task-mode-sanitize/task-mode-env-sanitizer.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/README.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/description-refinement-guide.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/log-skill-invocation.js +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/run-production-criteria-tests.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-analytics-dashboard.js +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-invocation-hook.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-invocations.sql +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-corpus.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-data-generator.js +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-manual-override-rate.js +0 -0
- /package/.claude/{skills → cfn-extras/skills/analytics}/cfn-analytics/validate-skill-selection.js +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-improvement-recommender/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-improvement-recommender/recommend-improvements.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-memory-monitoring/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-pattern-extraction/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-pattern-extraction/extract-patterns.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-retrospective-report/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-retrospective-report/generate-report.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-telemetry/collect-metrics.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/analytics}/cfn-telemetry/start-telemetry.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/SKILL.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/add-bullet.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/analyze-anti-pattern-effectiveness.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/classify-task.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/export-ace-metrics.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/extract-tags.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/format-negative-context.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/init-indexes.sql +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-curate.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-inject.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-query.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-reflect.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-stats.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/log-merge.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/monitor-injection-performance.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/optimize-injection-pipeline.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-anti-patterns.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-contexts.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-reflections.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/001-create-context-reflections.sql +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/README.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/SCHEMA_DESIGN_SUMMARY.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/populate-test-data-simple.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/populate-test-data.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/run-migration.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/validate-schema.sql +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/score-relevance-adapter.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/score-relevance.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/sprint-7-lessons.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/store-reflection.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/test-ace-skill.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/track-ab-test.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/update-reflection.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/SKILL.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry-clean.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry-fixed.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry.json +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/discover-agents.py +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/discover-agents.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/invoke-registry.sh +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/temp_script.py +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-selector/SKILL.md +0 -0
- /package/.claude/{skills → cfn-extras/skills/deprecated}/cfn-agent-selector/select-agents.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/deprecated}/cfn-cli-setup/validate-cli-environment.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/deprecated}/cfn-simplified-agent-lifecycle/COST_ANALYSIS.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/deprecated}/cfn-simplified-agent-lifecycle/DESIGN.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/deprecated}/cfn-simplified-agent-lifecycle/MIGRATION_PLAN.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/operations/get-campaign-performance.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/operations/pause-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/operations/set-budget.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-ad-campaigns/operations/update-bid-strategy.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/operations/get-ad-performance.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/operations/get-conversion-funnel.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/operations/get-email-performance.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/operations/get-social-engagement.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-analytics-data/operations/get-website-traffic.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/operations/get-conversation-history.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/operations/qualify-lead.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/operations/schedule-demo.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/operations/send-message.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-chatbot-conversations/operations/transfer-to-human.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/operations/get-backlink-profile.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/operations/get-keyword-rankings.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/operations/get-trending-topics.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/operations/monitor-competitor.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-competitive-intel/operations/search-brand-mentions.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/operations/add-to-segment.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/operations/create-contact.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/operations/get-contact.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/operations/remove-from-segment.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-crm-contacts/operations/update-contact.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/operations/get-campaign-stats.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/operations/list-templates.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-email-campaigns/operations/send-test-email.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/operations/create-ab-test.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/operations/create-landing-page.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/operations/get-page-performance.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/operations/publish-page.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-landing-pages/operations/unpublish-page.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-monitoring/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-monitoring/operations/create-crisis-alert.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-monitoring/operations/export-report.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-monitoring/operations/get-sentiment-analysis.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-monitoring/operations/search-mentions.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-outreach/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-outreach/operations/search-journalists.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-outreach/operations/send-pitch.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-outreach/operations/submit-haro-response.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-media-outreach/operations/track-pitch-engagement.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-press-distribution/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-press-distribution/operations/distribute-press-release.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-press-distribution/operations/get-distribution-status.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-press-distribution/operations/get-pickup-metrics.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-press-distribution/operations/list-templates.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/operations/create-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/operations/get-delivery-status.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/operations/opt-out.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/operations/schedule-campaign.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-sms-campaigns/operations/send-sms.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/operations/create-post.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/operations/delete-post.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/operations/get-post-stats.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/operations/schedule-post.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/marketing}/cfn-marketing-social-publishing/operations/upload-media.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/DESIGN.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-agents.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-dashboard.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-events.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-metrics.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-start.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/invoke-portal-stop.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/test-web-portal-skill.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/ui-portal}/cfn-web-portal/validate-deployment.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/utility}/cfn-environment-sanitization/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/utility}/cfn-environment-sanitization/sanitize-environment.sh +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/utility}/cfn-process-instrumentation/SKILL.md +0 -0
- /package/{claude-assets/skills → .claude/cfn-extras/skills/utility}/cfn-process-instrumentation/instrument-process.sh +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/DELEGATION_MATRIX.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/HUMANIZER_PROMPTS.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/INTEGRATION_REQUIREMENTS.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/cfn-seo-coordinator.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/competitive-seo-analyst.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/content-atomization-specialist.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/content-seo-strategist.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/eeat-content-auditor.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/geo-optimization-expert.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/link-building-specialist.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/local-seo-optimizer.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/programmatic-seo-engineer.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/schema-markup-engineer.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-analytics-specialist.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/accessibility-validator.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/audience-validator.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/branding-validator.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/seo-validators/humanizer-validator.md +0 -0
- /package/claude-assets/{cfn-agents-ignore → cfn-extras/agents}/cfn-seo-team/technical-seo-specialist.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/README.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/SKILL.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/config.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/eventbus-wrapper.cjs +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-event-publish.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-event-subscribe.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/invoke-lifecycle-track.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-event-bus/test-event-bus.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/README.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/SKILL.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/config.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-allocate.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-balance.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-metrics.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/invoke-fleet-register.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/advanced-features}/cfn-fleet-manager/test-fleet-manager.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/README.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/description-refinement-guide.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/log-skill-invocation.js +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/run-production-criteria-tests.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-analytics-dashboard.js +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-invocation-hook.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/skill-invocations.sql +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-corpus.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-data-generator.js +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/test-manual-override-rate.js +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/analytics}/cfn-analytics/validate-skill-selection.js +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/SKILL.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/add-bullet.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/analyze-anti-pattern-effectiveness.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/classify-task.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/export-ace-metrics.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/extract-tags.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/format-negative-context.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/init-indexes.sql +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-curate.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-inject.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-query.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-reflect.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/invoke-context-stats.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/log-merge.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/monitor-injection-performance.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/optimize-injection-pipeline.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-anti-patterns.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-contexts.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/query-reflections.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/001-create-context-reflections.sql +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/README.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/SCHEMA_DESIGN_SUMMARY.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/populate-test-data-simple.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/populate-test-data.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/run-migration.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/schema/validate-schema.sql +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/score-relevance-adapter.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/score-relevance.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/sprint-7-lessons.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/store-reflection.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/test-ace-skill.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/track-ab-test.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-ace-system/update-reflection.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/SKILL.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry-clean.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry-fixed.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/agents-registry.json +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/discover-agents.py +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/discover-agents.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/invoke-registry.sh +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-discovery/temp_script.py +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-selector/SKILL.md +0 -0
- /package/claude-assets/{skills → cfn-extras/skills/deprecated}/cfn-agent-selector/select-agents.sh +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/agent/skill-mcp-selector.js"],"sourcesContent":["/**\r\n * Skill-based MCP Selection System\r\n * Automatically selects MCP servers based on agent skills and requirements\r\n */\r\n\r\nconst fs = require('fs').promises;\r\nconst path = require('path');\r\nconst AgentTokenManager = require('../cli/agent-token-manager.js');\r\n\r\nclass SkillMCPSelector {\r\n constructor(options = {}) {\r\n this.tokenManager = new AgentTokenManager(options);\r\n this.agentConfigPath = options.agentConfigPath || './config/agent-whitelist.json';\r\n this.skillConfigPath = options.skillConfigPath || './config/skill-requirements.json';\r\n this.mcpServersPath = options.mcpServersPath || './config/mcp-servers.json';\r\n\r\n this.agentWhitelist = new Map();\r\n this.skillRequirements = new Map();\r\n this.mcpServers = new Map();\r\n }\r\n\r\n async initialize() {\r\n await this.tokenManager.initialize();\r\n await this.loadConfigurations();\r\n console.log('[SkillMCPSelector] Initialized successfully');\r\n }\r\n\r\n async loadConfigurations() {\r\n // Load agent whitelist\r\n const agentConfig = await this.loadJson(this.agentConfigPath);\r\n this.agentWhitelist.clear();\r\n for (const agent of agentConfig.agents) {\r\n this.agentWhitelist.set(agent.type, agent);\r\n }\r\n\r\n // Load skill requirements\r\n const skillConfig = await this.loadJson(this.skillConfigPath);\r\n this.skillRequirements.clear();\r\n for (const [tool, requirements] of Object.entries(skillConfig.tools)) {\r\n this.skillRequirements.set(tool, requirements);\r\n }\r\n\r\n // Load MCP server configurations\r\n try {\r\n const mcpConfig = await this.loadJson(this.mcpServersPath);\r\n for (const [name, config] of Object.entries(mcpConfig.servers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n } catch (error) {\r\n console.warn('[SkillMCPSelector] MCP servers config not found, using defaults');\r\n this.initializeDefaultMCPServers();\r\n }\r\n }\r\n\r\n async loadJson(filePath) {\r\n const resolvedPath = path.resolve(filePath);\r\n const content = await fs.readFile(resolvedPath, 'utf8');\r\n return JSON.parse(content);\r\n }\r\n\r\n initializeDefaultMCPServers() {\r\n // Default MCP server configurations\r\n const defaultServers = {\r\n 'playwright': {\r\n name: 'playwright',\r\n displayName: 'Playwright Browser Automation',\r\n description: 'Browser automation and screenshot capabilities',\r\n containerImage: 'claude-flow-novice:mcp-playwright',\r\n tools: ['take_screenshot', 'search_google', 'navigate_and_interact'],\r\n skills: ['browser-automation', 'screenshot-capture', 'web-interaction'],\r\n resourceRequirements: {\r\n memoryMB: 1024,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'redis': {\r\n name: 'redis',\r\n displayName: 'Redis Database',\r\n description: 'Redis key-value store operations',\r\n containerImage: 'claude-flow-novice:mcp-redis',\r\n tools: ['redis_get', 'redis_set', 'redis_keys'],\r\n skills: ['redis-operations', 'cache-management'],\r\n resourceRequirements: {\r\n memoryMB: 256,\r\n cpuUnits: 1\r\n }\r\n },\r\n 'postgres': {\r\n name: 'postgres',\r\n displayName: 'PostgreSQL Database',\r\n description: 'PostgreSQL database operations',\r\n containerImage: 'claude-flow-novice:mcp-postgres',\r\n tools: ['postgres_query', 'postgres_schema', 'postgres_migrate'],\r\n skills: ['database-design', 'sql-operations'],\r\n resourceRequirements: {\r\n memoryMB: 512,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'security-scanner': {\r\n name: 'security-scanner',\r\n displayName: 'Security Scanner',\r\n description: 'Security vulnerability scanning and analysis',\r\n containerImage: 'claude-flow-novice:mcp-security',\r\n tools: ['security_scan', 'vulnerability_check', 'compliance_validate'],\r\n skills: ['security-auditing', 'vulnerability-scanning'],\r\n resourceRequirements: {\r\n memoryMB: 1536,\r\n cpuUnits: 4\r\n }\r\n }\r\n };\r\n\r\n for (const [name, config] of Object.entries(defaultServers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n }\r\n\r\n /**\r\n * Determine which MCP servers an agent needs based on their skills\r\n */\r\n selectMCPServers(agentType, agentSkills = null) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n throw new Error(`Unknown agent type: ${agentType}`);\r\n }\r\n\r\n // Use provided skills or fall back to agent config\r\n const skills = agentSkills || agentConfig.skills;\r\n\r\n // Determine required MCP servers based on skills\r\n const requiredMCPServers = new Set();\r\n const skillToMCPServerMap = this.getSkillToMCPServerMapping();\r\n\r\n // Map skills to required MCP servers\r\n for (const skill of skills) {\r\n if (skillToMCPServerMap.has(skill)) {\r\n const servers = skillToMCPServerMap.get(skill);\r\n servers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n }\r\n\r\n // Add explicitly allowed MCP servers from agent config\r\n if (agentConfig.allowedMcpServers) {\r\n agentConfig.allowedMcpServers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n\r\n // Convert to array and sort by priority\r\n const selectedServers = Array.from(requiredMCPServers)\r\n .filter(server => this.mcpServers.has(server))\r\n .sort((a, b) => {\r\n const priorityA = this.mcpServers.get(a).priority || 999;\r\n const priorityB = this.mcpServers.get(b).priority || 999;\r\n return priorityA - priorityB;\r\n });\r\n\r\n return {\r\n agentType,\r\n agentSkills: skills,\r\n selectedMCPServers,\r\n serverDetails: selectedServers.map(server => this.mcpServers.get(server)),\r\n totalMemoryRequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.memoryMB || 512), 0),\r\n totalCPURequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.cpuUnits || 1), 0)\r\n };\r\n }\r\n\r\n /**\r\n * Get mapping from skills to required MCP servers\r\n */\r\n getSkillToMCPServerMapping() {\r\n const skillMap = new Map();\r\n\r\n // Build mapping from MCP server configurations\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n for (const skill of serverConfig.skills || []) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n\r\n // Also add mappings from tool requirements\r\n for (const [toolName, toolConfig] of this.skillRequirements.entries()) {\r\n for (const skill of toolConfig.requiredSkills || []) {\r\n // Find MCP servers that provide this tool\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n if (serverConfig.tools?.includes(toolName)) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n }\r\n }\r\n\r\n return skillMap;\r\n }\r\n\r\n /**\r\n * Generate tokens for selected MCP servers\r\n */\r\n async generateMCPTokens(agentType, selectedServers, options = {}) {\r\n const tokens = [];\r\n\r\n for (const serverName of selectedServers) {\r\n try {\r\n const serverConfig = this.mcpServers.get(serverName);\r\n if (!serverConfig) {\r\n console.warn(`[SkillMCPSelector] Server configuration not found: ${serverName}`);\r\n continue;\r\n }\r\n\r\n // Generate server-specific token\r\n const tokenData = await this.tokenManager.registerAgentToken(agentType, {\r\n expiresIn: options.expiresIn || '24h',\r\n description: `Token for ${serverConfig.displayName}`,\r\n createdBy: 'skill-mcp-selector',\r\n mcpServer: serverName\r\n });\r\n\r\n tokens.push({\r\n serverName,\r\n displayName: serverConfig.displayName,\r\n token: tokenData.token,\r\n expiresAt: tokenData.expiresAt,\r\n containerImage: serverConfig.containerImage,\r\n connectionInfo: this.generateConnectionInfo(serverName, serverConfig, tokenData.token)\r\n });\r\n\r\n console.log(`[SkillMCPSelector] Generated token for ${agentType} → ${serverName}`);\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to generate token for ${serverName}:`, error);\r\n }\r\n }\r\n\r\n return tokens;\r\n }\r\n\r\n /**\r\n * Generate connection information for MCP server\r\n */\r\n generateConnectionInfo(serverName, serverConfig, token) {\r\n const baseInfo = {\r\n serverName,\r\n token,\r\n authentication: {\r\n type: 'token-based',\r\n header: 'x-agent-token',\r\n agentTypeHeader: 'x-agent-type'\r\n }\r\n };\r\n\r\n // Add server-specific connection details\r\n if (serverConfig.connectionType === 'docker') {\r\n return {\r\n ...baseInfo,\r\n type: 'docker-container',\r\n containerName: `mcp-${serverName}`,\r\n containerImage: serverConfig.containerImage,\r\n dockerArgs: [\r\n 'run', '--rm', '--init',\r\n '--name', `mcp-${serverName}`,\r\n '--memory', `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n '--cpus', `${serverConfig.resourceRequirements?.cpuUnits || 1}`,\r\n '-e', `MCP_SERVER=${serverName}`,\r\n '-e', `MCP_AUTH_REQUIRED=true`,\r\n '-e', `MCP_REDIS_URL=${process.env.MCP_REDIS_URL || 'redis://localhost:6379'}`,\r\n serverConfig.containerImage,\r\n 'node', `/app/mcp-${serverName}-server.js`\r\n ]\r\n };\r\n } else {\r\n return {\r\n ...baseInfo,\r\n type: 'http-endpoint',\r\n url: serverConfig.url || `http://localhost:${3000 + this.mcpServers.size}`,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'x-agent-token': token,\r\n 'x-agent-type': 'dynamic'\r\n }\r\n };\r\n }\r\n }\r\n\r\n /**\r\n * Get complete MCP configuration for an agent\r\n */\r\n async getAgentMCPConfiguration(agentType, agentSkills = null, options = {}) {\r\n try {\r\n // Select required MCP servers\r\n const selection = this.selectMCPServers(agentType, agentSkills);\r\n\r\n // Generate tokens for selected servers\r\n const tokens = await this.generateMCPTokens(\r\n agentType,\r\n selection.selectedMCPServers,\r\n options\r\n );\r\n\r\n return {\r\n agentType,\r\n agentSkills: selection.agentSkills,\r\n mcpConfiguration: {\r\n mcpServers: tokens.reduce((config, tokenInfo) => {\r\n config[tokenInfo.serverName] = {\r\n command: 'docker',\r\n args: tokenInfo.connectionInfo.dockerArgs,\r\n env: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n }\r\n };\r\n return config;\r\n }, {})\r\n },\r\n selection,\r\n tokens,\r\n resourceSummary: {\r\n totalMemoryMB: selection.totalMemoryRequired,\r\n totalCPUUnits: selection.totalCPUUnits,\r\n serverCount: selection.selectedMCPServers.length\r\n }\r\n };\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to get MCP configuration for ${agentType}:`, error);\r\n throw error;\r\n }\r\n }\r\n\r\n /**\r\n * Generate Docker Compose configuration for agent with MCP servers\r\n */\r\n async generateDockerComposeConfiguration(agentType, agentSkills = null, options = {}) {\r\n const config = await this.getAgentMCPConfiguration(agentType, agentSkills, options);\r\n\r\n const dockerCompose = {\r\n version: '3.8',\r\n services: {},\r\n networks: {\r\n 'mcp-network': {\r\n driver: 'bridge'\r\n }\r\n }\r\n };\r\n\r\n // Add agent service\r\n dockerCompose.services[`${agentType}-agent`] = {\r\n image: 'claude-flow-novice:agent-container',\r\n container_name: `agent-${agentType}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'AGENT_TYPE': agentType,\r\n 'AGENT_MODE': 'containerized',\r\n 'MCP_AUTH_ENABLED': 'true',\r\n 'REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379'\r\n },\r\n volumes: [\r\n '${PWD}/.claude:/app/.claude:ro',\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${config.resourceSummary.totalMemoryMB + 512}m`,\r\n depends_on: config.selection.selectedMCPServers.map(server => `mcp-${server}`).join(' ')\r\n };\r\n\r\n // Add MCP server services\r\n for (const tokenInfo of config.tokens) {\r\n const serverName = `mcp-${tokenInfo.serverName}`;\r\n const serverConfig = this.mcpServers.get(tokenInfo.serverName);\r\n\r\n dockerCompose.services[serverName] = {\r\n image: tokenInfo.containerImage,\r\n container_name: `${serverName}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'MCP_REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n },\r\n volumes: [\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n cpus: `${(serverConfig.resourceRequirements?.cpuUnits || 1) / 4}`\r\n };\r\n }\r\n\r\n // Add Redis service if not present\r\n if (!dockerCompose.services.redis) {\r\n dockerCompose.services.redis = {\r\n image: 'redis:7-alpine',\r\n container_name: 'mcp-redis',\r\n networks: ['mcp-network'],\r\n volumes: ['redis-data:/data'],\r\n mem_limit: '256m'\r\n };\r\n dockerCompose.volumes = {\r\n 'redis-data': {}\r\n };\r\n }\r\n\r\n return dockerCompose;\r\n }\r\n\r\n /**\r\n * Get statistics about skill-MCP mappings\r\n */\r\n getStatistics() {\r\n const skillMap = this.getSkillToMCPServerMapping();\r\n\r\n return {\r\n totalAgents: this.agentWhitelist.size,\r\n totalMCPServers: this.mcpServers.size,\r\n totalSkills: skillMap.size,\r\n agentTypes: Array.from(this.agentWhitelist.keys()),\r\n mcpServerNames: Array.from(this.mcpServers.keys()),\r\n skillCoverage: Array.from(skillMap.entries()).map(([skill, servers]) => ({\r\n skill,\r\n requiredServers: Array.from(servers),\r\n serverCount: servers.size\r\n }))\r\n };\r\n }\r\n\r\n /**\r\n * Validate agent-MCP configuration\r\n */\r\n validateConfiguration(agentType, mcpConfiguration) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n return { valid: false, errors: [`Unknown agent type: ${agentType}`] };\r\n }\r\n\r\n const errors = [];\r\n const warnings = [];\r\n\r\n // Check required MCP servers\r\n const requiredServers = agentConfig.allowedMcpServers || [];\r\n const configuredServers = Object.keys(mcpConfiguration.mcpServers || {});\r\n\r\n for (const server of requiredServers) {\r\n if (!configuredServers.includes(server)) {\r\n errors.push(`Required MCP server missing: ${server}`);\r\n }\r\n }\r\n\r\n // Check for unauthorized servers\r\n for (const server of configuredServers) {\r\n if (!requiredServers.includes(server)) {\r\n warnings.push(`Potentially unauthorized MCP server: ${server}`);\r\n }\r\n }\r\n\r\n return {\r\n valid: errors.length === 0,\r\n errors,\r\n warnings\r\n };\r\n }\r\n\r\n async shutdown() {\r\n await this.tokenManager.shutdown();\r\n }\r\n}\r\n\r\nmodule.exports = SkillMCPSelector;"],"names":["fs","require","promises","path","AgentTokenManager","SkillMCPSelector","options","tokenManager","agentConfigPath","skillConfigPath","mcpServersPath","agentWhitelist","Map","skillRequirements","mcpServers","initialize","loadConfigurations","console","log","agentConfig","loadJson","clear","agent","agents","set","type","skillConfig","tool","requirements","Object","entries","tools","mcpConfig","name","config","servers","error","warn","initializeDefaultMCPServers","filePath","resolvedPath","resolve","content","readFile","JSON","parse","defaultServers","displayName","description","containerImage","skills","resourceRequirements","memoryMB","cpuUnits","selectMCPServers","agentType","agentSkills","get","Error","requiredMCPServers","Set","skillToMCPServerMap","getSkillToMCPServerMapping","skill","has","forEach","server","add","allowedMcpServers","selectedServers","Array","from","filter","sort","a","b","priorityA","priority","priorityB","selectedMCPServers","serverDetails","map","totalMemoryRequired","reduce","sum","totalCPURequired","skillMap","serverName","serverConfig","toolName","toolConfig","requiredSkills","includes","generateMCPTokens","tokens","tokenData","registerAgentToken","expiresIn","createdBy","mcpServer","push","token","expiresAt","connectionInfo","generateConnectionInfo","baseInfo","authentication","header","agentTypeHeader","connectionType","containerName","dockerArgs","process","env","MCP_REDIS_URL","url","size","headers","getAgentMCPConfiguration","selection","mcpConfiguration","tokenInfo","command","args","resourceSummary","totalMemoryMB","totalCPUUnits","serverCount","length","generateDockerComposeConfiguration","dockerCompose","version","services","networks","driver","image","container_name","Date","now","environment","volumes","mem_limit","depends_on","join","cpus","redis","getStatistics","totalAgents","totalMCPServers","totalSkills","agentTypes","keys","mcpServerNames","skillCoverage","requiredServers","validateConfiguration","valid","errors","warnings","configuredServers","shutdown","module","exports"],"mappings":"AAAA;;;CAGC,GAED,MAAMA,KAAKC,QAAQ,MAAMC,QAAQ;AACjC,MAAMC,OAAOF,QAAQ;AACrB,MAAMG,oBAAoBH,QAAQ;AAElC,IAAA,AAAMI,mBAAN,MAAMA;IACJ,YAAYC,UAAU,CAAC,CAAC,CAAE;QACxB,IAAI,CAACC,YAAY,GAAG,IAAIH,kBAAkBE;QAC1C,IAAI,CAACE,eAAe,GAAGF,QAAQE,eAAe,IAAI;QAClD,IAAI,CAACC,eAAe,GAAGH,QAAQG,eAAe,IAAI;QAClD,IAAI,CAACC,cAAc,GAAGJ,QAAQI,cAAc,IAAI;QAEhD,IAAI,CAACC,cAAc,GAAG,IAAIC;QAC1B,IAAI,CAACC,iBAAiB,GAAG,IAAID;QAC7B,IAAI,CAACE,UAAU,GAAG,IAAIF;IACxB;IAEA,MAAMG,aAAa;QACjB,MAAM,IAAI,CAACR,YAAY,CAACQ,UAAU;QAClC,MAAM,IAAI,CAACC,kBAAkB;QAC7BC,QAAQC,GAAG,CAAC;IACd;IAEA,MAAMF,qBAAqB;QACzB,uBAAuB;QACvB,MAAMG,cAAc,MAAM,IAAI,CAACC,QAAQ,CAAC,IAAI,CAACZ,eAAe;QAC5D,IAAI,CAACG,cAAc,CAACU,KAAK;QACzB,KAAK,MAAMC,SAASH,YAAYI,MAAM,CAAE;YACtC,IAAI,CAACZ,cAAc,CAACa,GAAG,CAACF,MAAMG,IAAI,EAAEH;QACtC;QAEA,0BAA0B;QAC1B,MAAMI,cAAc,MAAM,IAAI,CAACN,QAAQ,CAAC,IAAI,CAACX,eAAe;QAC5D,IAAI,CAACI,iBAAiB,CAACQ,KAAK;QAC5B,KAAK,MAAM,CAACM,MAAMC,aAAa,IAAIC,OAAOC,OAAO,CAACJ,YAAYK,KAAK,EAAG;YACpE,IAAI,CAAClB,iBAAiB,CAACW,GAAG,CAACG,MAAMC;QACnC;QAEA,iCAAiC;QACjC,IAAI;YACF,MAAMI,YAAY,MAAM,IAAI,CAACZ,QAAQ,CAAC,IAAI,CAACV,cAAc;YACzD,KAAK,MAAM,CAACuB,MAAMC,OAAO,IAAIL,OAAOC,OAAO,CAACE,UAAUG,OAAO,EAAG;gBAC9D,IAAI,CAACrB,UAAU,CAACU,GAAG,CAACS,MAAMC;YAC5B;QACF,EAAE,OAAOE,OAAO;YACdnB,QAAQoB,IAAI,CAAC;YACb,IAAI,CAACC,2BAA2B;QAClC;IACF;IAEA,MAAMlB,SAASmB,QAAQ,EAAE;QACvB,MAAMC,eAAerC,KAAKsC,OAAO,CAACF;QAClC,MAAMG,UAAU,MAAM1C,GAAG2C,QAAQ,CAACH,cAAc;QAChD,OAAOI,KAAKC,KAAK,CAACH;IACpB;IAEAJ,8BAA8B;QAC5B,oCAAoC;QACpC,MAAMQ,iBAAiB;YACrB,cAAc;gBACZb,MAAM;gBACNc,aAAa;gBACbC,aAAa;gBACbC,gBAAgB;gBAChBlB,OAAO;oBAAC;oBAAmB;oBAAiB;iBAAwB;gBACpEmB,QAAQ;oBAAC;oBAAsB;oBAAsB;iBAAkB;gBACvEC,sBAAsB;oBACpBC,UAAU;oBACVC,UAAU;gBACZ;YACF;YACA,SAAS;gBACPpB,MAAM;gBACNc,aAAa;gBACbC,aAAa;gBACbC,gBAAgB;gBAChBlB,OAAO;oBAAC;oBAAa;oBAAa;iBAAa;gBAC/CmB,QAAQ;oBAAC;oBAAoB;iBAAmB;gBAChDC,sBAAsB;oBACpBC,UAAU;oBACVC,UAAU;gBACZ;YACF;YACA,YAAY;gBACVpB,MAAM;gBACNc,aAAa;gBACbC,aAAa;gBACbC,gBAAgB;gBAChBlB,OAAO;oBAAC;oBAAkB;oBAAmB;iBAAmB;gBAChEmB,QAAQ;oBAAC;oBAAmB;iBAAiB;gBAC7CC,sBAAsB;oBACpBC,UAAU;oBACVC,UAAU;gBACZ;YACF;YACA,oBAAoB;gBAClBpB,MAAM;gBACNc,aAAa;gBACbC,aAAa;gBACbC,gBAAgB;gBAChBlB,OAAO;oBAAC;oBAAiB;oBAAuB;iBAAsB;gBACtEmB,QAAQ;oBAAC;oBAAqB;iBAAyB;gBACvDC,sBAAsB;oBACpBC,UAAU;oBACVC,UAAU;gBACZ;YACF;QACF;QAEA,KAAK,MAAM,CAACpB,MAAMC,OAAO,IAAIL,OAAOC,OAAO,CAACgB,gBAAiB;YAC3D,IAAI,CAAChC,UAAU,CAACU,GAAG,CAACS,MAAMC;QAC5B;IACF;IAEA;;GAEC,GACDoB,iBAAiBC,SAAS,EAAEC,cAAc,IAAI,EAAE;QAC9C,MAAMrC,cAAc,IAAI,CAACR,cAAc,CAAC8C,GAAG,CAACF;QAC5C,IAAI,CAACpC,aAAa;YAChB,MAAM,IAAIuC,MAAM,CAAC,oBAAoB,EAAEH,WAAW;QACpD;QAEA,mDAAmD;QACnD,MAAML,SAASM,eAAerC,YAAY+B,MAAM;QAEhD,iDAAiD;QACjD,MAAMS,qBAAqB,IAAIC;QAC/B,MAAMC,sBAAsB,IAAI,CAACC,0BAA0B;QAE3D,qCAAqC;QACrC,KAAK,MAAMC,SAASb,OAAQ;YAC1B,IAAIW,oBAAoBG,GAAG,CAACD,QAAQ;gBAClC,MAAM5B,UAAU0B,oBAAoBJ,GAAG,CAACM;gBACxC5B,QAAQ8B,OAAO,CAACC,CAAAA,SAAUP,mBAAmBQ,GAAG,CAACD;YACnD;QACF;QAEA,uDAAuD;QACvD,IAAI/C,YAAYiD,iBAAiB,EAAE;YACjCjD,YAAYiD,iBAAiB,CAACH,OAAO,CAACC,CAAAA,SAAUP,mBAAmBQ,GAAG,CAACD;QACzE;QAEA,wCAAwC;QACxC,MAAMG,kBAAkBC,MAAMC,IAAI,CAACZ,oBAChCa,MAAM,CAACN,CAAAA,SAAU,IAAI,CAACpD,UAAU,CAACkD,GAAG,CAACE,SACrCO,IAAI,CAAC,CAACC,GAAGC;YACR,MAAMC,YAAY,IAAI,CAAC9D,UAAU,CAAC2C,GAAG,CAACiB,GAAGG,QAAQ,IAAI;YACrD,MAAMC,YAAY,IAAI,CAAChE,UAAU,CAAC2C,GAAG,CAACkB,GAAGE,QAAQ,IAAI;YACrD,OAAOD,YAAYE;QACrB;QAEF,OAAO;YACLvB;YACAC,aAAaN;YACb6B;YACAC,eAAeX,gBAAgBY,GAAG,CAACf,CAAAA,SAAU,IAAI,CAACpD,UAAU,CAAC2C,GAAG,CAACS;YACjEgB,qBAAqBb,gBAAgBc,MAAM,CAAC,CAACC,KAAKlB,SAChDkB,MAAO,CAAA,IAAI,CAACtE,UAAU,CAAC2C,GAAG,CAACS,QAAQf,oBAAoB,EAAEC,YAAY,GAAE,GAAI;YAC7EiC,kBAAkBhB,gBAAgBc,MAAM,CAAC,CAACC,KAAKlB,SAC7CkB,MAAO,CAAA,IAAI,CAACtE,UAAU,CAAC2C,GAAG,CAACS,QAAQf,oBAAoB,EAAEE,YAAY,CAAA,GAAI;QAC7E;IACF;IAEA;;GAEC,GACDS,6BAA6B;QAC3B,MAAMwB,WAAW,IAAI1E;QAErB,+CAA+C;QAC/C,KAAK,MAAM,CAAC2E,YAAYC,aAAa,IAAI,IAAI,CAAC1E,UAAU,CAACgB,OAAO,GAAI;YAClE,KAAK,MAAMiC,SAASyB,aAAatC,MAAM,IAAI,EAAE,CAAE;gBAC7C,IAAI,CAACoC,SAAStB,GAAG,CAACD,QAAQ;oBACxBuB,SAAS9D,GAAG,CAACuC,OAAO,IAAIH;gBAC1B;gBACA0B,SAAS7B,GAAG,CAACM,OAAOI,GAAG,CAACoB;YAC1B;QACF;QAEA,2CAA2C;QAC3C,KAAK,MAAM,CAACE,UAAUC,WAAW,IAAI,IAAI,CAAC7E,iBAAiB,CAACiB,OAAO,GAAI;YACrE,KAAK,MAAMiC,SAAS2B,WAAWC,cAAc,IAAI,EAAE,CAAE;gBACnD,0CAA0C;gBAC1C,KAAK,MAAM,CAACJ,YAAYC,aAAa,IAAI,IAAI,CAAC1E,UAAU,CAACgB,OAAO,GAAI;oBAClE,IAAI0D,aAAazD,KAAK,EAAE6D,SAASH,WAAW;wBAC1C,IAAI,CAACH,SAAStB,GAAG,CAACD,QAAQ;4BACxBuB,SAAS9D,GAAG,CAACuC,OAAO,IAAIH;wBAC1B;wBACA0B,SAAS7B,GAAG,CAACM,OAAOI,GAAG,CAACoB;oBAC1B;gBACF;YACF;QACF;QAEA,OAAOD;IACT;IAEA;;GAEC,GACD,MAAMO,kBAAkBtC,SAAS,EAAEc,eAAe,EAAE/D,UAAU,CAAC,CAAC,EAAE;QAChE,MAAMwF,SAAS,EAAE;QAEjB,KAAK,MAAMP,cAAclB,gBAAiB;YACxC,IAAI;gBACF,MAAMmB,eAAe,IAAI,CAAC1E,UAAU,CAAC2C,GAAG,CAAC8B;gBACzC,IAAI,CAACC,cAAc;oBACjBvE,QAAQoB,IAAI,CAAC,CAAC,mDAAmD,EAAEkD,YAAY;oBAC/E;gBACF;gBAEA,iCAAiC;gBACjC,MAAMQ,YAAY,MAAM,IAAI,CAACxF,YAAY,CAACyF,kBAAkB,CAACzC,WAAW;oBACtE0C,WAAW3F,QAAQ2F,SAAS,IAAI;oBAChCjD,aAAa,CAAC,UAAU,EAAEwC,aAAazC,WAAW,EAAE;oBACpDmD,WAAW;oBACXC,WAAWZ;gBACb;gBAEAO,OAAOM,IAAI,CAAC;oBACVb;oBACAxC,aAAayC,aAAazC,WAAW;oBACrCsD,OAAON,UAAUM,KAAK;oBACtBC,WAAWP,UAAUO,SAAS;oBAC9BrD,gBAAgBuC,aAAavC,cAAc;oBAC3CsD,gBAAgB,IAAI,CAACC,sBAAsB,CAACjB,YAAYC,cAAcO,UAAUM,KAAK;gBACvF;gBAEApF,QAAQC,GAAG,CAAC,CAAC,uCAAuC,EAAEqC,UAAU,GAAG,EAAEgC,YAAY;YACnF,EAAE,OAAOnD,OAAO;gBACdnB,QAAQmB,KAAK,CAAC,CAAC,gDAAgD,EAAEmD,WAAW,CAAC,CAAC,EAAEnD;YAClF;QACF;QAEA,OAAO0D;IACT;IAEA;;GAEC,GACDU,uBAAuBjB,UAAU,EAAEC,YAAY,EAAEa,KAAK,EAAE;QACtD,MAAMI,WAAW;YACflB;YACAc;YACAK,gBAAgB;gBACdjF,MAAM;gBACNkF,QAAQ;gBACRC,iBAAiB;YACnB;QACF;QAEA,yCAAyC;QACzC,IAAIpB,aAAaqB,cAAc,KAAK,UAAU;YAC5C,OAAO;gBACL,GAAGJ,QAAQ;gBACXhF,MAAM;gBACNqF,eAAe,CAAC,IAAI,EAAEvB,YAAY;gBAClCtC,gBAAgBuC,aAAavC,cAAc;gBAC3C8D,YAAY;oBACV;oBAAO;oBAAQ;oBACf;oBAAU,CAAC,IAAI,EAAExB,YAAY;oBAC7B;oBAAY,GAAGC,aAAarC,oBAAoB,EAAEC,YAAY,IAAI,CAAC,CAAC;oBACpE;oBAAU,GAAGoC,aAAarC,oBAAoB,EAAEE,YAAY,GAAG;oBAC/D;oBAAM,CAAC,WAAW,EAAEkC,YAAY;oBAChC;oBAAM,CAAC,sBAAsB,CAAC;oBAC9B;oBAAM,CAAC,cAAc,EAAEyB,QAAQC,GAAG,CAACC,aAAa,IAAI,0BAA0B;oBAC9E1B,aAAavC,cAAc;oBAC3B;oBAAQ,CAAC,SAAS,EAAEsC,WAAW,UAAU,CAAC;iBAC3C;YACH;QACF,OAAO;YACL,OAAO;gBACL,GAAGkB,QAAQ;gBACXhF,MAAM;gBACN0F,KAAK3B,aAAa2B,GAAG,IAAI,CAAC,iBAAiB,EAAE,OAAO,IAAI,CAACrG,UAAU,CAACsG,IAAI,EAAE;gBAC1EC,SAAS;oBACP,gBAAgB;oBAChB,iBAAiBhB;oBACjB,gBAAgB;gBAClB;YACF;QACF;IACF;IAEA;;GAEC,GACD,MAAMiB,yBAAyB/D,SAAS,EAAEC,cAAc,IAAI,EAAElD,UAAU,CAAC,CAAC,EAAE;QAC1E,IAAI;YACF,8BAA8B;YAC9B,MAAMiH,YAAY,IAAI,CAACjE,gBAAgB,CAACC,WAAWC;YAEnD,uCAAuC;YACvC,MAAMsC,SAAS,MAAM,IAAI,CAACD,iBAAiB,CACzCtC,WACAgE,UAAUxC,kBAAkB,EAC5BzE;YAGF,OAAO;gBACLiD;gBACAC,aAAa+D,UAAU/D,WAAW;gBAClCgE,kBAAkB;oBAChB1G,YAAYgF,OAAOX,MAAM,CAAC,CAACjD,QAAQuF;wBACjCvF,MAAM,CAACuF,UAAUlC,UAAU,CAAC,GAAG;4BAC7BmC,SAAS;4BACTC,MAAMF,UAAUlB,cAAc,CAACQ,UAAU;4BACzCE,KAAK;gCACH,cAAcQ,UAAUlC,UAAU;gCAClC,qBAAqB;gCACrB,eAAekC,UAAUpB,KAAK;4BAChC;wBACF;wBACA,OAAOnE;oBACT,GAAG,CAAC;gBACN;gBACAqF;gBACAzB;gBACA8B,iBAAiB;oBACfC,eAAeN,UAAUrC,mBAAmB;oBAC5C4C,eAAeP,UAAUO,aAAa;oBACtCC,aAAaR,UAAUxC,kBAAkB,CAACiD,MAAM;gBAClD;YACF;QACF,EAAE,OAAO5F,OAAO;YACdnB,QAAQmB,KAAK,CAAC,CAAC,uDAAuD,EAAEmB,UAAU,CAAC,CAAC,EAAEnB;YACtF,MAAMA;QACR;IACF;IAEA;;GAEC,GACD,MAAM6F,mCAAmC1E,SAAS,EAAEC,cAAc,IAAI,EAAElD,UAAU,CAAC,CAAC,EAAE;QACpF,MAAM4B,SAAS,MAAM,IAAI,CAACoF,wBAAwB,CAAC/D,WAAWC,aAAalD;QAE3E,MAAM4H,gBAAgB;YACpBC,SAAS;YACTC,UAAU,CAAC;YACXC,UAAU;gBACR,eAAe;oBACbC,QAAQ;gBACV;YACF;QACF;QAEA,oBAAoB;QACpBJ,cAAcE,QAAQ,CAAC,GAAG7E,UAAU,MAAM,CAAC,CAAC,GAAG;YAC7CgF,OAAO;YACPC,gBAAgB,CAAC,MAAM,EAAEjF,UAAU,CAAC,EAAEkF,KAAKC,GAAG,IAAI;YAClDL,UAAU;gBAAC;aAAc;YACzBM,aAAa;gBACX,cAAcpF;gBACd,cAAc;gBACd,oBAAoB;gBACpB,aAAayD,QAAQC,GAAG,CAACC,aAAa,IAAI;YAC5C;YACA0B,SAAS;gBACP;gBACA;aACD;YACDC,WAAW,GAAG3G,OAAO0F,eAAe,CAACC,aAAa,GAAG,IAAI,CAAC,CAAC;YAC3DiB,YAAY5G,OAAOqF,SAAS,CAACxC,kBAAkB,CAACE,GAAG,CAACf,CAAAA,SAAU,CAAC,IAAI,EAAEA,QAAQ,EAAE6E,IAAI,CAAC;QACtF;QAEA,0BAA0B;QAC1B,KAAK,MAAMtB,aAAavF,OAAO4D,MAAM,CAAE;YACrC,MAAMP,aAAa,CAAC,IAAI,EAAEkC,UAAUlC,UAAU,EAAE;YAChD,MAAMC,eAAe,IAAI,CAAC1E,UAAU,CAAC2C,GAAG,CAACgE,UAAUlC,UAAU;YAE7D2C,cAAcE,QAAQ,CAAC7C,WAAW,GAAG;gBACnCgD,OAAOd,UAAUxE,cAAc;gBAC/BuF,gBAAgB,GAAGjD,WAAW,CAAC,EAAEkD,KAAKC,GAAG,IAAI;gBAC7CL,UAAU;oBAAC;iBAAc;gBACzBM,aAAa;oBACX,cAAclB,UAAUlC,UAAU;oBAClC,qBAAqB;oBACrB,iBAAiByB,QAAQC,GAAG,CAACC,aAAa,IAAI;oBAC9C,eAAeO,UAAUpB,KAAK;gBAChC;gBACAuC,SAAS;oBACP;iBACD;gBACDC,WAAW,GAAGrD,aAAarC,oBAAoB,EAAEC,YAAY,IAAI,CAAC,CAAC;gBACnE4F,MAAM,GAAG,AAACxD,CAAAA,aAAarC,oBAAoB,EAAEE,YAAY,CAAA,IAAK,GAAG;YACnE;QACF;QAEA,mCAAmC;QACnC,IAAI,CAAC6E,cAAcE,QAAQ,CAACa,KAAK,EAAE;YACjCf,cAAcE,QAAQ,CAACa,KAAK,GAAG;gBAC7BV,OAAO;gBACPC,gBAAgB;gBAChBH,UAAU;oBAAC;iBAAc;gBACzBO,SAAS;oBAAC;iBAAmB;gBAC7BC,WAAW;YACb;YACAX,cAAcU,OAAO,GAAG;gBACtB,cAAc,CAAC;YACjB;QACF;QAEA,OAAOV;IACT;IAEA;;GAEC,GACDgB,gBAAgB;QACd,MAAM5D,WAAW,IAAI,CAACxB,0BAA0B;QAEhD,OAAO;YACLqF,aAAa,IAAI,CAACxI,cAAc,CAACyG,IAAI;YACrCgC,iBAAiB,IAAI,CAACtI,UAAU,CAACsG,IAAI;YACrCiC,aAAa/D,SAAS8B,IAAI;YAC1BkC,YAAYhF,MAAMC,IAAI,CAAC,IAAI,CAAC5D,cAAc,CAAC4I,IAAI;YAC/CC,gBAAgBlF,MAAMC,IAAI,CAAC,IAAI,CAACzD,UAAU,CAACyI,IAAI;YAC/CE,eAAenF,MAAMC,IAAI,CAACe,SAASxD,OAAO,IAAImD,GAAG,CAAC,CAAC,CAAClB,OAAO5B,QAAQ,GAAM,CAAA;oBACvE4B;oBACA2F,iBAAiBpF,MAAMC,IAAI,CAACpC;oBAC5B4F,aAAa5F,QAAQiF,IAAI;gBAC3B,CAAA;QACF;IACF;IAEA;;GAEC,GACDuC,sBAAsBpG,SAAS,EAAEiE,gBAAgB,EAAE;QACjD,MAAMrG,cAAc,IAAI,CAACR,cAAc,CAAC8C,GAAG,CAACF;QAC5C,IAAI,CAACpC,aAAa;YAChB,OAAO;gBAAEyI,OAAO;gBAAOC,QAAQ;oBAAC,CAAC,oBAAoB,EAAEtG,WAAW;iBAAC;YAAC;QACtE;QAEA,MAAMsG,SAAS,EAAE;QACjB,MAAMC,WAAW,EAAE;QAEnB,6BAA6B;QAC7B,MAAMJ,kBAAkBvI,YAAYiD,iBAAiB,IAAI,EAAE;QAC3D,MAAM2F,oBAAoBlI,OAAO0H,IAAI,CAAC/B,iBAAiB1G,UAAU,IAAI,CAAC;QAEtE,KAAK,MAAMoD,UAAUwF,gBAAiB;YACpC,IAAI,CAACK,kBAAkBnE,QAAQ,CAAC1B,SAAS;gBACvC2F,OAAOzD,IAAI,CAAC,CAAC,6BAA6B,EAAElC,QAAQ;YACtD;QACF;QAEA,iCAAiC;QACjC,KAAK,MAAMA,UAAU6F,kBAAmB;YACtC,IAAI,CAACL,gBAAgB9D,QAAQ,CAAC1B,SAAS;gBACrC4F,SAAS1D,IAAI,CAAC,CAAC,qCAAqC,EAAElC,QAAQ;YAChE;QACF;QAEA,OAAO;YACL0F,OAAOC,OAAO7B,MAAM,KAAK;YACzB6B;YACAC;QACF;IACF;IAEA,MAAME,WAAW;QACf,MAAM,IAAI,CAACzJ,YAAY,CAACyJ,QAAQ;IAClC;AACF;AAEAC,OAAOC,OAAO,GAAG7J"}
|
|
1
|
+
{"version":3,"sources":["../../src/agent/skill-mcp-selector.js"],"sourcesContent":["/**\r\n * Skill-based MCP Selection System\r\n * Automatically selects MCP servers based on agent skills and requirements\r\n */\r\n\r\nconst fs = require('fs').promises;\r\nconst path = require('path');\r\nconst AgentTokenManager = require('../cli/agent-token-manager.js');\r\n\r\nclass SkillMCPSelector {\r\n constructor(options = {}) {\r\n this.tokenManager = new AgentTokenManager(options);\r\n this.agentConfigPath = options.agentConfigPath || './config/agent-whitelist.json';\r\n this.skillConfigPath = options.skillConfigPath || './config/skill-requirements.json';\r\n this.mcpServersPath = options.mcpServersPath || './config/mcp-servers.json';\r\n\r\n this.agentWhitelist = new Map();\r\n this.skillRequirements = new Map();\r\n this.mcpServers = new Map();\r\n }\r\n\r\n async initialize() {\r\n await this.tokenManager.initialize();\r\n await this.loadConfigurations();\r\n console.log('[SkillMCPSelector] Initialized successfully');\r\n }\r\n\r\n async loadConfigurations() {\r\n // Load agent whitelist\r\n const agentConfig = await this.loadJson(this.agentConfigPath);\r\n this.agentWhitelist.clear();\r\n for (const agent of agentConfig.agents) {\r\n this.agentWhitelist.set(agent.type, agent);\r\n }\r\n\r\n // Load skill requirements\r\n const skillConfig = await this.loadJson(this.skillConfigPath);\r\n this.skillRequirements.clear();\r\n for (const [tool, requirements] of Object.entries(skillConfig.tools)) {\r\n this.skillRequirements.set(tool, requirements);\r\n }\r\n\r\n // Load MCP server configurations\r\n try {\r\n const mcpConfig = await this.loadJson(this.mcpServersPath);\r\n for (const [name, config] of Object.entries(mcpConfig.servers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n } catch (error) {\r\n console.warn('[SkillMCPSelector] MCP servers config not found, using defaults');\r\n this.initializeDefaultMCPServers();\r\n }\r\n }\r\n\r\n async loadJson(filePath) {\r\n const resolvedPath = path.resolve(filePath);\r\n const content = await fs.readFile(resolvedPath, 'utf8');\r\n return JSON.parse(content);\r\n }\r\n\r\n initializeDefaultMCPServers() {\r\n // Default MCP server configurations\r\n const defaultServers = {\r\n 'playwright': {\r\n name: 'playwright',\r\n displayName: 'Playwright Browser Automation',\r\n description: 'Browser automation and screenshot capabilities',\r\n containerImage: 'claude-flow-novice:mcp-playwright',\r\n tools: ['take_screenshot', 'search_google', 'navigate_and_interact'],\r\n skills: ['browser-automation', 'screenshot-capture', 'web-interaction'],\r\n resourceRequirements: {\r\n memoryMB: 1024,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'redis': {\r\n name: 'redis',\r\n displayName: 'Redis Database',\r\n description: 'Redis key-value store operations',\r\n containerImage: 'claude-flow-novice:mcp-redis',\r\n tools: ['redis_get', 'redis_set', 'redis_keys'],\r\n skills: ['redis-operations', 'cache-management'],\r\n resourceRequirements: {\r\n memoryMB: 256,\r\n cpuUnits: 1\r\n }\r\n },\r\n 'postgres': {\r\n name: 'postgres',\r\n displayName: 'PostgreSQL Database',\r\n description: 'PostgreSQL database operations',\r\n containerImage: 'claude-flow-novice:mcp-postgres',\r\n tools: ['postgres_query', 'postgres_schema', 'postgres_migrate'],\r\n skills: ['database-design', 'sql-operations'],\r\n resourceRequirements: {\r\n memoryMB: 512,\r\n cpuUnits: 2\r\n }\r\n },\r\n 'security-scanner': {\r\n name: 'security-scanner',\r\n displayName: 'Security Scanner',\r\n description: 'Security vulnerability scanning and analysis',\r\n containerImage: 'claude-flow-novice:mcp-security',\r\n tools: ['security_scan', 'vulnerability_check', 'compliance_validate'],\r\n skills: ['security-auditing', 'vulnerability-scanning'],\r\n resourceRequirements: {\r\n memoryMB: 1536,\r\n cpuUnits: 4\r\n }\r\n }\r\n };\r\n\r\n for (const [name, config] of Object.entries(defaultServers)) {\r\n this.mcpServers.set(name, config);\r\n }\r\n }\r\n\r\n /**\r\n * Determine which MCP servers an agent needs based on their skills\r\n */\r\n selectMCPServers(agentType, agentSkills = null) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n throw new Error(`Unknown agent type: ${agentType}`);\r\n }\r\n\r\n // Use provided skills or fall back to agent config\r\n const skills = agentSkills || agentConfig.skills;\r\n\r\n // Determine required MCP servers based on skills\r\n const requiredMCPServers = new Set();\r\n const skillToMCPServerMap = this.getSkillToMCPServerMapping();\r\n\r\n // Map skills to required MCP servers\r\n for (const skill of skills) {\r\n if (skillToMCPServerMap.has(skill)) {\r\n const servers = skillToMCPServerMap.get(skill);\r\n servers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n }\r\n\r\n // Add explicitly allowed MCP servers from agent config\r\n if (agentConfig.allowedMcpServers) {\r\n agentConfig.allowedMcpServers.forEach(server => requiredMCPServers.add(server));\r\n }\r\n\r\n // Convert to array and sort by priority\r\n const selectedServers = Array.from(requiredMCPServers)\r\n .filter(server => this.mcpServers.has(server))\r\n .sort((a, b) => {\r\n const priorityA = this.mcpServers.get(a).priority || 999;\r\n const priorityB = this.mcpServers.get(b).priority || 999;\r\n return priorityA - priorityB;\r\n });\r\n\r\n return {\r\n agentType,\r\n agentSkills: skills,\r\n selectedMCPServers,\r\n serverDetails: selectedServers.map(server => this.mcpServers.get(server)),\r\n totalMemoryRequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.memoryMB || 512), 0),\r\n totalCPURequired: selectedServers.reduce((sum, server) =>\r\n sum + (this.mcpServers.get(server).resourceRequirements?.cpuUnits || 1), 0)\r\n };\r\n }\r\n\r\n /**\r\n * Get mapping from skills to required MCP servers\r\n */\r\n getSkillToMCPServerMapping() {\r\n const skillMap = new Map();\r\n\r\n // Build mapping from MCP server configurations\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n for (const skill of serverConfig.skills || []) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n\r\n // Also add mappings from tool requirements\r\n for (const [toolName, toolConfig] of this.skillRequirements.entries()) {\r\n for (const skill of toolConfig.requiredSkills || []) {\r\n // Find MCP servers that provide this tool\r\n for (const [serverName, serverConfig] of this.mcpServers.entries()) {\r\n if (serverConfig.tools?.includes(toolName)) {\r\n if (!skillMap.has(skill)) {\r\n skillMap.set(skill, new Set());\r\n }\r\n skillMap.get(skill).add(serverName);\r\n }\r\n }\r\n }\r\n }\r\n\r\n return skillMap;\r\n }\r\n\r\n /**\r\n * Generate tokens for selected MCP servers\r\n */\r\n async generateMCPTokens(agentType, selectedServers, options = {}) {\r\n const tokens = [];\r\n\r\n for (const serverName of selectedServers) {\r\n try {\r\n const serverConfig = this.mcpServers.get(serverName);\r\n if (!serverConfig) {\r\n console.warn(`[SkillMCPSelector] Server configuration not found: ${serverName}`);\r\n continue;\r\n }\r\n\r\n // Generate server-specific token\r\n const tokenData = await this.tokenManager.registerAgentToken(agentType, {\r\n expiresIn: options.expiresIn || '24h',\r\n description: `Token for ${serverConfig.displayName}`,\r\n createdBy: 'skill-mcp-selector',\r\n mcpServer: serverName\r\n });\r\n\r\n tokens.push({\r\n serverName,\r\n displayName: serverConfig.displayName,\r\n token: tokenData.token,\r\n expiresAt: tokenData.expiresAt,\r\n containerImage: serverConfig.containerImage,\r\n connectionInfo: this.generateConnectionInfo(serverName, serverConfig, tokenData.token)\r\n });\r\n\r\n console.log(`[SkillMCPSelector] Generated token for ${agentType} → ${serverName}`);\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to generate token for ${serverName}:`, error);\r\n }\r\n }\r\n\r\n return tokens;\r\n }\r\n\r\n /**\r\n * Generate connection information for MCP server\r\n */\r\n generateConnectionInfo(serverName, serverConfig, token) {\r\n const baseInfo = {\r\n serverName,\r\n token,\r\n authentication: {\r\n type: 'token-based',\r\n header: 'x-agent-token',\r\n agentTypeHeader: 'x-agent-type'\r\n }\r\n };\r\n\r\n // Add server-specific connection details\r\n if (serverConfig.connectionType === 'docker') {\r\n return {\r\n ...baseInfo,\r\n type: 'docker-container',\r\n containerName: `mcp-${serverName}`,\r\n containerImage: serverConfig.containerImage,\r\n dockerArgs: [\r\n 'run', '--rm', '--init',\r\n '--name', `mcp-${serverName}`,\r\n '--memory', `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n '--cpus', `${serverConfig.resourceRequirements?.cpuUnits || 1}`,\r\n '-e', `MCP_SERVER=${serverName}`,\r\n '-e', `MCP_AUTH_REQUIRED=true`,\r\n '-e', `MCP_REDIS_URL=${process.env.CFN_REDIS_URL || process.env.MCP_REDIS_URL || `redis://${process.env.CFN_REDIS_HOST || 'cfn-redis'}:${process.env.CFN_REDIS_PORT || 6379}`}`,\r\n serverConfig.containerImage,\r\n 'node', `/app/mcp-${serverName}-server.js`\r\n ]\r\n };\r\n } else {\r\n return {\r\n ...baseInfo,\r\n type: 'http-endpoint',\r\n url: serverConfig.url || `http://localhost:${3000 + this.mcpServers.size}`,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'x-agent-token': token,\r\n 'x-agent-type': 'dynamic'\r\n }\r\n };\r\n }\r\n }\r\n\r\n /**\r\n * Get complete MCP configuration for an agent\r\n */\r\n async getAgentMCPConfiguration(agentType, agentSkills = null, options = {}) {\r\n try {\r\n // Select required MCP servers\r\n const selection = this.selectMCPServers(agentType, agentSkills);\r\n\r\n // Generate tokens for selected servers\r\n const tokens = await this.generateMCPTokens(\r\n agentType,\r\n selection.selectedMCPServers,\r\n options\r\n );\r\n\r\n return {\r\n agentType,\r\n agentSkills: selection.agentSkills,\r\n mcpConfiguration: {\r\n mcpServers: tokens.reduce((config, tokenInfo) => {\r\n config[tokenInfo.serverName] = {\r\n command: 'docker',\r\n args: tokenInfo.connectionInfo.dockerArgs,\r\n env: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n }\r\n };\r\n return config;\r\n }, {})\r\n },\r\n selection,\r\n tokens,\r\n resourceSummary: {\r\n totalMemoryMB: selection.totalMemoryRequired,\r\n totalCPUUnits: selection.totalCPUUnits,\r\n serverCount: selection.selectedMCPServers.length\r\n }\r\n };\r\n } catch (error) {\r\n console.error(`[SkillMCPSelector] Failed to get MCP configuration for ${agentType}:`, error);\r\n throw error;\r\n }\r\n }\r\n\r\n /**\r\n * Generate Docker Compose configuration for agent with MCP servers\r\n */\r\n async generateDockerComposeConfiguration(agentType, agentSkills = null, options = {}) {\r\n const config = await this.getAgentMCPConfiguration(agentType, agentSkills, options);\r\n\r\n const dockerCompose = {\r\n version: '3.8',\r\n services: {},\r\n networks: {\r\n 'mcp-network': {\r\n driver: 'bridge'\r\n }\r\n }\r\n };\r\n\r\n // Add agent service\r\n dockerCompose.services[`${agentType}-agent`] = {\r\n image: 'claude-flow-novice:agent-container',\r\n container_name: `agent-${agentType}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'AGENT_TYPE': agentType,\r\n 'AGENT_MODE': 'containerized',\r\n 'MCP_AUTH_ENABLED': 'true',\r\n 'REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379'\r\n },\r\n volumes: [\r\n '${PWD}/.claude:/app/.claude:ro',\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${config.resourceSummary.totalMemoryMB + 512}m`,\r\n depends_on: config.selection.selectedMCPServers.map(server => `mcp-${server}`).join(' ')\r\n };\r\n\r\n // Add MCP server services\r\n for (const tokenInfo of config.tokens) {\r\n const serverName = `mcp-${tokenInfo.serverName}`;\r\n const serverConfig = this.mcpServers.get(tokenInfo.serverName);\r\n\r\n dockerCompose.services[serverName] = {\r\n image: tokenInfo.containerImage,\r\n container_name: `${serverName}-${Date.now()}`,\r\n networks: ['mcp-network'],\r\n environment: {\r\n 'MCP_SERVER': tokenInfo.serverName,\r\n 'MCP_AUTH_REQUIRED': 'true',\r\n 'MCP_REDIS_URL': process.env.MCP_REDIS_URL || 'redis://redis:6379',\r\n 'AGENT_TOKEN': tokenInfo.token\r\n },\r\n volumes: [\r\n '${PWD}/screenshots:/app/screenshots'\r\n ],\r\n mem_limit: `${serverConfig.resourceRequirements?.memoryMB || 512}m`,\r\n cpus: `${(serverConfig.resourceRequirements?.cpuUnits || 1) / 4}`\r\n };\r\n }\r\n\r\n // Add Redis service if not present\r\n if (!dockerCompose.services.redis) {\r\n dockerCompose.services.redis = {\r\n image: 'redis:7-alpine',\r\n container_name: 'mcp-redis',\r\n networks: ['mcp-network'],\r\n volumes: ['redis-data:/data'],\r\n mem_limit: '256m'\r\n };\r\n dockerCompose.volumes = {\r\n 'redis-data': {}\r\n };\r\n }\r\n\r\n return dockerCompose;\r\n }\r\n\r\n /**\r\n * Get statistics about skill-MCP mappings\r\n */\r\n getStatistics() {\r\n const skillMap = this.getSkillToMCPServerMapping();\r\n\r\n return {\r\n totalAgents: this.agentWhitelist.size,\r\n totalMCPServers: this.mcpServers.size,\r\n totalSkills: skillMap.size,\r\n agentTypes: Array.from(this.agentWhitelist.keys()),\r\n mcpServerNames: Array.from(this.mcpServers.keys()),\r\n skillCoverage: Array.from(skillMap.entries()).map(([skill, servers]) => ({\r\n skill,\r\n requiredServers: Array.from(servers),\r\n serverCount: servers.size\r\n }))\r\n };\r\n }\r\n\r\n /**\r\n * Validate agent-MCP configuration\r\n */\r\n validateConfiguration(agentType, mcpConfiguration) {\r\n const agentConfig = this.agentWhitelist.get(agentType);\r\n if (!agentConfig) {\r\n return { valid: false, errors: [`Unknown agent type: ${agentType}`] };\r\n }\r\n\r\n const errors = [];\r\n const warnings = [];\r\n\r\n // Check required MCP servers\r\n const requiredServers = agentConfig.allowedMcpServers || [];\r\n const configuredServers = Object.keys(mcpConfiguration.mcpServers || {});\r\n\r\n for (const server of requiredServers) {\r\n if (!configuredServers.includes(server)) {\r\n errors.push(`Required MCP server missing: ${server}`);\r\n }\r\n }\r\n\r\n // Check for unauthorized servers\r\n for (const server of configuredServers) {\r\n if (!requiredServers.includes(server)) {\r\n warnings.push(`Potentially unauthorized MCP server: ${server}`);\r\n }\r\n }\r\n\r\n return {\r\n valid: errors.length === 0,\r\n errors,\r\n warnings\r\n };\r\n }\r\n\r\n async shutdown() {\r\n await this.tokenManager.shutdown();\r\n }\r\n}\r\n\r\nmodule.exports = SkillMCPSelector;"],"names":["fs","require","promises","path","AgentTokenManager","SkillMCPSelector","options","tokenManager","agentConfigPath","skillConfigPath","mcpServersPath","agentWhitelist","Map","skillRequirements","mcpServers","initialize","loadConfigurations","console","log","agentConfig","loadJson","clear","agent","agents","set","type","skillConfig","tool","requirements","Object","entries","tools","mcpConfig","name","config","servers","error","warn","initializeDefaultMCPServers","filePath","resolvedPath","resolve","content","readFile","JSON","parse","defaultServers","displayName","description","containerImage","skills","resourceRequirements","memoryMB","cpuUnits","selectMCPServers","agentType","agentSkills","get","Error","requiredMCPServers","Set","skillToMCPServerMap","getSkillToMCPServerMapping","skill","has","forEach","server","add","allowedMcpServers","selectedServers","Array","from","filter","sort","a","b","priorityA","priority","priorityB","selectedMCPServers","serverDetails","map","totalMemoryRequired","reduce","sum","totalCPURequired","skillMap","serverName","serverConfig","toolName","toolConfig","requiredSkills","includes","generateMCPTokens","tokens","tokenData","registerAgentToken","expiresIn","createdBy","mcpServer","push","token","expiresAt","connectionInfo","generateConnectionInfo","baseInfo","authentication","header","agentTypeHeader","connectionType","containerName","dockerArgs","process","env","CFN_REDIS_URL","MCP_REDIS_URL","CFN_REDIS_HOST","CFN_REDIS_PORT","url","size","headers","getAgentMCPConfiguration","selection","mcpConfiguration","tokenInfo","command","args","resourceSummary","totalMemoryMB","totalCPUUnits","serverCount","length","generateDockerComposeConfiguration","dockerCompose","version","services","networks","driver","image","container_name","Date","now","environment","volumes","mem_limit","depends_on","join","cpus","redis","getStatistics","totalAgents","totalMCPServers","totalSkills","agentTypes","keys","mcpServerNames","skillCoverage","requiredServers","validateConfiguration","valid","errors","warnings","configuredServers","shutdown","module","exports"],"mappings":"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"}
|
|
@@ -5,11 +5,16 @@
|
|
|
5
5
|
* Supports agent definitions in .claude/agents/ directory structure.
|
|
6
6
|
*/ import fs from 'fs/promises';
|
|
7
7
|
import path from 'path';
|
|
8
|
+
import { fileURLToPath } from 'url';
|
|
8
9
|
import { glob } from 'glob';
|
|
10
|
+
// ES Module compatibility
|
|
11
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
12
|
+
const __dirname = path.dirname(__filename);
|
|
9
13
|
/**
|
|
10
14
|
* Parse YAML frontmatter from markdown content
|
|
15
|
+
* Supports both Unix (LF) and Windows (CRLF) line endings
|
|
11
16
|
*/ function parseFrontmatter(content) {
|
|
12
|
-
const frontmatterRegex = /^---\n([\s\S]*?)\n---\n([\s\S]*)$/;
|
|
17
|
+
const frontmatterRegex = /^---\r?\n([\s\S]*?)\r?\n---\r?\n([\s\S]*)$/;
|
|
13
18
|
const match = content.match(frontmatterRegex);
|
|
14
19
|
if (!match) {
|
|
15
20
|
return {
|
|
@@ -105,28 +110,43 @@ import { glob } from 'glob';
|
|
|
105
110
|
}
|
|
106
111
|
/**
|
|
107
112
|
* Find agent definition file by agent type/name
|
|
113
|
+
* Searches multiple locations for agent definitions
|
|
108
114
|
*/ async function findAgentFile(agentType, baseDir = '.claude/agents') {
|
|
109
115
|
// Normalize agent type (handle both kebab-case and underscores)
|
|
110
116
|
const normalizedType = agentType.toLowerCase().replace(/_/g, '-');
|
|
117
|
+
// Search locations (in order of priority)
|
|
118
|
+
const searchLocations = [
|
|
119
|
+
baseDir,
|
|
120
|
+
'.claude/agents',
|
|
121
|
+
path.join(__dirname, '../../.claude/agents'),
|
|
122
|
+
'/app/.claude/agents'
|
|
123
|
+
];
|
|
111
124
|
// Search patterns (in order of priority)
|
|
112
|
-
const
|
|
125
|
+
const searchPatterns = [
|
|
113
126
|
// Exact match in any subdirectory
|
|
114
|
-
|
|
127
|
+
(loc)=>`${loc}/**/${normalizedType}.md`,
|
|
115
128
|
// Match with different casing
|
|
116
|
-
|
|
129
|
+
(loc)=>`${loc}/**/*${normalizedType}*.md`
|
|
117
130
|
];
|
|
118
|
-
for (const
|
|
119
|
-
const
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
131
|
+
for (const location of searchLocations){
|
|
132
|
+
for (const patternFn of searchPatterns){
|
|
133
|
+
const pattern = patternFn(location);
|
|
134
|
+
try {
|
|
135
|
+
const files = await glob(pattern, {
|
|
136
|
+
nodir: true,
|
|
137
|
+
absolute: true
|
|
138
|
+
});
|
|
139
|
+
if (files.length > 0) {
|
|
140
|
+
// Prefer exact match over partial match
|
|
141
|
+
const exactMatch = files.find((f)=>{
|
|
142
|
+
const basename = path.basename(f, '.md').toLowerCase();
|
|
143
|
+
return basename === normalizedType;
|
|
144
|
+
});
|
|
145
|
+
return exactMatch || files[0];
|
|
146
|
+
}
|
|
147
|
+
} catch (error) {
|
|
148
|
+
continue;
|
|
149
|
+
}
|
|
130
150
|
}
|
|
131
151
|
}
|
|
132
152
|
return null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/cli/agent-definition-parser.ts"],"sourcesContent":["/**\r\n * Agent Definition Parser\r\n *\r\n * Parses agent definition files (.md) with YAML frontmatter and markdown content.\r\n * Supports agent definitions in .claude/agents/ directory structure.\r\n */\r\n\r\nimport fs from 'fs/promises';\r\nimport path from 'path';\r\nimport { glob } from 'glob';\r\n\r\nexport interface AgentDefinition {\r\n // YAML frontmatter fields\r\n name: string;\r\n description: string;\r\n tools: string[];\r\n model: 'haiku' | 'sonnet' | 'opus';\r\n type?: string;\r\n color?: string;\r\n acl_level?: number;\r\n capabilities?: string[];\r\n validation_hooks?: string[];\r\n lifecycle?: {\r\n pre_task?: string;\r\n post_task?: string;\r\n };\r\n\r\n // Parsed markdown content\r\n content: string;\r\n\r\n // File metadata\r\n filePath: string;\r\n category?: string; // e.g., 'core-agents', 'specialized', 'custom'\r\n}\r\n\r\n/**\r\n * Parse YAML frontmatter from markdown content\r\n */\r\nfunction parseFrontmatter(content: string): { frontmatter: Record<string, any>; body: string } {\r\n const frontmatterRegex = /^---\\n([\\s\\S]*?)\\n---\\n([\\s\\S]*)$/;\r\n const match = content.match(frontmatterRegex);\r\n\r\n if (!match) {\r\n return { frontmatter: {}, body: content };\r\n }\r\n\r\n const [, yamlContent, body] = match;\r\n\r\n \r\n // Simple YAML parser (handles basic key-value pairs, arrays, and objects)\r\n const frontmatter: Record<string, any> = {};\r\n const lines = yamlContent.split('\\n');\r\n let currentKey = '';\r\n let currentArray: string[] = [];\r\n let isInArray = false;\r\n let isInObject = false;\r\n let currentObject: Record<string, string> = {};\r\n let objectKey = '';\r\n\r\n for (const line of lines) {\r\n const trimmed = line.trim();\r\n if (!trimmed || trimmed.startsWith('#')) continue;\r\n\r\n // Array item\r\n if (trimmed.startsWith('- ')) {\r\n if (!isInArray) {\r\n isInArray = true;\r\n currentArray = [];\r\n }\r\n currentArray.push(trimmed.substring(2).trim());\r\n continue;\r\n }\r\n\r\n // End of array\r\n if (isInArray && !trimmed.startsWith('- ')) {\r\n frontmatter[currentKey] = currentArray;\r\n isInArray = false;\r\n currentArray = [];\r\n }\r\n\r\n // Object field (indented key-value)\r\n if (trimmed.match(/^\\s+\\w+:/) && isInObject) {\r\n const [objKey, ...objValueParts] = trimmed.split(':');\r\n const objValue = objValueParts.join(':').trim().replace(/^[\"']|[\"']$/g, '');\r\n currentObject[objKey.trim()] = objValue;\r\n continue;\r\n }\r\n\r\n // Key-value pair\r\n const colonIndex = trimmed.indexOf(':');\r\n if (colonIndex !== -1) {\r\n const key = trimmed.substring(0, colonIndex).trim();\r\n const value = trimmed.substring(colonIndex + 1).trim();\r\n\r\n // Check if this starts an object\r\n if (value === '') {\r\n isInObject = true;\r\n currentObject = {};\r\n objectKey = key;\r\n continue;\r\n }\r\n\r\n // End previous object if any\r\n if (isInObject && !trimmed.match(/^\\s+/)) {\r\n frontmatter[objectKey] = currentObject;\r\n isInObject = false;\r\n currentObject = {};\r\n }\r\n\r\n currentKey = key;\r\n\r\n // Multi-line string (starts with |)\r\n if (value === '|') {\r\n continue; // Will be handled by next lines\r\n }\r\n\r\n // Inline array (e.g., [item1, item2, item3])\r\n if (value.startsWith('[') && value.endsWith(']')) {\r\n const arrayContent = value.substring(1, value.length - 1);\r\n const items = arrayContent.split(',').map(item => item.trim());\r\n frontmatter[key] = items;\r\n continue;\r\n }\r\n\r\n // Remove quotes\r\n const cleanValue = value.replace(/^[\"']|[\"']$/g, '');\r\n frontmatter[key] = cleanValue;\r\n } else if (currentKey && trimmed && !isInArray && !isInObject) {\r\n // Continuation of multi-line string\r\n const existingValue = frontmatter[currentKey];\r\n frontmatter[currentKey] = existingValue\r\n ? `${existingValue}\\n${trimmed}`\r\n : trimmed;\r\n }\r\n }\r\n\r\n // Handle trailing array or object\r\n if (isInArray) {\r\n frontmatter[currentKey] = currentArray;\r\n }\r\n if (isInObject) {\r\n frontmatter[objectKey] = currentObject;\r\n }\r\n\r\n return { frontmatter, body: body.trim() };\r\n}\r\n\r\n/**\r\n * Find agent definition file by agent type/name\r\n */\r\nasync function findAgentFile(agentType: string, baseDir: string = '.claude/agents'): Promise<string | null> {\r\n // Normalize agent type (handle both kebab-case and underscores)\r\n const normalizedType = agentType.toLowerCase().replace(/_/g, '-');\r\n\r\n // Search patterns (in order of priority)\r\n const patterns = [\r\n // Exact match in any subdirectory\r\n `${baseDir}/**/${normalizedType}.md`,\r\n // Match with different casing\r\n `${baseDir}/**/*${normalizedType}*.md`,\r\n ];\r\n\r\n for (const pattern of patterns) {\r\n const files = await glob(pattern, { nodir: true, absolute: true });\r\n if (files.length > 0) {\r\n // Prefer exact match over partial match\r\n const exactMatch = files.find(f => {\r\n const basename = path.basename(f, '.md').toLowerCase();\r\n return basename === normalizedType;\r\n });\r\n return exactMatch || files[0];\r\n }\r\n }\r\n\r\n return null;\r\n}\r\n\r\n/**\r\n * Parse agent definition from file\r\n */\r\nexport async function parseAgentDefinition(agentType: string): Promise<AgentDefinition> {\r\n // Find agent file\r\n const filePath = await findAgentFile(agentType);\r\n\r\n if (!filePath) {\r\n throw new Error(`Agent definition not found: ${agentType}`);\r\n }\r\n\r\n // Read file content\r\n const content = await fs.readFile(filePath, 'utf-8');\r\n\r\n \r\n // Parse frontmatter and body\r\n const { frontmatter, body } = parseFrontmatter(content);\r\n\r\n // Extract category from path\r\n const relativePath = path.relative('.claude/agents', filePath);\r\n const category = relativePath.includes('/')\r\n ? relativePath.split('/')[0]\r\n : undefined;\r\n\r\n \r\n // Build agent definition\r\n const definition: AgentDefinition = {\r\n name: frontmatter.name || agentType,\r\n description: frontmatter.description || '',\r\n tools: Array.isArray(frontmatter.tools) ? frontmatter.tools : [],\r\n model: frontmatter.model || 'haiku',\r\n type: frontmatter.type,\r\n color: frontmatter.color,\r\n acl_level: frontmatter.acl_level ? parseInt(String(frontmatter.acl_level), 10) : undefined,\r\n capabilities: frontmatter.capabilities,\r\n validation_hooks: frontmatter.validation_hooks,\r\n lifecycle: frontmatter.lifecycle,\r\n content: body,\r\n filePath,\r\n category,\r\n };\r\n\r\n return definition;\r\n}\r\n\r\n/**\r\n * List all available agent definitions\r\n */\r\nexport async function listAgentDefinitions(baseDir: string = '.claude/agents'): Promise<string[]> {\r\n const pattern = `${baseDir}/**/*.md`;\r\n const files = await glob(pattern, { nodir: true });\r\n\r\n return files.map(f => path.basename(f, '.md'));\r\n}\r\n\r\n/**\r\n * Check if agent definition includes CFN Loop protocol\r\n */\r\nexport function hasCFNLoopProtocol(definition: AgentDefinition): boolean {\r\n const content = definition.content.toLowerCase();\r\n return (\r\n content.includes('cfn loop') &&\r\n content.includes('redis completion protocol') ||\r\n content.includes('invoke-waiting-mode.sh')\r\n );\r\n}\r\n"],"names":["fs","path","glob","parseFrontmatter","content","frontmatterRegex","match","frontmatter","body","yamlContent","lines","split","currentKey","currentArray","isInArray","isInObject","currentObject","objectKey","line","trimmed","trim","startsWith","push","substring","objKey","objValueParts","objValue","join","replace","colonIndex","indexOf","key","value","endsWith","arrayContent","length","items","map","item","cleanValue","existingValue","findAgentFile","agentType","baseDir","normalizedType","toLowerCase","patterns","pattern","files","nodir","absolute","exactMatch","find","f","basename","parseAgentDefinition","filePath","Error","readFile","relativePath","relative","category","includes","undefined","definition","name","description","tools","Array","isArray","model","type","color","acl_level","parseInt","String","capabilities","validation_hooks","lifecycle","listAgentDefinitions","hasCFNLoopProtocol"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/cli/agent-definition-parser.ts"],"sourcesContent":["/**\r\n * Agent Definition Parser\r\n *\r\n * Parses agent definition files (.md) with YAML frontmatter and markdown content.\r\n * Supports agent definitions in .claude/agents/ directory structure.\r\n */\r\n\r\nimport fs from 'fs/promises';\r\nimport path from 'path';\r\nimport { fileURLToPath } from 'url';\r\nimport { glob } from 'glob';\r\n\r\n// ES Module compatibility\r\nconst __filename = fileURLToPath(import.meta.url);\r\nconst __dirname = path.dirname(__filename);\r\n\r\nexport interface AgentDefinition {\r\n // YAML frontmatter fields\r\n name: string;\r\n description: string;\r\n tools: string[];\r\n model: 'haiku' | 'sonnet' | 'opus';\r\n type?: string;\r\n color?: string;\r\n acl_level?: number;\r\n capabilities?: string[];\r\n validation_hooks?: string[];\r\n lifecycle?: {\r\n pre_task?: string;\r\n post_task?: string;\r\n };\r\n\r\n // Parsed markdown content\r\n content: string;\r\n\r\n // File metadata\r\n filePath: string;\r\n category?: string; // e.g., 'core-agents', 'specialized', 'custom'\r\n}\r\n\r\n/**\r\n * Parse YAML frontmatter from markdown content\r\n * Supports both Unix (LF) and Windows (CRLF) line endings\r\n */\r\nfunction parseFrontmatter(content: string): { frontmatter: Record<string, any>; body: string } {\r\n const frontmatterRegex = /^---\\r?\\n([\\s\\S]*?)\\r?\\n---\\r?\\n([\\s\\S]*)$/;\r\n const match = content.match(frontmatterRegex);\r\n\r\n if (!match) {\r\n return { frontmatter: {}, body: content };\r\n }\r\n\r\n const [, yamlContent, body] = match;\r\n\r\n \r\n // Simple YAML parser (handles basic key-value pairs, arrays, and objects)\r\n const frontmatter: Record<string, any> = {};\r\n const lines = yamlContent.split('\\n');\r\n let currentKey = '';\r\n let currentArray: string[] = [];\r\n let isInArray = false;\r\n let isInObject = false;\r\n let currentObject: Record<string, string> = {};\r\n let objectKey = '';\r\n\r\n for (const line of lines) {\r\n const trimmed = line.trim();\r\n if (!trimmed || trimmed.startsWith('#')) continue;\r\n\r\n // Array item\r\n if (trimmed.startsWith('- ')) {\r\n if (!isInArray) {\r\n isInArray = true;\r\n currentArray = [];\r\n }\r\n currentArray.push(trimmed.substring(2).trim());\r\n continue;\r\n }\r\n\r\n // End of array\r\n if (isInArray && !trimmed.startsWith('- ')) {\r\n frontmatter[currentKey] = currentArray;\r\n isInArray = false;\r\n currentArray = [];\r\n }\r\n\r\n // Object field (indented key-value)\r\n if (trimmed.match(/^\\s+\\w+:/) && isInObject) {\r\n const [objKey, ...objValueParts] = trimmed.split(':');\r\n const objValue = objValueParts.join(':').trim().replace(/^[\"']|[\"']$/g, '');\r\n currentObject[objKey.trim()] = objValue;\r\n continue;\r\n }\r\n\r\n // Key-value pair\r\n const colonIndex = trimmed.indexOf(':');\r\n if (colonIndex !== -1) {\r\n const key = trimmed.substring(0, colonIndex).trim();\r\n const value = trimmed.substring(colonIndex + 1).trim();\r\n\r\n // Check if this starts an object\r\n if (value === '') {\r\n isInObject = true;\r\n currentObject = {};\r\n objectKey = key;\r\n continue;\r\n }\r\n\r\n // End previous object if any\r\n if (isInObject && !trimmed.match(/^\\s+/)) {\r\n frontmatter[objectKey] = currentObject;\r\n isInObject = false;\r\n currentObject = {};\r\n }\r\n\r\n currentKey = key;\r\n\r\n // Multi-line string (starts with |)\r\n if (value === '|') {\r\n continue; // Will be handled by next lines\r\n }\r\n\r\n // Inline array (e.g., [item1, item2, item3])\r\n if (value.startsWith('[') && value.endsWith(']')) {\r\n const arrayContent = value.substring(1, value.length - 1);\r\n const items = arrayContent.split(',').map(item => item.trim());\r\n frontmatter[key] = items;\r\n continue;\r\n }\r\n\r\n // Remove quotes\r\n const cleanValue = value.replace(/^[\"']|[\"']$/g, '');\r\n frontmatter[key] = cleanValue;\r\n } else if (currentKey && trimmed && !isInArray && !isInObject) {\r\n // Continuation of multi-line string\r\n const existingValue = frontmatter[currentKey];\r\n frontmatter[currentKey] = existingValue\r\n ? `${existingValue}\\n${trimmed}`\r\n : trimmed;\r\n }\r\n }\r\n\r\n // Handle trailing array or object\r\n if (isInArray) {\r\n frontmatter[currentKey] = currentArray;\r\n }\r\n if (isInObject) {\r\n frontmatter[objectKey] = currentObject;\r\n }\r\n\r\n return { frontmatter, body: body.trim() };\r\n}\r\n\r\n/**\r\n * Find agent definition file by agent type/name\r\n * Searches multiple locations for agent definitions\r\n */\r\nasync function findAgentFile(agentType: string, baseDir: string = '.claude/agents'): Promise<string | null> {\r\n // Normalize agent type (handle both kebab-case and underscores)\r\n const normalizedType = agentType.toLowerCase().replace(/_/g, '-');\r\n\r\n // Search locations (in order of priority)\r\n const searchLocations = [\r\n baseDir, // Current working directory\r\n '.claude/agents', // Standard location\r\n path.join(__dirname, '../../.claude/agents'), // CLI installation directory\r\n '/app/.claude/agents', // Docker container location\r\n ];\r\n\r\n // Search patterns (in order of priority)\r\n const searchPatterns = [\r\n // Exact match in any subdirectory\r\n (loc: string) => `${loc}/**/${normalizedType}.md`,\r\n // Match with different casing\r\n (loc: string) => `${loc}/**/*${normalizedType}*.md`,\r\n ];\r\n\r\n for (const location of searchLocations) {\r\n for (const patternFn of searchPatterns) {\r\n const pattern = patternFn(location);\r\n try {\r\n const files = await glob(pattern, { nodir: true, absolute: true });\r\n if (files.length > 0) {\r\n // Prefer exact match over partial match\r\n const exactMatch = files.find(f => {\r\n const basename = path.basename(f, '.md').toLowerCase();\r\n return basename === normalizedType;\r\n });\r\n return exactMatch || files[0];\r\n }\r\n } catch (error) {\r\n // Skip location if it doesn't exist\r\n continue;\r\n }\r\n }\r\n }\r\n\r\n return null;\r\n}\r\n\r\n/**\r\n * Parse agent definition from file\r\n */\r\nexport async function parseAgentDefinition(agentType: string): Promise<AgentDefinition> {\r\n // Find agent file\r\n const filePath = await findAgentFile(agentType);\r\n\r\n if (!filePath) {\r\n throw new Error(`Agent definition not found: ${agentType}`);\r\n }\r\n\r\n // Read file content\r\n const content = await fs.readFile(filePath, 'utf-8');\r\n\r\n \r\n // Parse frontmatter and body\r\n const { frontmatter, body } = parseFrontmatter(content);\r\n\r\n // Extract category from path\r\n const relativePath = path.relative('.claude/agents', filePath);\r\n const category = relativePath.includes('/')\r\n ? relativePath.split('/')[0]\r\n : undefined;\r\n\r\n \r\n // Build agent definition\r\n const definition: AgentDefinition = {\r\n name: frontmatter.name || agentType,\r\n description: frontmatter.description || '',\r\n tools: Array.isArray(frontmatter.tools) ? frontmatter.tools : [],\r\n model: frontmatter.model || 'haiku',\r\n type: frontmatter.type,\r\n color: frontmatter.color,\r\n acl_level: frontmatter.acl_level ? parseInt(String(frontmatter.acl_level), 10) : undefined,\r\n capabilities: frontmatter.capabilities,\r\n validation_hooks: frontmatter.validation_hooks,\r\n lifecycle: frontmatter.lifecycle,\r\n content: body,\r\n filePath,\r\n category,\r\n };\r\n\r\n return definition;\r\n}\r\n\r\n/**\r\n * List all available agent definitions\r\n */\r\nexport async function listAgentDefinitions(baseDir: string = '.claude/agents'): Promise<string[]> {\r\n const pattern = `${baseDir}/**/*.md`;\r\n const files = await glob(pattern, { nodir: true });\r\n\r\n return files.map(f => path.basename(f, '.md'));\r\n}\r\n\r\n/**\r\n * Check if agent definition includes CFN Loop protocol\r\n */\r\nexport function hasCFNLoopProtocol(definition: AgentDefinition): boolean {\r\n const content = definition.content.toLowerCase();\r\n return (\r\n content.includes('cfn loop') &&\r\n content.includes('redis completion protocol') ||\r\n content.includes('invoke-waiting-mode.sh')\r\n );\r\n}\r\n"],"names":["fs","path","fileURLToPath","glob","__filename","url","__dirname","dirname","parseFrontmatter","content","frontmatterRegex","match","frontmatter","body","yamlContent","lines","split","currentKey","currentArray","isInArray","isInObject","currentObject","objectKey","line","trimmed","trim","startsWith","push","substring","objKey","objValueParts","objValue","join","replace","colonIndex","indexOf","key","value","endsWith","arrayContent","length","items","map","item","cleanValue","existingValue","findAgentFile","agentType","baseDir","normalizedType","toLowerCase","searchLocations","searchPatterns","loc","location","patternFn","pattern","files","nodir","absolute","exactMatch","find","f","basename","error","parseAgentDefinition","filePath","Error","readFile","relativePath","relative","category","includes","undefined","definition","name","description","tools","Array","isArray","model","type","color","acl_level","parseInt","String","capabilities","validation_hooks","lifecycle","listAgentDefinitions","hasCFNLoopProtocol"],"mappings":"AAAA;;;;;CAKC,GAED,OAAOA,QAAQ,cAAc;AAC7B,OAAOC,UAAU,OAAO;AACxB,SAASC,aAAa,QAAQ,MAAM;AACpC,SAASC,IAAI,QAAQ,OAAO;AAE5B,0BAA0B;AAC1B,MAAMC,aAAaF,cAAc,YAAYG,GAAG;AAChD,MAAMC,YAAYL,KAAKM,OAAO,CAACH;AA0B/B;;;CAGC,GACD,SAASI,iBAAiBC,OAAe;IACvC,MAAMC,mBAAmB;IACzB,MAAMC,QAAQF,QAAQE,KAAK,CAACD;IAE5B,IAAI,CAACC,OAAO;QACV,OAAO;YAAEC,aAAa,CAAC;YAAGC,MAAMJ;QAAQ;IAC1C;IAEA,MAAM,GAAGK,aAAaD,KAAK,GAAGF;IAG9B,0EAA0E;IAC1E,MAAMC,cAAmC,CAAC;IAC1C,MAAMG,QAAQD,YAAYE,KAAK,CAAC;IAChC,IAAIC,aAAa;IACjB,IAAIC,eAAyB,EAAE;IAC/B,IAAIC,YAAY;IAChB,IAAIC,aAAa;IACjB,IAAIC,gBAAwC,CAAC;IAC7C,IAAIC,YAAY;IAEhB,KAAK,MAAMC,QAAQR,MAAO;QACxB,MAAMS,UAAUD,KAAKE,IAAI;QACzB,IAAI,CAACD,WAAWA,QAAQE,UAAU,CAAC,MAAM;QAEzC,aAAa;QACb,IAAIF,QAAQE,UAAU,CAAC,OAAO;YAC5B,IAAI,CAACP,WAAW;gBACdA,YAAY;gBACZD,eAAe,EAAE;YACnB;YACAA,aAAaS,IAAI,CAACH,QAAQI,SAAS,CAAC,GAAGH,IAAI;YAC3C;QACF;QAEA,eAAe;QACf,IAAIN,aAAa,CAACK,QAAQE,UAAU,CAAC,OAAO;YAC1Cd,WAAW,CAACK,WAAW,GAAGC;YAC1BC,YAAY;YACZD,eAAe,EAAE;QACnB;QAEA,oCAAoC;QACpC,IAAIM,QAAQb,KAAK,CAAC,eAAeS,YAAY;YAC3C,MAAM,CAACS,QAAQ,GAAGC,cAAc,GAAGN,QAAQR,KAAK,CAAC;YACjD,MAAMe,WAAWD,cAAcE,IAAI,CAAC,KAAKP,IAAI,GAAGQ,OAAO,CAAC,gBAAgB;YACxEZ,aAAa,CAACQ,OAAOJ,IAAI,GAAG,GAAGM;YAC/B;QACF;QAEA,iBAAiB;QACjB,MAAMG,aAAaV,QAAQW,OAAO,CAAC;QACnC,IAAID,eAAe,CAAC,GAAG;YACrB,MAAME,MAAMZ,QAAQI,SAAS,CAAC,GAAGM,YAAYT,IAAI;YACjD,MAAMY,QAAQb,QAAQI,SAAS,CAACM,aAAa,GAAGT,IAAI;YAEpD,iCAAiC;YACjC,IAAIY,UAAU,IAAI;gBAChBjB,aAAa;gBACbC,gBAAgB,CAAC;gBACjBC,YAAYc;gBACZ;YACF;YAEA,6BAA6B;YAC7B,IAAIhB,cAAc,CAACI,QAAQb,KAAK,CAAC,SAAS;gBACxCC,WAAW,CAACU,UAAU,GAAGD;gBACzBD,aAAa;gBACbC,gBAAgB,CAAC;YACnB;YAEAJ,aAAamB;YAEb,oCAAoC;YACpC,IAAIC,UAAU,KAAK;gBACjB,UAAU,gCAAgC;YAC5C;YAEA,6CAA6C;YAC7C,IAAIA,MAAMX,UAAU,CAAC,QAAQW,MAAMC,QAAQ,CAAC,MAAM;gBAChD,MAAMC,eAAeF,MAAMT,SAAS,CAAC,GAAGS,MAAMG,MAAM,GAAG;gBACvD,MAAMC,QAAQF,aAAavB,KAAK,CAAC,KAAK0B,GAAG,CAACC,CAAAA,OAAQA,KAAKlB,IAAI;gBAC3Db,WAAW,CAACwB,IAAI,GAAGK;gBACnB;YACF;YAEA,gBAAgB;YAChB,MAAMG,aAAaP,MAAMJ,OAAO,CAAC,gBAAgB;YACjDrB,WAAW,CAACwB,IAAI,GAAGQ;QACrB,OAAO,IAAI3B,cAAcO,WAAW,CAACL,aAAa,CAACC,YAAY;YAC7D,oCAAoC;YACpC,MAAMyB,gBAAgBjC,WAAW,CAACK,WAAW;YAC7CL,WAAW,CAACK,WAAW,GAAG4B,gBACtB,GAAGA,cAAc,EAAE,EAAErB,SAAS,GAC9BA;QACN;IACF;IAEA,kCAAkC;IAClC,IAAIL,WAAW;QACbP,WAAW,CAACK,WAAW,GAAGC;IAC5B;IACA,IAAIE,YAAY;QACdR,WAAW,CAACU,UAAU,GAAGD;IAC3B;IAEA,OAAO;QAAET;QAAaC,MAAMA,KAAKY,IAAI;IAAG;AAC1C;AAEA;;;CAGC,GACD,eAAeqB,cAAcC,SAAiB,EAAEC,UAAkB,gBAAgB;IAChF,gEAAgE;IAChE,MAAMC,iBAAiBF,UAAUG,WAAW,GAAGjB,OAAO,CAAC,MAAM;IAE7D,0CAA0C;IAC1C,MAAMkB,kBAAkB;QACtBH;QACA;QACA/C,KAAK+B,IAAI,CAAC1B,WAAW;QACrB;KACD;IAED,yCAAyC;IACzC,MAAM8C,iBAAiB;QACrB,kCAAkC;QAClC,CAACC,MAAgB,GAAGA,IAAI,IAAI,EAAEJ,eAAe,GAAG,CAAC;QACjD,8BAA8B;QAC9B,CAACI,MAAgB,GAAGA,IAAI,KAAK,EAAEJ,eAAe,IAAI,CAAC;KACpD;IAED,KAAK,MAAMK,YAAYH,gBAAiB;QACtC,KAAK,MAAMI,aAAaH,eAAgB;YACtC,MAAMI,UAAUD,UAAUD;YAC1B,IAAI;gBACF,MAAMG,QAAQ,MAAMtD,KAAKqD,SAAS;oBAAEE,OAAO;oBAAMC,UAAU;gBAAK;gBAChE,IAAIF,MAAMjB,MAAM,GAAG,GAAG;oBACpB,wCAAwC;oBACxC,MAAMoB,aAAaH,MAAMI,IAAI,CAACC,CAAAA;wBAC5B,MAAMC,WAAW9D,KAAK8D,QAAQ,CAACD,GAAG,OAAOZ,WAAW;wBACpD,OAAOa,aAAad;oBACtB;oBACA,OAAOW,cAAcH,KAAK,CAAC,EAAE;gBAC/B;YACF,EAAE,OAAOO,OAAO;gBAEd;YACF;QACF;IACF;IAEA,OAAO;AACT;AAEA;;CAEC,GACD,OAAO,eAAeC,qBAAqBlB,SAAiB;IAC1D,kBAAkB;IAClB,MAAMmB,WAAW,MAAMpB,cAAcC;IAErC,IAAI,CAACmB,UAAU;QACb,MAAM,IAAIC,MAAM,CAAC,4BAA4B,EAAEpB,WAAW;IAC5D;IAEA,oBAAoB;IACpB,MAAMtC,UAAU,MAAMT,GAAGoE,QAAQ,CAACF,UAAU;IAG5C,6BAA6B;IAC7B,MAAM,EAAEtD,WAAW,EAAEC,IAAI,EAAE,GAAGL,iBAAiBC;IAE/C,6BAA6B;IAC7B,MAAM4D,eAAepE,KAAKqE,QAAQ,CAAC,kBAAkBJ;IACrD,MAAMK,WAAWF,aAAaG,QAAQ,CAAC,OACnCH,aAAarD,KAAK,CAAC,IAAI,CAAC,EAAE,GAC1ByD;IAGJ,yBAAyB;IACzB,MAAMC,aAA8B;QAClCC,MAAM/D,YAAY+D,IAAI,IAAI5B;QAC1B6B,aAAahE,YAAYgE,WAAW,IAAI;QACxCC,OAAOC,MAAMC,OAAO,CAACnE,YAAYiE,KAAK,IAAIjE,YAAYiE,KAAK,GAAG,EAAE;QAChEG,OAAOpE,YAAYoE,KAAK,IAAI;QAC5BC,MAAMrE,YAAYqE,IAAI;QACtBC,OAAOtE,YAAYsE,KAAK;QACxBC,WAAWvE,YAAYuE,SAAS,GAAGC,SAASC,OAAOzE,YAAYuE,SAAS,GAAG,MAAMV;QACjFa,cAAc1E,YAAY0E,YAAY;QACtCC,kBAAkB3E,YAAY2E,gBAAgB;QAC9CC,WAAW5E,YAAY4E,SAAS;QAChC/E,SAASI;QACTqD;QACAK;IACF;IAEA,OAAOG;AACT;AAEA;;CAEC,GACD,OAAO,eAAee,qBAAqBzC,UAAkB,gBAAgB;IAC3E,MAAMQ,UAAU,GAAGR,QAAQ,QAAQ,CAAC;IACpC,MAAMS,QAAQ,MAAMtD,KAAKqD,SAAS;QAAEE,OAAO;IAAK;IAEhD,OAAOD,MAAMf,GAAG,CAACoB,CAAAA,IAAK7D,KAAK8D,QAAQ,CAACD,GAAG;AACzC;AAEA;;CAEC,GACD,OAAO,SAAS4B,mBAAmBhB,UAA2B;IAC5D,MAAMjE,UAAUiE,WAAWjE,OAAO,CAACyC,WAAW;IAC9C,OACEzC,QAAQ+D,QAAQ,CAAC,eACjB/D,QAAQ+D,QAAQ,CAAC,gCACjB/D,QAAQ+D,QAAQ,CAAC;AAErB"}
|
|
@@ -16,6 +16,9 @@ import fs from 'fs/promises';
|
|
|
16
16
|
import path from 'path';
|
|
17
17
|
import os from 'os';
|
|
18
18
|
const execAsync = promisify(exec);
|
|
19
|
+
// Bug #6 Fix: Read Redis connection parameters from process.env
|
|
20
|
+
const redisHost = process.env.CFN_REDIS_HOST || 'cfn-redis';
|
|
21
|
+
const redisPort = process.env.CFN_REDIS_PORT || '6379';
|
|
19
22
|
/**
|
|
20
23
|
* Extract confidence score from agent output
|
|
21
24
|
* Looks for patterns like:
|
|
@@ -57,7 +60,7 @@ const execAsync = promisify(exec);
|
|
|
57
60
|
try {
|
|
58
61
|
// Step 1: Signal completion
|
|
59
62
|
console.log('[CFN Protocol] Step 1: Signaling completion...');
|
|
60
|
-
await execAsync(`redis-cli lpush "swarm:${taskId}:${agentId}:done" "complete"`);
|
|
63
|
+
await execAsync(`redis-cli -h "${redisHost}" -p "${redisPort}" lpush "swarm:${taskId}:${agentId}:done" "complete"`);
|
|
61
64
|
console.log('[CFN Protocol] ✓ Completion signaled');
|
|
62
65
|
// Step 2: Extract and report confidence
|
|
63
66
|
const confidence = extractConfidence(output);
|
|
@@ -221,18 +224,50 @@ const execAsync = promisify(exec);
|
|
|
221
224
|
console.log(`[agent-executor] Prompt file: ${promptFile}`);
|
|
222
225
|
return new Promise((resolve)=>{
|
|
223
226
|
const scriptPath = path.join('.claude', 'skills', 'agent-execution', 'execute-agent.sh');
|
|
224
|
-
// Build environment variables
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
227
|
+
// Build environment variables - WHITELIST ONLY APPROACH
|
|
228
|
+
// SECURITY FIX: Do not use ...process.env spread which exposes ALL variables including secrets
|
|
229
|
+
// Instead, explicitly whitelist safe variables to pass to spawned process
|
|
230
|
+
const safeEnvVars = [
|
|
231
|
+
'CFN_REDIS_HOST',
|
|
232
|
+
'CFN_REDIS_PORT',
|
|
233
|
+
'CFN_REDIS_URL',
|
|
234
|
+
'CFN_MEMORY_BUDGET',
|
|
235
|
+
'CFN_API_HOST',
|
|
236
|
+
'CFN_API_PORT',
|
|
237
|
+
'CFN_LOG_LEVEL',
|
|
238
|
+
'CFN_LOG_FORMAT',
|
|
239
|
+
'CFN_CONTAINER_MODE',
|
|
240
|
+
'CFN_DOCKER_SOCKET',
|
|
241
|
+
'CFN_NETWORK_NAME',
|
|
242
|
+
'CFN_CUSTOM_ROUTING',
|
|
243
|
+
'CFN_DEFAULT_PROVIDER',
|
|
244
|
+
'NODE_ENV',
|
|
245
|
+
'PATH',
|
|
246
|
+
'HOME'
|
|
247
|
+
];
|
|
248
|
+
const env = {};
|
|
249
|
+
// Add whitelisted variables
|
|
250
|
+
for (const key of safeEnvVars){
|
|
251
|
+
const value = process.env[key];
|
|
252
|
+
if (value !== undefined) {
|
|
253
|
+
env[key] = value;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
// Add API key only when explicitly needed (with strict validation)
|
|
257
|
+
if (process.env.ANTHROPIC_API_KEY) {
|
|
258
|
+
if (process.env.ANTHROPIC_API_KEY.match(/^sk-[a-zA-Z0-9-]+$/)) {
|
|
259
|
+
env.ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// Add agent execution context (safe values)
|
|
263
|
+
env.AGENT_TYPE = definition.name;
|
|
264
|
+
env.AGENT_ID = agentId;
|
|
265
|
+
env.AGENT_MODEL = definition.model;
|
|
266
|
+
env.AGENT_TOOLS = definition.tools.join(',');
|
|
267
|
+
env.TASK_ID = context.taskId || '';
|
|
268
|
+
env.ITERATION = String(context.iteration || 1);
|
|
269
|
+
env.MODE = context.mode || 'cli';
|
|
270
|
+
env.PROMPT_FILE = promptFile;
|
|
236
271
|
// Check if execute script exists
|
|
237
272
|
fs.access(scriptPath).then(()=>{
|
|
238
273
|
// Use execution script
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/cli/agent-executor.ts"],"sourcesContent":["/**\r\n * Agent Executor\r\n *\r\n * Executes CLI-spawned agents by:\r\n * 1. Checking custom routing configuration (z.ai vs Anthropic)\r\n * 2. Invoking the appropriate API\r\n * 3. Managing agent lifecycle and output\r\n */\r\n\r\nimport { spawn } from 'child_process';\r\nimport { exec } from 'child_process';\r\nimport { promisify } from 'util';\r\nimport { AgentDefinition } from './agent-definition-parser.js';\r\nimport { TaskContext, getAgentId } from './agent-prompt-builder.js';\r\nimport { buildCLIAgentSystemPrompt, loadContextFromEnv } from './cli-agent-context.js';\r\nimport {\r\n loadMessages,\r\n storeMessage,\r\n getCurrentFork,\r\n formatMessagesForAPI,\r\n type Message\r\n} from './conversation-fork.js';\r\nimport { convertToolNames } from './tool-definitions.js';\r\nimport fs from 'fs/promises';\r\nimport path from 'path';\r\nimport os from 'os';\r\n\r\nconst execAsync = promisify(exec);\r\n\r\nexport interface AgentExecutionResult {\r\n success: boolean;\r\n agentId: string;\r\n output?: string;\r\n error?: string;\r\n exitCode: number;\r\n}\r\n\r\n/**\r\n * Extract confidence score from agent output\r\n * Looks for patterns like:\r\n * - \"confidence: 0.85\"\r\n * - \"Confidence: 0.90\"\r\n * - \"confidence score: 0.95\"\r\n * - \"self-confidence: 0.88\"\r\n */\r\nfunction extractConfidence(output: string | undefined): number {\r\n if (!output) return 0.85;\r\n\r\n // Try multiple patterns\r\n const patterns = [\r\n /confidence:\\s*([0-9.]+)/i,\r\n /confidence\\s+score:\\s*([0-9.]+)/i,\r\n /self-confidence:\\s*([0-9.]+)/i,\r\n /my\\s+confidence:\\s*([0-9.]+)/i,\r\n ];\r\n\r\n for (const pattern of patterns) {\r\n const match = output.match(pattern);\r\n if (match && match[1]) {\r\n const score = parseFloat(match[1]);\r\n if (score >= 0 && score <= 1) {\r\n return score;\r\n }\r\n }\r\n }\r\n\r\n // Default to 0.85 if not found\r\n return 0.85;\r\n}\r\n\r\n/**\r\n * Execute CFN Loop protocol after agent completes work\r\n *\r\n * Steps:\r\n * 1. Signal completion to orchestrator\r\n * 2. Report confidence score\r\n * 3. Enter waiting mode (if iterations enabled)\r\n */\r\nasync function executeCFNProtocol(\r\n taskId: string,\r\n agentId: string,\r\n output: string | undefined,\r\n iteration: number,\r\n enableIterations: boolean = false,\r\n maxIterations: number = 10\r\n): Promise<void> {\r\n console.log(`\\n[CFN Protocol] Starting for agent ${agentId}`);\r\n console.log(`[CFN Protocol] Task ID: ${taskId}, Iteration: ${iteration}`);\r\n\r\n try {\r\n // Step 1: Signal completion\r\n console.log('[CFN Protocol] Step 1: Signaling completion...');\r\n await execAsync(`redis-cli lpush \"swarm:${taskId}:${agentId}:done\" \"complete\"`);\r\n console.log('[CFN Protocol] ✓ Completion signaled');\r\n\r\n // Step 2: Extract and report confidence\r\n const confidence = extractConfidence(output);\r\n console.log(`[CFN Protocol] Step 2: Reporting confidence (${confidence})...`);\r\n\r\n const reportCmd = `./.claude/skills/cfn-redis-coordination/report-completion.sh \\\r\n --task-id \"${taskId}\" \\\r\n --agent-id \"${agentId}\" \\\r\n --confidence ${confidence} \\\r\n --iteration ${iteration}`;\r\n\r\n await execAsync(reportCmd);\r\n console.log('[CFN Protocol] ✓ Confidence reported');\r\n\r\n // Step 3: Exit cleanly (BUG #18 FIX - removed waiting mode)\r\n // Orchestrator will spawn appropriate specialist agent for next iteration\r\n // This enables adaptive agent specialization based on feedback type\r\n console.log('[CFN Protocol] Step 3: Exiting cleanly (iteration complete)');\r\n console.log('[CFN Protocol] Protocol complete\\n');\r\n } catch (error) {\r\n console.error('[CFN Protocol] Error:', error);\r\n throw error;\r\n }\r\n}\r\n\r\n/**\r\n * Check if custom routing (z.ai) is enabled\r\n */\r\nasync function isCustomRoutingEnabled(): Promise<boolean> {\r\n // Check environment variable\r\n if (process.env.CLAUDE_API_PROVIDER === 'zai') {\r\n return true;\r\n }\r\n\r\n // Check config file (.claude/config/api-provider.json)\r\n try {\r\n const configPath = path.join('.claude', 'config', 'api-provider.json');\r\n const config = JSON.parse(await fs.readFile(configPath, 'utf-8'));\r\n return config.provider === 'zai' || config.provider === 'z.ai';\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Get API provider configuration\r\n */\r\nasync function getAPIProvider(): Promise<'anthropic' | 'zai'> {\r\n const customEnabled = await isCustomRoutingEnabled();\r\n return customEnabled ? 'zai' : 'anthropic';\r\n}\r\n\r\n/**\r\n * Execute agent using direct API calls\r\n */\r\nasync function executeViaAPI(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext\r\n): Promise<AgentExecutionResult> {\r\n const agentId = getAgentId(definition, context);\r\n\r\n console.log(`[agent-executor] Executing agent via API: ${definition.name}`);\r\n console.log(`[agent-executor] Agent ID: ${agentId}`);\r\n console.log(`[agent-executor] Model: ${definition.model}`);\r\n console.log('');\r\n\r\n try {\r\n // Check for conversation fork (Sprint 4 enhancement)\r\n const forkId = process.env.FORK_ID || await getCurrentFork(context.taskId || '', agentId);\r\n const iteration = context.iteration || 1;\r\n\r\n let systemPrompt: string;\r\n let messages: Array<{role: string, content: string}> = [];\r\n\r\n if (forkId && iteration > 1) {\r\n // Continue from fork (iterations 2+)\r\n console.log(`[agent-executor] Continuing from fork: ${forkId}`);\r\n\r\n // Load fork messages\r\n const forkMessages = await loadMessages(context.taskId || '', agentId, forkId);\r\n console.log(`[agent-executor] Loaded ${forkMessages.length} messages from fork`);\r\n\r\n // Extract system prompt from first message (it's always the system message)\r\n // The fork messages are assistant/user pairs, we need to add system separately\r\n systemPrompt = forkMessages[0]?.content || '';\r\n\r\n // Format remaining messages for API\r\n messages = formatMessagesForAPI(forkMessages.slice(1));\r\n\r\n // Add new user message with feedback\r\n messages.push({\r\n role: 'user',\r\n content: prompt\r\n });\r\n\r\n console.log(`[agent-executor] Fork continuation: ${messages.length} messages`);\r\n } else {\r\n // New conversation (iteration 1)\r\n console.log('[agent-executor] Starting new conversation');\r\n console.log('[agent-executor] Building system prompt with context...');\r\n\r\n const contextOptions = loadContextFromEnv();\r\n contextOptions.agentType = definition.name;\r\n if (context.taskId) contextOptions.taskId = context.taskId;\r\n if (context.iteration) contextOptions.iteration = context.iteration;\r\n\r\n systemPrompt = await buildCLIAgentSystemPrompt(contextOptions);\r\n console.log('[agent-executor] System prompt built successfully');\r\n\r\n // Initial user message\r\n messages = [{\r\n role: 'user',\r\n content: prompt\r\n }];\r\n }\r\n\r\n console.log('');\r\n\r\n // Dynamic import to avoid bundling issues\r\n const { executeAgentAPI } = await import('./anthropic-client.js');\r\n\r\n // Convert agent tool names to Anthropic API format\r\n const tools = definition.tools && definition.tools.length > 0\r\n ? convertToolNames(definition.tools)\r\n : undefined;\r\n\r\n const result = await executeAgentAPI(\r\n definition.name,\r\n agentId,\r\n definition.model,\r\n prompt,\r\n systemPrompt,\r\n messages.length > 1 ? messages : undefined,\r\n undefined, // maxTokens (use default)\r\n tools // Pass converted tools\r\n );\r\n\r\n // Store messages in conversation history (for future forking)\r\n if (context.taskId) {\r\n // Store user message\r\n const userMessage: Message = {\r\n role: 'user',\r\n content: prompt,\r\n iteration,\r\n timestamp: new Date().toISOString()\r\n };\r\n await storeMessage(context.taskId, agentId, userMessage);\r\n\r\n // Store assistant response\r\n if (result.output) {\r\n const assistantMessage: Message = {\r\n role: 'assistant',\r\n content: result.output,\r\n iteration,\r\n timestamp: new Date().toISOString()\r\n };\r\n await storeMessage(context.taskId, agentId, assistantMessage);\r\n }\r\n\r\n console.log(`[agent-executor] Stored messages for iteration ${iteration}`);\r\n\r\n // Execute CFN Loop protocol (signal completion, report confidence, enter waiting mode)\r\n // Iterations are enabled for CFN Loop tasks (indicated by presence of taskId)\r\n try {\r\n const maxIterations = 10; // Default max iterations\r\n const enableIterations = true; // Enable iterations for all CFN Loop tasks\r\n\r\n await executeCFNProtocol(\r\n context.taskId,\r\n agentId,\r\n result.output,\r\n iteration,\r\n enableIterations,\r\n maxIterations\r\n );\r\n } catch (error) {\r\n console.error('[agent-executor] CFN Protocol execution failed:', error);\r\n // Don't fail the entire agent execution if CFN protocol fails\r\n // This allows agents to complete even if Redis coordination has issues\r\n }\r\n }\r\n\r\n return {\r\n success: result.success,\r\n agentId,\r\n output: result.output,\r\n error: result.error,\r\n exitCode: result.success ? 0 : 1,\r\n };\r\n } catch (error) {\r\n console.error('[agent-executor] API execution failed:', error);\r\n return {\r\n success: false,\r\n agentId,\r\n error: error instanceof Error ? error.message : String(error),\r\n exitCode: 1,\r\n };\r\n }\r\n}\r\n\r\n/**\r\n * Execute agent using shell script (fallback/simulation)\r\n */\r\nasync function executeViaScript(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext\r\n): Promise<AgentExecutionResult> {\r\n const agentId = getAgentId(definition, context);\r\n\r\n // Write prompt to temporary file\r\n const tmpDir = os.tmpdir();\r\n const promptFile = path.join(tmpDir, `agent-${agentId}-${Date.now()}.md`);\r\n await fs.writeFile(promptFile, prompt, 'utf-8');\r\n\r\n console.log(`[agent-executor] Executing agent via script: ${definition.name}`);\r\n console.log(`[agent-executor] Agent ID: ${agentId}`);\r\n console.log(`[agent-executor] Model: ${definition.model}`);\r\n console.log(`[agent-executor] Prompt file: ${promptFile}`);\r\n\r\n return new Promise((resolve) => {\r\n const scriptPath = path.join('.claude', 'skills', 'agent-execution', 'execute-agent.sh');\r\n\r\n // Build environment variables\r\n const env = {\r\n ...process.env,\r\n AGENT_TYPE: definition.name,\r\n AGENT_ID: agentId,\r\n AGENT_MODEL: definition.model,\r\n AGENT_TOOLS: definition.tools.join(','),\r\n TASK_ID: context.taskId || '',\r\n ITERATION: String(context.iteration || 1),\r\n MODE: context.mode || 'cli',\r\n PROMPT_FILE: promptFile,\r\n };\r\n\r\n // Check if execute script exists\r\n fs.access(scriptPath)\r\n .then(() => {\r\n // Use execution script\r\n const proc = spawn('bash', [scriptPath], { env, stdio: 'inherit' });\r\n\r\n proc.on('exit', (code) => {\r\n resolve({\r\n success: code === 0,\r\n agentId,\r\n exitCode: code || 0,\r\n });\r\n });\r\n\r\n proc.on('error', (err) => {\r\n resolve({\r\n success: false,\r\n agentId,\r\n error: err.message,\r\n exitCode: 1,\r\n });\r\n });\r\n })\r\n .catch(() => {\r\n // Fallback: Print prompt\r\n console.log('\\n=== Agent Prompt ===');\r\n console.log(prompt.substring(0, 500) + '...');\r\n console.log('\\n[agent-executor] Execution script not found');\r\n console.log('[agent-executor] Using simulation mode\\n');\r\n\r\n resolve({\r\n success: true,\r\n agentId,\r\n output: prompt,\r\n exitCode: 0,\r\n });\r\n });\r\n });\r\n}\r\n\r\n/**\r\n * Main agent execution function\r\n */\r\nexport async function executeAgent(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext,\r\n options: {\r\n method?: 'auto' | 'api' | 'script';\r\n } = {}\r\n): Promise<AgentExecutionResult> {\r\n const method = options.method || 'auto';\r\n\r\n // Auto-select execution method\r\n if (method === 'auto') {\r\n // Try API execution first, fallback to script if API key not available\r\n try {\r\n return await executeViaAPI(definition, prompt, context);\r\n } catch (error) {\r\n if (error instanceof Error && error.message.includes('API key not found')) {\r\n console.log('[agent-executor] API key not found, using script fallback');\r\n return executeViaScript(definition, prompt, context);\r\n }\r\n throw error;\r\n }\r\n }\r\n\r\n if (method === 'api') {\r\n return executeViaAPI(definition, prompt, context);\r\n }\r\n\r\n return executeViaScript(definition, prompt, context);\r\n}\r\n\r\n/**\r\n * Write agent output to file for debugging\r\n */\r\nexport async function saveAgentOutput(\r\n agentId: string,\r\n output: string,\r\n outputDir: string = '.claude/tmp/agent-output'\r\n): Promise<string> {\r\n await fs.mkdir(outputDir, { recursive: true });\r\n\r\n const timestamp = new Date().toISOString().replace(/[:.]/g, '-');\r\n const filename = `${agentId}-${timestamp}.txt`;\r\n const filepath = path.join(outputDir, filename);\r\n\r\n await fs.writeFile(filepath, output, 'utf-8');\r\n\r\n return filepath;\r\n}\r\n"],"names":["spawn","exec","promisify","getAgentId","buildCLIAgentSystemPrompt","loadContextFromEnv","loadMessages","storeMessage","getCurrentFork","formatMessagesForAPI","convertToolNames","fs","path","os","execAsync","extractConfidence","output","patterns","pattern","match","score","parseFloat","executeCFNProtocol","taskId","agentId","iteration","enableIterations","maxIterations","console","log","confidence","reportCmd","error","isCustomRoutingEnabled","process","env","CLAUDE_API_PROVIDER","configPath","join","config","JSON","parse","readFile","provider","getAPIProvider","customEnabled","executeViaAPI","definition","prompt","context","name","model","forkId","FORK_ID","systemPrompt","messages","forkMessages","length","content","slice","push","role","contextOptions","agentType","executeAgentAPI","tools","undefined","result","userMessage","timestamp","Date","toISOString","assistantMessage","success","exitCode","Error","message","String","executeViaScript","tmpDir","tmpdir","promptFile","now","writeFile","Promise","resolve","scriptPath","AGENT_TYPE","AGENT_ID","AGENT_MODEL","AGENT_TOOLS","TASK_ID","ITERATION","MODE","mode","PROMPT_FILE","access","then","proc","stdio","on","code","err","catch","substring","executeAgent","options","method","includes","saveAgentOutput","outputDir","mkdir","recursive","replace","filename","filepath"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/cli/agent-executor.ts"],"sourcesContent":["/**\r\n * Agent Executor\r\n *\r\n * Executes CLI-spawned agents by:\r\n * 1. Checking custom routing configuration (z.ai vs Anthropic)\r\n * 2. Invoking the appropriate API\r\n * 3. Managing agent lifecycle and output\r\n */\r\n\r\nimport { spawn } from 'child_process';\r\nimport { exec } from 'child_process';\r\nimport { promisify } from 'util';\r\nimport { AgentDefinition } from './agent-definition-parser.js';\r\nimport { TaskContext, getAgentId } from './agent-prompt-builder.js';\r\nimport { buildCLIAgentSystemPrompt, loadContextFromEnv } from './cli-agent-context.js';\r\nimport {\r\n loadMessages,\r\n storeMessage,\r\n getCurrentFork,\r\n formatMessagesForAPI,\r\n type Message\r\n} from './conversation-fork.js';\r\nimport { convertToolNames } from './tool-definitions.js';\r\nimport fs from 'fs/promises';\r\nimport path from 'path';\r\nimport os from 'os';\r\n\r\nconst execAsync = promisify(exec);\r\n\r\n// Bug #6 Fix: Read Redis connection parameters from process.env\r\nconst redisHost = process.env.CFN_REDIS_HOST || 'cfn-redis';\r\nconst redisPort = process.env.CFN_REDIS_PORT || '6379';\r\n\r\nexport interface AgentExecutionResult {\r\n success: boolean;\r\n agentId: string;\r\n output?: string;\r\n error?: string;\r\n exitCode: number;\r\n}\r\n\r\n/**\r\n * Extract confidence score from agent output\r\n * Looks for patterns like:\r\n * - \"confidence: 0.85\"\r\n * - \"Confidence: 0.90\"\r\n * - \"confidence score: 0.95\"\r\n * - \"self-confidence: 0.88\"\r\n */\r\nfunction extractConfidence(output: string | undefined): number {\r\n if (!output) return 0.85;\r\n\r\n // Try multiple patterns\r\n const patterns = [\r\n /confidence:\\s*([0-9.]+)/i,\r\n /confidence\\s+score:\\s*([0-9.]+)/i,\r\n /self-confidence:\\s*([0-9.]+)/i,\r\n /my\\s+confidence:\\s*([0-9.]+)/i,\r\n ];\r\n\r\n for (const pattern of patterns) {\r\n const match = output.match(pattern);\r\n if (match && match[1]) {\r\n const score = parseFloat(match[1]);\r\n if (score >= 0 && score <= 1) {\r\n return score;\r\n }\r\n }\r\n }\r\n\r\n // Default to 0.85 if not found\r\n return 0.85;\r\n}\r\n\r\n/**\r\n * Execute CFN Loop protocol after agent completes work\r\n *\r\n * Steps:\r\n * 1. Signal completion to orchestrator\r\n * 2. Report confidence score\r\n * 3. Enter waiting mode (if iterations enabled)\r\n */\r\nasync function executeCFNProtocol(\r\n taskId: string,\r\n agentId: string,\r\n output: string | undefined,\r\n iteration: number,\r\n enableIterations: boolean = false,\r\n maxIterations: number = 10\r\n): Promise<void> {\r\n console.log(`\\n[CFN Protocol] Starting for agent ${agentId}`);\r\n console.log(`[CFN Protocol] Task ID: ${taskId}, Iteration: ${iteration}`);\r\n\r\n try {\r\n // Step 1: Signal completion\r\n console.log('[CFN Protocol] Step 1: Signaling completion...');\r\n await execAsync(`redis-cli -h \"${redisHost}\" -p \"${redisPort}\" lpush \"swarm:${taskId}:${agentId}:done\" \"complete\"`);\r\n console.log('[CFN Protocol] ✓ Completion signaled');\r\n\r\n // Step 2: Extract and report confidence\r\n const confidence = extractConfidence(output);\r\n console.log(`[CFN Protocol] Step 2: Reporting confidence (${confidence})...`);\r\n\r\n const reportCmd = `./.claude/skills/cfn-redis-coordination/report-completion.sh \\\r\n --task-id \"${taskId}\" \\\r\n --agent-id \"${agentId}\" \\\r\n --confidence ${confidence} \\\r\n --iteration ${iteration}`;\r\n\r\n await execAsync(reportCmd);\r\n console.log('[CFN Protocol] ✓ Confidence reported');\r\n\r\n // Step 3: Exit cleanly (BUG #18 FIX - removed waiting mode)\r\n // Orchestrator will spawn appropriate specialist agent for next iteration\r\n // This enables adaptive agent specialization based on feedback type\r\n console.log('[CFN Protocol] Step 3: Exiting cleanly (iteration complete)');\r\n console.log('[CFN Protocol] Protocol complete\\n');\r\n } catch (error) {\r\n console.error('[CFN Protocol] Error:', error);\r\n throw error;\r\n }\r\n}\r\n\r\n/**\r\n * Check if custom routing (z.ai) is enabled\r\n */\r\nasync function isCustomRoutingEnabled(): Promise<boolean> {\r\n // Check environment variable\r\n if (process.env.CLAUDE_API_PROVIDER === 'zai') {\r\n return true;\r\n }\r\n\r\n // Check config file (.claude/config/api-provider.json)\r\n try {\r\n const configPath = path.join('.claude', 'config', 'api-provider.json');\r\n const config = JSON.parse(await fs.readFile(configPath, 'utf-8'));\r\n return config.provider === 'zai' || config.provider === 'z.ai';\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Get API provider configuration\r\n */\r\nasync function getAPIProvider(): Promise<'anthropic' | 'zai'> {\r\n const customEnabled = await isCustomRoutingEnabled();\r\n return customEnabled ? 'zai' : 'anthropic';\r\n}\r\n\r\n/**\r\n * Execute agent using direct API calls\r\n */\r\nasync function executeViaAPI(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext\r\n): Promise<AgentExecutionResult> {\r\n const agentId = getAgentId(definition, context);\r\n\r\n console.log(`[agent-executor] Executing agent via API: ${definition.name}`);\r\n console.log(`[agent-executor] Agent ID: ${agentId}`);\r\n console.log(`[agent-executor] Model: ${definition.model}`);\r\n console.log('');\r\n\r\n try {\r\n // Check for conversation fork (Sprint 4 enhancement)\r\n const forkId = process.env.FORK_ID || await getCurrentFork(context.taskId || '', agentId);\r\n const iteration = context.iteration || 1;\r\n\r\n let systemPrompt: string;\r\n let messages: Array<{role: string, content: string}> = [];\r\n\r\n if (forkId && iteration > 1) {\r\n // Continue from fork (iterations 2+)\r\n console.log(`[agent-executor] Continuing from fork: ${forkId}`);\r\n\r\n // Load fork messages\r\n const forkMessages = await loadMessages(context.taskId || '', agentId, forkId);\r\n console.log(`[agent-executor] Loaded ${forkMessages.length} messages from fork`);\r\n\r\n // Extract system prompt from first message (it's always the system message)\r\n // The fork messages are assistant/user pairs, we need to add system separately\r\n systemPrompt = forkMessages[0]?.content || '';\r\n\r\n // Format remaining messages for API\r\n messages = formatMessagesForAPI(forkMessages.slice(1));\r\n\r\n // Add new user message with feedback\r\n messages.push({\r\n role: 'user',\r\n content: prompt\r\n });\r\n\r\n console.log(`[agent-executor] Fork continuation: ${messages.length} messages`);\r\n } else {\r\n // New conversation (iteration 1)\r\n console.log('[agent-executor] Starting new conversation');\r\n console.log('[agent-executor] Building system prompt with context...');\r\n\r\n const contextOptions = loadContextFromEnv();\r\n contextOptions.agentType = definition.name;\r\n if (context.taskId) contextOptions.taskId = context.taskId;\r\n if (context.iteration) contextOptions.iteration = context.iteration;\r\n\r\n systemPrompt = await buildCLIAgentSystemPrompt(contextOptions);\r\n console.log('[agent-executor] System prompt built successfully');\r\n\r\n // Initial user message\r\n messages = [{\r\n role: 'user',\r\n content: prompt\r\n }];\r\n }\r\n\r\n console.log('');\r\n\r\n // Dynamic import to avoid bundling issues\r\n const { executeAgentAPI } = await import('./anthropic-client.js');\r\n\r\n // Convert agent tool names to Anthropic API format\r\n const tools = definition.tools && definition.tools.length > 0\r\n ? convertToolNames(definition.tools)\r\n : undefined;\r\n\r\n const result = await executeAgentAPI(\r\n definition.name,\r\n agentId,\r\n definition.model,\r\n prompt,\r\n systemPrompt,\r\n messages.length > 1 ? messages : undefined,\r\n undefined, // maxTokens (use default)\r\n tools // Pass converted tools\r\n );\r\n\r\n // Store messages in conversation history (for future forking)\r\n if (context.taskId) {\r\n // Store user message\r\n const userMessage: Message = {\r\n role: 'user',\r\n content: prompt,\r\n iteration,\r\n timestamp: new Date().toISOString()\r\n };\r\n await storeMessage(context.taskId, agentId, userMessage);\r\n\r\n // Store assistant response\r\n if (result.output) {\r\n const assistantMessage: Message = {\r\n role: 'assistant',\r\n content: result.output,\r\n iteration,\r\n timestamp: new Date().toISOString()\r\n };\r\n await storeMessage(context.taskId, agentId, assistantMessage);\r\n }\r\n\r\n console.log(`[agent-executor] Stored messages for iteration ${iteration}`);\r\n\r\n // Execute CFN Loop protocol (signal completion, report confidence, enter waiting mode)\r\n // Iterations are enabled for CFN Loop tasks (indicated by presence of taskId)\r\n try {\r\n const maxIterations = 10; // Default max iterations\r\n const enableIterations = true; // Enable iterations for all CFN Loop tasks\r\n\r\n await executeCFNProtocol(\r\n context.taskId,\r\n agentId,\r\n result.output,\r\n iteration,\r\n enableIterations,\r\n maxIterations\r\n );\r\n } catch (error) {\r\n console.error('[agent-executor] CFN Protocol execution failed:', error);\r\n // Don't fail the entire agent execution if CFN protocol fails\r\n // This allows agents to complete even if Redis coordination has issues\r\n }\r\n }\r\n\r\n return {\r\n success: result.success,\r\n agentId,\r\n output: result.output,\r\n error: result.error,\r\n exitCode: result.success ? 0 : 1,\r\n };\r\n } catch (error) {\r\n console.error('[agent-executor] API execution failed:', error);\r\n return {\r\n success: false,\r\n agentId,\r\n error: error instanceof Error ? error.message : String(error),\r\n exitCode: 1,\r\n };\r\n }\r\n}\r\n\r\n/**\r\n * Execute agent using shell script (fallback/simulation)\r\n */\r\nasync function executeViaScript(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext\r\n): Promise<AgentExecutionResult> {\r\n const agentId = getAgentId(definition, context);\r\n\r\n // Write prompt to temporary file\r\n const tmpDir = os.tmpdir();\r\n const promptFile = path.join(tmpDir, `agent-${agentId}-${Date.now()}.md`);\r\n await fs.writeFile(promptFile, prompt, 'utf-8');\r\n\r\n console.log(`[agent-executor] Executing agent via script: ${definition.name}`);\r\n console.log(`[agent-executor] Agent ID: ${agentId}`);\r\n console.log(`[agent-executor] Model: ${definition.model}`);\r\n console.log(`[agent-executor] Prompt file: ${promptFile}`);\r\n\r\n return new Promise((resolve) => {\r\n const scriptPath = path.join('.claude', 'skills', 'agent-execution', 'execute-agent.sh');\r\n\r\n // Build environment variables - WHITELIST ONLY APPROACH\r\n // SECURITY FIX: Do not use ...process.env spread which exposes ALL variables including secrets\r\n // Instead, explicitly whitelist safe variables to pass to spawned process\r\n const safeEnvVars = [\r\n 'CFN_REDIS_HOST',\r\n 'CFN_REDIS_PORT',\r\n 'CFN_REDIS_URL',\r\n 'CFN_MEMORY_BUDGET',\r\n 'CFN_API_HOST',\r\n 'CFN_API_PORT',\r\n 'CFN_LOG_LEVEL',\r\n 'CFN_LOG_FORMAT',\r\n 'CFN_CONTAINER_MODE',\r\n 'CFN_DOCKER_SOCKET',\r\n 'CFN_NETWORK_NAME',\r\n 'CFN_CUSTOM_ROUTING',\r\n 'CFN_DEFAULT_PROVIDER',\r\n 'NODE_ENV',\r\n 'PATH',\r\n 'HOME'\r\n ];\r\n\r\n const env: Record<string, string> = {};\r\n\r\n // Add whitelisted variables\r\n for (const key of safeEnvVars) {\r\n const value = process.env[key];\r\n if (value !== undefined) {\r\n env[key] = value;\r\n }\r\n }\r\n\r\n // Add API key only when explicitly needed (with strict validation)\r\n if (process.env.ANTHROPIC_API_KEY) {\r\n if (process.env.ANTHROPIC_API_KEY.match(/^sk-[a-zA-Z0-9-]+$/)) {\r\n env.ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY;\r\n }\r\n }\r\n\r\n // Add agent execution context (safe values)\r\n env.AGENT_TYPE = definition.name;\r\n env.AGENT_ID = agentId;\r\n env.AGENT_MODEL = definition.model;\r\n env.AGENT_TOOLS = definition.tools.join(',');\r\n env.TASK_ID = context.taskId || '';\r\n env.ITERATION = String(context.iteration || 1);\r\n env.MODE = context.mode || 'cli';\r\n env.PROMPT_FILE = promptFile;\r\n\r\n // Check if execute script exists\r\n fs.access(scriptPath)\r\n .then(() => {\r\n // Use execution script\r\n const proc = spawn('bash', [scriptPath], { env, stdio: 'inherit' });\r\n\r\n proc.on('exit', (code) => {\r\n resolve({\r\n success: code === 0,\r\n agentId,\r\n exitCode: code || 0,\r\n });\r\n });\r\n\r\n proc.on('error', (err) => {\r\n resolve({\r\n success: false,\r\n agentId,\r\n error: err.message,\r\n exitCode: 1,\r\n });\r\n });\r\n })\r\n .catch(() => {\r\n // Fallback: Print prompt\r\n console.log('\\n=== Agent Prompt ===');\r\n console.log(prompt.substring(0, 500) + '...');\r\n console.log('\\n[agent-executor] Execution script not found');\r\n console.log('[agent-executor] Using simulation mode\\n');\r\n\r\n resolve({\r\n success: true,\r\n agentId,\r\n output: prompt,\r\n exitCode: 0,\r\n });\r\n });\r\n });\r\n}\r\n\r\n/**\r\n * Main agent execution function\r\n */\r\nexport async function executeAgent(\r\n definition: AgentDefinition,\r\n prompt: string,\r\n context: TaskContext,\r\n options: {\r\n method?: 'auto' | 'api' | 'script';\r\n } = {}\r\n): Promise<AgentExecutionResult> {\r\n const method = options.method || 'auto';\r\n\r\n // Auto-select execution method\r\n if (method === 'auto') {\r\n // Try API execution first, fallback to script if API key not available\r\n try {\r\n return await executeViaAPI(definition, prompt, context);\r\n } catch (error) {\r\n if (error instanceof Error && error.message.includes('API key not found')) {\r\n console.log('[agent-executor] API key not found, using script fallback');\r\n return executeViaScript(definition, prompt, context);\r\n }\r\n throw error;\r\n }\r\n }\r\n\r\n if (method === 'api') {\r\n return executeViaAPI(definition, prompt, context);\r\n }\r\n\r\n return executeViaScript(definition, prompt, context);\r\n}\r\n\r\n/**\r\n * Write agent output to file for debugging\r\n */\r\nexport async function saveAgentOutput(\r\n agentId: string,\r\n output: string,\r\n outputDir: string = '.claude/tmp/agent-output'\r\n): Promise<string> {\r\n await fs.mkdir(outputDir, { recursive: true });\r\n\r\n const timestamp = new Date().toISOString().replace(/[:.]/g, '-');\r\n const filename = `${agentId}-${timestamp}.txt`;\r\n const filepath = path.join(outputDir, filename);\r\n\r\n await fs.writeFile(filepath, output, 'utf-8');\r\n\r\n return filepath;\r\n}\r\n"],"names":["spawn","exec","promisify","getAgentId","buildCLIAgentSystemPrompt","loadContextFromEnv","loadMessages","storeMessage","getCurrentFork","formatMessagesForAPI","convertToolNames","fs","path","os","execAsync","redisHost","process","env","CFN_REDIS_HOST","redisPort","CFN_REDIS_PORT","extractConfidence","output","patterns","pattern","match","score","parseFloat","executeCFNProtocol","taskId","agentId","iteration","enableIterations","maxIterations","console","log","confidence","reportCmd","error","isCustomRoutingEnabled","CLAUDE_API_PROVIDER","configPath","join","config","JSON","parse","readFile","provider","getAPIProvider","customEnabled","executeViaAPI","definition","prompt","context","name","model","forkId","FORK_ID","systemPrompt","messages","forkMessages","length","content","slice","push","role","contextOptions","agentType","executeAgentAPI","tools","undefined","result","userMessage","timestamp","Date","toISOString","assistantMessage","success","exitCode","Error","message","String","executeViaScript","tmpDir","tmpdir","promptFile","now","writeFile","Promise","resolve","scriptPath","safeEnvVars","key","value","ANTHROPIC_API_KEY","AGENT_TYPE","AGENT_ID","AGENT_MODEL","AGENT_TOOLS","TASK_ID","ITERATION","MODE","mode","PROMPT_FILE","access","then","proc","stdio","on","code","err","catch","substring","executeAgent","options","method","includes","saveAgentOutput","outputDir","mkdir","recursive","replace","filename","filepath"],"mappings":"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"}
|
|
@@ -176,14 +176,40 @@ The orchestrator will:
|
|
|
176
176
|
if (context.mode) env.push(`MODE=${context.mode}`);
|
|
177
177
|
if (context.priority) env.push(`PRIORITY=${context.priority}`);
|
|
178
178
|
if (context.parentTaskId) env.push(`PARENT_TASK_ID=${context.parentTaskId}`);
|
|
179
|
-
|
|
180
|
-
|
|
179
|
+
// Docker workspace detection
|
|
180
|
+
const isDockerEnv = process.env.DOCKER_AGENT === 'true' || process.env.WORKSPACE_ROOT;
|
|
181
|
+
const workspaceRoot = process.env.WORKSPACE_ROOT || '/workspace';
|
|
182
|
+
if (isDockerEnv) {
|
|
183
|
+
env.push(`WORKSPACE_ROOT=${workspaceRoot}`);
|
|
184
|
+
}
|
|
185
|
+
// Always include Docker context if detected, even if env array is empty
|
|
186
|
+
if (isDockerEnv && env.length === 0) {
|
|
187
|
+
env.push(`WORKSPACE_ROOT=${workspaceRoot}`);
|
|
188
|
+
}
|
|
189
|
+
if (env.length === 0 && !isDockerEnv) return '';
|
|
190
|
+
let contextText = `
|
|
181
191
|
## Environment Variables
|
|
182
192
|
|
|
183
193
|
\`\`\`bash
|
|
184
194
|
${env.join('\n')}
|
|
185
195
|
\`\`\`
|
|
186
196
|
`;
|
|
197
|
+
// Add Docker workspace notice if detected
|
|
198
|
+
if (isDockerEnv) {
|
|
199
|
+
contextText += `
|
|
200
|
+
|
|
201
|
+
## Docker Container Environment
|
|
202
|
+
|
|
203
|
+
**CRITICAL:** You are running inside a Docker container.
|
|
204
|
+
|
|
205
|
+
- **Working Directory:** \`${workspaceRoot}\`
|
|
206
|
+
- **File Paths:** All file operations use \`${workspaceRoot}/\` prefix
|
|
207
|
+
- **Example:** To read \`src/file.ts\`, use \`${workspaceRoot}/src/file.ts\`
|
|
208
|
+
|
|
209
|
+
**DO NOT** use paths from your training data or Main Chat context. Use \`${workspaceRoot}/\` for all file operations.
|
|
210
|
+
`;
|
|
211
|
+
}
|
|
212
|
+
return contextText;
|
|
187
213
|
}
|
|
188
214
|
/**
|
|
189
215
|
* Build complete prompt for agent execution (async for iteration history)
|