@interf/compiler 0.22.2 → 0.50.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/README.md +119 -282
- package/dist/bin-mcp.d.ts +2 -0
- package/dist/bin-mcp.js +63 -0
- package/dist/bin-runtime.d.ts +2 -0
- package/dist/bin-runtime.js +111 -0
- package/dist/cli/commands/agents.js +4 -35
- package/dist/cli/commands/auth.d.ts +20 -0
- package/dist/cli/commands/auth.js +161 -0
- package/dist/cli/commands/benchmark.d.ts +9 -0
- package/dist/cli/commands/benchmark.js +58 -0
- package/dist/cli/commands/build-plan.js +107 -139
- package/dist/cli/commands/build.d.ts +3 -4
- package/dist/cli/commands/build.js +16 -45
- package/dist/cli/commands/doctor.js +3 -3
- package/dist/cli/commands/graphs.d.ts +2 -0
- package/dist/cli/commands/graphs.js +344 -0
- package/dist/cli/commands/login.js +4 -6
- package/dist/cli/commands/logout.js +1 -1
- package/dist/cli/commands/mcp.d.ts +4 -2
- package/dist/cli/commands/mcp.js +846 -232
- package/dist/cli/commands/project.d.ts +2 -0
- package/dist/cli/commands/project.js +176 -0
- package/dist/cli/commands/reset.d.ts +3 -4
- package/dist/cli/commands/reset.js +10 -31
- package/dist/cli/commands/runs.js +136 -57
- package/dist/cli/commands/runtime.d.ts +24 -0
- package/dist/cli/commands/runtime.js +373 -0
- package/dist/cli/commands/status.d.ts +1 -0
- package/dist/cli/commands/status.js +35 -45
- package/dist/cli/commands/traces.d.ts +2 -0
- package/dist/cli/commands/traces.js +97 -0
- package/dist/cli/commands/wizard.js +171 -178
- package/dist/cli/index.d.ts +7 -4
- package/dist/cli/index.js +13 -7
- package/dist/cli/lib/http-client.d.ts +39 -0
- package/dist/cli/lib/http-client.js +73 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.js +2 -2
- package/dist/packages/build-plans/authoring/brief.d.ts +538 -0
- package/dist/packages/build-plans/authoring/brief.js +89 -0
- package/dist/packages/build-plans/authoring/build-plan-authoring.d.ts +52 -11
- package/dist/packages/build-plans/authoring/build-plan-authoring.js +493 -46
- package/dist/packages/build-plans/authoring/build-plan-edit-session.d.ts +10 -1
- package/dist/packages/build-plans/authoring/build-plan-edit-session.js +27 -4
- package/dist/packages/build-plans/authoring/build-plan-improvement.d.ts +9 -6
- package/dist/packages/build-plans/authoring/build-plan-improvement.js +97 -46
- package/dist/packages/build-plans/authoring/lib/build-plan-edit-utils.d.ts +1 -0
- package/dist/packages/build-plans/authoring/lib/build-plan-edit-utils.js +7 -7
- package/dist/packages/build-plans/build-plan-resolution.d.ts +1 -1
- package/dist/packages/build-plans/build-plan-resolution.js +3 -3
- package/dist/packages/build-plans/index.d.ts +1 -1
- package/dist/packages/build-plans/index.js +1 -1
- package/dist/packages/build-plans/package/build-plan-definitions.d.ts +14 -13
- package/dist/packages/build-plans/package/build-plan-definitions.js +45 -42
- package/dist/packages/build-plans/package/build-plan-helpers.d.ts +3 -2
- package/dist/packages/build-plans/package/build-plan-helpers.js +27 -13
- package/dist/packages/build-plans/package/build-plan-review-paths.d.ts +5 -5
- package/dist/packages/build-plans/package/build-plan-review-paths.js +15 -15
- package/dist/packages/build-plans/package/build-plan-stage-runner.d.ts +5 -4
- package/dist/packages/build-plans/package/build-plan-stage-runner.js +23 -11
- package/dist/packages/build-plans/package/builtin-build-plan.d.ts +7 -8
- package/dist/packages/build-plans/package/builtin-build-plan.js +10 -11
- package/dist/packages/build-plans/package/context-interface.d.ts +14 -9
- package/dist/packages/build-plans/package/context-interface.js +14 -33
- package/dist/packages/build-plans/package/interf-build-plan-package.d.ts +6 -17
- package/dist/packages/build-plans/package/interf-build-plan-package.js +68 -64
- package/dist/packages/build-plans/package/local-build-plans.d.ts +21 -14
- package/dist/packages/build-plans/package/local-build-plans.js +105 -55
- package/dist/packages/build-plans/package/user-build-plans.js +1 -1
- package/dist/packages/contracts/index.d.ts +5 -2
- package/dist/packages/contracts/index.js +3 -1
- package/dist/packages/contracts/lib/context-graph-layer.d.ts +161 -0
- package/dist/packages/contracts/lib/context-graph-layer.js +216 -0
- package/dist/packages/contracts/lib/project-paths.d.ts +144 -0
- package/dist/packages/contracts/lib/project-paths.js +220 -0
- package/dist/packages/contracts/lib/project-schema.d.ts +423 -0
- package/dist/packages/contracts/lib/project-schema.js +138 -0
- package/dist/packages/contracts/lib/schema.d.ts +1273 -81
- package/dist/packages/contracts/lib/schema.js +675 -79
- package/dist/packages/contracts/utils/filesystem.d.ts +1 -0
- package/dist/packages/contracts/utils/filesystem.js +29 -1
- package/dist/packages/contracts/utils/parse.js +67 -0
- package/dist/packages/projects/index.d.ts +6 -0
- package/dist/packages/{project → projects}/index.js +0 -3
- package/dist/packages/{project → projects}/interf-detect.d.ts +12 -12
- package/dist/packages/{project → projects}/interf-detect.js +56 -50
- package/dist/packages/projects/interf.d.ts +2 -0
- package/dist/packages/projects/interf.js +1 -0
- package/dist/packages/projects/lib/schema.d.ts +77 -0
- package/dist/packages/projects/lib/schema.js +91 -0
- package/dist/packages/projects/source-config.d.ts +53 -0
- package/dist/packages/projects/source-config.js +339 -0
- package/dist/packages/projects/source-folders.d.ts +11 -0
- package/dist/packages/{project → projects}/source-folders.js +26 -26
- package/dist/packages/{engine → runtime}/action-planner.d.ts +1 -1
- package/dist/packages/{engine → runtime}/action-planner.js +20 -22
- package/dist/packages/runtime/action-values.d.ts +1 -0
- package/dist/packages/runtime/action-values.js +1 -0
- package/dist/packages/runtime/actions/errors.d.ts +2 -0
- package/dist/packages/runtime/actions/errors.js +12 -0
- package/dist/packages/runtime/actions/fields.d.ts +86 -0
- package/dist/packages/runtime/actions/form-builders.d.ts +14 -0
- package/dist/packages/runtime/actions/form-builders.js +667 -0
- package/dist/packages/runtime/actions/form-validators.d.ts +8 -0
- package/dist/packages/runtime/actions/form-validators.js +134 -0
- package/dist/packages/runtime/actions/helpers.d.ts +11 -0
- package/dist/packages/runtime/actions/helpers.js +80 -0
- package/dist/packages/runtime/actions/index.d.ts +8 -0
- package/dist/packages/runtime/actions/index.js +11 -0
- package/dist/packages/runtime/actions/registry.d.ts +64 -0
- package/dist/packages/runtime/actions/registry.js +62 -0
- package/dist/packages/runtime/actions/requests.d.ts +45 -0
- package/dist/packages/runtime/actions/requests.js +164 -0
- package/dist/packages/runtime/actions/schemas.d.ts +161 -0
- package/dist/packages/runtime/actions/schemas.js +37 -0
- package/dist/packages/runtime/agent-handoff.d.ts +11 -0
- package/dist/packages/runtime/agent-handoff.js +102 -0
- package/dist/packages/{engine → runtime}/agents/index.d.ts +1 -2
- package/dist/packages/{engine → runtime}/agents/index.js +1 -2
- package/dist/packages/runtime/agents/lib/args.d.ts +14 -0
- package/dist/packages/runtime/agents/lib/args.js +24 -0
- package/dist/packages/{engine → runtime}/agents/lib/constants.d.ts +4 -1
- package/dist/packages/runtime/agents/lib/constants.js +13 -0
- package/dist/packages/runtime/agents/lib/context-graph-bootstrap.d.ts +3 -0
- package/dist/packages/{engine/agents/lib/verifiable-context-bootstrap.js → runtime/agents/lib/context-graph-bootstrap.js} +5 -6
- package/dist/packages/{engine → runtime}/agents/lib/detection.d.ts +5 -0
- package/dist/packages/{engine → runtime}/agents/lib/detection.js +16 -7
- package/dist/packages/{engine → runtime}/agents/lib/execution-profile.d.ts +14 -0
- package/dist/packages/{engine → runtime}/agents/lib/execution-profile.js +31 -14
- package/dist/packages/{engine → runtime}/agents/lib/execution.js +22 -6
- package/dist/packages/{engine → runtime}/agents/lib/executors.d.ts +1 -0
- package/dist/packages/{engine → runtime}/agents/lib/executors.js +11 -2
- package/dist/packages/runtime/agents/lib/logs.d.ts +12 -0
- package/dist/packages/runtime/agents/lib/logs.js +41 -0
- package/dist/packages/{engine → runtime}/agents/lib/preflight.js +19 -14
- package/dist/packages/runtime/agents/lib/render.d.ts +26 -0
- package/dist/packages/{engine → runtime}/agents/lib/render.js +48 -22
- package/dist/packages/runtime/agents/lib/shell-fs.d.ts +18 -0
- package/dist/packages/runtime/agents/lib/shell-fs.js +190 -0
- package/dist/packages/runtime/agents/lib/shell-paths.d.ts +16 -0
- package/dist/packages/runtime/agents/lib/shell-paths.js +63 -0
- package/dist/packages/runtime/agents/lib/shell-projection.d.ts +25 -0
- package/dist/packages/runtime/agents/lib/shell-projection.js +314 -0
- package/dist/packages/runtime/agents/lib/shell-templates.d.ts +30 -0
- package/dist/packages/runtime/agents/lib/shell-templates.js +494 -0
- package/dist/packages/runtime/agents/lib/shell-workspace.d.ts +17 -0
- package/dist/packages/runtime/agents/lib/shell-workspace.js +70 -0
- package/dist/packages/runtime/agents/lib/shells.d.ts +92 -0
- package/dist/packages/runtime/agents/lib/shells.js +509 -0
- package/dist/packages/runtime/agents/lib/source-context-scan.d.ts +10 -0
- package/dist/packages/runtime/agents/lib/source-context-scan.js +388 -0
- package/dist/packages/{engine → runtime}/agents/lib/status.js +1 -14
- package/dist/packages/runtime/agents/lib/string-utils.d.ts +16 -0
- package/dist/packages/runtime/agents/lib/string-utils.js +36 -0
- package/dist/packages/{engine → runtime}/agents/lib/types.d.ts +1 -0
- package/dist/packages/{engine → runtime}/agents/lib/user-config.d.ts +8 -2
- package/dist/packages/{engine → runtime}/agents/lib/user-config.js +8 -2
- package/dist/packages/runtime/agents/providers/claude-code.d.ts +13 -0
- package/dist/packages/runtime/agents/providers/claude-code.js +45 -0
- package/dist/packages/runtime/agents/providers/codex.d.ts +17 -0
- package/dist/packages/runtime/agents/providers/codex.js +66 -0
- package/dist/packages/runtime/agents/providers/cursor.d.ts +9 -0
- package/dist/packages/runtime/agents/providers/cursor.js +24 -0
- package/dist/packages/runtime/agents/providers/index.d.ts +9 -0
- package/dist/packages/runtime/agents/providers/index.js +31 -0
- package/dist/packages/runtime/agents/providers/types.d.ts +50 -0
- package/dist/packages/{engine → runtime}/agents/registry.d.ts +13 -2
- package/dist/packages/{engine → runtime}/agents/registry.js +48 -10
- package/dist/packages/{engine → runtime}/agents/role-executors.d.ts +1 -1
- package/dist/packages/{engine → runtime}/agents/role-executors.js +9 -7
- package/dist/packages/{engine → runtime}/agents/role-router.js +7 -5
- package/dist/packages/runtime/auth/account-context.d.ts +52 -0
- package/dist/packages/runtime/auth/account-context.js +68 -0
- package/dist/packages/runtime/auth/auth-flow.d.ts +73 -0
- package/dist/packages/runtime/auth/auth-flow.js +189 -0
- package/dist/packages/runtime/auth/jwt-validator.d.ts +58 -0
- package/dist/packages/runtime/auth/jwt-validator.js +86 -0
- package/dist/packages/runtime/auth/keychain.d.ts +35 -0
- package/dist/packages/runtime/auth/keychain.js +85 -0
- package/dist/packages/runtime/auth/session-store.d.ts +38 -0
- package/dist/packages/runtime/auth/session-store.js +96 -0
- package/dist/packages/runtime/auth/workos-client.d.ts +58 -0
- package/dist/packages/runtime/auth/workos-client.js +87 -0
- package/dist/packages/runtime/benchmark-question-draft.d.ts +23 -0
- package/dist/packages/runtime/benchmark-question-draft.js +153 -0
- package/dist/packages/runtime/build/artifact-counts.d.ts +1 -0
- package/dist/packages/{engine → runtime}/build/artifact-counts.js +5 -9
- package/dist/packages/{engine → runtime}/build/artifact-status.d.ts +6 -6
- package/dist/packages/{engine → runtime}/build/artifact-status.js +26 -24
- package/dist/packages/runtime/build/atomic-fs.d.ts +3 -0
- package/dist/packages/runtime/build/atomic-fs.js +95 -0
- package/dist/packages/runtime/build/billing-events.d.ts +78 -0
- package/dist/packages/{engine → runtime}/build/billing-events.js +17 -19
- package/dist/packages/runtime/build/build-evidence.d.ts +16 -0
- package/dist/packages/runtime/build/build-evidence.js +179 -0
- package/dist/packages/{engine → runtime}/build/build-pipeline.d.ts +12 -8
- package/dist/packages/runtime/build/build-pipeline.js +388 -0
- package/dist/packages/{engine → runtime}/build/build-plan-primitives.d.ts +1 -1
- package/dist/packages/{engine → runtime}/build/build-plan-primitives.js +0 -1
- package/dist/packages/runtime/build/build-plan-runs.d.ts +14 -0
- package/dist/packages/runtime/build/build-plan-runs.js +31 -0
- package/dist/packages/runtime/build/build-stage-plan.d.ts +16 -0
- package/dist/packages/runtime/build/build-stage-plan.js +101 -0
- package/dist/packages/{engine → runtime}/build/build-stage-runner.d.ts +2 -1
- package/dist/packages/runtime/build/build-stage-runner.js +302 -0
- package/dist/packages/{engine → runtime}/build/build-target.d.ts +7 -4
- package/dist/packages/runtime/build/build-target.js +40 -0
- package/dist/packages/{engine → runtime}/build/check-evaluator.d.ts +14 -16
- package/dist/packages/runtime/build/check-evaluator.js +1226 -0
- package/dist/packages/runtime/build/context-graph-paths.d.ts +64 -0
- package/dist/packages/runtime/build/context-graph-paths.js +160 -0
- package/dist/packages/runtime/build/context-graph-schema.d.ts +19 -0
- package/dist/packages/runtime/build/context-graph-schema.js +39 -0
- package/dist/packages/{engine → runtime}/build/discovery.d.ts +2 -2
- package/dist/packages/{engine → runtime}/build/discovery.js +4 -4
- package/dist/packages/{engine → runtime}/build/index.d.ts +7 -5
- package/dist/packages/{engine → runtime}/build/index.js +7 -5
- package/dist/packages/runtime/build/inspect-map.d.ts +10 -0
- package/dist/packages/runtime/build/inspect-map.js +270 -0
- package/dist/packages/{engine → runtime}/build/lib/schema.d.ts +449 -123
- package/dist/packages/runtime/build/lib/schema.js +494 -0
- package/dist/packages/runtime/build/native-entrypoint.d.ts +2 -0
- package/dist/packages/runtime/build/native-entrypoint.js +286 -0
- package/dist/packages/runtime/build/reset.d.ts +2 -0
- package/dist/packages/runtime/build/reset.js +62 -0
- package/dist/packages/{engine → runtime}/build/runtime-contracts.js +13 -7
- package/dist/packages/runtime/build/runtime-inventory.d.ts +7 -0
- package/dist/packages/{engine → runtime}/build/runtime-inventory.js +3 -3
- package/dist/packages/runtime/build/runtime-log-paths.d.ts +3 -0
- package/dist/packages/runtime/build/runtime-log-paths.js +16 -0
- package/dist/packages/{engine → runtime}/build/runtime-prompt.js +12 -9
- package/dist/packages/{engine → runtime}/build/runtime-reconcile.d.ts +1 -1
- package/dist/packages/{engine → runtime}/build/runtime-reconcile.js +25 -21
- package/dist/packages/runtime/build/runtime-runs.d.ts +10 -0
- package/dist/packages/runtime/build/runtime-runs.js +318 -0
- package/dist/packages/{engine → runtime}/build/runtime-types.d.ts +9 -6
- package/dist/packages/runtime/build/runtime-types.js +1 -0
- package/dist/packages/runtime/build/runtime.d.ts +8 -0
- package/dist/packages/runtime/build/runtime.js +7 -0
- package/dist/packages/runtime/build/source-files.d.ts +58 -0
- package/dist/packages/runtime/build/source-files.js +193 -0
- package/dist/packages/runtime/build/source-inventory.d.ts +28 -0
- package/dist/packages/runtime/build/source-inventory.js +512 -0
- package/dist/packages/runtime/build/source-manifest.d.ts +63 -0
- package/dist/packages/runtime/build/source-manifest.js +220 -0
- package/dist/packages/runtime/build/stage-evidence.d.ts +22 -0
- package/dist/packages/runtime/build/stage-evidence.js +386 -0
- package/dist/packages/runtime/build/stage-manifest.d.ts +45 -0
- package/dist/packages/runtime/build/stage-manifest.js +1125 -0
- package/dist/packages/runtime/build/stage-reuse.d.ts +11 -0
- package/dist/packages/runtime/build/stage-reuse.js +154 -0
- package/dist/packages/runtime/build/stage-session.d.ts +81 -0
- package/dist/packages/runtime/build/stage-session.js +308 -0
- package/dist/packages/runtime/build/state-artifacts.d.ts +9 -0
- package/dist/packages/runtime/build/state-artifacts.js +14 -0
- package/dist/packages/runtime/build/state-health.d.ts +4 -0
- package/dist/packages/{engine → runtime}/build/state-health.js +21 -26
- package/dist/packages/runtime/build/state-io.d.ts +12 -0
- package/dist/packages/runtime/build/state-io.js +118 -0
- package/dist/packages/runtime/build/state-view.d.ts +5 -0
- package/dist/packages/runtime/build/state-view.js +121 -0
- package/dist/packages/runtime/build/state.d.ts +7 -0
- package/dist/packages/runtime/build/state.js +12 -0
- package/dist/packages/runtime/build/summary-coverage-index.d.ts +21 -0
- package/dist/packages/runtime/build/summary-coverage-index.js +189 -0
- package/dist/packages/runtime/build/traces.d.ts +30 -0
- package/dist/packages/runtime/build/traces.js +133 -0
- package/dist/packages/{engine/build/validate-verifiable-context.d.ts → runtime/build/validate-context-graph.d.ts} +6 -6
- package/dist/packages/{engine/build/validate-verifiable-context.js → runtime/build/validate-context-graph.js} +49 -36
- package/dist/packages/{engine → runtime}/build/validate.d.ts +5 -5
- package/dist/packages/{engine → runtime}/build/validate.js +26 -26
- package/dist/packages/{engine → runtime}/client.d.ts +18 -18
- package/dist/packages/{engine → runtime}/client.js +48 -36
- package/dist/packages/{engine → runtime}/connection-config.d.ts +3 -2
- package/dist/packages/{engine → runtime}/connection-config.js +9 -8
- package/dist/packages/runtime/context-checks.d.ts +10 -0
- package/dist/packages/runtime/context-checks.js +127 -0
- package/dist/packages/runtime/context-graph-scaffold.d.ts +9 -0
- package/dist/packages/runtime/context-graph-scaffold.js +135 -0
- package/dist/packages/runtime/context-graph-semantic-graph.d.ts +9 -0
- package/dist/packages/runtime/context-graph-semantic-graph.js +416 -0
- package/dist/packages/runtime/entitlement-guard.d.ts +43 -0
- package/dist/packages/runtime/entitlement-guard.js +70 -0
- package/dist/packages/{engine → runtime}/execution/index.d.ts +2 -2
- package/dist/packages/{engine → runtime}/execution/index.js +1 -1
- package/dist/packages/{engine → runtime}/execution/lib/schema.d.ts +272 -191
- package/dist/packages/{engine → runtime}/execution/lib/schema.js +35 -32
- package/dist/packages/runtime/index.d.ts +29 -0
- package/dist/packages/runtime/index.js +21 -0
- package/dist/packages/runtime/instance-paths.d.ts +30 -0
- package/dist/packages/runtime/instance-paths.js +29 -0
- package/dist/packages/runtime/native-run-handlers.d.ts +63 -0
- package/dist/packages/{engine → runtime}/native-run-handlers.js +217 -166
- package/dist/packages/runtime/plan-artifact-contract.d.ts +17 -0
- package/dist/packages/runtime/plan-artifact-contract.js +42 -0
- package/dist/packages/runtime/project-entries.d.ts +11 -0
- package/dist/packages/runtime/project-entries.js +49 -0
- package/dist/packages/runtime/project-source-state.d.ts +26 -0
- package/dist/packages/runtime/project-source-state.js +56 -0
- package/dist/packages/runtime/project-store.d.ts +90 -0
- package/dist/packages/runtime/project-store.js +195 -0
- package/dist/packages/runtime/requested-artifacts.d.ts +7 -0
- package/dist/packages/{engine → runtime}/requested-artifacts.js +23 -1
- package/dist/packages/{engine → runtime}/run-observability.d.ts +2 -1
- package/dist/packages/{engine → runtime}/run-observability.js +174 -87
- package/dist/packages/runtime/runtime-action-proposals.d.ts +7 -0
- package/dist/packages/runtime/runtime-action-proposals.js +542 -0
- package/dist/packages/runtime/runtime-build-plans.d.ts +5 -0
- package/dist/packages/runtime/runtime-build-plans.js +175 -0
- package/dist/packages/runtime/runtime-build-runs.d.ts +47 -0
- package/dist/packages/runtime/runtime-build-runs.js +555 -0
- package/dist/packages/runtime/runtime-caches.d.ts +117 -0
- package/dist/packages/runtime/runtime-caches.js +266 -0
- package/dist/packages/{engine → runtime}/runtime-event-applier.d.ts +3 -1
- package/dist/packages/{engine → runtime}/runtime-event-applier.js +53 -17
- package/dist/packages/runtime/runtime-executor.d.ts +22 -0
- package/dist/packages/runtime/runtime-executor.js +131 -0
- package/dist/packages/runtime/runtime-jobs.d.ts +13 -0
- package/dist/packages/runtime/runtime-jobs.js +463 -0
- package/dist/packages/runtime/runtime-observability.d.ts +11 -0
- package/dist/packages/runtime/runtime-observability.js +39 -0
- package/dist/packages/{engine → runtime}/runtime-persistence.d.ts +9 -18
- package/dist/packages/{engine → runtime}/runtime-persistence.js +25 -25
- package/dist/packages/runtime/runtime-project-mutations.d.ts +7 -0
- package/dist/packages/runtime/runtime-project-mutations.js +65 -0
- package/dist/packages/runtime/runtime-project-reads.d.ts +18 -0
- package/dist/packages/runtime/runtime-project-reads.js +574 -0
- package/dist/packages/runtime/runtime-proposal-helpers.d.ts +22 -0
- package/dist/packages/runtime/runtime-proposal-helpers.js +223 -0
- package/dist/packages/{engine → runtime}/runtime-resource-builders.d.ts +23 -16
- package/dist/packages/{engine → runtime}/runtime-resource-builders.js +58 -46
- package/dist/packages/runtime/runtime-status.d.ts +14 -0
- package/dist/packages/runtime/runtime-status.js +15 -0
- package/dist/packages/runtime/runtime-verify-runs.d.ts +84 -0
- package/dist/packages/runtime/runtime-verify-runs.js +296 -0
- package/dist/packages/runtime/runtime.d.ts +1582 -0
- package/dist/packages/runtime/runtime.js +431 -0
- package/dist/packages/runtime/schemas/actions.d.ts +1206 -0
- package/dist/packages/runtime/schemas/actions.js +117 -0
- package/dist/packages/runtime/schemas/agents.d.ts +104 -0
- package/dist/packages/runtime/schemas/agents.js +74 -0
- package/dist/packages/runtime/schemas/build-plans.d.ts +1132 -0
- package/dist/packages/runtime/schemas/build-plans.js +141 -0
- package/dist/packages/runtime/schemas/context-graphs.d.ts +1522 -0
- package/dist/packages/runtime/schemas/context-graphs.js +110 -0
- package/dist/packages/runtime/schemas/files.d.ts +227 -0
- package/dist/packages/runtime/schemas/files.js +28 -0
- package/dist/packages/runtime/schemas/index.d.ts +9 -0
- package/dist/packages/runtime/schemas/index.js +13 -0
- package/dist/packages/runtime/schemas/instance.d.ts +141 -0
- package/dist/packages/runtime/schemas/instance.js +143 -0
- package/dist/packages/runtime/schemas/jobs.d.ts +339 -0
- package/dist/packages/runtime/schemas/jobs.js +107 -0
- package/dist/packages/runtime/schemas/projects.d.ts +366 -0
- package/dist/packages/runtime/schemas/projects.js +160 -0
- package/dist/packages/runtime/schemas/runs.d.ts +3445 -0
- package/dist/packages/runtime/schemas/runs.js +115 -0
- package/dist/packages/runtime/service/index.d.ts +3 -0
- package/dist/packages/runtime/service/index.js +3 -0
- package/dist/packages/runtime/service/openapi.d.ts +7 -0
- package/dist/packages/runtime/service/openapi.js +118 -0
- package/dist/packages/runtime/service/operations.d.ts +3011 -0
- package/dist/packages/runtime/service/operations.js +375 -0
- package/dist/packages/runtime/service/routes.d.ts +114 -0
- package/dist/packages/runtime/service/routes.js +128 -0
- package/dist/packages/runtime/service/server-api-files.d.ts +10 -0
- package/dist/packages/runtime/service/server-api-files.js +85 -0
- package/dist/packages/runtime/service/server-app-boot.d.ts +4 -0
- package/dist/packages/runtime/service/server-app-boot.js +46 -0
- package/dist/packages/runtime/service/server-guards.d.ts +63 -0
- package/dist/packages/runtime/service/server-guards.js +181 -0
- package/dist/packages/runtime/service/server-helpers.d.ts +38 -0
- package/dist/packages/runtime/service/server-helpers.js +108 -0
- package/dist/packages/runtime/service/server-instance-helpers.d.ts +30 -0
- package/dist/packages/runtime/service/server-instance-helpers.js +114 -0
- package/dist/packages/runtime/service/server-routes-action-proposals.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-action-proposals.js +45 -0
- package/dist/packages/runtime/service/server-routes-agents.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-agents.js +132 -0
- package/dist/packages/runtime/service/server-routes-auth.d.ts +33 -0
- package/dist/packages/runtime/service/server-routes-auth.js +138 -0
- package/dist/packages/runtime/service/server-routes-build-plans.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-build-plans.js +86 -0
- package/dist/packages/runtime/service/server-routes-discovery.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-discovery.js +196 -0
- package/dist/packages/runtime/service/server-routes-events.d.ts +5 -0
- package/dist/packages/runtime/service/server-routes-events.js +99 -0
- package/dist/packages/runtime/service/server-routes-project-context.d.ts +9 -0
- package/dist/packages/runtime/service/server-routes-project-context.js +287 -0
- package/dist/packages/runtime/service/server-routes-project-jobs.d.ts +9 -0
- package/dist/packages/runtime/service/server-routes-project-jobs.js +137 -0
- package/dist/packages/runtime/service/server-routes-project-runs.d.ts +14 -0
- package/dist/packages/runtime/service/server-routes-project-runs.js +88 -0
- package/dist/packages/runtime/service/server-routes-projects.d.ts +4 -0
- package/dist/packages/runtime/service/server-routes-projects.js +96 -0
- package/dist/packages/runtime/service/server-routes-runs.d.ts +3 -0
- package/dist/packages/runtime/service/server-routes-runs.js +119 -0
- package/dist/packages/runtime/service/server.d.ts +37 -0
- package/dist/packages/runtime/service/server.js +300 -0
- package/dist/packages/{engine → runtime/service}/service-registry.d.ts +5 -5
- package/dist/packages/{engine → runtime/service}/service-registry.js +7 -7
- package/dist/packages/runtime/verify/benchmark-run.d.ts +81 -0
- package/dist/packages/runtime/verify/benchmark-run.js +303 -0
- package/dist/packages/{engine → runtime}/verify/index.d.ts +2 -2
- package/dist/packages/{engine → runtime}/verify/index.js +1 -1
- package/dist/packages/{engine → runtime}/verify/lib/schema.d.ts +83 -16
- package/dist/packages/{engine → runtime}/verify/lib/schema.js +38 -18
- package/dist/packages/runtime/verify/test-file-guard.d.ts +2 -0
- package/dist/packages/runtime/verify/test-file-guard.js +29 -0
- package/dist/packages/{engine → runtime}/verify/verify-execution.d.ts +7 -0
- package/dist/packages/{engine → runtime}/verify/verify-execution.js +119 -45
- package/dist/packages/{engine → runtime}/verify/verify-paths.d.ts +5 -4
- package/dist/packages/runtime/verify/verify-paths.js +65 -0
- package/dist/packages/{engine → runtime}/verify/verify-sandbox.d.ts +1 -1
- package/dist/packages/runtime/verify/verify-sandbox.js +88 -0
- package/dist/packages/{engine → runtime}/verify/verify-specs.d.ts +2 -0
- package/dist/packages/runtime/verify/verify-specs.js +126 -0
- package/dist/packages/runtime/verify/verify-targets.d.ts +5 -0
- package/dist/packages/{engine → runtime}/verify/verify-targets.js +12 -12
- package/dist/packages/runtime/verify/verify-types.js +1 -0
- package/dist/packages/{engine → runtime}/verify/verify.d.ts +1 -1
- package/dist/packages/{engine → runtime}/verify/verify.js +1 -1
- package/dist/packages/runtime/wire-schemas.d.ts +18 -0
- package/dist/packages/runtime/wire-schemas.js +27 -0
- package/package.json +32 -30
- package/public-repo/CONTRIBUTING.md +16 -18
- package/public-repo/README.md +119 -282
- package/public-repo/SECURITY.md +3 -4
- package/public-repo/build-plans/interf-default/README.md +24 -16
- package/public-repo/build-plans/interf-default/build/stages/entrypoint/SKILL.md +74 -0
- package/public-repo/build-plans/interf-default/build/stages/knowledge/SKILL.md +95 -0
- package/public-repo/build-plans/interf-default/build/stages/summarize/SKILL.md +49 -4
- package/public-repo/build-plans/interf-default/build-plan.json +49 -39
- package/public-repo/build-plans/interf-default/build-plan.schema.json +59 -33
- package/public-repo/build-plans/interf-default/improve/SKILL.md +3 -3
- package/public-repo/build-plans/interf-default/use/query/SKILL.md +18 -11
- package/public-repo/openapi/local-service.openapi.json +14227 -0
- package/public-repo/skills/interf/SKILL.md +508 -187
- package/dist/cli/commands/prep.d.ts +0 -2
- package/dist/cli/commands/prep.js +0 -240
- package/dist/cli/commands/test.d.ts +0 -10
- package/dist/cli/commands/test.js +0 -85
- package/dist/cli/commands/web.d.ts +0 -2
- package/dist/cli/commands/web.js +0 -286
- package/dist/interf-ui/404.html +0 -1
- package/dist/interf-ui/__next.__PAGE__.txt +0 -10
- package/dist/interf-ui/__next._full.txt +0 -20
- package/dist/interf-ui/__next._head.txt +0 -5
- package/dist/interf-ui/__next._index.txt +0 -5
- package/dist/interf-ui/__next._tree.txt +0 -5
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_buildManifest.js +0 -11
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_clientMiddlewareManifest.js +0 -1
- package/dist/interf-ui/_next/static/--reS3xBzM5zc6QxNjZd6/_ssgManifest.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0.tjb6f4golw..css +0 -3
- package/dist/interf-ui/_next/static/chunks/03~yq9q893hmn.js +0 -1
- package/dist/interf-ui/_next/static/chunks/085-n_jv2ng_q.css +0 -1
- package/dist/interf-ui/_next/static/chunks/0dn41fa_zvgsl.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0g-ea0zj5d-0k.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0gwqglc4iz583.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0haldgm65ve6l.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0nv3am99vjzn4.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0s77gt_o4jwtx.js +0 -1
- package/dist/interf-ui/_next/static/chunks/0y5z3t-z1c8ks.js.map +0 -5
- package/dist/interf-ui/_next/static/chunks/0~a36ujuzpaz..js +0 -116
- package/dist/interf-ui/_next/static/chunks/10jeodxe4nkgj.js +0 -31
- package/dist/interf-ui/_next/static/chunks/119h2rouych2t.js +0 -1
- package/dist/interf-ui/_next/static/chunks/13c8b~m8knjsf.js +0 -1
- package/dist/interf-ui/_next/static/chunks/14dznb2qpt-ho.js +0 -91
- package/dist/interf-ui/_next/static/chunks/15z_en80lrq-3.js +0 -5
- package/dist/interf-ui/_next/static/chunks/turbopack-0p.pvcjrtq-jh.js +0 -1
- package/dist/interf-ui/_next/static/chunks/turbopack-0usj_75.8frlw.js +0 -1
- package/dist/interf-ui/_next/static/chunks/turbopack-worker-0sjn--fhq~1cg.js +0 -1
- package/dist/interf-ui/_next/static/media/GeistMono_Variable.p.17jn9btb_52pq.woff2 +0 -0
- package/dist/interf-ui/_next/static/media/Geist_Variable-s.p.0-te~ja_gpvcf.woff2 +0 -0
- package/dist/interf-ui/_next/static/media/worker.102zas1s52_pf.js +0 -109
- package/dist/interf-ui/_not-found/__next._full.txt +0 -15
- package/dist/interf-ui/_not-found/__next._head.txt +0 -5
- package/dist/interf-ui/_not-found/__next._index.txt +0 -5
- package/dist/interf-ui/_not-found/__next._not-found.__PAGE__.txt +0 -5
- package/dist/interf-ui/_not-found/__next._not-found.txt +0 -5
- package/dist/interf-ui/_not-found/__next._tree.txt +0 -2
- package/dist/interf-ui/_not-found.html +0 -1
- package/dist/interf-ui/_not-found.txt +0 -15
- package/dist/interf-ui/index.html +0 -1
- package/dist/interf-ui/index.txt +0 -20
- package/dist/packages/contracts/lib/preparation-paths.d.ts +0 -117
- package/dist/packages/contracts/lib/preparation-paths.js +0 -177
- package/dist/packages/engine/action-definitions.d.ts +0 -407
- package/dist/packages/engine/action-definitions.js +0 -1158
- package/dist/packages/engine/action-values.d.ts +0 -1
- package/dist/packages/engine/action-values.js +0 -1
- package/dist/packages/engine/agents/lib/args.d.ts +0 -4
- package/dist/packages/engine/agents/lib/args.js +0 -52
- package/dist/packages/engine/agents/lib/chart-guidance.d.ts +0 -1
- package/dist/packages/engine/agents/lib/chart-guidance.js +0 -8
- package/dist/packages/engine/agents/lib/constants.js +0 -28
- package/dist/packages/engine/agents/lib/logs.d.ts +0 -2
- package/dist/packages/engine/agents/lib/logs.js +0 -17
- package/dist/packages/engine/agents/lib/render.d.ts +0 -8
- package/dist/packages/engine/agents/lib/schema.d.ts +0 -8
- package/dist/packages/engine/agents/lib/schema.js +0 -7
- package/dist/packages/engine/agents/lib/shells.d.ts +0 -74
- package/dist/packages/engine/agents/lib/shells.js +0 -1052
- package/dist/packages/engine/agents/lib/verifiable-context-bootstrap.d.ts +0 -3
- package/dist/packages/engine/build/artifact-counts.d.ts +0 -1
- package/dist/packages/engine/build/billing-events.d.ts +0 -89
- package/dist/packages/engine/build/build-pipeline.js +0 -175
- package/dist/packages/engine/build/build-plan-runs.d.ts +0 -14
- package/dist/packages/engine/build/build-plan-runs.js +0 -31
- package/dist/packages/engine/build/build-stage-plan.d.ts +0 -16
- package/dist/packages/engine/build/build-stage-plan.js +0 -100
- package/dist/packages/engine/build/build-stage-runner.js +0 -94
- package/dist/packages/engine/build/build-target.js +0 -16
- package/dist/packages/engine/build/check-evaluator.js +0 -298
- package/dist/packages/engine/build/lib/schema.js +0 -316
- package/dist/packages/engine/build/reset.d.ts +0 -2
- package/dist/packages/engine/build/reset.js +0 -74
- package/dist/packages/engine/build/runtime-inventory.d.ts +0 -7
- package/dist/packages/engine/build/runtime-paths.d.ts +0 -8
- package/dist/packages/engine/build/runtime-paths.js +0 -26
- package/dist/packages/engine/build/runtime-runs.d.ts +0 -10
- package/dist/packages/engine/build/runtime-runs.js +0 -224
- package/dist/packages/engine/build/runtime.d.ts +0 -5
- package/dist/packages/engine/build/runtime.js +0 -4
- package/dist/packages/engine/build/source-files.d.ts +0 -46
- package/dist/packages/engine/build/source-files.js +0 -149
- package/dist/packages/engine/build/state-artifacts.d.ts +0 -9
- package/dist/packages/engine/build/state-artifacts.js +0 -14
- package/dist/packages/engine/build/state-health.d.ts +0 -4
- package/dist/packages/engine/build/state-io.d.ts +0 -11
- package/dist/packages/engine/build/state-io.js +0 -82
- package/dist/packages/engine/build/state-paths.d.ts +0 -5
- package/dist/packages/engine/build/state-paths.js +0 -16
- package/dist/packages/engine/build/state-view.d.ts +0 -5
- package/dist/packages/engine/build/state-view.js +0 -94
- package/dist/packages/engine/build/state.d.ts +0 -7
- package/dist/packages/engine/build/state.js +0 -12
- package/dist/packages/engine/build/validate-helpers.d.ts +0 -12
- package/dist/packages/engine/build/validate-helpers.js +0 -41
- package/dist/packages/engine/build/verifiable-context-paths.d.ts +0 -47
- package/dist/packages/engine/build/verifiable-context-paths.js +0 -121
- package/dist/packages/engine/build/verifiable-context-schema.d.ts +0 -21
- package/dist/packages/engine/build/verifiable-context-schema.js +0 -126
- package/dist/packages/engine/cloud-seams.d.ts +0 -115
- package/dist/packages/engine/cloud-seams.js +0 -84
- package/dist/packages/engine/index.d.ts +0 -22
- package/dist/packages/engine/index.js +0 -15
- package/dist/packages/engine/instance-paths.d.ts +0 -106
- package/dist/packages/engine/instance-paths.js +0 -171
- package/dist/packages/engine/lib/schema.d.ts +0 -6304
- package/dist/packages/engine/lib/schema.js +0 -730
- package/dist/packages/engine/native-run-handlers.d.ts +0 -25
- package/dist/packages/engine/preparation-store.d.ts +0 -105
- package/dist/packages/engine/preparation-store.js +0 -213
- package/dist/packages/engine/readiness-check-draft.d.ts +0 -20
- package/dist/packages/engine/readiness-check-draft.js +0 -111
- package/dist/packages/engine/requested-artifacts.d.ts +0 -5
- package/dist/packages/engine/routes.d.ts +0 -85
- package/dist/packages/engine/routes.js +0 -99
- package/dist/packages/engine/runtime-caches.d.ts +0 -76
- package/dist/packages/engine/runtime-caches.js +0 -191
- package/dist/packages/engine/runtime-proposal-helpers.d.ts +0 -35
- package/dist/packages/engine/runtime-proposal-helpers.js +0 -247
- package/dist/packages/engine/runtime.d.ts +0 -371
- package/dist/packages/engine/runtime.js +0 -2463
- package/dist/packages/engine/server.d.ts +0 -58
- package/dist/packages/engine/server.js +0 -1399
- package/dist/packages/engine/verify/readiness-check-run.d.ts +0 -82
- package/dist/packages/engine/verify/readiness-check-run.js +0 -265
- package/dist/packages/engine/verify/verify-paths.js +0 -61
- package/dist/packages/engine/verify/verify-sandbox.js +0 -88
- package/dist/packages/engine/verify/verify-specs.js +0 -114
- package/dist/packages/engine/verify/verify-targets.d.ts +0 -5
- package/dist/packages/engine/wire-schemas.d.ts +0 -547
- package/dist/packages/engine/wire-schemas.js +0 -59
- package/dist/packages/project/index.d.ts +0 -9
- package/dist/packages/project/interf-bootstrap.d.ts +0 -1
- package/dist/packages/project/interf-bootstrap.js +0 -1
- package/dist/packages/project/interf-scaffold.d.ts +0 -3
- package/dist/packages/project/interf-scaffold.js +0 -136
- package/dist/packages/project/interf.d.ts +0 -4
- package/dist/packages/project/interf.js +0 -3
- package/dist/packages/project/lib/schema.d.ts +0 -328
- package/dist/packages/project/lib/schema.js +0 -136
- package/dist/packages/project/preparation-entries.d.ts +0 -11
- package/dist/packages/project/preparation-entries.js +0 -49
- package/dist/packages/project/source-config.d.ts +0 -46
- package/dist/packages/project/source-config.js +0 -394
- package/dist/packages/project/source-folders.d.ts +0 -11
- package/public-repo/build-plans/interf-default/build/stages/shape/SKILL.md +0 -27
- package/public-repo/build-plans/interf-default/build/stages/structure/SKILL.md +0 -21
- package/public-repo/plugins/README.md +0 -9
- package/public-repo/plugins/interf/.claude-plugin/plugin.json +0 -21
- package/public-repo/plugins/interf/.mcp.json +0 -12
- package/public-repo/plugins/interf/README.md +0 -32
- package/public-repo/plugins/interf/skills/interf/SKILL.md +0 -376
- /package/dist/packages/{engine/agents/lib/types.js → runtime/actions/fields.js} +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/agents.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/agents.js +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/execution.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/preflight.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/agents/lib/status.d.ts +0 -0
- /package/dist/packages/{engine/build/runtime-types.js → runtime/agents/lib/types.js} +0 -0
- /package/dist/packages/{engine/verify/verify-types.js → runtime/agents/providers/types.js} +0 -0
- /package/dist/packages/{engine → runtime}/agents/role-router.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/build-execution.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/build-execution.js +0 -0
- /package/dist/packages/{engine → runtime}/build/runtime-contracts.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/build/runtime-prompt.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/adapters.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/adapters.js +0 -0
- /package/dist/packages/{engine → runtime}/execution/events.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/execution/events.js +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-profile-presets.d.ts +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-profile-presets.js +0 -0
- /package/dist/packages/{engine → runtime}/verify/verify-types.d.ts +0 -0
|
@@ -1,298 +0,0 @@
|
|
|
1
|
-
import { existsSync, readFileSync, statSync } from "node:fs";
|
|
2
|
-
import { resolve } from "node:path";
|
|
3
|
-
import { listFilesRecursive } from "../../contracts/utils/filesystem.js";
|
|
4
|
-
import { CheckKindSchema, } from "../../contracts/lib/schema.js";
|
|
5
|
-
import { countBrokenWikilinks, isOutputMarkdownFile, validateSynthFiles, } from "./validate.js";
|
|
6
|
-
/**
|
|
7
|
-
* Build a Proof envelope from an evaluator outcome. Centralizes the
|
|
8
|
-
* timestamp + required-flag plumbing so individual evaluators can
|
|
9
|
-
* focus on the pass/fail decision and a one-line summary.
|
|
10
|
-
*/
|
|
11
|
-
function makeProof(check, passed, summary, details) {
|
|
12
|
-
return {
|
|
13
|
-
check_id: check.id,
|
|
14
|
-
kind: check.kind,
|
|
15
|
-
passed,
|
|
16
|
-
required: check.required,
|
|
17
|
-
summary,
|
|
18
|
-
...(details !== undefined ? { details } : {}),
|
|
19
|
-
evaluated_at: new Date().toISOString(),
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
function resolveTargetPath(check, context) {
|
|
23
|
-
const target = context.targetPath;
|
|
24
|
-
if (!target)
|
|
25
|
-
return null;
|
|
26
|
-
const root = resolve(context.rootPath);
|
|
27
|
-
const absolute = resolve(root, target);
|
|
28
|
-
// Defense in depth — schema-level validation already rejects path
|
|
29
|
-
// traversal, but a hand-edited Build Plan or stale on-disk fixture could
|
|
30
|
-
// slip through. Reject anything that escapes the root.
|
|
31
|
-
if (absolute !== root && !absolute.startsWith(`${root}/`)) {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
return absolute;
|
|
35
|
-
}
|
|
36
|
-
function listMarkdownFiles(absolutePath) {
|
|
37
|
-
if (!existsSync(absolutePath))
|
|
38
|
-
return [];
|
|
39
|
-
try {
|
|
40
|
-
const stats = statSync(absolutePath);
|
|
41
|
-
if (stats.isFile()) {
|
|
42
|
-
return isOutputMarkdownFile(absolutePath) ? [absolutePath] : [];
|
|
43
|
-
}
|
|
44
|
-
if (stats.isDirectory()) {
|
|
45
|
-
return listFilesRecursive(absolutePath, isOutputMarkdownFile);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
catch {
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
return [];
|
|
52
|
-
}
|
|
53
|
-
function countFiles(absolutePath) {
|
|
54
|
-
if (!existsSync(absolutePath))
|
|
55
|
-
return 0;
|
|
56
|
-
try {
|
|
57
|
-
const stats = statSync(absolutePath);
|
|
58
|
-
if (stats.isFile())
|
|
59
|
-
return 1;
|
|
60
|
-
if (stats.isDirectory()) {
|
|
61
|
-
return listFilesRecursive(absolutePath, () => true).length;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
catch {
|
|
65
|
-
return 0;
|
|
66
|
-
}
|
|
67
|
-
return 0;
|
|
68
|
-
}
|
|
69
|
-
const EVALUATORS = {
|
|
70
|
-
file_exists(check, context) {
|
|
71
|
-
const target = resolveTargetPath(check, context);
|
|
72
|
-
if (!target) {
|
|
73
|
-
return makeProof(check, false, "No target path provided for file_exists check.");
|
|
74
|
-
}
|
|
75
|
-
if (!existsSync(target)) {
|
|
76
|
-
return makeProof(check, false, "File or directory does not exist.", { path: context.targetPath });
|
|
77
|
-
}
|
|
78
|
-
try {
|
|
79
|
-
const stats = statSync(target);
|
|
80
|
-
if (stats.isFile() && stats.size === 0) {
|
|
81
|
-
return makeProof(check, false, "File exists but is empty.", { path: context.targetPath });
|
|
82
|
-
}
|
|
83
|
-
return makeProof(check, true, `Path exists (${stats.isDirectory() ? "directory" : "file"}).`);
|
|
84
|
-
}
|
|
85
|
-
catch {
|
|
86
|
-
return makeProof(check, false, "Could not stat target path.", { path: context.targetPath });
|
|
87
|
-
}
|
|
88
|
-
},
|
|
89
|
-
min_file_count(check, context) {
|
|
90
|
-
const target = resolveTargetPath(check, context);
|
|
91
|
-
if (!target) {
|
|
92
|
-
return makeProof(check, false, "No target path provided for min_file_count check.");
|
|
93
|
-
}
|
|
94
|
-
const min = typeof check.params?.min === "number" ? check.params.min : 1;
|
|
95
|
-
const actual = countFiles(target);
|
|
96
|
-
if (actual >= min) {
|
|
97
|
-
return makeProof(check, true, `${actual} file(s) (≥ ${min}).`, { actual, min });
|
|
98
|
-
}
|
|
99
|
-
return makeProof(check, false, `Found ${actual} file(s); expected at least ${min}.`, { actual, min });
|
|
100
|
-
},
|
|
101
|
-
min_file_count_matches_source(check, context) {
|
|
102
|
-
const target = resolveTargetPath(check, context);
|
|
103
|
-
if (!target) {
|
|
104
|
-
return makeProof(check, false, "No target path provided for min_file_count_matches_source check.");
|
|
105
|
-
}
|
|
106
|
-
const matchKey = typeof check.params?.match === "string" ? check.params.match : "source_total";
|
|
107
|
-
const expected = context.counts?.[matchKey];
|
|
108
|
-
if (typeof expected !== "number") {
|
|
109
|
-
return makeProof(check, false, `Cannot evaluate: count "${matchKey}" not available in context.`, { matchKey });
|
|
110
|
-
}
|
|
111
|
-
const actual = countFiles(target);
|
|
112
|
-
if (actual >= expected) {
|
|
113
|
-
return makeProof(check, true, `${actual} of ${expected} source files covered.`, { actual, expected });
|
|
114
|
-
}
|
|
115
|
-
return makeProof(check, false, `Only ${actual} of ${expected} source files covered.`, { actual, expected, matchKey });
|
|
116
|
-
},
|
|
117
|
-
frontmatter_valid(check, context) {
|
|
118
|
-
const target = resolveTargetPath(check, context);
|
|
119
|
-
if (!target) {
|
|
120
|
-
return makeProof(check, false, "No target path provided for frontmatter_valid check.");
|
|
121
|
-
}
|
|
122
|
-
const files = listMarkdownFiles(target);
|
|
123
|
-
if (files.length === 0) {
|
|
124
|
-
return makeProof(check, true, "No markdown files to validate.");
|
|
125
|
-
}
|
|
126
|
-
const validation = validateSynthFiles(files);
|
|
127
|
-
if (validation.invalid_frontmatter === 0) {
|
|
128
|
-
return makeProof(check, true, `${files.length} markdown file(s) have valid frontmatter.`);
|
|
129
|
-
}
|
|
130
|
-
return makeProof(check, false, `${validation.invalid_frontmatter} of ${files.length} markdown file(s) have invalid frontmatter.`, { invalid: validation.invalid_frontmatter, total: files.length });
|
|
131
|
-
},
|
|
132
|
-
frontmatter_required_keys(check, context) {
|
|
133
|
-
const target = resolveTargetPath(check, context);
|
|
134
|
-
if (!target) {
|
|
135
|
-
return makeProof(check, false, "No target path provided for frontmatter_required_keys check.");
|
|
136
|
-
}
|
|
137
|
-
const keys = Array.isArray(check.params?.keys) ? check.params.keys.filter((k) => typeof k === "string") : [];
|
|
138
|
-
if (keys.length === 0) {
|
|
139
|
-
return makeProof(check, false, "frontmatter_required_keys check requires `params.keys: string[]`.");
|
|
140
|
-
}
|
|
141
|
-
const files = listMarkdownFiles(target);
|
|
142
|
-
if (files.length === 0) {
|
|
143
|
-
return makeProof(check, true, "No markdown files to validate.");
|
|
144
|
-
}
|
|
145
|
-
const validation = validateSynthFiles(files, { requiredFrontmatterKeys: keys });
|
|
146
|
-
if (validation.invalid_frontmatter === 0) {
|
|
147
|
-
return makeProof(check, true, `All ${files.length} markdown file(s) have required keys: ${keys.join(", ")}.`);
|
|
148
|
-
}
|
|
149
|
-
return makeProof(check, false, `${validation.invalid_frontmatter} of ${files.length} file(s) missing required keys (${keys.join(", ")}).`, { invalid: validation.invalid_frontmatter, total: files.length, requiredKeys: keys });
|
|
150
|
-
},
|
|
151
|
-
wikilinks_valid(check, context) {
|
|
152
|
-
const target = resolveTargetPath(check, context);
|
|
153
|
-
if (!target) {
|
|
154
|
-
return makeProof(check, false, "No target path provided for wikilinks_valid check.");
|
|
155
|
-
}
|
|
156
|
-
const broken = countBrokenWikilinks(context.rootPath, [context.rootPath], [target]);
|
|
157
|
-
if (broken === 0) {
|
|
158
|
-
return makeProof(check, true, "All wikilinks resolve.");
|
|
159
|
-
}
|
|
160
|
-
return makeProof(check, false, `${broken} broken wikilink(s).`, { broken });
|
|
161
|
-
},
|
|
162
|
-
must_not_contain(check, context) {
|
|
163
|
-
const target = resolveTargetPath(check, context);
|
|
164
|
-
if (!target || !existsSync(target)) {
|
|
165
|
-
return makeProof(check, false, "Target path does not exist.", { path: context.targetPath });
|
|
166
|
-
}
|
|
167
|
-
const phrases = Array.isArray(check.params?.phrases)
|
|
168
|
-
? check.params.phrases.filter((p) => typeof p === "string")
|
|
169
|
-
: [];
|
|
170
|
-
if (phrases.length === 0) {
|
|
171
|
-
return makeProof(check, false, "must_not_contain check requires `params.phrases: string[]`.");
|
|
172
|
-
}
|
|
173
|
-
try {
|
|
174
|
-
const stats = statSync(target);
|
|
175
|
-
const files = stats.isFile() ? [target] : listFilesRecursive(target, () => true);
|
|
176
|
-
const offenders = [];
|
|
177
|
-
for (const file of files) {
|
|
178
|
-
const content = readFileSync(file, "utf8");
|
|
179
|
-
for (const phrase of phrases) {
|
|
180
|
-
if (content.includes(phrase)) {
|
|
181
|
-
offenders.push(`${file}: contains "${phrase}"`);
|
|
182
|
-
break;
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
if (offenders.length === 0) {
|
|
187
|
-
return makeProof(check, true, `No forbidden phrases found across ${files.length} file(s).`);
|
|
188
|
-
}
|
|
189
|
-
return makeProof(check, false, `${offenders.length} file(s) contain forbidden phrases.`, { offenders, phrases });
|
|
190
|
-
}
|
|
191
|
-
catch (error) {
|
|
192
|
-
return makeProof(check, false, `Error reading target: ${error instanceof Error ? error.message : String(error)}`);
|
|
193
|
-
}
|
|
194
|
-
},
|
|
195
|
-
must_contain(check, context) {
|
|
196
|
-
const target = resolveTargetPath(check, context);
|
|
197
|
-
if (!target || !existsSync(target)) {
|
|
198
|
-
return makeProof(check, false, "Target path does not exist.", { path: context.targetPath });
|
|
199
|
-
}
|
|
200
|
-
const phrases = Array.isArray(check.params?.phrases)
|
|
201
|
-
? check.params.phrases.filter((p) => typeof p === "string")
|
|
202
|
-
: [];
|
|
203
|
-
if (phrases.length === 0) {
|
|
204
|
-
return makeProof(check, false, "must_contain check requires `params.phrases: string[]`.");
|
|
205
|
-
}
|
|
206
|
-
try {
|
|
207
|
-
const stats = statSync(target);
|
|
208
|
-
// For directories, must_contain checks across ALL files (every phrase
|
|
209
|
-
// must appear in at least one file). For files, all phrases must
|
|
210
|
-
// appear in that single file.
|
|
211
|
-
if (stats.isFile()) {
|
|
212
|
-
const content = readFileSync(target, "utf8");
|
|
213
|
-
const missing = phrases.filter((phrase) => !content.includes(phrase));
|
|
214
|
-
if (missing.length === 0) {
|
|
215
|
-
return makeProof(check, true, `All ${phrases.length} required phrase(s) present.`);
|
|
216
|
-
}
|
|
217
|
-
return makeProof(check, false, `${missing.length} required phrase(s) missing.`, { missing });
|
|
218
|
-
}
|
|
219
|
-
const files = listFilesRecursive(target, () => true);
|
|
220
|
-
const remaining = new Set(phrases);
|
|
221
|
-
for (const file of files) {
|
|
222
|
-
const content = readFileSync(file, "utf8");
|
|
223
|
-
for (const phrase of [...remaining]) {
|
|
224
|
-
if (content.includes(phrase))
|
|
225
|
-
remaining.delete(phrase);
|
|
226
|
-
}
|
|
227
|
-
if (remaining.size === 0)
|
|
228
|
-
break;
|
|
229
|
-
}
|
|
230
|
-
if (remaining.size === 0) {
|
|
231
|
-
return makeProof(check, true, `All ${phrases.length} required phrase(s) found across files.`);
|
|
232
|
-
}
|
|
233
|
-
return makeProof(check, false, `${remaining.size} required phrase(s) missing across all files.`, { missing: [...remaining] });
|
|
234
|
-
}
|
|
235
|
-
catch (error) {
|
|
236
|
-
return makeProof(check, false, `Error reading target: ${error instanceof Error ? error.message : String(error)}`);
|
|
237
|
-
}
|
|
238
|
-
},
|
|
239
|
-
qa_match(check, context) {
|
|
240
|
-
const expected = typeof check.params?.expected === "string" ? check.params.expected : "";
|
|
241
|
-
const strictness = typeof check.params?.strictness === "string" ? check.params.strictness : "loose";
|
|
242
|
-
const answer = context.agentAnswer ?? "";
|
|
243
|
-
if (!expected) {
|
|
244
|
-
return makeProof(check, false, "qa_match check requires `params.expected: string`.");
|
|
245
|
-
}
|
|
246
|
-
if (!answer) {
|
|
247
|
-
return makeProof(check, false, "No agent answer available for qa_match evaluation.");
|
|
248
|
-
}
|
|
249
|
-
if (strictness === "strict") {
|
|
250
|
-
const passed = answer.trim() === expected.trim();
|
|
251
|
-
return makeProof(check, passed, passed ? "Answer matches expected exactly." : "Answer does not match expected.");
|
|
252
|
-
}
|
|
253
|
-
// Loose: case-insensitive substring match either direction.
|
|
254
|
-
const a = answer.trim().toLowerCase();
|
|
255
|
-
const e = expected.trim().toLowerCase();
|
|
256
|
-
const passed = a.includes(e) || e.includes(a);
|
|
257
|
-
return makeProof(check, passed, passed ? "Answer matches expected (loose)." : "Answer does not match expected.");
|
|
258
|
-
},
|
|
259
|
-
};
|
|
260
|
-
/**
|
|
261
|
-
* Evaluate a single Check against a context, returning a Proof.
|
|
262
|
-
*/
|
|
263
|
-
export function evaluateCheck(check, context) {
|
|
264
|
-
const evaluator = EVALUATORS[check.kind];
|
|
265
|
-
if (!evaluator) {
|
|
266
|
-
return {
|
|
267
|
-
check_id: check.id,
|
|
268
|
-
kind: check.kind,
|
|
269
|
-
passed: false,
|
|
270
|
-
required: check.required,
|
|
271
|
-
summary: `Unknown check kind: ${check.kind}`,
|
|
272
|
-
evaluated_at: new Date().toISOString(),
|
|
273
|
-
};
|
|
274
|
-
}
|
|
275
|
-
return evaluator(check, context);
|
|
276
|
-
}
|
|
277
|
-
/**
|
|
278
|
-
* Evaluate a list of checks. Aggregate ready/not_ready verdict over
|
|
279
|
-
* the proofs: `ready` if every required check passed, otherwise
|
|
280
|
-
* `not_ready`. Soft checks (required: false) that fail produce a
|
|
281
|
-
* proof but don't change the verdict.
|
|
282
|
-
*/
|
|
283
|
-
export function evaluateChecks(checks, context) {
|
|
284
|
-
const proofs = checks.map((check) => evaluateCheck(check, context));
|
|
285
|
-
const failures = proofs.filter((proof) => !proof.passed && proof.required);
|
|
286
|
-
return {
|
|
287
|
-
proofs,
|
|
288
|
-
ready: failures.length === 0,
|
|
289
|
-
failures,
|
|
290
|
-
};
|
|
291
|
-
}
|
|
292
|
-
/**
|
|
293
|
-
* Type guard for the canonical CheckKinds. Useful at parse boundaries
|
|
294
|
-
* where a string came from on-disk JSON.
|
|
295
|
-
*/
|
|
296
|
-
export function isCheckKind(value) {
|
|
297
|
-
return CheckKindSchema.safeParse(value).success;
|
|
298
|
-
}
|
|
@@ -1,316 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
import { BUILD_PLAN_ARTIFACT_KINDS, } from "../build-plan-primitives.js";
|
|
3
|
-
import { ArtifactIdSchema, ArtifactSchema, CheckSchema, RuntimeContractTypeSchema, RuntimeExecutorInfoSchema, RuntimeStageSchema, RuntimeTargetTypeSchema, SourceBuildMaxAttemptsSchema, SourceBuildMaxLoopsSchema, InterfIdPattern, BuildPlanIdSchema, } from "../../../contracts/lib/schema.js";
|
|
4
|
-
// `ArtifactSchema` is used internally below in `BuildPlanContextRawSchema`'s
|
|
5
|
-
// `artifacts[]` field. The other Artifact* schemas/types are NOT
|
|
6
|
-
// re-exported through this module — callers import them directly
|
|
7
|
-
// from `contracts/lib/schema.js`. The 0.17 PR cross-check pruned
|
|
8
|
-
// re-exports that had zero consumers.
|
|
9
|
-
export { GateStatusSchema, ReadinessGateSchema, ReadinessSchema, ReadinessStatusSchema, VerifyTargetResultSchema, RuntimeContractTypeSchema, RuntimeExecutorInfoSchema, RuntimeStageSchema, RuntimeTargetTypeSchema, SourceFilesSchema, SourceFileSchema, SourceKindSchema, SourceSchema, SourceSnapshotSchema, StageInputSchema, StageInputsSchema, SourceBuildMaxAttemptsSchema, SourceBuildMaxLoopsSchema, TestCaseExpectSchema, TestTargetTypeSchema, InterfIdPattern, BuildPlanIdSchema, } from "../../../contracts/lib/schema.js";
|
|
10
|
-
const JsonRecordSchema = z.record(z.string(), z.unknown());
|
|
11
|
-
const COMPILED_RELATIVE_PATH_SEGMENT = /^(?!\.{1,2}$)[^/\\]+$/;
|
|
12
|
-
function isVerifiableContextRelativePath(value) {
|
|
13
|
-
if (value.length === 0)
|
|
14
|
-
return false;
|
|
15
|
-
if (value.startsWith("/") || value.startsWith("\\"))
|
|
16
|
-
return false;
|
|
17
|
-
return value
|
|
18
|
-
.split(/[\\/]+/)
|
|
19
|
-
.every((segment) => COMPILED_RELATIVE_PATH_SEGMENT.test(segment));
|
|
20
|
-
}
|
|
21
|
-
export const BuildPlanArtifactIdSchema = z.string().regex(InterfIdPattern);
|
|
22
|
-
export const BuildPlanArtifactKindSchema = z.enum(BUILD_PLAN_ARTIFACT_KINDS);
|
|
23
|
-
export const BuildPlanArtifactRoleSchema = z.enum(["input", "working", "output", "runtime"]);
|
|
24
|
-
export const BuildStageStatusSchema = z.enum(["idle", "running", "succeeded", "failed"]);
|
|
25
|
-
export const VerifiableContextStageStateSchema = z.object({
|
|
26
|
-
contract_type: RuntimeContractTypeSchema.optional(),
|
|
27
|
-
status: BuildStageStatusSchema.optional(),
|
|
28
|
-
started_at: z.string().nullable().optional(),
|
|
29
|
-
finished_at: z.string().nullable().optional(),
|
|
30
|
-
counts: z.record(z.string(), z.number()).optional(),
|
|
31
|
-
artifact_counts: z.record(z.string(), z.number()).optional(),
|
|
32
|
-
artifacts: z.array(z.string()).optional(),
|
|
33
|
-
summary: z.string().nullable().optional(),
|
|
34
|
-
run_id: z.string().nullable().optional(),
|
|
35
|
-
});
|
|
36
|
-
export const VerifiableContextStateSchema = z.object({
|
|
37
|
-
version: z.number().int().min(1),
|
|
38
|
-
pending: z.array(z.string()),
|
|
39
|
-
stages: z.record(z.string().regex(InterfIdPattern), VerifiableContextStageStateSchema).optional(),
|
|
40
|
-
last_add: z.string().nullable().optional(),
|
|
41
|
-
last_build: z.string().nullable().optional(),
|
|
42
|
-
warning_count: z.number().optional(),
|
|
43
|
-
error_count: z.number().optional(),
|
|
44
|
-
}).strict();
|
|
45
|
-
export const ViewSectionSchema = z.object({
|
|
46
|
-
id: z.string(),
|
|
47
|
-
type: z.enum(["status", "cards", "graph", "documents", "table"]),
|
|
48
|
-
title: z.string(),
|
|
49
|
-
path: z.string().optional(),
|
|
50
|
-
paths: z.array(z.string()).optional(),
|
|
51
|
-
});
|
|
52
|
-
export const ViewCardSchema = z.object({
|
|
53
|
-
id: z.string(),
|
|
54
|
-
label: z.string(),
|
|
55
|
-
metric: z.string(),
|
|
56
|
-
denominator_metric: z.string().optional(),
|
|
57
|
-
format: z.enum(["number", "fraction", "timestamp"]),
|
|
58
|
-
});
|
|
59
|
-
export const VerifiableContextHealthSchema = z.object({
|
|
60
|
-
kind: z.literal("verifiable-context-health"),
|
|
61
|
-
version: z.number().int().min(1),
|
|
62
|
-
generated_at: z.string(),
|
|
63
|
-
target_name: z.string(),
|
|
64
|
-
status: z.enum(["idle", "running", "built", "stale", "failed"]),
|
|
65
|
-
stage: z.union([
|
|
66
|
-
z.enum(["idle", "built", "failed"]),
|
|
67
|
-
RuntimeStageSchema,
|
|
68
|
-
]),
|
|
69
|
-
summary: z.string(),
|
|
70
|
-
metrics: z.record(z.string(), z.number()),
|
|
71
|
-
checks: z.record(z.string(), z.boolean()),
|
|
72
|
-
});
|
|
73
|
-
export const VerifiableContextViewSpecSchema = z.object({
|
|
74
|
-
kind: z.literal("verifiable-context-view-spec"),
|
|
75
|
-
version: z.number().int().min(1),
|
|
76
|
-
generated_at: z.string(),
|
|
77
|
-
target_name: z.string(),
|
|
78
|
-
health_source: z.string(),
|
|
79
|
-
state_source: z.string(),
|
|
80
|
-
default_note: z.string().nullable(),
|
|
81
|
-
graph_scope: z.array(z.string()),
|
|
82
|
-
cards: z.array(ViewCardSchema),
|
|
83
|
-
sections: z.array(ViewSectionSchema),
|
|
84
|
-
});
|
|
85
|
-
export const BuildPlanPurposeSchema = z.object({
|
|
86
|
-
label: z.string().min(1),
|
|
87
|
-
task_hint: z.string().min(1),
|
|
88
|
-
}).strict();
|
|
89
|
-
export const BuildPlanArtifactProjectionSchema = z.object({
|
|
90
|
-
id: BuildPlanArtifactIdSchema,
|
|
91
|
-
role: BuildPlanArtifactRoleSchema,
|
|
92
|
-
path: z.string().min(1).refine(isVerifiableContextRelativePath, {
|
|
93
|
-
message: "Artifact paths must stay inside the verifiable context root",
|
|
94
|
-
}),
|
|
95
|
-
kind: BuildPlanArtifactKindSchema,
|
|
96
|
-
required: z.boolean(),
|
|
97
|
-
owned_by: z.array(z.string().regex(InterfIdPattern)),
|
|
98
|
-
description: z.string().min(1),
|
|
99
|
-
});
|
|
100
|
-
export const BuildPlanArtifactSchema = BuildPlanArtifactProjectionSchema;
|
|
101
|
-
// Persisted schema for the Build Plan-defined artifact interface that one
|
|
102
|
-
// verifiable context must implement on disk.
|
|
103
|
-
export const BuildPlanContextRawSchema = z.object({
|
|
104
|
-
kind: z.literal("build-plan-schema"),
|
|
105
|
-
version: z.literal(1),
|
|
106
|
-
target_type: z.literal("verifiable-context"),
|
|
107
|
-
label: z.string().min(1),
|
|
108
|
-
artifacts: z.array(ArtifactSchema).min(1),
|
|
109
|
-
}).strict();
|
|
110
|
-
export const BuildPlanContextSchemaSchema = BuildPlanContextRawSchema;
|
|
111
|
-
export const BuildPlanEngineApiSchema = z.object({
|
|
112
|
-
kind: z.literal("build"),
|
|
113
|
-
version: z.literal(1),
|
|
114
|
-
});
|
|
115
|
-
export const BuildPlanStageArtifactReadAccessSchema = z.array(ArtifactIdSchema);
|
|
116
|
-
export const BuildPlanStageArtifactWriteAccessSchema = z.array(ArtifactIdSchema).min(1);
|
|
117
|
-
export const ExecutionShellArtifactMountSchema = z.object({
|
|
118
|
-
artifact_id: ArtifactIdSchema,
|
|
119
|
-
artifact_path: z.string(),
|
|
120
|
-
shell_root_path: z.string(),
|
|
121
|
-
input_mount_path: z.string().nullable(),
|
|
122
|
-
output_mount_path: z.string().nullable(),
|
|
123
|
-
});
|
|
124
|
-
export const ExecutionShellPathsSchema = z.object({
|
|
125
|
-
kind: z.literal("interf-execution-shell"),
|
|
126
|
-
version: z.literal(1),
|
|
127
|
-
build_plan: BuildPlanIdSchema,
|
|
128
|
-
stage: RuntimeStageSchema,
|
|
129
|
-
reads: z.array(ExecutionShellArtifactMountSchema),
|
|
130
|
-
writes: z.array(ExecutionShellArtifactMountSchema),
|
|
131
|
-
});
|
|
132
|
-
export const RuntimeStageInstructionsSchema = z.object({
|
|
133
|
-
stage_skill_dir: z.string().regex(InterfIdPattern),
|
|
134
|
-
effective_mode: z.enum(["builtin", "extend", "override"]),
|
|
135
|
-
local_mode: z.enum(["extend", "override"]).nullable(),
|
|
136
|
-
local_docs: z.array(z.string()),
|
|
137
|
-
mode_sources: z.array(z.string()),
|
|
138
|
-
}).strict();
|
|
139
|
-
export const RuntimeStageContractSchema = z.object({
|
|
140
|
-
kind: z.literal("interf-stage-contract"),
|
|
141
|
-
version: z.literal(1),
|
|
142
|
-
generated_at: z.string(),
|
|
143
|
-
run_id: z.string(),
|
|
144
|
-
target_type: RuntimeTargetTypeSchema,
|
|
145
|
-
target_name: z.string(),
|
|
146
|
-
build_plan: z.object({
|
|
147
|
-
id: BuildPlanIdSchema,
|
|
148
|
-
stage_index: z.number().nullable(),
|
|
149
|
-
stage_total: z.number(),
|
|
150
|
-
stages: z.array(RuntimeStageSchema),
|
|
151
|
-
}),
|
|
152
|
-
stage: RuntimeStageSchema,
|
|
153
|
-
stage_label: z.string(),
|
|
154
|
-
contract_type: RuntimeContractTypeSchema,
|
|
155
|
-
executor: RuntimeExecutorInfoSchema,
|
|
156
|
-
instructions: RuntimeStageInstructionsSchema,
|
|
157
|
-
counts: z.record(z.string(), z.number()),
|
|
158
|
-
artifacts: z.object({
|
|
159
|
-
reads: z.array(z.string()),
|
|
160
|
-
writes: z.array(z.string()),
|
|
161
|
-
write_contracts: z.array(z.object({
|
|
162
|
-
artifact_id: ArtifactIdSchema,
|
|
163
|
-
path: z.string().min(1),
|
|
164
|
-
checks: z.array(CheckSchema),
|
|
165
|
-
}).strict()).default([]),
|
|
166
|
-
}),
|
|
167
|
-
policies: z.object({
|
|
168
|
-
execution_mode: z.literal("deterministic"),
|
|
169
|
-
status_prefixes: z.array(z.string()),
|
|
170
|
-
notes: z.array(z.string()),
|
|
171
|
-
evidence_weighting: z.object({
|
|
172
|
-
required_fields: z.array(z.string()),
|
|
173
|
-
preserve_tiers: z.boolean(),
|
|
174
|
-
}).optional(),
|
|
175
|
-
working_set: z.object({
|
|
176
|
-
target_context_fraction: z.number(),
|
|
177
|
-
strategy: z.string(),
|
|
178
|
-
}).optional(),
|
|
179
|
-
}),
|
|
180
|
-
});
|
|
181
|
-
export const RuntimeRunSchema = z.object({
|
|
182
|
-
kind: z.literal("interf-run"),
|
|
183
|
-
version: z.literal(1),
|
|
184
|
-
run_id: z.string(),
|
|
185
|
-
target_type: RuntimeTargetTypeSchema,
|
|
186
|
-
target_name: z.string(),
|
|
187
|
-
build_plan: BuildPlanIdSchema,
|
|
188
|
-
stage: RuntimeStageSchema,
|
|
189
|
-
stage_label: z.string(),
|
|
190
|
-
contract_type: RuntimeContractTypeSchema,
|
|
191
|
-
status: z.enum(["running", "succeeded", "failed"]),
|
|
192
|
-
executor: RuntimeExecutorInfoSchema,
|
|
193
|
-
started_at: z.string(),
|
|
194
|
-
updated_at: z.string(),
|
|
195
|
-
finished_at: z.string().nullable(),
|
|
196
|
-
contract_path: z.string(),
|
|
197
|
-
execution_path: z.string().optional(),
|
|
198
|
-
counts: z.record(z.string(), z.number()),
|
|
199
|
-
output_artifacts: z.array(z.string()),
|
|
200
|
-
logs: z.object({
|
|
201
|
-
prompt_path: z.string(),
|
|
202
|
-
event_stream_path: z.string(),
|
|
203
|
-
status_path: z.string().optional(),
|
|
204
|
-
}).optional(),
|
|
205
|
-
summary: z.string(),
|
|
206
|
-
exit_code: z.number().nullable(),
|
|
207
|
-
error: z.string().nullable(),
|
|
208
|
-
});
|
|
209
|
-
export const RuntimeInventoryEntrySchema = z.object({
|
|
210
|
-
input_artifact: ArtifactIdSchema.optional(),
|
|
211
|
-
input_path: z.string().min(1).optional(),
|
|
212
|
-
output_artifact: ArtifactIdSchema,
|
|
213
|
-
output_path: z.string().min(1),
|
|
214
|
-
state: z.string().min(1).optional(),
|
|
215
|
-
metadata: JsonRecordSchema.optional(),
|
|
216
|
-
}).strict();
|
|
217
|
-
export const RuntimeInventorySchema = z.object({
|
|
218
|
-
kind: z.literal("verifiable-context-runtime-ledger").optional(),
|
|
219
|
-
version: z.number().int().min(1).optional(),
|
|
220
|
-
stage: RuntimeStageSchema.optional(),
|
|
221
|
-
entries: z.array(RuntimeInventoryEntrySchema),
|
|
222
|
-
total: z.number().int().nonnegative(),
|
|
223
|
-
});
|
|
224
|
-
export const BuildPlanImprovementLoopSummarySchema = z.object({
|
|
225
|
-
variation: z.number().int().min(1),
|
|
226
|
-
kind: z.enum(["baseline", "edited"]),
|
|
227
|
-
attempts_run: z.number().int().min(1),
|
|
228
|
-
passed: z.boolean(),
|
|
229
|
-
passed_questions: z.number().int().min(0),
|
|
230
|
-
total_questions: z.number().int().min(0),
|
|
231
|
-
failed_stage: z.string().nullable().optional(),
|
|
232
|
-
test_run_path: z.string().nullable().optional(),
|
|
233
|
-
test_sandbox_path: z.string().nullable().optional(),
|
|
234
|
-
summary: z.string().min(1),
|
|
235
|
-
});
|
|
236
|
-
export const BuildPlanImprovementContextSchema = z.object({
|
|
237
|
-
kind: z.literal("interf-build-plan-improvement-loop"),
|
|
238
|
-
version: z.literal(1),
|
|
239
|
-
generated_at: z.string(),
|
|
240
|
-
target_name: z.string(),
|
|
241
|
-
build_plan_id: BuildPlanIdSchema,
|
|
242
|
-
loop_index: z.number().int().min(1),
|
|
243
|
-
max_loops: SourceBuildMaxLoopsSchema,
|
|
244
|
-
max_attempts: SourceBuildMaxAttemptsSchema,
|
|
245
|
-
review_paths: z.object({
|
|
246
|
-
build_plan_root: z.string(),
|
|
247
|
-
verifiable_context_runtime: z.string().nullable(),
|
|
248
|
-
readiness_runs: z.string().nullable(),
|
|
249
|
-
execution_shells: z.string().nullable(),
|
|
250
|
-
test_runs: z.string().nullable(),
|
|
251
|
-
test_sandboxes: z.string().nullable(),
|
|
252
|
-
}),
|
|
253
|
-
readiness_checks: z.object({
|
|
254
|
-
count: z.number().int().min(0),
|
|
255
|
-
questions: z.array(z.object({
|
|
256
|
-
id: z.string(),
|
|
257
|
-
question: z.string(),
|
|
258
|
-
})),
|
|
259
|
-
}),
|
|
260
|
-
previous_variations: z.array(BuildPlanImprovementLoopSummarySchema),
|
|
261
|
-
latest_failure: BuildPlanImprovementLoopSummarySchema.nullable(),
|
|
262
|
-
});
|
|
263
|
-
export const PreservedShellTypeSchema = z.enum([
|
|
264
|
-
"stage-execution",
|
|
265
|
-
"build-plan-authoring",
|
|
266
|
-
"build-plan-improvement",
|
|
267
|
-
]);
|
|
268
|
-
export const PreservedShellSnapshotSchema = z.object({
|
|
269
|
-
kind: z.literal("interf-preserved-shell"),
|
|
270
|
-
version: z.literal(1),
|
|
271
|
-
shell_type: PreservedShellTypeSchema,
|
|
272
|
-
generated_at: z.string(),
|
|
273
|
-
root_path: z.string(),
|
|
274
|
-
materialized_symlinks: z.number().int().min(0),
|
|
275
|
-
});
|
|
276
|
-
export const BuildPlanPackageValidationSchema = z.object({
|
|
277
|
-
ok: z.boolean(),
|
|
278
|
-
summary: z.string(),
|
|
279
|
-
errors: z.array(z.string()),
|
|
280
|
-
counts: z.record(z.string(), z.number()),
|
|
281
|
-
});
|
|
282
|
-
export const BuildPlanImprovementLoopRecordSchema = z.object({
|
|
283
|
-
kind: z.literal("interf-build-plan-improvement-loop-record"),
|
|
284
|
-
version: z.literal(1),
|
|
285
|
-
recorded_at: z.string(),
|
|
286
|
-
run_id: z.string(),
|
|
287
|
-
loop_index: z.number().int().min(1),
|
|
288
|
-
target_name: z.string(),
|
|
289
|
-
build_plan_id: BuildPlanIdSchema,
|
|
290
|
-
result: z.enum(["updated", "no-change", "invalid", "executor-failed"]),
|
|
291
|
-
changed: z.boolean(),
|
|
292
|
-
applied: z.boolean(),
|
|
293
|
-
summary: z.string(),
|
|
294
|
-
shell_path: z.string(),
|
|
295
|
-
loop_root_path: z.string(),
|
|
296
|
-
context_path: z.string(),
|
|
297
|
-
build_plan_before_path: z.string(),
|
|
298
|
-
build_plan_after_path: z.string(),
|
|
299
|
-
prompt_log_path: z.string(),
|
|
300
|
-
event_log_path: z.string(),
|
|
301
|
-
status_log_path: z.string(),
|
|
302
|
-
preserved_shell_manifest_path: z.string().nullable(),
|
|
303
|
-
validation: BuildPlanPackageValidationSchema.nullable(),
|
|
304
|
-
});
|
|
305
|
-
export const BuildPlanImprovementRunLedgerSchema = z.object({
|
|
306
|
-
kind: z.literal("interf-build-plan-improvement-run"),
|
|
307
|
-
version: z.literal(1),
|
|
308
|
-
generated_at: z.string(),
|
|
309
|
-
updated_at: z.string(),
|
|
310
|
-
run_id: z.string(),
|
|
311
|
-
target_name: z.string(),
|
|
312
|
-
build_plan_id: BuildPlanIdSchema,
|
|
313
|
-
max_loops: SourceBuildMaxLoopsSchema,
|
|
314
|
-
max_attempts: SourceBuildMaxAttemptsSchema,
|
|
315
|
-
loops: z.array(BuildPlanImprovementLoopRecordSchema),
|
|
316
|
-
});
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import { existsSync, readdirSync, rmSync } from "node:fs";
|
|
2
|
-
import { join } from "node:path";
|
|
3
|
-
import { listBuildPlanContextArtifacts, readBuildPlanContextFile } from "./verifiable-context-schema.js";
|
|
4
|
-
import { initializeBuildRuntimeState } from "./state.js";
|
|
5
|
-
import { stageExecutionShellsRoot, testRootForVerifiableContext, testTargetsRootForVerifiableContext, buildPlanImprovementLoopsRoot, verifiableContextQueryAcceptanceRoot, verifiableContextRuntimeRoot, verifiableContextRuntimeLogsRoot, buildPlanPackagePathForVerifiableContext, } from "./verifiable-context-paths.js";
|
|
6
|
-
function removeIfExists(path) {
|
|
7
|
-
if (existsSync(path)) {
|
|
8
|
-
rmSync(path, { recursive: true, force: true });
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
const BUILD_RUNTIME_RESET_ENTRIES = [
|
|
12
|
-
"state.json",
|
|
13
|
-
"health.json",
|
|
14
|
-
"view-spec.json",
|
|
15
|
-
"inventory.json",
|
|
16
|
-
"run.json",
|
|
17
|
-
"source-files.json",
|
|
18
|
-
"source-snapshot.json",
|
|
19
|
-
"stage-contract.json",
|
|
20
|
-
"stages",
|
|
21
|
-
];
|
|
22
|
-
const PRESERVED_COMPILED_ROOTS = new Set([
|
|
23
|
-
".agents",
|
|
24
|
-
".claude",
|
|
25
|
-
".codex",
|
|
26
|
-
".cursor",
|
|
27
|
-
".gitignore",
|
|
28
|
-
".interf",
|
|
29
|
-
".interfignore",
|
|
30
|
-
"AGENTS.md",
|
|
31
|
-
"CLAUDE.md",
|
|
32
|
-
]);
|
|
33
|
-
export function clearBuildRuntimeDerivedArtifacts(verifiableContextPath) {
|
|
34
|
-
const runtimeRoot = verifiableContextRuntimeRoot(verifiableContextPath);
|
|
35
|
-
for (const entry of BUILD_RUNTIME_RESET_ENTRIES) {
|
|
36
|
-
removeIfExists(join(runtimeRoot, entry));
|
|
37
|
-
}
|
|
38
|
-
removeIfExists(verifiableContextQueryAcceptanceRoot(verifiableContextPath));
|
|
39
|
-
}
|
|
40
|
-
function activeBuildInputRoots(verifiableContextPath) {
|
|
41
|
-
const schema = readBuildPlanContextFile(buildPlanPackagePathForVerifiableContext(verifiableContextPath));
|
|
42
|
-
const roots = new Set();
|
|
43
|
-
for (const artifact of schema ? listBuildPlanContextArtifacts(schema) : []) {
|
|
44
|
-
if (artifact.role !== "input")
|
|
45
|
-
continue;
|
|
46
|
-
const root = artifact.path.split("/")[0]?.trim();
|
|
47
|
-
if (root)
|
|
48
|
-
roots.add(root);
|
|
49
|
-
}
|
|
50
|
-
return roots;
|
|
51
|
-
}
|
|
52
|
-
function resetBuildGeneratedOutputs(verifiableContextPath) {
|
|
53
|
-
const preservedInputRoots = activeBuildInputRoots(verifiableContextPath);
|
|
54
|
-
for (const entry of readdirSync(verifiableContextPath)) {
|
|
55
|
-
if (PRESERVED_COMPILED_ROOTS.has(entry))
|
|
56
|
-
continue;
|
|
57
|
-
if (preservedInputRoots.has(entry))
|
|
58
|
-
continue;
|
|
59
|
-
removeIfExists(join(verifiableContextPath, entry));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
export function resetBuildGeneratedState(verifiableContextPath, scope = "build") {
|
|
63
|
-
resetBuildGeneratedOutputs(verifiableContextPath);
|
|
64
|
-
clearBuildRuntimeDerivedArtifacts(verifiableContextPath);
|
|
65
|
-
initializeBuildRuntimeState(verifiableContextPath);
|
|
66
|
-
if (scope === "all") {
|
|
67
|
-
removeIfExists(stageExecutionShellsRoot(verifiableContextPath));
|
|
68
|
-
removeIfExists(buildPlanImprovementLoopsRoot(verifiableContextPath));
|
|
69
|
-
removeIfExists(verifiableContextRuntimeLogsRoot(verifiableContextPath));
|
|
70
|
-
removeIfExists(join(verifiableContextRuntimeRoot(verifiableContextPath), "run-history.jsonl"));
|
|
71
|
-
removeIfExists(testRootForVerifiableContext(verifiableContextPath));
|
|
72
|
-
removeIfExists(testTargetsRootForVerifiableContext(verifiableContextPath));
|
|
73
|
-
}
|
|
74
|
-
}
|