agentic-orchestrator 0.1.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/.dockerignore +24 -0
- package/.github/workflows/mcp-contract-validation.yml +38 -0
- package/Agentic-Orchestrator.iml +9 -0
- package/LICENSE +21 -0
- package/README.md +679 -0
- package/agentic/orchestrator/agents.yaml +14 -0
- package/agentic/orchestrator/gates.yaml +31 -0
- package/agentic/orchestrator/policy.yaml +145 -0
- package/agentic/orchestrator/prompts/builder.system.md +1 -0
- package/agentic/orchestrator/prompts/planner.system.md +15 -0
- package/agentic/orchestrator/prompts/qa.system.md +1 -0
- package/agentic/orchestrator/schemas/agents.schema.json +49 -0
- package/agentic/orchestrator/schemas/gates.schema.json +65 -0
- package/agentic/orchestrator/schemas/index.schema.json +108 -0
- package/agentic/orchestrator/schemas/plan.schema.json +127 -0
- package/agentic/orchestrator/schemas/policy.schema.json +227 -0
- package/agentic/orchestrator/schemas/qa_test_index.schema.json +53 -0
- package/agentic/orchestrator/schemas/state.schema.json +92 -0
- package/agentic/orchestrator/tools/catalog.json +399 -0
- package/agentic/orchestrator/tools/errors.schema.json +21 -0
- package/agentic/orchestrator/tools/protocol.json +8 -0
- package/agentic/orchestrator/tools/schemas/input/collisions.scan.input.schema.json +7 -0
- package/agentic/orchestrator/tools/schemas/input/evidence.latest.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/feature.delete.input.schema.json +42 -0
- package/agentic/orchestrator/tools/schemas/input/feature.discover_specs.input.schema.json +7 -0
- package/agentic/orchestrator/tools/schemas/input/feature.get_context.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/feature.init.input.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/input/feature.log_append.input.schema.json +26 -0
- package/agentic/orchestrator/tools/schemas/input/feature.ready_to_merge.input.schema.json +34 -0
- package/agentic/orchestrator/tools/schemas/input/feature.state_get.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/feature.state_patch.input.schema.json +28 -0
- package/agentic/orchestrator/tools/schemas/input/gates.list.input.schema.json +11 -0
- package/agentic/orchestrator/tools/schemas/input/gates.run.input.schema.json +29 -0
- package/agentic/orchestrator/tools/schemas/input/locks.acquire.input.schema.json +29 -0
- package/agentic/orchestrator/tools/schemas/input/locks.release.input.schema.json +26 -0
- package/agentic/orchestrator/tools/schemas/input/mutating.schema.json +14 -0
- package/agentic/orchestrator/tools/schemas/input/plan.get.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/plan.submit.input.schema.json +28 -0
- package/agentic/orchestrator/tools/schemas/input/plan.update.input.schema.json +29 -0
- package/agentic/orchestrator/tools/schemas/input/qa.test_index_get.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/qa.test_index_update.input.schema.json +38 -0
- package/agentic/orchestrator/tools/schemas/input/read.schema.json +6 -0
- package/agentic/orchestrator/tools/schemas/input/repo.apply_patch.input.schema.json +25 -0
- package/agentic/orchestrator/tools/schemas/input/repo.diff.input.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/input/repo.diff_bundle.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/repo.ensure_worktree.input.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/input/repo.read_file.input.schema.json +20 -0
- package/agentic/orchestrator/tools/schemas/input/repo.search.input.schema.json +20 -0
- package/agentic/orchestrator/tools/schemas/input/repo.status.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/input/report.dashboard.input.schema.json +7 -0
- package/agentic/orchestrator/tools/schemas/input/report.feature_summary.input.schema.json +15 -0
- package/agentic/orchestrator/tools/schemas/output/collisions.scan.output.schema.json +17 -0
- package/agentic/orchestrator/tools/schemas/output/evidence.latest.output.schema.json +20 -0
- package/agentic/orchestrator/tools/schemas/output/feature.delete.output.schema.json +224 -0
- package/agentic/orchestrator/tools/schemas/output/feature.discover_specs.output.schema.json +32 -0
- package/agentic/orchestrator/tools/schemas/output/feature.get_context.output.schema.json +40 -0
- package/agentic/orchestrator/tools/schemas/output/feature.init.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/feature.log_append.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/feature.ready_to_merge.output.schema.json +30 -0
- package/agentic/orchestrator/tools/schemas/output/feature.state_get.output.schema.json +18 -0
- package/agentic/orchestrator/tools/schemas/output/feature.state_patch.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/gates.list.output.schema.json +42 -0
- package/agentic/orchestrator/tools/schemas/output/gates.run.output.schema.json +37 -0
- package/agentic/orchestrator/tools/schemas/output/locks.acquire.output.schema.json +34 -0
- package/agentic/orchestrator/tools/schemas/output/locks.release.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/plan.get.output.schema.json +26 -0
- package/agentic/orchestrator/tools/schemas/output/plan.submit.output.schema.json +23 -0
- package/agentic/orchestrator/tools/schemas/output/plan.update.output.schema.json +23 -0
- package/agentic/orchestrator/tools/schemas/output/qa.test_index_get.output.schema.json +22 -0
- package/agentic/orchestrator/tools/schemas/output/qa.test_index_update.output.schema.json +19 -0
- package/agentic/orchestrator/tools/schemas/output/repo.apply_patch.output.schema.json +33 -0
- package/agentic/orchestrator/tools/schemas/output/repo.diff.output.schema.json +19 -0
- package/agentic/orchestrator/tools/schemas/output/repo.diff_bundle.output.schema.json +32 -0
- package/agentic/orchestrator/tools/schemas/output/repo.ensure_worktree.output.schema.json +29 -0
- package/agentic/orchestrator/tools/schemas/output/repo.read_file.output.schema.json +24 -0
- package/agentic/orchestrator/tools/schemas/output/repo.search.output.schema.json +26 -0
- package/agentic/orchestrator/tools/schemas/output/repo.status.output.schema.json +27 -0
- package/agentic/orchestrator/tools/schemas/output/report.dashboard.output.schema.json +21 -0
- package/agentic/orchestrator/tools/schemas/output/report.feature_summary.output.schema.json +36 -0
- package/agentic/orchestrator/tools/schemas/output/standard_success.schema.json +6 -0
- package/agentic/orchestrator/tools.md +32 -0
- package/apps/control-plane/project.json +39 -0
- package/apps/control-plane/scripts/validate-architecture-rules.mjs +170 -0
- package/apps/control-plane/scripts/validate-docker-mcp-contract.mjs +84 -0
- package/apps/control-plane/scripts/validate-mcp-contracts.ts +61 -0
- package/apps/control-plane/src/application/services/collision-queue-service.ts +227 -0
- package/apps/control-plane/src/application/services/feature-deletion-service.ts +459 -0
- package/apps/control-plane/src/application/services/feature-lifecycle-service.ts +177 -0
- package/apps/control-plane/src/application/services/feature-state-service.ts +125 -0
- package/apps/control-plane/src/application/services/gate-service.ts +232 -0
- package/apps/control-plane/src/application/services/lock-service.ts +298 -0
- package/apps/control-plane/src/application/services/merge-service.ts +246 -0
- package/apps/control-plane/src/application/services/patch-service.ts +259 -0
- package/apps/control-plane/src/application/services/plan-service.ts +302 -0
- package/apps/control-plane/src/application/services/qa-index-service.ts +98 -0
- package/apps/control-plane/src/application/services/reporting-service.ts +120 -0
- package/apps/control-plane/src/application/services/run-lease-service.ts +340 -0
- package/apps/control-plane/src/application/tools/tool-metadata.ts +56 -0
- package/apps/control-plane/src/application/tools/tool-router.ts +43 -0
- package/apps/control-plane/src/cli/aop.ts +31 -0
- package/apps/control-plane/src/cli/cli-argument-parser.ts +116 -0
- package/apps/control-plane/src/cli/delete-command-handler.ts +90 -0
- package/apps/control-plane/src/cli/io.ts +14 -0
- package/apps/control-plane/src/cli/resume-command-handler.ts +228 -0
- package/apps/control-plane/src/cli/run-command-handler.ts +57 -0
- package/apps/control-plane/src/cli/spec-ingestion-service.ts +88 -0
- package/apps/control-plane/src/cli/spec-input-resolver.ts +95 -0
- package/apps/control-plane/src/cli/spec-utils.ts +40 -0
- package/apps/control-plane/src/cli/status-command-handler.ts +17 -0
- package/apps/control-plane/src/cli/stop-command-handler.ts +5 -0
- package/apps/control-plane/src/cli/tooling.ts +36 -0
- package/apps/control-plane/src/cli/types.ts +34 -0
- package/apps/control-plane/src/core/collisions.ts +121 -0
- package/apps/control-plane/src/core/constants.ts +72 -0
- package/apps/control-plane/src/core/error-codes.ts +54 -0
- package/apps/control-plane/src/core/frontmatter.ts +42 -0
- package/apps/control-plane/src/core/fs.ts +173 -0
- package/apps/control-plane/src/core/gates.ts +361 -0
- package/apps/control-plane/src/core/git.ts +115 -0
- package/apps/control-plane/src/core/kernel.ts +1077 -0
- package/apps/control-plane/src/core/patch.ts +152 -0
- package/apps/control-plane/src/core/path-layout.ts +113 -0
- package/apps/control-plane/src/core/path-rules.ts +71 -0
- package/apps/control-plane/src/core/qa-index.ts +179 -0
- package/apps/control-plane/src/core/response.ts +62 -0
- package/apps/control-plane/src/core/runtime-sessions.ts +20 -0
- package/apps/control-plane/src/core/schemas.ts +125 -0
- package/apps/control-plane/src/index.ts +21 -0
- package/apps/control-plane/src/interfaces/cli/bootstrap.ts +100 -0
- package/apps/control-plane/src/mcp/kernel-tool-executor.ts +39 -0
- package/apps/control-plane/src/mcp/mcp-server-adapter.ts +74 -0
- package/apps/control-plane/src/mcp/operation-ledger.ts +108 -0
- package/apps/control-plane/src/mcp/protocol-contract.ts +9 -0
- package/apps/control-plane/src/mcp/runtime-factory.ts +105 -0
- package/apps/control-plane/src/mcp/runtime-types.ts +44 -0
- package/apps/control-plane/src/mcp/token-auth-verifier.ts +63 -0
- package/apps/control-plane/src/mcp/token-claims-validator.ts +72 -0
- package/apps/control-plane/src/mcp/token-codec.ts +62 -0
- package/apps/control-plane/src/mcp/tool-authorizer.ts +43 -0
- package/apps/control-plane/src/mcp/tool-client.ts +78 -0
- package/apps/control-plane/src/mcp/tool-contract-validator.ts +83 -0
- package/apps/control-plane/src/mcp/tool-registry-loader.ts +135 -0
- package/apps/control-plane/src/mcp/tool-runtime.ts +336 -0
- package/apps/control-plane/src/mcp/tools-markdown-generator.ts +26 -0
- package/apps/control-plane/src/mcp/transport-types.ts +16 -0
- package/apps/control-plane/src/mcp/types.ts +2 -0
- package/apps/control-plane/src/providers/providers.ts +177 -0
- package/apps/control-plane/src/supervisor/build-wave-executor.ts +55 -0
- package/apps/control-plane/src/supervisor/lease-heartbeat-service.ts +22 -0
- package/apps/control-plane/src/supervisor/planning-wave-executor.ts +316 -0
- package/apps/control-plane/src/supervisor/prompt-bundle-loader.ts +62 -0
- package/apps/control-plane/src/supervisor/qa-wave-executor.ts +99 -0
- package/apps/control-plane/src/supervisor/run-coordinator.ts +224 -0
- package/apps/control-plane/src/supervisor/runtime.ts +347 -0
- package/apps/control-plane/src/supervisor/session-orchestrator.ts +268 -0
- package/apps/control-plane/src/supervisor/types.ts +149 -0
- package/apps/control-plane/src/supervisor/worker-decision-loop.ts +299 -0
- package/apps/control-plane/test/aop.spec.ts +101 -0
- package/apps/control-plane/test/cli-helpers.spec.ts +102 -0
- package/apps/control-plane/test/cli.spec.ts +12 -0
- package/apps/control-plane/test/cli.unit.spec.ts +609 -0
- package/apps/control-plane/test/collision-queue.spec.ts +158 -0
- package/apps/control-plane/test/collisions.spec.ts +138 -0
- package/apps/control-plane/test/core-utils.spec.ts +102 -0
- package/apps/control-plane/test/delete-command-handler.spec.ts +202 -0
- package/apps/control-plane/test/epoch-tracking.spec.ts +121 -0
- package/apps/control-plane/test/gates.spec.ts +452 -0
- package/apps/control-plane/test/helpers.ts +68 -0
- package/apps/control-plane/test/index.spec.ts +18 -0
- package/apps/control-plane/test/kernel-collision-replay.spec.ts +222 -0
- package/apps/control-plane/test/kernel.branches.spec.ts +321 -0
- package/apps/control-plane/test/kernel.coverage.spec.ts +408 -0
- package/apps/control-plane/test/kernel.spec.ts +369 -0
- package/apps/control-plane/test/mcp-helpers.spec.ts +195 -0
- package/apps/control-plane/test/mcp.spec.ts +776 -0
- package/apps/control-plane/test/merge-service.spec.ts +357 -0
- package/apps/control-plane/test/plan-service.spec.ts +195 -0
- package/apps/control-plane/test/planning-wave-executor.spec.ts +229 -0
- package/apps/control-plane/test/providers.spec.ts +168 -0
- package/apps/control-plane/test/qa-index-service.spec.ts +187 -0
- package/apps/control-plane/test/qa-index.spec.ts +317 -0
- package/apps/control-plane/test/response.spec.ts +55 -0
- package/apps/control-plane/test/run-coordinator.spec.ts +334 -0
- package/apps/control-plane/test/schema-date-time.spec.ts +170 -0
- package/apps/control-plane/test/service-retry-paths.spec.ts +305 -0
- package/apps/control-plane/test/services.spec.ts +693 -0
- package/apps/control-plane/test/spec-input-resolver.spec.ts +76 -0
- package/apps/control-plane/test/supervisor-collaborators.spec.ts +201 -0
- package/apps/control-plane/test/supervisor.calltool.spec.ts +120 -0
- package/apps/control-plane/test/supervisor.spec.ts +415 -0
- package/apps/control-plane/test/supervisor.unit.spec.ts +522 -0
- package/apps/control-plane/test/token-auth-verifier.spec.ts +111 -0
- package/apps/control-plane/test/tool-registry-loader.spec.ts +268 -0
- package/apps/control-plane/test/tool-runtime.spec.ts +294 -0
- package/apps/control-plane/test/worker-decision-loop.spec.ts +587 -0
- package/apps/control-plane/tsconfig.build.json +17 -0
- package/apps/control-plane/tsconfig.json +11 -0
- package/apps/control-plane/vitest.config.ts +28 -0
- package/dist/apps/control-plane/application/services/collision-queue-service.d.ts +69 -0
- package/dist/apps/control-plane/application/services/collision-queue-service.js +158 -0
- package/dist/apps/control-plane/application/services/collision-queue-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/feature-deletion-service.d.ts +79 -0
- package/dist/apps/control-plane/application/services/feature-deletion-service.js +336 -0
- package/dist/apps/control-plane/application/services/feature-deletion-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.d.ts +81 -0
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.js +117 -0
- package/dist/apps/control-plane/application/services/feature-lifecycle-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/feature-state-service.d.ts +34 -0
- package/dist/apps/control-plane/application/services/feature-state-service.js +90 -0
- package/dist/apps/control-plane/application/services/feature-state-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/gate-service.d.ts +46 -0
- package/dist/apps/control-plane/application/services/gate-service.js +160 -0
- package/dist/apps/control-plane/application/services/gate-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/lock-service.d.ts +56 -0
- package/dist/apps/control-plane/application/services/lock-service.js +242 -0
- package/dist/apps/control-plane/application/services/lock-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/merge-service.d.ts +33 -0
- package/dist/apps/control-plane/application/services/merge-service.js +194 -0
- package/dist/apps/control-plane/application/services/merge-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/patch-service.d.ts +39 -0
- package/dist/apps/control-plane/application/services/patch-service.js +189 -0
- package/dist/apps/control-plane/application/services/patch-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/plan-service.d.ts +60 -0
- package/dist/apps/control-plane/application/services/plan-service.js +234 -0
- package/dist/apps/control-plane/application/services/plan-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/qa-index-service.d.ts +26 -0
- package/dist/apps/control-plane/application/services/qa-index-service.js +66 -0
- package/dist/apps/control-plane/application/services/qa-index-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/reporting-service.d.ts +47 -0
- package/dist/apps/control-plane/application/services/reporting-service.js +90 -0
- package/dist/apps/control-plane/application/services/reporting-service.js.map +1 -0
- package/dist/apps/control-plane/application/services/run-lease-service.d.ts +74 -0
- package/dist/apps/control-plane/application/services/run-lease-service.js +263 -0
- package/dist/apps/control-plane/application/services/run-lease-service.js.map +1 -0
- package/dist/apps/control-plane/application/tools/tool-metadata.d.ts +8 -0
- package/dist/apps/control-plane/application/tools/tool-metadata.js +37 -0
- package/dist/apps/control-plane/application/tools/tool-metadata.js.map +1 -0
- package/dist/apps/control-plane/application/tools/tool-router.d.ts +16 -0
- package/dist/apps/control-plane/application/tools/tool-router.js +25 -0
- package/dist/apps/control-plane/application/tools/tool-router.js.map +1 -0
- package/dist/apps/control-plane/cli/aop.d.ts +5 -0
- package/dist/apps/control-plane/cli/aop.js +19 -0
- package/dist/apps/control-plane/cli/aop.js.map +1 -0
- package/dist/apps/control-plane/cli/cli-argument-parser.d.ts +5 -0
- package/dist/apps/control-plane/cli/cli-argument-parser.js +109 -0
- package/dist/apps/control-plane/cli/cli-argument-parser.js.map +1 -0
- package/dist/apps/control-plane/cli/delete-command-handler.d.ts +8 -0
- package/dist/apps/control-plane/cli/delete-command-handler.js +77 -0
- package/dist/apps/control-plane/cli/delete-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/io.d.ts +2 -0
- package/dist/apps/control-plane/cli/io.js +14 -0
- package/dist/apps/control-plane/cli/io.js.map +1 -0
- package/dist/apps/control-plane/cli/resume-command-handler.d.ts +17 -0
- package/dist/apps/control-plane/cli/resume-command-handler.js +178 -0
- package/dist/apps/control-plane/cli/resume-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/run-command-handler.d.ts +15 -0
- package/dist/apps/control-plane/cli/run-command-handler.js +39 -0
- package/dist/apps/control-plane/cli/run-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/spec-ingestion-service.d.ts +8 -0
- package/dist/apps/control-plane/cli/spec-ingestion-service.js +77 -0
- package/dist/apps/control-plane/cli/spec-ingestion-service.js.map +1 -0
- package/dist/apps/control-plane/cli/spec-input-resolver.d.ts +9 -0
- package/dist/apps/control-plane/cli/spec-input-resolver.js +81 -0
- package/dist/apps/control-plane/cli/spec-input-resolver.js.map +1 -0
- package/dist/apps/control-plane/cli/spec-utils.d.ts +3 -0
- package/dist/apps/control-plane/cli/spec-utils.js +36 -0
- package/dist/apps/control-plane/cli/spec-utils.js.map +1 -0
- package/dist/apps/control-plane/cli/status-command-handler.d.ts +7 -0
- package/dist/apps/control-plane/cli/status-command-handler.js +14 -0
- package/dist/apps/control-plane/cli/status-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/stop-command-handler.d.ts +3 -0
- package/dist/apps/control-plane/cli/stop-command-handler.js +6 -0
- package/dist/apps/control-plane/cli/stop-command-handler.js.map +1 -0
- package/dist/apps/control-plane/cli/tooling.d.ts +4 -0
- package/dist/apps/control-plane/cli/tooling.js +24 -0
- package/dist/apps/control-plane/cli/tooling.js.map +1 -0
- package/dist/apps/control-plane/cli/types.d.ts +31 -0
- package/dist/apps/control-plane/cli/types.js +2 -0
- package/dist/apps/control-plane/cli/types.js.map +1 -0
- package/dist/apps/control-plane/core/collisions.d.ts +39 -0
- package/dist/apps/control-plane/core/collisions.js +78 -0
- package/dist/apps/control-plane/core/collisions.js.map +1 -0
- package/dist/apps/control-plane/core/constants.d.ts +64 -0
- package/dist/apps/control-plane/core/constants.js +64 -0
- package/dist/apps/control-plane/core/constants.js.map +1 -0
- package/dist/apps/control-plane/core/error-codes.d.ts +50 -0
- package/dist/apps/control-plane/core/error-codes.js +52 -0
- package/dist/apps/control-plane/core/error-codes.js.map +1 -0
- package/dist/apps/control-plane/core/frontmatter.d.ts +11 -0
- package/dist/apps/control-plane/core/frontmatter.js +30 -0
- package/dist/apps/control-plane/core/frontmatter.js.map +1 -0
- package/dist/apps/control-plane/core/fs.d.ts +33 -0
- package/dist/apps/control-plane/core/fs.js +134 -0
- package/dist/apps/control-plane/core/fs.js.map +1 -0
- package/dist/apps/control-plane/core/gates.d.ts +88 -0
- package/dist/apps/control-plane/core/gates.js +229 -0
- package/dist/apps/control-plane/core/gates.js.map +1 -0
- package/dist/apps/control-plane/core/git.d.ts +31 -0
- package/dist/apps/control-plane/core/git.js +79 -0
- package/dist/apps/control-plane/core/git.js.map +1 -0
- package/dist/apps/control-plane/core/kernel.d.ts +445 -0
- package/dist/apps/control-plane/core/kernel.js +805 -0
- package/dist/apps/control-plane/core/kernel.js.map +1 -0
- package/dist/apps/control-plane/core/patch.d.ts +23 -0
- package/dist/apps/control-plane/core/patch.js +118 -0
- package/dist/apps/control-plane/core/patch.js.map +1 -0
- package/dist/apps/control-plane/core/path-layout.d.ts +23 -0
- package/dist/apps/control-plane/core/path-layout.js +90 -0
- package/dist/apps/control-plane/core/path-layout.js.map +1 -0
- package/dist/apps/control-plane/core/path-rules.d.ts +13 -0
- package/dist/apps/control-plane/core/path-rules.js +52 -0
- package/dist/apps/control-plane/core/path-rules.js.map +1 -0
- package/dist/apps/control-plane/core/qa-index.d.ts +53 -0
- package/dist/apps/control-plane/core/qa-index.js +112 -0
- package/dist/apps/control-plane/core/qa-index.js.map +1 -0
- package/dist/apps/control-plane/core/response.d.ts +19 -0
- package/dist/apps/control-plane/core/response.js +34 -0
- package/dist/apps/control-plane/core/response.js.map +1 -0
- package/dist/apps/control-plane/core/runtime-sessions.d.ts +19 -0
- package/dist/apps/control-plane/core/runtime-sessions.js +2 -0
- package/dist/apps/control-plane/core/runtime-sessions.js.map +1 -0
- package/dist/apps/control-plane/core/schemas.d.ts +23 -0
- package/dist/apps/control-plane/core/schemas.js +80 -0
- package/dist/apps/control-plane/core/schemas.js.map +1 -0
- package/dist/apps/control-plane/index.d.ts +11 -0
- package/dist/apps/control-plane/index.js +9 -0
- package/dist/apps/control-plane/index.js.map +1 -0
- package/dist/apps/control-plane/interfaces/cli/bootstrap.d.ts +2 -0
- package/dist/apps/control-plane/interfaces/cli/bootstrap.js +86 -0
- package/dist/apps/control-plane/interfaces/cli/bootstrap.js.map +1 -0
- package/dist/apps/control-plane/mcp/kernel-tool-executor.d.ts +14 -0
- package/dist/apps/control-plane/mcp/kernel-tool-executor.js +26 -0
- package/dist/apps/control-plane/mcp/kernel-tool-executor.js.map +1 -0
- package/dist/apps/control-plane/mcp/mcp-server-adapter.d.ts +19 -0
- package/dist/apps/control-plane/mcp/mcp-server-adapter.js +55 -0
- package/dist/apps/control-plane/mcp/mcp-server-adapter.js.map +1 -0
- package/dist/apps/control-plane/mcp/operation-ledger.d.ts +21 -0
- package/dist/apps/control-plane/mcp/operation-ledger.js +75 -0
- package/dist/apps/control-plane/mcp/operation-ledger.js.map +1 -0
- package/dist/apps/control-plane/mcp/protocol-contract.d.ts +8 -0
- package/dist/apps/control-plane/mcp/protocol-contract.js +9 -0
- package/dist/apps/control-plane/mcp/protocol-contract.js.map +1 -0
- package/dist/apps/control-plane/mcp/runtime-factory.d.ts +38 -0
- package/dist/apps/control-plane/mcp/runtime-factory.js +71 -0
- package/dist/apps/control-plane/mcp/runtime-factory.js.map +1 -0
- package/dist/apps/control-plane/mcp/runtime-types.d.ts +40 -0
- package/dist/apps/control-plane/mcp/runtime-types.js +2 -0
- package/dist/apps/control-plane/mcp/runtime-types.js.map +1 -0
- package/dist/apps/control-plane/mcp/token-auth-verifier.d.ts +24 -0
- package/dist/apps/control-plane/mcp/token-auth-verifier.js +45 -0
- package/dist/apps/control-plane/mcp/token-auth-verifier.js.map +1 -0
- package/dist/apps/control-plane/mcp/token-claims-validator.d.ts +9 -0
- package/dist/apps/control-plane/mcp/token-claims-validator.js +62 -0
- package/dist/apps/control-plane/mcp/token-claims-validator.js.map +1 -0
- package/dist/apps/control-plane/mcp/token-codec.d.ts +11 -0
- package/dist/apps/control-plane/mcp/token-codec.js +46 -0
- package/dist/apps/control-plane/mcp/token-codec.js.map +1 -0
- package/dist/apps/control-plane/mcp/tool-authorizer.d.ts +8 -0
- package/dist/apps/control-plane/mcp/tool-authorizer.js +36 -0
- package/dist/apps/control-plane/mcp/tool-authorizer.js.map +1 -0
- package/dist/apps/control-plane/mcp/tool-client.d.ts +30 -0
- package/dist/apps/control-plane/mcp/tool-client.js +50 -0
- package/dist/apps/control-plane/mcp/tool-client.js.map +1 -0
- package/dist/apps/control-plane/mcp/tool-contract-validator.d.ts +29 -0
- package/dist/apps/control-plane/mcp/tool-contract-validator.js +61 -0
- package/dist/apps/control-plane/mcp/tool-contract-validator.js.map +1 -0
- package/dist/apps/control-plane/mcp/tool-registry-loader.d.ts +15 -0
- package/dist/apps/control-plane/mcp/tool-registry-loader.js +109 -0
- package/dist/apps/control-plane/mcp/tool-registry-loader.js.map +1 -0
- package/dist/apps/control-plane/mcp/tool-runtime.d.ts +34 -0
- package/dist/apps/control-plane/mcp/tool-runtime.js +252 -0
- package/dist/apps/control-plane/mcp/tool-runtime.js.map +1 -0
- package/dist/apps/control-plane/mcp/tools-markdown-generator.d.ts +7 -0
- package/dist/apps/control-plane/mcp/tools-markdown-generator.js +22 -0
- package/dist/apps/control-plane/mcp/tools-markdown-generator.js.map +1 -0
- package/dist/apps/control-plane/mcp/transport-types.d.ts +14 -0
- package/dist/apps/control-plane/mcp/transport-types.js +2 -0
- package/dist/apps/control-plane/mcp/transport-types.js.map +1 -0
- package/dist/apps/control-plane/mcp/types.d.ts +2 -0
- package/dist/apps/control-plane/mcp/types.js +3 -0
- package/dist/apps/control-plane/mcp/types.js.map +1 -0
- package/dist/apps/control-plane/providers/providers.d.ts +72 -0
- package/dist/apps/control-plane/providers/providers.js +94 -0
- package/dist/apps/control-plane/providers/providers.js.map +1 -0
- package/dist/apps/control-plane/supervisor/build-wave-executor.d.ts +13 -0
- package/dist/apps/control-plane/supervisor/build-wave-executor.js +40 -0
- package/dist/apps/control-plane/supervisor/build-wave-executor.js.map +1 -0
- package/dist/apps/control-plane/supervisor/lease-heartbeat-service.d.ts +12 -0
- package/dist/apps/control-plane/supervisor/lease-heartbeat-service.js +14 -0
- package/dist/apps/control-plane/supervisor/lease-heartbeat-service.js.map +1 -0
- package/dist/apps/control-plane/supervisor/planning-wave-executor.d.ts +19 -0
- package/dist/apps/control-plane/supervisor/planning-wave-executor.js +249 -0
- package/dist/apps/control-plane/supervisor/planning-wave-executor.js.map +1 -0
- package/dist/apps/control-plane/supervisor/prompt-bundle-loader.d.ts +9 -0
- package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js +53 -0
- package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js.map +1 -0
- package/dist/apps/control-plane/supervisor/qa-wave-executor.d.ts +24 -0
- package/dist/apps/control-plane/supervisor/qa-wave-executor.js +70 -0
- package/dist/apps/control-plane/supervisor/qa-wave-executor.js.map +1 -0
- package/dist/apps/control-plane/supervisor/run-coordinator.d.ts +49 -0
- package/dist/apps/control-plane/supervisor/run-coordinator.js +162 -0
- package/dist/apps/control-plane/supervisor/run-coordinator.js.map +1 -0
- package/dist/apps/control-plane/supervisor/runtime.d.ts +58 -0
- package/dist/apps/control-plane/supervisor/runtime.js +270 -0
- package/dist/apps/control-plane/supervisor/runtime.js.map +1 -0
- package/dist/apps/control-plane/supervisor/session-orchestrator.d.ts +29 -0
- package/dist/apps/control-plane/supervisor/session-orchestrator.js +211 -0
- package/dist/apps/control-plane/supervisor/session-orchestrator.js.map +1 -0
- package/dist/apps/control-plane/supervisor/types.d.ts +148 -0
- package/dist/apps/control-plane/supervisor/types.js +2 -0
- package/dist/apps/control-plane/supervisor/types.js.map +1 -0
- package/dist/apps/control-plane/supervisor/worker-decision-loop.d.ts +37 -0
- package/dist/apps/control-plane/supervisor/worker-decision-loop.js +236 -0
- package/dist/apps/control-plane/supervisor/worker-decision-loop.js.map +1 -0
- package/docker/mcp.Dockerfile +14 -0
- package/docker/mcp.compose.yaml +15 -0
- package/docker/mcp.entrypoint.sh +17 -0
- package/eslint.config.mjs +93 -0
- package/example-configurations/README.md +26 -0
- package/example-configurations/java/agents.yaml +14 -0
- package/example-configurations/java/gates.yaml +29 -0
- package/example-configurations/java/policy.yaml +148 -0
- package/example-configurations/node/agents.yaml +14 -0
- package/example-configurations/node/gates.yaml +32 -0
- package/example-configurations/node/policy.yaml +143 -0
- package/nx.json +16 -0
- package/package.json +39 -0
- package/prompts/vitest-testing-standards.instructions.md +204 -0
- package/scripts/dev-shell-env.sh +7 -0
- package/scripts/nx-safe.mjs +33 -0
- package/spec-files/agentic_orchestrator_cli_delete_command_spec.md +310 -0
- package/spec-files/agentic_orchestrator_dot_aop_generated_artifacts_spec.md +211 -0
- package/spec-files/agentic_orchestrator_mcp_formalization_spec.md +379 -0
- package/spec-files/agentic_orchestrator_oop_refactor_spec.md +415 -0
- package/spec-files/agentic_orchestrator_single_global_orchestrator_spec.md +265 -0
- package/spec-files/agentic_orchestrator_spec.md +1334 -0
- package/spec-files/progress.md +452 -0
- package/tsconfig.base.json +15 -0
- package/tsconfig.json +11 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ERROR_CODES } from './error-codes.js';
|
|
2
|
+
export function ok(data = {}, evidence) {
|
|
3
|
+
const response = { ok: true, data };
|
|
4
|
+
if (evidence) {
|
|
5
|
+
response.evidence = evidence;
|
|
6
|
+
}
|
|
7
|
+
return response;
|
|
8
|
+
}
|
|
9
|
+
export function fail(code, message, details = {}, evidence) {
|
|
10
|
+
const normalizedCode = Object.values(ERROR_CODES).includes(code)
|
|
11
|
+
? code
|
|
12
|
+
: ERROR_CODES.INTERNAL_ERROR;
|
|
13
|
+
const response = {
|
|
14
|
+
ok: false,
|
|
15
|
+
error: {
|
|
16
|
+
code: normalizedCode,
|
|
17
|
+
message,
|
|
18
|
+
details
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
if (evidence) {
|
|
22
|
+
response.evidence = evidence;
|
|
23
|
+
}
|
|
24
|
+
return response;
|
|
25
|
+
}
|
|
26
|
+
export function withSuggestedActions(details, actions = []) {
|
|
27
|
+
return {
|
|
28
|
+
...details,
|
|
29
|
+
retryable: details.retryable ?? false,
|
|
30
|
+
requires_human: details.requires_human ?? false,
|
|
31
|
+
suggested_next_actions: actions
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=response.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"response.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/core/response.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAkB,MAAM,kBAAkB,CAAC;AAoB/D,MAAM,UAAU,EAAE,CAA8B,OAAU,EAAO,EAAE,QAAkC;IACnG,MAAM,QAAQ,GAAkB,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IACnD,IAAI,QAAQ,EAAE,CAAC;QACb,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC/B,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,IAAI,CAClB,IAAY,EACZ,OAAe,EACf,UAAmC,EAAE,EACrC,QAAkC;IAElC,MAAM,cAAc,GAAI,MAAM,CAAC,MAAM,CAAC,WAAW,CAAc,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC5E,CAAC,CAAE,IAAkB;QACrB,CAAC,CAAC,WAAW,CAAC,cAAc,CAAC;IAC/B,MAAM,QAAQ,GAAiB;QAC7B,EAAE,EAAE,KAAK;QACT,KAAK,EAAE;YACL,IAAI,EAAE,cAAc;YACpB,OAAO;YACP,OAAO;SACR;KACF,CAAC;IACF,IAAI,QAAQ,EAAE,CAAC;QACb,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC/B,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,OAAgC,EAChC,UAAoB,EAAE;IAEtB,OAAO;QACL,GAAG,OAAO;QACV,SAAS,EAAG,OAAO,CAAC,SAAiC,IAAI,KAAK;QAC9D,cAAc,EAAG,OAAO,CAAC,cAAsC,IAAI,KAAK;QACxE,sBAAsB,EAAE,OAAO;KAChC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export interface RuntimeFeatureSessions {
|
|
2
|
+
planner_session_id: string;
|
|
3
|
+
builder_session_id: string;
|
|
4
|
+
qa_session_id: string;
|
|
5
|
+
}
|
|
6
|
+
export interface RuntimeSessionsSnapshot {
|
|
7
|
+
run_id: string;
|
|
8
|
+
orchestrator_session_id: string;
|
|
9
|
+
provider: string;
|
|
10
|
+
model: string;
|
|
11
|
+
provider_config_ref_hash: string;
|
|
12
|
+
owner_instance_id: string;
|
|
13
|
+
lease_id: string;
|
|
14
|
+
started_at: string;
|
|
15
|
+
last_heartbeat_at: string;
|
|
16
|
+
lease_expires_at: string;
|
|
17
|
+
orchestrator_epoch?: number;
|
|
18
|
+
feature_sessions?: Record<string, RuntimeFeatureSessions>;
|
|
19
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-sessions.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/core/runtime-sessions.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { ErrorObject, ValidateFunction } from 'ajv';
|
|
2
|
+
export type SchemaId = string;
|
|
3
|
+
export interface ValidationResult {
|
|
4
|
+
valid: boolean;
|
|
5
|
+
errors: ErrorObject[];
|
|
6
|
+
}
|
|
7
|
+
export interface SchemaValidator {
|
|
8
|
+
validate(name: SchemaId, payload: unknown): Promise<ValidationResult>;
|
|
9
|
+
}
|
|
10
|
+
export declare class SchemaRegistry implements SchemaValidator {
|
|
11
|
+
readonly repoRoot: string;
|
|
12
|
+
private readonly ajv;
|
|
13
|
+
private readonly validators;
|
|
14
|
+
constructor(repoRoot: string);
|
|
15
|
+
schemaPath(name: SchemaId): string;
|
|
16
|
+
loadSchema(name: SchemaId): Promise<ValidateFunction>;
|
|
17
|
+
validate(name: SchemaId, payload: unknown): Promise<ValidationResult>;
|
|
18
|
+
}
|
|
19
|
+
export declare function loadYamlFile<T = unknown>(filePath: string): Promise<T>;
|
|
20
|
+
export declare function loadAndValidateYaml<T = unknown>(schemaRegistry: SchemaValidator, schemaName: SchemaId, yamlPath: string): Promise<{
|
|
21
|
+
parsed: T;
|
|
22
|
+
validation: ValidationResult;
|
|
23
|
+
}>;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import fs from 'node:fs/promises';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import YAML from 'yaml';
|
|
4
|
+
import Ajv2020Import from 'ajv/dist/2020.js';
|
|
5
|
+
const RFC3339_DATE_TIME = /^(\d{4})-(\d{2})-(\d{2})T([0-2]\d):([0-5]\d):([0-5]\d)(\.\d{1,9})?(Z|([+-])([0-2]\d):([0-5]\d))$/;
|
|
6
|
+
function isStrictRfc3339DateTime(value) {
|
|
7
|
+
if (typeof value !== 'string') {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
const match = RFC3339_DATE_TIME.exec(value);
|
|
11
|
+
if (!match) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
const year = Number(match[1]);
|
|
15
|
+
const month = Number(match[2]);
|
|
16
|
+
const day = Number(match[3]);
|
|
17
|
+
const hour = Number(match[4]);
|
|
18
|
+
const minute = Number(match[5]);
|
|
19
|
+
const second = Number(match[6]);
|
|
20
|
+
const offsetHour = Number(match[10] ?? 0);
|
|
21
|
+
const offsetMinute = Number(match[11] ?? 0);
|
|
22
|
+
if (month < 1 || month > 12) {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
const daysInMonth = new Date(Date.UTC(year, month, 0)).getUTCDate();
|
|
26
|
+
if (day < 1 || day > daysInMonth) {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
if (hour > 23 || minute > 59 || second > 59) {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
if (offsetHour > 23 || offsetMinute > 59) {
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
return !Number.isNaN(Date.parse(value));
|
|
36
|
+
}
|
|
37
|
+
export class SchemaRegistry {
|
|
38
|
+
repoRoot;
|
|
39
|
+
ajv;
|
|
40
|
+
validators;
|
|
41
|
+
constructor(repoRoot) {
|
|
42
|
+
this.repoRoot = repoRoot;
|
|
43
|
+
const Ajv2020Ctor = Ajv2020Import;
|
|
44
|
+
this.ajv = new Ajv2020Ctor({ allErrors: true, strict: false });
|
|
45
|
+
this.ajv.addFormat?.('date-time', {
|
|
46
|
+
type: 'string',
|
|
47
|
+
validate: isStrictRfc3339DateTime
|
|
48
|
+
});
|
|
49
|
+
this.validators = new Map();
|
|
50
|
+
}
|
|
51
|
+
schemaPath(name) {
|
|
52
|
+
return path.join(this.repoRoot, 'agentic', 'orchestrator', 'schemas', name);
|
|
53
|
+
}
|
|
54
|
+
async loadSchema(name) {
|
|
55
|
+
const filePath = this.schemaPath(name);
|
|
56
|
+
const schemaText = await fs.readFile(filePath, 'utf8');
|
|
57
|
+
const schema = JSON.parse(schemaText);
|
|
58
|
+
const validator = this.ajv.compile(schema);
|
|
59
|
+
this.validators.set(name, validator);
|
|
60
|
+
return validator;
|
|
61
|
+
}
|
|
62
|
+
async validate(name, payload) {
|
|
63
|
+
const validator = this.validators.get(name) ?? (await this.loadSchema(name));
|
|
64
|
+
const valid = validator(payload);
|
|
65
|
+
return {
|
|
66
|
+
valid: Boolean(valid),
|
|
67
|
+
errors: valid ? [] : ((validator.errors ?? []))
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
export async function loadYamlFile(filePath) {
|
|
72
|
+
const raw = await fs.readFile(filePath, 'utf8');
|
|
73
|
+
return YAML.parse(raw);
|
|
74
|
+
}
|
|
75
|
+
export async function loadAndValidateYaml(schemaRegistry, schemaName, yamlPath) {
|
|
76
|
+
const parsed = await loadYamlFile(yamlPath);
|
|
77
|
+
const validation = await schemaRegistry.validate(schemaName, parsed);
|
|
78
|
+
return { parsed, validation };
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/core/schemas.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { AopKernel } from './core/kernel.js';
|
|
2
|
+
export type { AgentsConfigSnapshot } from './core/kernel.js';
|
|
3
|
+
export { SupervisorRuntime } from './supervisor/runtime.js';
|
|
4
|
+
export { resolveProviderSelection, NullWorkerProvider } from './providers/providers.js';
|
|
5
|
+
export type { WorkerProvider, ProviderSelectionResolver } from './providers/providers.js';
|
|
6
|
+
export { createToolingRuntime, resolveToolClient } from './mcp/runtime-factory.js';
|
|
7
|
+
export type { ToolingKernelPort, CreateToolingRuntimeOptions } from './mcp/runtime-factory.js';
|
|
8
|
+
export { InProcessToolClient, McpToolClient, createOperationId } from './mcp/tool-client.js';
|
|
9
|
+
export { TokenAuthVerifier } from './mcp/token-auth-verifier.js';
|
|
10
|
+
export { McpServerAdapter } from './mcp/mcp-server-adapter.js';
|
|
11
|
+
export { TOOL_BEHAVIOR_METADATA, isMutatingTool, toolRequiresOperationId } from './application/tools/tool-metadata.js';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { AopKernel } from './core/kernel.js';
|
|
2
|
+
export { SupervisorRuntime } from './supervisor/runtime.js';
|
|
3
|
+
export { resolveProviderSelection, NullWorkerProvider } from './providers/providers.js';
|
|
4
|
+
export { createToolingRuntime, resolveToolClient } from './mcp/runtime-factory.js';
|
|
5
|
+
export { InProcessToolClient, McpToolClient, createOperationId } from './mcp/tool-client.js';
|
|
6
|
+
export { TokenAuthVerifier } from './mcp/token-auth-verifier.js';
|
|
7
|
+
export { McpServerAdapter } from './mcp/mcp-server-adapter.js';
|
|
8
|
+
export { TOOL_BEHAVIOR_METADATA, isMutatingTool, toolRequiresOperationId } from './application/tools/tool-metadata.js';
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../apps/control-plane/src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EACL,wBAAwB,EACxB,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAElC,OAAO,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAKnF,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAC7F,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EACL,sBAAsB,EACtB,cAAc,EACd,uBAAuB,EACxB,MAAM,sCAAsC,CAAC"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import crypto from 'node:crypto';
|
|
2
|
+
import { AopKernel } from '../../core/kernel.js';
|
|
3
|
+
import { ERROR_CODES } from '../../core/error-codes.js';
|
|
4
|
+
import { createToolingRuntime, resolveToolClient } from '../../mcp/runtime-factory.js';
|
|
5
|
+
import { CliArgumentParser } from '../../cli/cli-argument-parser.js';
|
|
6
|
+
import { printError, printPayload } from '../../cli/io.js';
|
|
7
|
+
import { StatusCommandHandler } from '../../cli/status-command-handler.js';
|
|
8
|
+
import { ResumeCommandHandler } from '../../cli/resume-command-handler.js';
|
|
9
|
+
import { StopCommandHandler } from '../../cli/stop-command-handler.js';
|
|
10
|
+
import { DeleteCommandHandler } from '../../cli/delete-command-handler.js';
|
|
11
|
+
import { RunCommandHandler } from '../../cli/run-command-handler.js';
|
|
12
|
+
const SUPPORTED_COMMANDS = new Set(['run', 'status', 'resume', 'stop', 'delete']);
|
|
13
|
+
export async function runCli(argv = process.argv.slice(2), runtime = { cwd: process.cwd(), env: process.env }) {
|
|
14
|
+
const parser = new CliArgumentParser();
|
|
15
|
+
const options = parser.parse(argv);
|
|
16
|
+
const repoRoot = runtime.cwd;
|
|
17
|
+
try {
|
|
18
|
+
if (!SUPPORTED_COMMANDS.has(options.command)) {
|
|
19
|
+
printError(ERROR_CODES.INVALID_CLI_ARGS, `Unknown command: ${options.command}`, {
|
|
20
|
+
command: options.command
|
|
21
|
+
});
|
|
22
|
+
return 1;
|
|
23
|
+
}
|
|
24
|
+
const transport = parser.resolveTransport(options.transport);
|
|
25
|
+
const runId = `run:${crypto.randomUUID()}`;
|
|
26
|
+
const kernel = new AopKernel(repoRoot);
|
|
27
|
+
await kernel.ensureLoaded();
|
|
28
|
+
const tooling = await createToolingRuntime(repoRoot, kernel);
|
|
29
|
+
const toolClient = resolveToolClient(transport, tooling);
|
|
30
|
+
if (options.command === 'status') {
|
|
31
|
+
const handler = new StatusCommandHandler(toolClient, runId);
|
|
32
|
+
const payload = await handler.execute();
|
|
33
|
+
printPayload(payload);
|
|
34
|
+
return 0;
|
|
35
|
+
}
|
|
36
|
+
if (options.command === 'resume') {
|
|
37
|
+
const handler = new ResumeCommandHandler();
|
|
38
|
+
const payload = await handler.execute({
|
|
39
|
+
repoRoot,
|
|
40
|
+
env: runtime.env,
|
|
41
|
+
runId,
|
|
42
|
+
transport,
|
|
43
|
+
options,
|
|
44
|
+
kernel,
|
|
45
|
+
toolClient
|
|
46
|
+
});
|
|
47
|
+
printPayload(payload);
|
|
48
|
+
return 0;
|
|
49
|
+
}
|
|
50
|
+
if (options.command === 'stop') {
|
|
51
|
+
const handler = new StopCommandHandler();
|
|
52
|
+
const payload = await handler.execute();
|
|
53
|
+
printPayload(payload);
|
|
54
|
+
return 0;
|
|
55
|
+
}
|
|
56
|
+
if (options.command === 'delete') {
|
|
57
|
+
const handler = new DeleteCommandHandler(toolClient, runId);
|
|
58
|
+
const payload = await handler.execute(options);
|
|
59
|
+
printPayload(payload);
|
|
60
|
+
return 0;
|
|
61
|
+
}
|
|
62
|
+
const handler = new RunCommandHandler();
|
|
63
|
+
const payload = await handler.execute({
|
|
64
|
+
repoRoot,
|
|
65
|
+
env: runtime.env,
|
|
66
|
+
runId,
|
|
67
|
+
transport,
|
|
68
|
+
options,
|
|
69
|
+
kernel,
|
|
70
|
+
toolClient
|
|
71
|
+
});
|
|
72
|
+
printPayload(payload);
|
|
73
|
+
return 0;
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
const typed = error;
|
|
77
|
+
const code = typed.code || ERROR_CODES.INTERNAL_ERROR;
|
|
78
|
+
printError(code, typed.message || 'Unhandled CLI error', {
|
|
79
|
+
...(typed.details ?? {}),
|
|
80
|
+
retryable: false,
|
|
81
|
+
requires_human: true
|
|
82
|
+
});
|
|
83
|
+
return 1;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=bootstrap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../../../../../apps/control-plane/src/interfaces/cli/bootstrap.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type ToolResponse } from '../core/response.js';
|
|
2
|
+
import type { ToolCatalogEntry, VerifiedActorClaims } from './runtime-types.js';
|
|
3
|
+
export interface ToolExecutionRouterPort {
|
|
4
|
+
dispatchTool(toolName: string, args: Record<string, unknown>, context: {
|
|
5
|
+
actorType: string;
|
|
6
|
+
actorId: string;
|
|
7
|
+
}): Promise<unknown>;
|
|
8
|
+
normalizeError(error: unknown): ToolResponse;
|
|
9
|
+
}
|
|
10
|
+
export declare class KernelToolExecutor {
|
|
11
|
+
readonly router: ToolExecutionRouterPort;
|
|
12
|
+
constructor(router: ToolExecutionRouterPort);
|
|
13
|
+
execute(tool: ToolCatalogEntry, args: Record<string, unknown>, claims: VerifiedActorClaims): Promise<ToolResponse>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ok } from '../core/response.js';
|
|
2
|
+
export class KernelToolExecutor {
|
|
3
|
+
router;
|
|
4
|
+
constructor(router) {
|
|
5
|
+
this.router = router;
|
|
6
|
+
}
|
|
7
|
+
async execute(tool, args, claims) {
|
|
8
|
+
try {
|
|
9
|
+
const result = (await this.router.dispatchTool(tool.name, args, {
|
|
10
|
+
actorType: claims.actor_type,
|
|
11
|
+
actorId: claims.actor_id
|
|
12
|
+
}));
|
|
13
|
+
const payload = result.data && typeof result.data === 'object'
|
|
14
|
+
? result.data
|
|
15
|
+
: result;
|
|
16
|
+
const evidence = result.evidence && typeof result.evidence === 'object'
|
|
17
|
+
? result.evidence
|
|
18
|
+
: undefined;
|
|
19
|
+
return ok(payload, evidence);
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
return this.router.normalizeError(error);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=kernel-tool-executor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kernel-tool-executor.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/mcp/kernel-tool-executor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAqB,MAAM,qBAAqB,CAAC;AAY5D,MAAM,OAAO,kBAAkB;IACpB,MAAM,CAA0B;IAEzC,YAAY,MAA+B;QACzC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,IAAsB,EAAE,IAA6B,EAAE,MAA2B;QAC9F,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE;gBAC9D,SAAS,EAAE,MAAM,CAAC,UAAU;gBAC5B,OAAO,EAAE,MAAM,CAAC,QAAQ;aACzB,CAAC,CAA4B,CAAC;YAC/B,MAAM,OAAO,GACX,MAAM,CAAC,IAAI,IAAI,OAAO,MAAM,CAAC,IAAI,KAAK,QAAQ;gBAC5C,CAAC,CAAE,MAAM,CAAC,IAAgC;gBAC1C,CAAC,CAAC,MAAM,CAAC;YACb,MAAM,QAAQ,GACZ,MAAM,CAAC,QAAQ,IAAI,OAAO,MAAM,CAAC,QAAQ,KAAK,QAAQ;gBACpD,CAAC,CAAE,MAAM,CAAC,QAAoC;gBAC9C,CAAC,CAAC,SAAS,CAAC;YAChB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC/B,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { ToolResponse } from '../core/response.js';
|
|
2
|
+
import type { ToolDescriptor } from './transport-types.js';
|
|
3
|
+
import { type TokenAuthVerifier } from './token-auth-verifier.js';
|
|
4
|
+
import { type ToolRuntime } from './tool-runtime.js';
|
|
5
|
+
interface McpCallRequest {
|
|
6
|
+
name: string;
|
|
7
|
+
arguments?: Record<string, unknown>;
|
|
8
|
+
session_token?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare class McpServerAdapter {
|
|
11
|
+
readonly authVerifier: TokenAuthVerifier;
|
|
12
|
+
readonly runtime: ToolRuntime;
|
|
13
|
+
constructor(runtime: ToolRuntime, authVerifier: TokenAuthVerifier);
|
|
14
|
+
toolsList(): Promise<{
|
|
15
|
+
tools: ToolDescriptor[];
|
|
16
|
+
}>;
|
|
17
|
+
toolsCall(request: McpCallRequest): Promise<ToolResponse>;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { ERROR_CODES } from '../core/error-codes.js';
|
|
2
|
+
import { fail } from '../core/response.js';
|
|
3
|
+
function extractActorClaimsFromArgs(args) {
|
|
4
|
+
const actor_type = typeof args.actor_type === 'string' ? args.actor_type : undefined;
|
|
5
|
+
const actor_id = typeof args.actor_id === 'string' ? args.actor_id : undefined;
|
|
6
|
+
return { actor_type, actor_id };
|
|
7
|
+
}
|
|
8
|
+
export class McpServerAdapter {
|
|
9
|
+
authVerifier;
|
|
10
|
+
runtime;
|
|
11
|
+
constructor(runtime, authVerifier) {
|
|
12
|
+
this.runtime = runtime;
|
|
13
|
+
this.authVerifier = authVerifier;
|
|
14
|
+
}
|
|
15
|
+
async toolsList() {
|
|
16
|
+
const tools = await this.runtime.listTools();
|
|
17
|
+
return { tools };
|
|
18
|
+
}
|
|
19
|
+
async toolsCall(request) {
|
|
20
|
+
const args = { ...(request.arguments ?? {}) };
|
|
21
|
+
try {
|
|
22
|
+
const claims = this.authVerifier.verifyToken(request.session_token ?? '');
|
|
23
|
+
const supplied = extractActorClaimsFromArgs(args);
|
|
24
|
+
if ((supplied.actor_type && supplied.actor_type !== claims.actor_type) || (supplied.actor_id && supplied.actor_id !== claims.actor_id)) {
|
|
25
|
+
return fail(ERROR_CODES.INVALID_ACTOR_CLAIM, 'actor claim does not match signed token', {
|
|
26
|
+
retryable: false,
|
|
27
|
+
requires_human: true,
|
|
28
|
+
supplied,
|
|
29
|
+
token_claims: {
|
|
30
|
+
actor_type: claims.actor_type,
|
|
31
|
+
actor_id: claims.actor_id
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
delete args.actor_type;
|
|
36
|
+
delete args.actor_id;
|
|
37
|
+
return this.runtime.callTool(request.name, args, claims);
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
if (typeof error === 'object' &&
|
|
41
|
+
error !== null &&
|
|
42
|
+
'normalizedResponse' in error) {
|
|
43
|
+
return error.normalizedResponse;
|
|
44
|
+
}
|
|
45
|
+
const message = typeof error === 'object' && error !== null && 'message' in error
|
|
46
|
+
? error.message
|
|
47
|
+
: undefined;
|
|
48
|
+
return fail(ERROR_CODES.UNAUTHENTICATED, String(message ?? error), {
|
|
49
|
+
retryable: false,
|
|
50
|
+
requires_human: true
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=mcp-server-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mcp-server-adapter.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/mcp/mcp-server-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAY3C,SAAS,0BAA0B,CAAC,IAA6B;IAC/D,MAAM,UAAU,GAAG,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;IACrF,MAAM,QAAQ,GAAG,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/E,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;AAClC,CAAC;AAED,MAAM,OAAO,gBAAgB;IAClB,YAAY,CAAoB;IAChC,OAAO,CAAc;IAE9B,YAAY,OAAoB,EAAE,YAA+B;QAC/D,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,SAAS;QACb,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QAC7C,OAAO,EAAE,KAAK,EAAE,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,OAAuB;QACrC,MAAM,IAAI,GAAG,EAAE,GAAG,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC,EAAE,CAAC;QAE9C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;YAC1E,MAAM,QAAQ,GAAG,0BAA0B,CAAC,IAAI,CAAC,CAAC;YAClD,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAI,QAAQ,CAAC,UAAU,KAAK,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACvI,OAAO,IAAI,CAAC,WAAW,CAAC,mBAAmB,EAAE,yCAAyC,EAAE;oBACtF,SAAS,EAAE,KAAK;oBAChB,cAAc,EAAE,IAAI;oBACpB,QAAQ;oBACR,YAAY,EAAE;wBACZ,UAAU,EAAE,MAAM,CAAC,UAAU;wBAC7B,QAAQ,EAAE,MAAM,CAAC,QAAQ;qBAC1B;iBACF,CAAC,CAAC;YACL,CAAC;YAED,OAAO,IAAI,CAAC,UAAU,CAAC;YACvB,OAAO,IAAI,CAAC,QAAQ,CAAC;YAErB,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAC3D,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACxB,IACE,OAAO,KAAK,KAAK,QAAQ;gBACzB,KAAK,KAAK,IAAI;gBACd,oBAAoB,IAAI,KAAK,EAC7B,CAAC;gBACD,OAAQ,KAA8C,CAAC,kBAAkB,CAAC;YAC5E,CAAC;YACD,MAAM,OAAO,GACX,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,SAAS,IAAI,KAAK;gBAC/D,CAAC,CAAE,KAA+B,CAAC,OAAO;gBAC1C,CAAC,CAAC,SAAS,CAAC;YAChB,OAAO,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,EAAE;gBACjE,SAAS,EAAE,KAAK;gBAChB,cAAc,EAAE,IAAI;aACrB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { AopPathLayout } from '../core/path-layout.js';
|
|
2
|
+
import type { ToolResponse } from '../core/response.js';
|
|
3
|
+
export declare class OperationLedger {
|
|
4
|
+
readonly repoRoot: string;
|
|
5
|
+
readonly pathLayout: AopPathLayout;
|
|
6
|
+
constructor(repoRoot: string);
|
|
7
|
+
get ledgerRoot(): string;
|
|
8
|
+
ledgerPath(runId: string): string;
|
|
9
|
+
lockPath(runId: string): string;
|
|
10
|
+
ensureRunLedger(runId: string): Promise<void>;
|
|
11
|
+
resolveOperation(runId: string, operationId: string, requestHash: string): Promise<{
|
|
12
|
+
status: 'new';
|
|
13
|
+
} | {
|
|
14
|
+
status: 'replay';
|
|
15
|
+
response: ToolResponse;
|
|
16
|
+
} | {
|
|
17
|
+
status: 'mismatch';
|
|
18
|
+
existing_hash: string;
|
|
19
|
+
}>;
|
|
20
|
+
recordOperation(runId: string, operationId: string, toolName: string, requestHash: string, response: ToolResponse): Promise<void>;
|
|
21
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { atomicWriteJson, ensureDir, readJson, withFileLock, nowIso } from '../core/fs.js';
|
|
3
|
+
import { AopPathLayout } from '../core/path-layout.js';
|
|
4
|
+
export class OperationLedger {
|
|
5
|
+
repoRoot;
|
|
6
|
+
pathLayout;
|
|
7
|
+
constructor(repoRoot) {
|
|
8
|
+
this.repoRoot = repoRoot;
|
|
9
|
+
this.pathLayout = new AopPathLayout(repoRoot);
|
|
10
|
+
}
|
|
11
|
+
get ledgerRoot() {
|
|
12
|
+
return this.pathLayout.operationLedgerRoot;
|
|
13
|
+
}
|
|
14
|
+
ledgerPath(runId) {
|
|
15
|
+
return path.join(this.ledgerRoot, `${runId}.json`);
|
|
16
|
+
}
|
|
17
|
+
lockPath(runId) {
|
|
18
|
+
return path.join(this.ledgerRoot, `${runId}.lock`);
|
|
19
|
+
}
|
|
20
|
+
async ensureRunLedger(runId) {
|
|
21
|
+
await ensureDir(this.ledgerRoot);
|
|
22
|
+
const existing = await readJson(this.ledgerPath(runId), null);
|
|
23
|
+
if (!existing) {
|
|
24
|
+
await atomicWriteJson(this.ledgerPath(runId), {
|
|
25
|
+
run_id: runId,
|
|
26
|
+
updated_at: nowIso(),
|
|
27
|
+
operations: {}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
async resolveOperation(runId, operationId, requestHash) {
|
|
32
|
+
await this.ensureRunLedger(runId);
|
|
33
|
+
return await withFileLock(this.lockPath(runId), async () => {
|
|
34
|
+
const ledger = await readJson(this.ledgerPath(runId), null);
|
|
35
|
+
const operations = ledger?.operations ?? {};
|
|
36
|
+
const existing = operations[operationId];
|
|
37
|
+
if (!existing) {
|
|
38
|
+
return { status: 'new' };
|
|
39
|
+
}
|
|
40
|
+
if (existing.request_hash !== requestHash) {
|
|
41
|
+
return {
|
|
42
|
+
status: 'mismatch',
|
|
43
|
+
existing_hash: existing.request_hash
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
status: 'replay',
|
|
48
|
+
response: existing.response
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
async recordOperation(runId, operationId, toolName, requestHash, response) {
|
|
53
|
+
await this.ensureRunLedger(runId);
|
|
54
|
+
await withFileLock(this.lockPath(runId), async () => {
|
|
55
|
+
const ledger = (await readJson(this.ledgerPath(runId), null)) ?? {
|
|
56
|
+
run_id: runId,
|
|
57
|
+
updated_at: nowIso(),
|
|
58
|
+
operations: {}
|
|
59
|
+
};
|
|
60
|
+
const now = nowIso();
|
|
61
|
+
const existing = ledger.operations[operationId];
|
|
62
|
+
ledger.operations[operationId] = {
|
|
63
|
+
operation_id: operationId,
|
|
64
|
+
tool_name: toolName,
|
|
65
|
+
request_hash: requestHash,
|
|
66
|
+
response,
|
|
67
|
+
created_at: existing?.created_at ?? now,
|
|
68
|
+
updated_at: now
|
|
69
|
+
};
|
|
70
|
+
ledger.updated_at = now;
|
|
71
|
+
await atomicWriteJson(this.ledgerPath(runId), ledger);
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=operation-ledger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operation-ledger.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/mcp/operation-ledger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-contract.js","sourceRoot":"","sources":["../../../../apps/control-plane/src/mcp/protocol-contract.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,oBAAoB,EAAE,YAAY;IAClC,GAAG,EAAE;QACH,OAAO,EAAE,2BAA2B;QACpC,OAAO,EAAE,QAAQ;KAClB;CACO,CAAC;AAEX,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,OAAO,CAAU,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { OperationLedger } from './operation-ledger.js';
|
|
2
|
+
import { KernelToolExecutor, type ToolExecutionRouterPort } from './kernel-tool-executor.js';
|
|
3
|
+
import { McpServerAdapter } from './mcp-server-adapter.js';
|
|
4
|
+
import { TokenAuthVerifier } from './token-auth-verifier.js';
|
|
5
|
+
import { ToolAuthorizer } from './tool-authorizer.js';
|
|
6
|
+
import { ToolContractValidator } from './tool-contract-validator.js';
|
|
7
|
+
import { InProcessToolClient, McpToolClient, type ToolClient } from './tool-client.js';
|
|
8
|
+
import { ToolRegistryLoader } from './tool-registry-loader.js';
|
|
9
|
+
import { ToolRuntime } from './tool-runtime.js';
|
|
10
|
+
export interface ToolingKernelPort extends ToolExecutionRouterPort {
|
|
11
|
+
getRbacPolicy(): Record<string, string[]>;
|
|
12
|
+
}
|
|
13
|
+
export interface CreateToolingRuntimeOptions {
|
|
14
|
+
generateToolsMarkdown?: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface ToolingRuntime {
|
|
17
|
+
loader: ToolRegistryLoader;
|
|
18
|
+
registry: Awaited<ReturnType<ToolRegistryLoader['load']>>;
|
|
19
|
+
validator: ToolContractValidator;
|
|
20
|
+
authorizer: ToolAuthorizer;
|
|
21
|
+
ledger: OperationLedger;
|
|
22
|
+
executor: KernelToolExecutor;
|
|
23
|
+
runtime: ToolRuntime;
|
|
24
|
+
authVerifier: TokenAuthVerifier;
|
|
25
|
+
mcpAdapter: McpServerAdapter;
|
|
26
|
+
inProcessClient: InProcessToolClient;
|
|
27
|
+
mcpClient: McpToolClient;
|
|
28
|
+
}
|
|
29
|
+
export declare class ToolingRuntimeComposer {
|
|
30
|
+
private readonly repoRoot;
|
|
31
|
+
private readonly kernel;
|
|
32
|
+
private readonly options;
|
|
33
|
+
constructor(repoRoot: string, kernel: ToolingKernelPort, options?: CreateToolingRuntimeOptions);
|
|
34
|
+
compose(): Promise<ToolingRuntime>;
|
|
35
|
+
private generateToolsMarkdownIfEnabled;
|
|
36
|
+
}
|
|
37
|
+
export declare function createToolingRuntime(repoRoot: string, kernel: ToolingKernelPort, options?: CreateToolingRuntimeOptions): Promise<ToolingRuntime>;
|
|
38
|
+
export declare function resolveToolClient(transport: 'inprocess' | 'mcp', tooling: ToolingRuntime): ToolClient;
|