@planu/cli 0.30.0 → 0.31.0
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/dist/config/ide-registry.json +204 -0
- package/dist/config/injection-patterns.json +30 -0
- package/dist/config/known-cves.json +41 -0
- package/dist/config/license-plans.json +32 -2
- package/dist/config/llm-providers.json +198 -0
- package/dist/config/model-equivalences.json +41 -0
- package/dist/config/model-language-affinity.json +16 -0
- package/dist/config/orchestration-templates.json +76 -0
- package/dist/config/orchestration-topologies.json +36 -0
- package/dist/config/plugin-marketplace.json +59 -0
- package/dist/config/security-runtime-config.json +26 -0
- package/dist/config/workers-registry.json +100 -0
- package/dist/engine/deleter/audit-logger.d.ts +11 -0
- package/dist/engine/deleter/audit-logger.d.ts.map +1 -0
- package/dist/engine/deleter/audit-logger.js +30 -0
- package/dist/engine/deleter/audit-logger.js.map +1 -0
- package/dist/engine/deleter/core.d.ts +39 -0
- package/dist/engine/deleter/core.d.ts.map +1 -0
- package/dist/engine/deleter/core.js +267 -0
- package/dist/engine/deleter/core.js.map +1 -0
- package/dist/engine/deleter/trash-manager.d.ts +18 -0
- package/dist/engine/deleter/trash-manager.d.ts.map +1 -0
- package/dist/engine/deleter/trash-manager.js +92 -0
- package/dist/engine/deleter/trash-manager.js.map +1 -0
- package/dist/engine/github/adapters/bitbucket-adapter.d.ts +12 -0
- package/dist/engine/github/adapters/bitbucket-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/bitbucket-adapter.js +32 -0
- package/dist/engine/github/adapters/bitbucket-adapter.js.map +1 -0
- package/dist/engine/github/adapters/github-adapter.d.ts +20 -0
- package/dist/engine/github/adapters/github-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/github-adapter.js +221 -0
- package/dist/engine/github/adapters/github-adapter.js.map +1 -0
- package/dist/engine/github/adapters/gitlab-adapter.d.ts +12 -0
- package/dist/engine/github/adapters/gitlab-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/gitlab-adapter.js +32 -0
- package/dist/engine/github/adapters/gitlab-adapter.js.map +1 -0
- package/dist/engine/github/adapters/index.d.ts +4 -0
- package/dist/engine/github/adapters/index.d.ts.map +1 -0
- package/dist/engine/github/adapters/index.js +5 -0
- package/dist/engine/github/adapters/index.js.map +1 -0
- package/dist/engine/github/auth.d.ts +13 -0
- package/dist/engine/github/auth.d.ts.map +1 -0
- package/dist/engine/github/auth.js +59 -0
- package/dist/engine/github/auth.js.map +1 -0
- package/dist/engine/github/changelog.d.ts +26 -0
- package/dist/engine/github/changelog.d.ts.map +1 -0
- package/dist/engine/github/changelog.js +117 -0
- package/dist/engine/github/changelog.js.map +1 -0
- package/dist/engine/github/ci-status.d.ts +13 -0
- package/dist/engine/github/ci-status.d.ts.map +1 -0
- package/dist/engine/github/ci-status.js +32 -0
- package/dist/engine/github/ci-status.js.map +1 -0
- package/dist/engine/github/client.d.ts +18 -0
- package/dist/engine/github/client.d.ts.map +1 -0
- package/dist/engine/github/client.js +55 -0
- package/dist/engine/github/client.js.map +1 -0
- package/dist/engine/github/gh-cli.d.ts +22 -0
- package/dist/engine/github/gh-cli.d.ts.map +1 -0
- package/dist/engine/github/gh-cli.js +53 -0
- package/dist/engine/github/gh-cli.js.map +1 -0
- package/dist/engine/github/index.d.ts +9 -0
- package/dist/engine/github/index.d.ts.map +1 -0
- package/dist/engine/github/index.js +10 -0
- package/dist/engine/github/index.js.map +1 -0
- package/dist/engine/github/pr-template.d.ts +17 -0
- package/dist/engine/github/pr-template.d.ts.map +1 -0
- package/dist/engine/github/pr-template.js +79 -0
- package/dist/engine/github/pr-template.js.map +1 -0
- package/dist/engine/github/review-analyzer.d.ts +19 -0
- package/dist/engine/github/review-analyzer.d.ts.map +1 -0
- package/dist/engine/github/review-analyzer.js +146 -0
- package/dist/engine/github/review-analyzer.js.map +1 -0
- package/dist/engine/github/spec-linker.d.ts +18 -0
- package/dist/engine/github/spec-linker.d.ts.map +1 -0
- package/dist/engine/github/spec-linker.js +54 -0
- package/dist/engine/github/spec-linker.js.map +1 -0
- package/dist/engine/ide-config/core.d.ts +14 -0
- package/dist/engine/ide-config/core.d.ts.map +1 -0
- package/dist/engine/ide-config/core.js +103 -0
- package/dist/engine/ide-config/core.js.map +1 -0
- package/dist/engine/ide-config/detector.d.ts +18 -0
- package/dist/engine/ide-config/detector.d.ts.map +1 -0
- package/dist/engine/ide-config/detector.js +97 -0
- package/dist/engine/ide-config/detector.js.map +1 -0
- package/dist/engine/ide-config/generators.d.ts +6 -0
- package/dist/engine/ide-config/generators.d.ts.map +1 -0
- package/dist/engine/ide-config/generators.js +146 -0
- package/dist/engine/ide-config/generators.js.map +1 -0
- package/dist/engine/ide-config/index.d.ts +6 -0
- package/dist/engine/ide-config/index.d.ts.map +1 -0
- package/dist/engine/ide-config/index.js +7 -0
- package/dist/engine/ide-config/index.js.map +1 -0
- package/dist/engine/ide-config/path-resolver.d.ts +23 -0
- package/dist/engine/ide-config/path-resolver.d.ts.map +1 -0
- package/dist/engine/ide-config/path-resolver.js +55 -0
- package/dist/engine/ide-config/path-resolver.js.map +1 -0
- package/dist/engine/ide-config/validator.d.ts +7 -0
- package/dist/engine/ide-config/validator.d.ts.map +1 -0
- package/dist/engine/ide-config/validator.js +55 -0
- package/dist/engine/ide-config/validator.js.map +1 -0
- package/dist/engine/license-validator/lemon-squeezy.d.ts.map +1 -1
- package/dist/engine/license-validator/lemon-squeezy.js +16 -12
- package/dist/engine/license-validator/lemon-squeezy.js.map +1 -1
- package/dist/engine/llm-providers/cost-optimizer.d.ts +26 -0
- package/dist/engine/llm-providers/cost-optimizer.d.ts.map +1 -0
- package/dist/engine/llm-providers/cost-optimizer.js +101 -0
- package/dist/engine/llm-providers/cost-optimizer.js.map +1 -0
- package/dist/engine/llm-providers/cost-tracker.d.ts +26 -0
- package/dist/engine/llm-providers/cost-tracker.d.ts.map +1 -0
- package/dist/engine/llm-providers/cost-tracker.js +75 -0
- package/dist/engine/llm-providers/cost-tracker.js.map +1 -0
- package/dist/engine/llm-providers/failover-chain.d.ts +23 -0
- package/dist/engine/llm-providers/failover-chain.d.ts.map +1 -0
- package/dist/engine/llm-providers/failover-chain.js +88 -0
- package/dist/engine/llm-providers/failover-chain.js.map +1 -0
- package/dist/engine/llm-providers/health-checker.d.ts +18 -0
- package/dist/engine/llm-providers/health-checker.d.ts.map +1 -0
- package/dist/engine/llm-providers/health-checker.js +45 -0
- package/dist/engine/llm-providers/health-checker.js.map +1 -0
- package/dist/engine/llm-providers/index.d.ts +10 -0
- package/dist/engine/llm-providers/index.d.ts.map +1 -0
- package/dist/engine/llm-providers/index.js +11 -0
- package/dist/engine/llm-providers/index.js.map +1 -0
- package/dist/engine/llm-providers/key-manager.d.ts +23 -0
- package/dist/engine/llm-providers/key-manager.d.ts.map +1 -0
- package/dist/engine/llm-providers/key-manager.js +47 -0
- package/dist/engine/llm-providers/key-manager.js.map +1 -0
- package/dist/engine/llm-providers/load-balancer.d.ts +13 -0
- package/dist/engine/llm-providers/load-balancer.d.ts.map +1 -0
- package/dist/engine/llm-providers/load-balancer.js +94 -0
- package/dist/engine/llm-providers/load-balancer.js.map +1 -0
- package/dist/engine/llm-providers/provider-adapter.d.ts +25 -0
- package/dist/engine/llm-providers/provider-adapter.d.ts.map +1 -0
- package/dist/engine/llm-providers/provider-adapter.js +86 -0
- package/dist/engine/llm-providers/provider-adapter.js.map +1 -0
- package/dist/engine/llm-providers/rate-limiter.d.ts +29 -0
- package/dist/engine/llm-providers/rate-limiter.d.ts.map +1 -0
- package/dist/engine/llm-providers/rate-limiter.js +70 -0
- package/dist/engine/llm-providers/rate-limiter.js.map +1 -0
- package/dist/engine/orchestrator/agent-spawner.d.ts +22 -0
- package/dist/engine/orchestrator/agent-spawner.d.ts.map +1 -0
- package/dist/engine/orchestrator/agent-spawner.js +117 -0
- package/dist/engine/orchestrator/agent-spawner.js.map +1 -0
- package/dist/engine/orchestrator/conflict-resolver.d.ts +11 -0
- package/dist/engine/orchestrator/conflict-resolver.d.ts.map +1 -0
- package/dist/engine/orchestrator/conflict-resolver.js +81 -0
- package/dist/engine/orchestrator/conflict-resolver.js.map +1 -0
- package/dist/engine/orchestrator/file-ownership.d.ts +25 -0
- package/dist/engine/orchestrator/file-ownership.d.ts.map +1 -0
- package/dist/engine/orchestrator/file-ownership.js +62 -0
- package/dist/engine/orchestrator/file-ownership.js.map +1 -0
- package/dist/engine/orchestrator/handoff-generator.d.ts +20 -0
- package/dist/engine/orchestrator/handoff-generator.d.ts.map +1 -0
- package/dist/engine/orchestrator/handoff-generator.js +95 -0
- package/dist/engine/orchestrator/handoff-generator.js.map +1 -0
- package/dist/engine/orchestrator/index.d.ts +10 -0
- package/dist/engine/orchestrator/index.d.ts.map +1 -0
- package/dist/engine/orchestrator/index.js +11 -0
- package/dist/engine/orchestrator/index.js.map +1 -0
- package/dist/engine/orchestrator/progress-tracker.d.ts +32 -0
- package/dist/engine/orchestrator/progress-tracker.d.ts.map +1 -0
- package/dist/engine/orchestrator/progress-tracker.js +102 -0
- package/dist/engine/orchestrator/progress-tracker.js.map +1 -0
- package/dist/engine/orchestrator/result-collector.d.ts +23 -0
- package/dist/engine/orchestrator/result-collector.d.ts.map +1 -0
- package/dist/engine/orchestrator/result-collector.js +124 -0
- package/dist/engine/orchestrator/result-collector.js.map +1 -0
- package/dist/engine/orchestrator/runtime.d.ts +21 -0
- package/dist/engine/orchestrator/runtime.d.ts.map +1 -0
- package/dist/engine/orchestrator/runtime.js +231 -0
- package/dist/engine/orchestrator/runtime.js.map +1 -0
- package/dist/engine/orchestrator/task-distributor.d.ts +8 -0
- package/dist/engine/orchestrator/task-distributor.d.ts.map +1 -0
- package/dist/engine/orchestrator/task-distributor.js +106 -0
- package/dist/engine/orchestrator/task-distributor.js.map +1 -0
- package/dist/engine/orchestrator/topologies.d.ts +30 -0
- package/dist/engine/orchestrator/topologies.d.ts.map +1 -0
- package/dist/engine/orchestrator/topologies.js +89 -0
- package/dist/engine/orchestrator/topologies.js.map +1 -0
- package/dist/engine/plugins/compatibility.d.ts +24 -0
- package/dist/engine/plugins/compatibility.d.ts.map +1 -0
- package/dist/engine/plugins/compatibility.js +140 -0
- package/dist/engine/plugins/compatibility.js.map +1 -0
- package/dist/engine/plugins/doc-generator.d.ts +6 -0
- package/dist/engine/plugins/doc-generator.d.ts.map +1 -0
- package/dist/engine/plugins/doc-generator.js +79 -0
- package/dist/engine/plugins/doc-generator.js.map +1 -0
- package/dist/engine/plugins/extensions/analyzer-extension.d.ts +26 -0
- package/dist/engine/plugins/extensions/analyzer-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/analyzer-extension.js +100 -0
- package/dist/engine/plugins/extensions/analyzer-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/template-extension.d.ts +25 -0
- package/dist/engine/plugins/extensions/template-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/template-extension.js +65 -0
- package/dist/engine/plugins/extensions/template-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/tool-extension.d.ts +34 -0
- package/dist/engine/plugins/extensions/tool-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/tool-extension.js +80 -0
- package/dist/engine/plugins/extensions/tool-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/worker-extension.d.ts +24 -0
- package/dist/engine/plugins/extensions/worker-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/worker-extension.js +88 -0
- package/dist/engine/plugins/extensions/worker-extension.js.map +1 -0
- package/dist/engine/plugins/index.d.ts +11 -0
- package/dist/engine/plugins/index.d.ts.map +1 -0
- package/dist/engine/plugins/index.js +12 -0
- package/dist/engine/plugins/index.js.map +1 -0
- package/dist/engine/plugins/lifecycle.d.ts +26 -0
- package/dist/engine/plugins/lifecycle.d.ts.map +1 -0
- package/dist/engine/plugins/lifecycle.js +208 -0
- package/dist/engine/plugins/lifecycle.js.map +1 -0
- package/dist/engine/plugins/loader.d.ts +17 -0
- package/dist/engine/plugins/loader.d.ts.map +1 -0
- package/dist/engine/plugins/loader.js +113 -0
- package/dist/engine/plugins/loader.js.map +1 -0
- package/dist/engine/plugins/sandbox.d.ts +20 -0
- package/dist/engine/plugins/sandbox.d.ts.map +1 -0
- package/dist/engine/plugins/sandbox.js +111 -0
- package/dist/engine/plugins/sandbox.js.map +1 -0
- package/dist/engine/plugins/validator.d.ts +18 -0
- package/dist/engine/plugins/validator.d.ts.map +1 -0
- package/dist/engine/plugins/validator.js +125 -0
- package/dist/engine/plugins/validator.js.map +1 -0
- package/dist/engine/runtime-security/audit-logger.d.ts +7 -0
- package/dist/engine/runtime-security/audit-logger.d.ts.map +1 -0
- package/dist/engine/runtime-security/audit-logger.js +120 -0
- package/dist/engine/runtime-security/audit-logger.js.map +1 -0
- package/dist/engine/runtime-security/checkers/command-injection.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/command-injection.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/command-injection.js +91 -0
- package/dist/engine/runtime-security/checkers/command-injection.js.map +1 -0
- package/dist/engine/runtime-security/checkers/content-security.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/content-security.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/content-security.js +106 -0
- package/dist/engine/runtime-security/checkers/content-security.js.map +1 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts +4 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.js +93 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.js.map +1 -0
- package/dist/engine/runtime-security/checkers/file-permissions.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/file-permissions.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/file-permissions.js +60 -0
- package/dist/engine/runtime-security/checkers/file-permissions.js.map +1 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts +4 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.js +101 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.js.map +1 -0
- package/dist/engine/runtime-security/checkers/path-traversal.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/path-traversal.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/path-traversal.js +102 -0
- package/dist/engine/runtime-security/checkers/path-traversal.js.map +1 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.d.ts +7 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.js +103 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.js.map +1 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.js +71 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.js.map +1 -0
- package/dist/engine/runtime-security/index.d.ts +12 -0
- package/dist/engine/runtime-security/index.d.ts.map +1 -0
- package/dist/engine/runtime-security/index.js +13 -0
- package/dist/engine/runtime-security/index.js.map +1 -0
- package/dist/engine/runtime-security/rate-limiter.d.ts +5 -0
- package/dist/engine/runtime-security/rate-limiter.d.ts.map +1 -0
- package/dist/engine/runtime-security/rate-limiter.js +91 -0
- package/dist/engine/runtime-security/rate-limiter.js.map +1 -0
- package/dist/engine/runtime-security/validator.d.ts +9 -0
- package/dist/engine/runtime-security/validator.d.ts.map +1 -0
- package/dist/engine/runtime-security/validator.js +118 -0
- package/dist/engine/runtime-security/validator.js.map +1 -0
- package/dist/engine/session/auto-save.d.ts +18 -0
- package/dist/engine/session/auto-save.d.ts.map +1 -0
- package/dist/engine/session/auto-save.js +96 -0
- package/dist/engine/session/auto-save.js.map +1 -0
- package/dist/engine/session/context-snapshot.d.ts +8 -0
- package/dist/engine/session/context-snapshot.d.ts.map +1 -0
- package/dist/engine/session/context-snapshot.js +49 -0
- package/dist/engine/session/context-snapshot.js.map +1 -0
- package/dist/engine/session/index.d.ts +6 -0
- package/dist/engine/session/index.d.ts.map +1 -0
- package/dist/engine/session/index.js +7 -0
- package/dist/engine/session/index.js.map +1 -0
- package/dist/engine/session/memory-sync.d.ts +12 -0
- package/dist/engine/session/memory-sync.d.ts.map +1 -0
- package/dist/engine/session/memory-sync.js +34 -0
- package/dist/engine/session/memory-sync.js.map +1 -0
- package/dist/engine/session/session-diff.d.ts +11 -0
- package/dist/engine/session/session-diff.d.ts.map +1 -0
- package/dist/engine/session/session-diff.js +42 -0
- package/dist/engine/session/session-diff.js.map +1 -0
- package/dist/engine/session/session-merge.d.ts +12 -0
- package/dist/engine/session/session-merge.d.ts.map +1 -0
- package/dist/engine/session/session-merge.js +55 -0
- package/dist/engine/session/session-merge.js.map +1 -0
- package/dist/engine/token-optimizer/batcher.d.ts +34 -0
- package/dist/engine/token-optimizer/batcher.d.ts.map +1 -0
- package/dist/engine/token-optimizer/batcher.js +89 -0
- package/dist/engine/token-optimizer/batcher.js.map +1 -0
- package/dist/engine/token-optimizer/budget.d.ts +54 -0
- package/dist/engine/token-optimizer/budget.d.ts.map +1 -0
- package/dist/engine/token-optimizer/budget.js +102 -0
- package/dist/engine/token-optimizer/budget.js.map +1 -0
- package/dist/engine/token-optimizer/context-compressor.d.ts +16 -0
- package/dist/engine/token-optimizer/context-compressor.d.ts.map +1 -0
- package/dist/engine/token-optimizer/context-compressor.js +148 -0
- package/dist/engine/token-optimizer/context-compressor.js.map +1 -0
- package/dist/engine/token-optimizer/counter.d.ts +16 -0
- package/dist/engine/token-optimizer/counter.d.ts.map +1 -0
- package/dist/engine/token-optimizer/counter.js +68 -0
- package/dist/engine/token-optimizer/counter.js.map +1 -0
- package/dist/engine/token-optimizer/deduplicator.d.ts +32 -0
- package/dist/engine/token-optimizer/deduplicator.d.ts.map +1 -0
- package/dist/engine/token-optimizer/deduplicator.js +102 -0
- package/dist/engine/token-optimizer/deduplicator.js.map +1 -0
- package/dist/engine/token-optimizer/incremental.d.ts +30 -0
- package/dist/engine/token-optimizer/incremental.d.ts.map +1 -0
- package/dist/engine/token-optimizer/incremental.js +88 -0
- package/dist/engine/token-optimizer/incremental.js.map +1 -0
- package/dist/engine/token-optimizer/index.d.ts +10 -0
- package/dist/engine/token-optimizer/index.d.ts.map +1 -0
- package/dist/engine/token-optimizer/index.js +11 -0
- package/dist/engine/token-optimizer/index.js.map +1 -0
- package/dist/engine/token-optimizer/optimizer.d.ts +47 -0
- package/dist/engine/token-optimizer/optimizer.d.ts.map +1 -0
- package/dist/engine/token-optimizer/optimizer.js +126 -0
- package/dist/engine/token-optimizer/optimizer.js.map +1 -0
- package/dist/engine/token-optimizer/reporter.d.ts +51 -0
- package/dist/engine/token-optimizer/reporter.d.ts.map +1 -0
- package/dist/engine/token-optimizer/reporter.js +143 -0
- package/dist/engine/token-optimizer/reporter.js.map +1 -0
- package/dist/engine/token-optimizer/response-cache.d.ts +49 -0
- package/dist/engine/token-optimizer/response-cache.d.ts.map +1 -0
- package/dist/engine/token-optimizer/response-cache.js +158 -0
- package/dist/engine/token-optimizer/response-cache.js.map +1 -0
- package/dist/engine/workers/handlers/code-map.d.ts +3 -0
- package/dist/engine/workers/handlers/code-map.d.ts.map +1 -0
- package/dist/engine/workers/handlers/code-map.js +227 -0
- package/dist/engine/workers/handlers/code-map.js.map +1 -0
- package/dist/engine/workers/handlers/dependency-health.d.ts +3 -0
- package/dist/engine/workers/handlers/dependency-health.d.ts.map +1 -0
- package/dist/engine/workers/handlers/dependency-health.js +254 -0
- package/dist/engine/workers/handlers/dependency-health.js.map +1 -0
- package/dist/engine/workers/handlers/documentation.d.ts +3 -0
- package/dist/engine/workers/handlers/documentation.d.ts.map +1 -0
- package/dist/engine/workers/handlers/documentation.js +207 -0
- package/dist/engine/workers/handlers/documentation.js.map +1 -0
- package/dist/engine/workers/handlers/optimization.d.ts +3 -0
- package/dist/engine/workers/handlers/optimization.d.ts.map +1 -0
- package/dist/engine/workers/handlers/optimization.js +161 -0
- package/dist/engine/workers/handlers/optimization.js.map +1 -0
- package/dist/engine/workers/handlers/security-audit.d.ts +3 -0
- package/dist/engine/workers/handlers/security-audit.d.ts.map +1 -0
- package/dist/engine/workers/handlers/security-audit.js +222 -0
- package/dist/engine/workers/handlers/security-audit.js.map +1 -0
- package/dist/engine/workers/handlers/test-gaps.d.ts +3 -0
- package/dist/engine/workers/handlers/test-gaps.d.ts.map +1 -0
- package/dist/engine/workers/handlers/test-gaps.js +186 -0
- package/dist/engine/workers/handlers/test-gaps.js.map +1 -0
- package/dist/engine/workers/index.d.ts +8 -0
- package/dist/engine/workers/index.d.ts.map +1 -0
- package/dist/engine/workers/index.js +9 -0
- package/dist/engine/workers/index.js.map +1 -0
- package/dist/engine/workers/worker-engine.d.ts +24 -0
- package/dist/engine/workers/worker-engine.d.ts.map +1 -0
- package/dist/engine/workers/worker-engine.js +233 -0
- package/dist/engine/workers/worker-engine.js.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -1
- package/dist/resources/process.js +1 -1
- package/dist/storage/index.d.ts +1 -0
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/storage/index.js +1 -0
- package/dist/storage/index.js.map +1 -1
- package/dist/storage/session-store.d.ts +20 -0
- package/dist/storage/session-store.d.ts.map +1 -0
- package/dist/storage/session-store.js +118 -0
- package/dist/storage/session-store.js.map +1 -0
- package/dist/storage/token-cache-store.d.ts +10 -0
- package/dist/storage/token-cache-store.d.ts.map +1 -0
- package/dist/storage/token-cache-store.js +67 -0
- package/dist/storage/token-cache-store.js.map +1 -0
- package/dist/storage/trash-store.d.ts +35 -0
- package/dist/storage/trash-store.d.ts.map +1 -0
- package/dist/storage/trash-store.js +163 -0
- package/dist/storage/trash-store.js.map +1 -0
- package/dist/storage/worker-store.d.ts +11 -0
- package/dist/storage/worker-store.d.ts.map +1 -0
- package/dist/storage/worker-store.js +120 -0
- package/dist/storage/worker-store.js.map +1 -0
- package/dist/tools/agent-swarm-status.d.ts +7 -0
- package/dist/tools/agent-swarm-status.d.ts.map +1 -0
- package/dist/tools/agent-swarm-status.js +94 -0
- package/dist/tools/agent-swarm-status.js.map +1 -0
- package/dist/tools/configure-llm-providers-handler.d.ts +18 -0
- package/dist/tools/configure-llm-providers-handler.d.ts.map +1 -0
- package/dist/tools/configure-llm-providers-handler.js +127 -0
- package/dist/tools/configure-llm-providers-handler.js.map +1 -0
- package/dist/tools/configure-workers-handler.d.ts +3 -0
- package/dist/tools/configure-workers-handler.d.ts.map +1 -0
- package/dist/tools/configure-workers-handler.js +116 -0
- package/dist/tools/configure-workers-handler.js.map +1 -0
- package/dist/tools/delete-decision.d.ts +7 -0
- package/dist/tools/delete-decision.d.ts.map +1 -0
- package/dist/tools/delete-decision.js +54 -0
- package/dist/tools/delete-decision.js.map +1 -0
- package/dist/tools/delete-pattern.d.ts +7 -0
- package/dist/tools/delete-pattern.d.ts.map +1 -0
- package/dist/tools/delete-pattern.js +54 -0
- package/dist/tools/delete-pattern.js.map +1 -0
- package/dist/tools/delete-project.d.ts +7 -0
- package/dist/tools/delete-project.d.ts.map +1 -0
- package/dist/tools/delete-project.js +53 -0
- package/dist/tools/delete-project.js.map +1 -0
- package/dist/tools/delete-spec.d.ts +7 -0
- package/dist/tools/delete-spec.d.ts.map +1 -0
- package/dist/tools/delete-spec.js +54 -0
- package/dist/tools/delete-spec.js.map +1 -0
- package/dist/tools/export-session.d.ts +3 -0
- package/dist/tools/export-session.d.ts.map +1 -0
- package/dist/tools/export-session.js +87 -0
- package/dist/tools/export-session.js.map +1 -0
- package/dist/tools/github-pr-handler.d.ts +13 -0
- package/dist/tools/github-pr-handler.d.ts.map +1 -0
- package/dist/tools/github-pr-handler.js +109 -0
- package/dist/tools/github-pr-handler.js.map +1 -0
- package/dist/tools/github-release-handler.d.ts +14 -0
- package/dist/tools/github-release-handler.d.ts.map +1 -0
- package/dist/tools/github-release-handler.js +55 -0
- package/dist/tools/github-release-handler.js.map +1 -0
- package/dist/tools/github-review-handler.d.ts +7 -0
- package/dist/tools/github-review-handler.d.ts.map +1 -0
- package/dist/tools/github-review-handler.js +61 -0
- package/dist/tools/github-review-handler.js.map +1 -0
- package/dist/tools/ide-config-handler.d.ts +11 -0
- package/dist/tools/ide-config-handler.d.ts.map +1 -0
- package/dist/tools/ide-config-handler.js +56 -0
- package/dist/tools/ide-config-handler.js.map +1 -0
- package/dist/tools/license-status.d.ts.map +1 -1
- package/dist/tools/license-status.js +17 -2
- package/dist/tools/license-status.js.map +1 -1
- package/dist/tools/list-sessions.d.ts +3 -0
- package/dist/tools/list-sessions.d.ts.map +1 -0
- package/dist/tools/list-sessions.js +28 -0
- package/dist/tools/list-sessions.js.map +1 -0
- package/dist/tools/llm-provider-status-handler.d.ts +7 -0
- package/dist/tools/llm-provider-status-handler.d.ts.map +1 -0
- package/dist/tools/llm-provider-status-handler.js +63 -0
- package/dist/tools/llm-provider-status-handler.js.map +1 -0
- package/dist/tools/manage-plugins-handler.d.ts +6 -0
- package/dist/tools/manage-plugins-handler.d.ts.map +1 -0
- package/dist/tools/manage-plugins-handler.js +128 -0
- package/dist/tools/manage-plugins-handler.js.map +1 -0
- package/dist/tools/manage-trash.d.ts +7 -0
- package/dist/tools/manage-trash.d.ts.map +1 -0
- package/dist/tools/manage-trash.js +54 -0
- package/dist/tools/manage-trash.js.map +1 -0
- package/dist/tools/orchestrate-runtime.d.ts +7 -0
- package/dist/tools/orchestrate-runtime.d.ts.map +1 -0
- package/dist/tools/orchestrate-runtime.js +72 -0
- package/dist/tools/orchestrate-runtime.js.map +1 -0
- package/dist/tools/register-delete-tools.d.ts +6 -0
- package/dist/tools/register-delete-tools.d.ts.map +1 -0
- package/dist/tools/register-delete-tools.js +95 -0
- package/dist/tools/register-delete-tools.js.map +1 -0
- package/dist/tools/register-github-tools.d.ts +3 -0
- package/dist/tools/register-github-tools.d.ts.map +1 -0
- package/dist/tools/register-github-tools.js +47 -0
- package/dist/tools/register-github-tools.js.map +1 -0
- package/dist/tools/register-ide-tools.d.ts +3 -0
- package/dist/tools/register-ide-tools.d.ts.map +1 -0
- package/dist/tools/register-ide-tools.js +28 -0
- package/dist/tools/register-ide-tools.js.map +1 -0
- package/dist/tools/register-llm-provider-tools.d.ts +3 -0
- package/dist/tools/register-llm-provider-tools.d.ts.map +1 -0
- package/dist/tools/register-llm-provider-tools.js +73 -0
- package/dist/tools/register-llm-provider-tools.js.map +1 -0
- package/dist/tools/register-orchestrator-tools.d.ts +3 -0
- package/dist/tools/register-orchestrator-tools.d.ts.map +1 -0
- package/dist/tools/register-orchestrator-tools.js +68 -0
- package/dist/tools/register-orchestrator-tools.js.map +1 -0
- package/dist/tools/register-plugin-tools.d.ts +3 -0
- package/dist/tools/register-plugin-tools.d.ts.map +1 -0
- package/dist/tools/register-plugin-tools.js +27 -0
- package/dist/tools/register-plugin-tools.js.map +1 -0
- package/dist/tools/register-runtime-security-tools.d.ts +3 -0
- package/dist/tools/register-runtime-security-tools.d.ts.map +1 -0
- package/dist/tools/register-runtime-security-tools.js +19 -0
- package/dist/tools/register-runtime-security-tools.js.map +1 -0
- package/dist/tools/register-session-tools.d.ts +3 -0
- package/dist/tools/register-session-tools.d.ts.map +1 -0
- package/dist/tools/register-session-tools.js +34 -0
- package/dist/tools/register-session-tools.js.map +1 -0
- package/dist/tools/register-token-tools.d.ts +3 -0
- package/dist/tools/register-token-tools.d.ts.map +1 -0
- package/dist/tools/register-token-tools.js +17 -0
- package/dist/tools/register-token-tools.js.map +1 -0
- package/dist/tools/register-worker-tools.d.ts +3 -0
- package/dist/tools/register-worker-tools.d.ts.map +1 -0
- package/dist/tools/register-worker-tools.js +31 -0
- package/dist/tools/register-worker-tools.js.map +1 -0
- package/dist/tools/restore-session.d.ts +3 -0
- package/dist/tools/restore-session.d.ts.map +1 -0
- package/dist/tools/restore-session.js +60 -0
- package/dist/tools/restore-session.js.map +1 -0
- package/dist/tools/scaffold-plugin-handler.d.ts +6 -0
- package/dist/tools/scaffold-plugin-handler.d.ts.map +1 -0
- package/dist/tools/scaffold-plugin-handler.js +208 -0
- package/dist/tools/scaffold-plugin-handler.js.map +1 -0
- package/dist/tools/schemas/delete.d.ts +19 -0
- package/dist/tools/schemas/delete.d.ts.map +1 -0
- package/dist/tools/schemas/delete.js +12 -0
- package/dist/tools/schemas/delete.js.map +1 -0
- package/dist/tools/schemas/github.d.ts +51 -0
- package/dist/tools/schemas/github.d.ts.map +1 -0
- package/dist/tools/schemas/github.js +52 -0
- package/dist/tools/schemas/github.js.map +1 -0
- package/dist/tools/schemas/ide-config.d.ts +36 -0
- package/dist/tools/schemas/ide-config.d.ts.map +1 -0
- package/dist/tools/schemas/ide-config.js +27 -0
- package/dist/tools/schemas/ide-config.js.map +1 -0
- package/dist/tools/schemas/index.d.ts +9 -0
- package/dist/tools/schemas/index.d.ts.map +1 -1
- package/dist/tools/schemas/index.js +9 -0
- package/dist/tools/schemas/index.js.map +1 -1
- package/dist/tools/schemas/llm-provider-schemas.d.ts +26 -0
- package/dist/tools/schemas/llm-provider-schemas.d.ts.map +1 -0
- package/dist/tools/schemas/llm-provider-schemas.js +16 -0
- package/dist/tools/schemas/llm-provider-schemas.js.map +1 -0
- package/dist/tools/schemas/plugins-schemas.d.ts +40 -0
- package/dist/tools/schemas/plugins-schemas.d.ts.map +1 -0
- package/dist/tools/schemas/plugins-schemas.js +29 -0
- package/dist/tools/schemas/plugins-schemas.js.map +1 -0
- package/dist/tools/schemas/runtime-security.d.ts +12 -0
- package/dist/tools/schemas/runtime-security.d.ts.map +1 -0
- package/dist/tools/schemas/runtime-security.js +9 -0
- package/dist/tools/schemas/runtime-security.js.map +1 -0
- package/dist/tools/schemas/session.d.ts +22 -0
- package/dist/tools/schemas/session.d.ts.map +1 -0
- package/dist/tools/schemas/session.js +25 -0
- package/dist/tools/schemas/session.js.map +1 -0
- package/dist/tools/schemas/token-optimization.d.ts +12 -0
- package/dist/tools/schemas/token-optimization.d.ts.map +1 -0
- package/dist/tools/schemas/token-optimization.js +9 -0
- package/dist/tools/schemas/token-optimization.js.map +1 -0
- package/dist/tools/schemas/workers-schema.d.ts +75 -0
- package/dist/tools/schemas/workers-schema.d.ts.map +1 -0
- package/dist/tools/schemas/workers-schema.js +63 -0
- package/dist/tools/schemas/workers-schema.js.map +1 -0
- package/dist/tools/security-report-handler.d.ts +3 -0
- package/dist/tools/security-report-handler.d.ts.map +1 -0
- package/dist/tools/security-report-handler.js +66 -0
- package/dist/tools/security-report-handler.js.map +1 -0
- package/dist/tools/token-usage-handler.d.ts +15 -0
- package/dist/tools/token-usage-handler.d.ts.map +1 -0
- package/dist/tools/token-usage-handler.js +53 -0
- package/dist/tools/token-usage-handler.js.map +1 -0
- package/dist/tools/worker-status-handler.d.ts +3 -0
- package/dist/tools/worker-status-handler.d.ts.map +1 -0
- package/dist/tools/worker-status-handler.js +93 -0
- package/dist/tools/worker-status-handler.js.map +1 -0
- package/dist/types/delete.d.ts +68 -0
- package/dist/types/delete.d.ts.map +1 -0
- package/dist/types/delete.js +3 -0
- package/dist/types/delete.js.map +1 -0
- package/dist/types/github.d.ts +156 -0
- package/dist/types/github.d.ts.map +1 -0
- package/dist/types/github.js +11 -0
- package/dist/types/github.js.map +1 -0
- package/dist/types/ide.d.ts +70 -0
- package/dist/types/ide.d.ts.map +1 -0
- package/dist/types/ide.js +3 -0
- package/dist/types/ide.js.map +1 -0
- package/dist/types/index.d.ts +10 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +10 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/llm-providers.d.ts +140 -0
- package/dist/types/llm-providers.d.ts.map +1 -0
- package/dist/types/llm-providers.js +3 -0
- package/dist/types/llm-providers.js.map +1 -0
- package/dist/types/orchestration-runtime.d.ts +198 -0
- package/dist/types/orchestration-runtime.d.ts.map +1 -0
- package/dist/types/orchestration-runtime.js +4 -0
- package/dist/types/orchestration-runtime.js.map +1 -0
- package/dist/types/plugins.d.ts +144 -0
- package/dist/types/plugins.d.ts.map +1 -0
- package/dist/types/plugins.js +3 -0
- package/dist/types/plugins.js.map +1 -0
- package/dist/types/runtime-security.d.ts +110 -0
- package/dist/types/runtime-security.d.ts.map +1 -0
- package/dist/types/runtime-security.js +4 -0
- package/dist/types/runtime-security.js.map +1 -0
- package/dist/types/session.d.ts +82 -0
- package/dist/types/session.d.ts.map +1 -0
- package/dist/types/session.js +3 -0
- package/dist/types/session.js.map +1 -0
- package/dist/types/token-optimization.d.ts +121 -0
- package/dist/types/token-optimization.d.ts.map +1 -0
- package/dist/types/token-optimization.js +3 -0
- package/dist/types/token-optimization.js.map +1 -0
- package/dist/types/workers.d.ts +132 -0
- package/dist/types/workers.d.ts.map +1 -0
- package/dist/types/workers.js +3 -0
- package/dist/types/workers.js.map +1 -0
- package/package.json +1 -1
- package/src/config/ide-registry.json +204 -0
- package/src/config/injection-patterns.json +30 -0
- package/src/config/known-cves.json +41 -0
- package/src/config/license-plans.json +32 -2
- package/src/config/llm-providers.json +198 -0
- package/src/config/model-equivalences.json +41 -0
- package/src/config/model-language-affinity.json +16 -0
- package/src/config/orchestration-templates.json +76 -0
- package/src/config/orchestration-topologies.json +36 -0
- package/src/config/plugin-marketplace.json +59 -0
- package/src/config/security-runtime-config.json +26 -0
- package/src/config/workers-registry.json +100 -0
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
// orchestrator/agent-spawner.ts — Agent process spawning (SPEC-079 AC-03)
|
|
2
|
+
// Launches agents as CLI subprocesses with configurable commands.
|
|
3
|
+
/**
|
|
4
|
+
* Build a spawn descriptor for an agent based on spawn method.
|
|
5
|
+
* Language-agnostic: command is fully configurable per agent.
|
|
6
|
+
*/
|
|
7
|
+
export function buildSpawnDescriptor(agent, context, spawnMethod, timeoutMs) {
|
|
8
|
+
const baseArgs = [...agent.args];
|
|
9
|
+
if (spawnMethod === 'cli-subprocess') {
|
|
10
|
+
// For CLI subprocess, append the context as a prompt argument
|
|
11
|
+
if (agent.command.includes('claude')) {
|
|
12
|
+
baseArgs.push('-p', context);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
baseArgs.push('--context', context);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return {
|
|
19
|
+
command: agent.command,
|
|
20
|
+
args: baseArgs,
|
|
21
|
+
env: {
|
|
22
|
+
ORCHESTRATION_AGENT_ID: agent.id,
|
|
23
|
+
ORCHESTRATION_MODEL_TIER: agent.modelTier ?? 'sonnet',
|
|
24
|
+
},
|
|
25
|
+
cwd: agent.workDir ?? process.cwd(),
|
|
26
|
+
timeoutMs,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Create an initial AgentProcess record in pending state.
|
|
31
|
+
*/
|
|
32
|
+
export function createAgentProcess(agentId) {
|
|
33
|
+
return {
|
|
34
|
+
agentId,
|
|
35
|
+
pid: 0,
|
|
36
|
+
status: 'pending',
|
|
37
|
+
startedAt: new Date().toISOString(),
|
|
38
|
+
stdout: '',
|
|
39
|
+
stderr: '',
|
|
40
|
+
retryCount: 0,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Spawn an agent as a child process (real execution).
|
|
45
|
+
* Returns a new RuntimeAgentProcess with the result.
|
|
46
|
+
* In tests, this function should be mocked.
|
|
47
|
+
*/
|
|
48
|
+
export async function spawnAgent(descriptor, initial, onProgress) {
|
|
49
|
+
// Dynamic import to allow mocking in tests
|
|
50
|
+
const { spawn } = await import('node:child_process');
|
|
51
|
+
return new Promise((resolve) => {
|
|
52
|
+
const result = { ...initial, status: 'spawning' };
|
|
53
|
+
onProgress?.(result.agentId, 'spawning');
|
|
54
|
+
const child = spawn(descriptor.command, descriptor.args, {
|
|
55
|
+
cwd: descriptor.cwd,
|
|
56
|
+
env: { ...process.env, ...descriptor.env },
|
|
57
|
+
stdio: ['pipe', 'pipe', 'pipe'],
|
|
58
|
+
});
|
|
59
|
+
result.pid = child.pid ?? 0;
|
|
60
|
+
result.status = 'running';
|
|
61
|
+
onProgress?.(result.agentId, 'running');
|
|
62
|
+
let stdout = '';
|
|
63
|
+
let stderr = '';
|
|
64
|
+
child.stdout.on('data', (data) => {
|
|
65
|
+
stdout += data.toString();
|
|
66
|
+
});
|
|
67
|
+
child.stderr.on('data', (data) => {
|
|
68
|
+
stderr += data.toString();
|
|
69
|
+
});
|
|
70
|
+
const timer = setTimeout(() => {
|
|
71
|
+
child.kill('SIGTERM');
|
|
72
|
+
result.status = 'failed';
|
|
73
|
+
result.stderr = `${stderr}\n[TIMEOUT]`;
|
|
74
|
+
result.stdout = stdout;
|
|
75
|
+
result.completedAt = new Date().toISOString();
|
|
76
|
+
onProgress?.(result.agentId, 'failed');
|
|
77
|
+
resolve(result);
|
|
78
|
+
}, descriptor.timeoutMs);
|
|
79
|
+
child.on('close', (code) => {
|
|
80
|
+
clearTimeout(timer);
|
|
81
|
+
result.stdout = stdout;
|
|
82
|
+
result.stderr = stderr;
|
|
83
|
+
result.exitCode = code ?? 1;
|
|
84
|
+
result.status = code === 0 ? 'completed' : 'failed';
|
|
85
|
+
result.completedAt = new Date().toISOString();
|
|
86
|
+
onProgress?.(result.agentId, result.status);
|
|
87
|
+
resolve(result);
|
|
88
|
+
});
|
|
89
|
+
child.on('error', (err) => {
|
|
90
|
+
clearTimeout(timer);
|
|
91
|
+
result.status = 'failed';
|
|
92
|
+
result.stderr = `${stderr}\n[SPAWN ERROR] ${err.message}`;
|
|
93
|
+
result.stdout = stdout;
|
|
94
|
+
result.completedAt = new Date().toISOString();
|
|
95
|
+
onProgress?.(result.agentId, 'failed');
|
|
96
|
+
resolve(result);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Parse token usage from agent stdout.
|
|
102
|
+
* Looks for patterns like "Tokens used: 1234" or JSON with token counts.
|
|
103
|
+
*/
|
|
104
|
+
export function parseTokenUsage(stdout) {
|
|
105
|
+
// Try structured JSON pattern
|
|
106
|
+
const jsonMatch = /\{[^}]*"tokens"\s*:\s*(\d+)[^}]*\}/u.exec(stdout);
|
|
107
|
+
if (jsonMatch?.[1]) {
|
|
108
|
+
return parseInt(jsonMatch[1], 10);
|
|
109
|
+
}
|
|
110
|
+
// Try plain text pattern
|
|
111
|
+
const textMatch = /tokens?\s*(?:used|consumed|count)\s*[:=]\s*(\d+)/iu.exec(stdout);
|
|
112
|
+
if (textMatch?.[1]) {
|
|
113
|
+
return parseInt(textMatch[1], 10);
|
|
114
|
+
}
|
|
115
|
+
return 0;
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=agent-spawner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-spawner.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/agent-spawner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { RuntimeConflictStrategy, RuntimeConflictRecord } from '../../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Resolve a file conflict between multiple agents using the configured strategy.
|
|
4
|
+
*/
|
|
5
|
+
export declare function resolveConflict(file: string, agents: string[], strategy: RuntimeConflictStrategy): RuntimeConflictRecord;
|
|
6
|
+
/**
|
|
7
|
+
* Get the winning agent for a conflict given the strategy.
|
|
8
|
+
* Returns undefined for unresolved conflicts.
|
|
9
|
+
*/
|
|
10
|
+
export declare function getConflictWinner(record: RuntimeConflictRecord): string | undefined;
|
|
11
|
+
//# sourceMappingURL=conflict-resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conflict-resolver.d.ts","sourceRoot":"","sources":["../../../src/engine/orchestrator/conflict-resolver.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAE3F;;GAEG;AACH,wBAAgB,eAAe,CAC7B,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,EAAE,EAChB,QAAQ,EAAE,uBAAuB,GAChC,qBAAqB,CAgCvB;AA8BD;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,qBAAqB,GAAG,MAAM,GAAG,SAAS,CAenF"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// orchestrator/conflict-resolver.ts — File conflict resolution (SPEC-079 AC-06)
|
|
2
|
+
// Strategies: last-wins, first-wins, merge-auto, flag-for-review.
|
|
3
|
+
/**
|
|
4
|
+
* Resolve a file conflict between multiple agents using the configured strategy.
|
|
5
|
+
*/
|
|
6
|
+
export function resolveConflict(file, agents, strategy) {
|
|
7
|
+
switch (strategy) {
|
|
8
|
+
case 'last-wins':
|
|
9
|
+
return {
|
|
10
|
+
file,
|
|
11
|
+
agents,
|
|
12
|
+
strategy,
|
|
13
|
+
resolved: true,
|
|
14
|
+
resolution: `Agent ${agents[agents.length - 1] ?? 'unknown'} wins (last writer)`,
|
|
15
|
+
};
|
|
16
|
+
case 'first-wins':
|
|
17
|
+
return {
|
|
18
|
+
file,
|
|
19
|
+
agents,
|
|
20
|
+
strategy,
|
|
21
|
+
resolved: true,
|
|
22
|
+
resolution: `Agent ${agents[0] ?? 'unknown'} wins (first writer)`,
|
|
23
|
+
};
|
|
24
|
+
case 'merge-auto':
|
|
25
|
+
return resolveMergeAuto(file, agents);
|
|
26
|
+
case 'flag-for-review':
|
|
27
|
+
return {
|
|
28
|
+
file,
|
|
29
|
+
agents,
|
|
30
|
+
strategy,
|
|
31
|
+
resolved: false,
|
|
32
|
+
resolution: `Conflict flagged for manual review. Agents: ${agents.join(', ')}`,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Attempt automatic merge of changes from multiple agents.
|
|
38
|
+
* If changes don't overlap in lines, merge succeeds.
|
|
39
|
+
* Otherwise, falls back to flag-for-review.
|
|
40
|
+
*/
|
|
41
|
+
function resolveMergeAuto(file, agents) {
|
|
42
|
+
// In a real implementation, this would use diff3 to attempt merge.
|
|
43
|
+
// For now, we flag non-trivial conflicts for review.
|
|
44
|
+
// Simple heuristic: if only 2 agents, attempt merge; 3+ always flag.
|
|
45
|
+
if (agents.length === 2) {
|
|
46
|
+
return {
|
|
47
|
+
file,
|
|
48
|
+
agents,
|
|
49
|
+
strategy: 'merge-auto',
|
|
50
|
+
resolved: true,
|
|
51
|
+
resolution: `Auto-merge attempted for ${file} between agents ${agents.join(' and ')}`,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
return {
|
|
55
|
+
file,
|
|
56
|
+
agents,
|
|
57
|
+
strategy: 'merge-auto',
|
|
58
|
+
resolved: false,
|
|
59
|
+
resolution: `Auto-merge not possible for ${file} with ${String(agents.length)} agents. Flagged for review.`,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Get the winning agent for a conflict given the strategy.
|
|
64
|
+
* Returns undefined for unresolved conflicts.
|
|
65
|
+
*/
|
|
66
|
+
export function getConflictWinner(record) {
|
|
67
|
+
if (!record.resolved) {
|
|
68
|
+
return undefined;
|
|
69
|
+
}
|
|
70
|
+
switch (record.strategy) {
|
|
71
|
+
case 'last-wins':
|
|
72
|
+
return record.agents[record.agents.length - 1];
|
|
73
|
+
case 'first-wins':
|
|
74
|
+
return record.agents[0];
|
|
75
|
+
case 'merge-auto':
|
|
76
|
+
return undefined; // Merged, no single winner
|
|
77
|
+
case 'flag-for-review':
|
|
78
|
+
return undefined;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=conflict-resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conflict-resolver.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/conflict-resolver.ts"],"names":[],"mappings":"AAAA,gFAAgF;AAChF,kEAAkE;AAIlE;;GAEG;AACH,MAAM,UAAU,eAAe,CAC7B,IAAY,EACZ,MAAgB,EAChB,QAAiC;IAEjC,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,WAAW;YACd,OAAO;gBACL,IAAI;gBACJ,MAAM;gBACN,QAAQ;gBACR,QAAQ,EAAE,IAAI;gBACd,UAAU,EAAE,SAAS,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,SAAS,qBAAqB;aACjF,CAAC;QAEJ,KAAK,YAAY;YACf,OAAO;gBACL,IAAI;gBACJ,MAAM;gBACN,QAAQ;gBACR,QAAQ,EAAE,IAAI;gBACd,UAAU,EAAE,SAAS,MAAM,CAAC,CAAC,CAAC,IAAI,SAAS,sBAAsB;aAClE,CAAC;QAEJ,KAAK,YAAY;YACf,OAAO,gBAAgB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAExC,KAAK,iBAAiB;YACpB,OAAO;gBACL,IAAI;gBACJ,MAAM;gBACN,QAAQ;gBACR,QAAQ,EAAE,KAAK;gBACf,UAAU,EAAE,+CAA+C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;aAC/E,CAAC;IACN,CAAC;AACH,CAAC;AAED;;;;GAIG;AACH,SAAS,gBAAgB,CAAC,IAAY,EAAE,MAAgB;IACtD,mEAAmE;IACnE,qDAAqD;IACrD,qEAAqE;IACrE,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO;YACL,IAAI;YACJ,MAAM;YACN,QAAQ,EAAE,YAAY;YACtB,QAAQ,EAAE,IAAI;YACd,UAAU,EAAE,4BAA4B,IAAI,mBAAmB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;SACtF,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI;QACJ,MAAM;QACN,QAAQ,EAAE,YAAY;QACtB,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,+BAA+B,IAAI,SAAS,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,8BAA8B;KAC5G,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,iBAAiB,CAAC,MAA6B;IAC7D,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACrB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,QAAQ,MAAM,CAAC,QAAQ,EAAE,CAAC;QACxB,KAAK,WAAW;YACd,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACjD,KAAK,YAAY;YACf,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAC1B,KAAK,YAAY;YACf,OAAO,SAAS,CAAC,CAAC,2BAA2B;QAC/C,KAAK,iBAAiB;YACpB,OAAO,SAAS,CAAC;IACrB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { RuntimeTaskAssignment } from '../../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Generate a FileOwnershipMap from task assignments.
|
|
4
|
+
* Maps each file path to the agent that owns it.
|
|
5
|
+
* If multiple agents claim the same file, the first assignment wins
|
|
6
|
+
* and conflicts are returned separately.
|
|
7
|
+
*/
|
|
8
|
+
export declare function generateFileOwnershipMap(assignments: RuntimeTaskAssignment[]): {
|
|
9
|
+
map: Record<string, string>;
|
|
10
|
+
conflicts: string[];
|
|
11
|
+
};
|
|
12
|
+
/**
|
|
13
|
+
* Get the list of files owned by a specific agent.
|
|
14
|
+
*/
|
|
15
|
+
export declare function getAgentFiles(ownershipMap: Record<string, string>, agentId: string): string[];
|
|
16
|
+
/**
|
|
17
|
+
* Check if an agent owns a specific file.
|
|
18
|
+
*/
|
|
19
|
+
export declare function agentOwnsFile(ownershipMap: Record<string, string>, agentId: string, file: string): boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Format ownership map as markdown for agent handoff context.
|
|
22
|
+
* Uses relative paths (not absolute) for language-agnostic portability.
|
|
23
|
+
*/
|
|
24
|
+
export declare function formatOwnershipContext(ownershipMap: Record<string, string>, agentId: string): string;
|
|
25
|
+
//# sourceMappingURL=file-ownership.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-ownership.d.ts","sourceRoot":"","sources":["../../../src/engine/orchestrator/file-ownership.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAElE;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,WAAW,EAAE,qBAAqB,EAAE,GAAG;IAC9E,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC5B,SAAS,EAAE,MAAM,EAAE,CAAC;CACrB,CAkBA;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,CAI7F;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,GACX,OAAO,CAET;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CACpC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,OAAO,EAAE,MAAM,GACd,MAAM,CAmBR"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
// orchestrator/file-ownership.ts — File ownership map generation (SPEC-079 AC-09)
|
|
2
|
+
// Generates ownership maps from task assignments, ensuring no conflicts.
|
|
3
|
+
/**
|
|
4
|
+
* Generate a FileOwnershipMap from task assignments.
|
|
5
|
+
* Maps each file path to the agent that owns it.
|
|
6
|
+
* If multiple agents claim the same file, the first assignment wins
|
|
7
|
+
* and conflicts are returned separately.
|
|
8
|
+
*/
|
|
9
|
+
export function generateFileOwnershipMap(assignments) {
|
|
10
|
+
const map = {};
|
|
11
|
+
const conflicts = [];
|
|
12
|
+
for (const assignment of assignments) {
|
|
13
|
+
for (const file of assignment.files) {
|
|
14
|
+
const existing = map[file];
|
|
15
|
+
if (existing !== undefined && existing !== assignment.agentId) {
|
|
16
|
+
if (!conflicts.includes(file)) {
|
|
17
|
+
conflicts.push(file);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else if (existing === undefined) {
|
|
21
|
+
map[file] = assignment.agentId;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return { map, conflicts };
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Get the list of files owned by a specific agent.
|
|
29
|
+
*/
|
|
30
|
+
export function getAgentFiles(ownershipMap, agentId) {
|
|
31
|
+
return Object.entries(ownershipMap)
|
|
32
|
+
.filter(([, owner]) => owner === agentId)
|
|
33
|
+
.map(([file]) => file);
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Check if an agent owns a specific file.
|
|
37
|
+
*/
|
|
38
|
+
export function agentOwnsFile(ownershipMap, agentId, file) {
|
|
39
|
+
return ownershipMap[file] === agentId;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Format ownership map as markdown for agent handoff context.
|
|
43
|
+
* Uses relative paths (not absolute) for language-agnostic portability.
|
|
44
|
+
*/
|
|
45
|
+
export function formatOwnershipContext(ownershipMap, agentId) {
|
|
46
|
+
const ownedFiles = getAgentFiles(ownershipMap, agentId);
|
|
47
|
+
const otherFiles = Object.entries(ownershipMap)
|
|
48
|
+
.filter(([, owner]) => owner !== agentId)
|
|
49
|
+
.map(([file, owner]) => ` - ${file} (owned by ${owner})`);
|
|
50
|
+
const lines = [
|
|
51
|
+
'## File Ownership',
|
|
52
|
+
'',
|
|
53
|
+
'### Your files (read + write):',
|
|
54
|
+
...ownedFiles.map((f) => ` - ${f}`),
|
|
55
|
+
'',
|
|
56
|
+
];
|
|
57
|
+
if (otherFiles.length > 0) {
|
|
58
|
+
lines.push('### Other files (read only):', ...otherFiles, '');
|
|
59
|
+
}
|
|
60
|
+
return lines.join('\n');
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=file-ownership.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-ownership.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/file-ownership.ts"],"names":[],"mappings":"AAAA,kFAAkF;AAClF,yEAAyE;AAIzE;;;;;GAKG;AACH,MAAM,UAAU,wBAAwB,CAAC,WAAoC;IAI3E,MAAM,GAAG,GAA2B,EAAE,CAAC;IACvC,MAAM,SAAS,GAAa,EAAE,CAAC;IAE/B,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;QACrC,KAAK,MAAM,IAAI,IAAI,UAAU,CAAC,KAAK,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,KAAK,UAAU,CAAC,OAAO,EAAE,CAAC;gBAC9D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC9B,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;YACH,CAAC;iBAAM,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAClC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,OAAO,CAAC;YACjC,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC;AAC5B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,YAAoC,EAAE,OAAe;IACjF,OAAO,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC;SAChC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,OAAO,CAAC;SACxC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAC3B,YAAoC,EACpC,OAAe,EACf,IAAY;IAEZ,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC;AACxC,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CACpC,YAAoC,EACpC,OAAe;IAEf,MAAM,UAAU,GAAG,aAAa,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IACxD,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC;SAC5C,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,OAAO,CAAC;SACxC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,OAAO,IAAI,cAAc,KAAK,GAAG,CAAC,CAAC;IAE7D,MAAM,KAAK,GAAG;QACZ,mBAAmB;QACnB,EAAE;QACF,gCAAgC;QAChC,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;QACpC,EAAE;KACH,CAAC;IAEF,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1B,KAAK,CAAC,IAAI,CAAC,8BAA8B,EAAE,GAAG,UAAU,EAAE,EAAE,CAAC,CAAC;IAChE,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { RuntimeTaskAssignment, RuntimeHandoffPackage, RuntimeAgentConfig } from '../../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Generate a handoff package for a specific agent.
|
|
4
|
+
* Includes context, files, restrictions, and success criteria.
|
|
5
|
+
*/
|
|
6
|
+
export declare function generateHandoffPackage(agent: RuntimeAgentConfig, assignment: RuntimeTaskAssignment, ownershipMap: Record<string, string>, previousOutput?: string): RuntimeHandoffPackage;
|
|
7
|
+
/**
|
|
8
|
+
* Generate handoff packages for all agents in the session.
|
|
9
|
+
*/
|
|
10
|
+
export declare function generateAllHandoffs(agents: RuntimeAgentConfig[], assignments: RuntimeTaskAssignment[], ownershipMap: Record<string, string>): RuntimeHandoffPackage[];
|
|
11
|
+
/**
|
|
12
|
+
* Generate a pipeline handoff: output of previous agent becomes context for next.
|
|
13
|
+
*/
|
|
14
|
+
export declare function generatePipelineHandoff(agents: RuntimeAgentConfig[], assignments: RuntimeTaskAssignment[], ownershipMap: Record<string, string>, previousOutputs: Map<string, string>): RuntimeHandoffPackage[];
|
|
15
|
+
/**
|
|
16
|
+
* Format a handoff package as a markdown prompt string.
|
|
17
|
+
* Language-agnostic format: works for any agent type.
|
|
18
|
+
*/
|
|
19
|
+
export declare function formatHandoffAsPrompt(handoff: RuntimeHandoffPackage): string;
|
|
20
|
+
//# sourceMappingURL=handoff-generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handoff-generator.d.ts","sourceRoot":"","sources":["../../../src/engine/orchestrator/handoff-generator.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,qBAAqB,EACrB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,sBAAsB,CAAC;AAG9B;;;GAGG;AACH,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,kBAAkB,EACzB,UAAU,EAAE,qBAAqB,EACjC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,cAAc,CAAC,EAAE,MAAM,GACtB,qBAAqB,CAoCvB;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,kBAAkB,EAAE,EAC5B,WAAW,EAAE,qBAAqB,EAAE,EACpC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,qBAAqB,EAAE,CAWzB;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,kBAAkB,EAAE,EAC5B,WAAW,EAAE,qBAAqB,EAAE,EACpC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,qBAAqB,EAAE,CAqBzB;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,qBAAqB,GAAG,MAAM,CAe5E"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
// orchestrator/handoff-generator.ts — Handoff package generation (SPEC-079 AC-12)
|
|
2
|
+
// Generates complete context packages for each agent.
|
|
3
|
+
import { getAgentFiles, formatOwnershipContext } from './file-ownership.js';
|
|
4
|
+
/**
|
|
5
|
+
* Generate a handoff package for a specific agent.
|
|
6
|
+
* Includes context, files, restrictions, and success criteria.
|
|
7
|
+
*/
|
|
8
|
+
export function generateHandoffPackage(agent, assignment, ownershipMap, previousOutput) {
|
|
9
|
+
const ownedFiles = getAgentFiles(ownershipMap, agent.id);
|
|
10
|
+
const otherAgentFiles = Object.entries(ownershipMap)
|
|
11
|
+
.filter(([, owner]) => owner !== agent.id)
|
|
12
|
+
.map(([file]) => file);
|
|
13
|
+
const restrictions = otherAgentFiles.map((f) => `DO NOT modify ${f} (owned by another agent)`);
|
|
14
|
+
const ownershipContext = formatOwnershipContext(ownershipMap, agent.id);
|
|
15
|
+
const contextParts = [ownershipContext, `\n## Task\n${assignment.context}`];
|
|
16
|
+
if (previousOutput) {
|
|
17
|
+
contextParts.push(`\n## Previous Agent Output\n${previousOutput}`);
|
|
18
|
+
}
|
|
19
|
+
if (assignment.dependencies.length > 0) {
|
|
20
|
+
contextParts.push(`\n## Dependencies\nThis task depends on: ${assignment.dependencies.join(', ')}`);
|
|
21
|
+
}
|
|
22
|
+
return {
|
|
23
|
+
agentId: agent.id,
|
|
24
|
+
role: agent.capabilities[0] ?? 'general',
|
|
25
|
+
filesToRead: [...ownedFiles, ...otherAgentFiles],
|
|
26
|
+
filesToModify: ownedFiles,
|
|
27
|
+
restrictions,
|
|
28
|
+
instructions: assignment.context,
|
|
29
|
+
context: contextParts.join('\n'),
|
|
30
|
+
successCriteria: [
|
|
31
|
+
`Complete task: ${assignment.context}`,
|
|
32
|
+
`Only modify assigned files: ${ownedFiles.join(', ')}`,
|
|
33
|
+
'Report any issues or blockers encountered',
|
|
34
|
+
],
|
|
35
|
+
dependencies: assignment.dependencies,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Generate handoff packages for all agents in the session.
|
|
40
|
+
*/
|
|
41
|
+
export function generateAllHandoffs(agents, assignments, ownershipMap) {
|
|
42
|
+
return assignments.map((assignment) => {
|
|
43
|
+
const agent = agents.find((a) => a.id === assignment.agentId);
|
|
44
|
+
const defaultAgent = {
|
|
45
|
+
id: assignment.agentId,
|
|
46
|
+
command: '',
|
|
47
|
+
args: [],
|
|
48
|
+
capabilities: [],
|
|
49
|
+
};
|
|
50
|
+
return generateHandoffPackage(agent ?? defaultAgent, assignment, ownershipMap);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Generate a pipeline handoff: output of previous agent becomes context for next.
|
|
55
|
+
*/
|
|
56
|
+
export function generatePipelineHandoff(agents, assignments, ownershipMap, previousOutputs) {
|
|
57
|
+
return assignments.map((assignment, index) => {
|
|
58
|
+
const agent = agents.find((a) => a.id === assignment.agentId);
|
|
59
|
+
const defaultAgent = {
|
|
60
|
+
id: assignment.agentId,
|
|
61
|
+
command: '',
|
|
62
|
+
args: [],
|
|
63
|
+
capabilities: [],
|
|
64
|
+
};
|
|
65
|
+
// Get previous agent's output for pipeline chain
|
|
66
|
+
let previousOutput;
|
|
67
|
+
if (index > 0) {
|
|
68
|
+
const prevAssignment = assignments[index - 1];
|
|
69
|
+
if (prevAssignment) {
|
|
70
|
+
previousOutput = previousOutputs.get(prevAssignment.agentId);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return generateHandoffPackage(agent ?? defaultAgent, assignment, ownershipMap, previousOutput);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Format a handoff package as a markdown prompt string.
|
|
78
|
+
* Language-agnostic format: works for any agent type.
|
|
79
|
+
*/
|
|
80
|
+
export function formatHandoffAsPrompt(handoff) {
|
|
81
|
+
const lines = [
|
|
82
|
+
`# Agent Handoff: ${handoff.agentId}`,
|
|
83
|
+
`**Role**: ${handoff.role}`,
|
|
84
|
+
'',
|
|
85
|
+
handoff.context,
|
|
86
|
+
'',
|
|
87
|
+
'## Success Criteria',
|
|
88
|
+
...handoff.successCriteria.map((c) => `- ${c}`),
|
|
89
|
+
'',
|
|
90
|
+
'## Restrictions',
|
|
91
|
+
...(handoff.restrictions.length > 0 ? handoff.restrictions.map((r) => `- ${r}`) : ['- None']),
|
|
92
|
+
];
|
|
93
|
+
return lines.join('\n');
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=handoff-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handoff-generator.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/handoff-generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { startOrchestration, getStatus, listSessions, cancelOrchestration, clearSessions, } from './runtime.js';
|
|
2
|
+
export { planExecution } from './topologies.js';
|
|
3
|
+
export { distributeTasks } from './task-distributor.js';
|
|
4
|
+
export { buildSpawnDescriptor, createAgentProcess, spawnAgent, parseTokenUsage, } from './agent-spawner.js';
|
|
5
|
+
export { generateFileOwnershipMap, getAgentFiles, agentOwnsFile, formatOwnershipContext, } from './file-ownership.js';
|
|
6
|
+
export { collectTaskResults, parseAgentOutput, detectAndResolveConflicts, calculateCost, buildOrchestrationResult, } from './result-collector.js';
|
|
7
|
+
export { resolveConflict, getConflictWinner } from './conflict-resolver.js';
|
|
8
|
+
export { ProgressTracker } from './progress-tracker.js';
|
|
9
|
+
export { generateHandoffPackage, generateAllHandoffs, generatePipelineHandoff, formatHandoffAsPrompt, } from './handoff-generator.js';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/engine/orchestrator/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,kBAAkB,EAClB,SAAS,EACT,YAAY,EACZ,mBAAmB,EACnB,aAAa,GACd,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EACL,oBAAoB,EACpB,kBAAkB,EAClB,UAAU,EACV,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EACL,wBAAwB,EACxB,aAAa,EACb,aAAa,EACb,sBAAsB,GACvB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,EACzB,aAAa,EACb,wBAAwB,GACzB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE5E,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EACL,sBAAsB,EACtB,mBAAmB,EACnB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
// orchestrator/index.ts — Barrel re-export for SPEC-079 orchestration runtime
|
|
2
|
+
export { startOrchestration, getStatus, listSessions, cancelOrchestration, clearSessions, } from './runtime.js';
|
|
3
|
+
export { planExecution } from './topologies.js';
|
|
4
|
+
export { distributeTasks } from './task-distributor.js';
|
|
5
|
+
export { buildSpawnDescriptor, createAgentProcess, spawnAgent, parseTokenUsage, } from './agent-spawner.js';
|
|
6
|
+
export { generateFileOwnershipMap, getAgentFiles, agentOwnsFile, formatOwnershipContext, } from './file-ownership.js';
|
|
7
|
+
export { collectTaskResults, parseAgentOutput, detectAndResolveConflicts, calculateCost, buildOrchestrationResult, } from './result-collector.js';
|
|
8
|
+
export { resolveConflict, getConflictWinner } from './conflict-resolver.js';
|
|
9
|
+
export { ProgressTracker } from './progress-tracker.js';
|
|
10
|
+
export { generateHandoffPackage, generateAllHandoffs, generatePipelineHandoff, formatHandoffAsPrompt, } from './handoff-generator.js';
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/index.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAC9E,OAAO,EACL,kBAAkB,EAClB,SAAS,EACT,YAAY,EACZ,mBAAmB,EACnB,aAAa,GACd,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EACL,oBAAoB,EACpB,kBAAkB,EAClB,UAAU,EACV,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EACL,wBAAwB,EACxB,aAAa,EACb,aAAa,EACb,sBAAsB,GACvB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,EACzB,aAAa,EACb,wBAAwB,GACzB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE5E,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EACL,sBAAsB,EACtB,mBAAmB,EACnB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { RuntimeAgentProcess, RuntimeAgentStatus, RuntimeTaskAssignment, RuntimeTaskStatus, RuntimeProgressEvent, RuntimeProgressCallback } from '../../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Progress tracker for an orchestration session.
|
|
4
|
+
* Uses callback pattern (not EventEmitter) to avoid extra dependencies.
|
|
5
|
+
*/
|
|
6
|
+
export declare class ProgressTracker {
|
|
7
|
+
private readonly sessionId;
|
|
8
|
+
private readonly agents;
|
|
9
|
+
private readonly tasks;
|
|
10
|
+
private readonly callbacks;
|
|
11
|
+
private readonly timeline;
|
|
12
|
+
constructor(sessionId: string);
|
|
13
|
+
/** Register a progress callback. */
|
|
14
|
+
onProgress(callback: RuntimeProgressCallback): void;
|
|
15
|
+
/** Initialize tracking for agents and tasks. */
|
|
16
|
+
init(agentProcesses: RuntimeAgentProcess[], assignments: RuntimeTaskAssignment[]): void;
|
|
17
|
+
/** Update agent status and emit event. */
|
|
18
|
+
updateAgentStatus(agentId: string, status: RuntimeAgentStatus): void;
|
|
19
|
+
/** Update task status and emit event. */
|
|
20
|
+
updateTaskStatus(taskId: string, status: RuntimeTaskStatus): void;
|
|
21
|
+
/** Calculate completion percentage. */
|
|
22
|
+
getCompletionPercent(): number;
|
|
23
|
+
/** Get timeline of all events. */
|
|
24
|
+
getTimeline(): RuntimeProgressEvent[];
|
|
25
|
+
/** Get current agent statuses. */
|
|
26
|
+
getAgentStatuses(): Record<string, RuntimeAgentStatus>;
|
|
27
|
+
/** Get current task statuses. */
|
|
28
|
+
getTaskStatuses(): Record<string, RuntimeTaskStatus>;
|
|
29
|
+
/** Emit a progress event to all callbacks. */
|
|
30
|
+
private emit;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=progress-tracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress-tracker.d.ts","sourceRoot":"","sources":["../../../src/engine/orchestrator/progress-tracker.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,mBAAmB,EACnB,kBAAkB,EAClB,qBAAqB,EACrB,iBAAiB,EACjB,oBAAoB,EACpB,uBAAuB,EACxB,MAAM,sBAAsB,CAAC;AAE9B;;;GAGG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyC;IAChE,OAAO,CAAC,QAAQ,CAAC,KAAK,CASlB;IACJ,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAiC;IAC3D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA8B;gBAE3C,SAAS,EAAE,MAAM;IAI7B,oCAAoC;IACpC,UAAU,CAAC,QAAQ,EAAE,uBAAuB,GAAG,IAAI;IAInD,gDAAgD;IAChD,IAAI,CAAC,cAAc,EAAE,mBAAmB,EAAE,EAAE,WAAW,EAAE,qBAAqB,EAAE,GAAG,IAAI;IAavF,0CAA0C;IAC1C,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,kBAAkB,GAAG,IAAI;IAWpE,yCAAyC;IACzC,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,iBAAiB,GAAG,IAAI;IAoBjE,uCAAuC;IACvC,oBAAoB,IAAI,MAAM;IAgB9B,kCAAkC;IAClC,WAAW,IAAI,oBAAoB,EAAE;IAIrC,kCAAkC;IAClC,gBAAgB,IAAI,MAAM,CAAC,MAAM,EAAE,kBAAkB,CAAC;IAItD,iCAAiC;IACjC,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC;IAQpD,8CAA8C;IAC9C,OAAO,CAAC,IAAI;CAMb"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
// orchestrator/progress-tracker.ts — Progress tracking (SPEC-079 AC-07)
|
|
2
|
+
// Tracks agent and task status, emits progress events via callbacks.
|
|
3
|
+
/**
|
|
4
|
+
* Progress tracker for an orchestration session.
|
|
5
|
+
* Uses callback pattern (not EventEmitter) to avoid extra dependencies.
|
|
6
|
+
*/
|
|
7
|
+
export class ProgressTracker {
|
|
8
|
+
sessionId;
|
|
9
|
+
agents = new Map();
|
|
10
|
+
tasks = new Map();
|
|
11
|
+
callbacks = [];
|
|
12
|
+
timeline = [];
|
|
13
|
+
constructor(sessionId) {
|
|
14
|
+
this.sessionId = sessionId;
|
|
15
|
+
}
|
|
16
|
+
/** Register a progress callback. */
|
|
17
|
+
onProgress(callback) {
|
|
18
|
+
this.callbacks.push(callback);
|
|
19
|
+
}
|
|
20
|
+
/** Initialize tracking for agents and tasks. */
|
|
21
|
+
init(agentProcesses, assignments) {
|
|
22
|
+
for (const agent of agentProcesses) {
|
|
23
|
+
this.agents.set(agent.agentId, agent.status);
|
|
24
|
+
}
|
|
25
|
+
for (const task of assignments) {
|
|
26
|
+
this.tasks.set(task.taskId, {
|
|
27
|
+
taskId: task.taskId,
|
|
28
|
+
agentId: task.agentId,
|
|
29
|
+
status: 'queued',
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/** Update agent status and emit event. */
|
|
34
|
+
updateAgentStatus(agentId, status) {
|
|
35
|
+
this.agents.set(agentId, status);
|
|
36
|
+
this.emit({
|
|
37
|
+
sessionId: this.sessionId,
|
|
38
|
+
agentId,
|
|
39
|
+
type: 'agent-status',
|
|
40
|
+
data: { status },
|
|
41
|
+
timestamp: new Date().toISOString(),
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
/** Update task status and emit event. */
|
|
45
|
+
updateTaskStatus(taskId, status) {
|
|
46
|
+
const tracked = this.tasks.get(taskId);
|
|
47
|
+
if (tracked) {
|
|
48
|
+
tracked.status = status;
|
|
49
|
+
if (status === 'in_progress' && !tracked.startedAt) {
|
|
50
|
+
tracked.startedAt = new Date().toISOString();
|
|
51
|
+
}
|
|
52
|
+
if (status === 'completed' || status === 'failed') {
|
|
53
|
+
tracked.completedAt = new Date().toISOString();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
this.emit({
|
|
57
|
+
sessionId: this.sessionId,
|
|
58
|
+
taskId,
|
|
59
|
+
type: 'task-status',
|
|
60
|
+
data: { status },
|
|
61
|
+
timestamp: new Date().toISOString(),
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
/** Calculate completion percentage. */
|
|
65
|
+
getCompletionPercent() {
|
|
66
|
+
const total = this.tasks.size;
|
|
67
|
+
if (total === 0) {
|
|
68
|
+
return 100;
|
|
69
|
+
}
|
|
70
|
+
let completed = 0;
|
|
71
|
+
for (const task of this.tasks.values()) {
|
|
72
|
+
if (task.status === 'completed') {
|
|
73
|
+
completed++;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return Math.round((completed / total) * 100);
|
|
77
|
+
}
|
|
78
|
+
/** Get timeline of all events. */
|
|
79
|
+
getTimeline() {
|
|
80
|
+
return [...this.timeline];
|
|
81
|
+
}
|
|
82
|
+
/** Get current agent statuses. */
|
|
83
|
+
getAgentStatuses() {
|
|
84
|
+
return Object.fromEntries(this.agents);
|
|
85
|
+
}
|
|
86
|
+
/** Get current task statuses. */
|
|
87
|
+
getTaskStatuses() {
|
|
88
|
+
const result = {};
|
|
89
|
+
for (const [id, tracked] of this.tasks) {
|
|
90
|
+
result[id] = tracked.status;
|
|
91
|
+
}
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
/** Emit a progress event to all callbacks. */
|
|
95
|
+
emit(event) {
|
|
96
|
+
this.timeline.push(event);
|
|
97
|
+
for (const cb of this.callbacks) {
|
|
98
|
+
cb(event);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=progress-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress-tracker.js","sourceRoot":"","sources":["../../../src/engine/orchestrator/progress-tracker.ts"],"names":[],"mappings":"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"}
|