agentic-orchestrator 0.1.27 → 0.2.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.
Files changed (837) hide show
  1. package/.claude/settings.local.json +46 -1
  2. package/.cortexrc +28 -0
  3. package/.github/agents/copilot-instructions.md +29 -0
  4. package/.github/copilot-instructions.md +93 -0
  5. package/.vscode/settings.json +13 -0
  6. package/.vscode/tms.code-snippets +223 -0
  7. package/AGENTS.md +72 -1
  8. package/Agentic-Orchestrator.iml +12 -11
  9. package/CLAUDE.md +72 -1
  10. package/CONSTITUTION.md +504 -0
  11. package/FUTURE-ENHANCEMENTS.md +85 -0
  12. package/NEXT-TASKS.md +25 -0
  13. package/PROMPTS.md +161 -0
  14. package/README.md +126 -29
  15. package/agentic/orchestrator/agents.yaml +4 -3
  16. package/agentic/orchestrator/defaults/policy.defaults.yaml +39 -3
  17. package/agentic/orchestrator/gates.yaml +15 -3
  18. package/agentic/orchestrator/policy.yaml +47 -3
  19. package/agentic/orchestrator/prompts/builder.system.md +69 -20
  20. package/agentic/orchestrator/prompts/planner-intake.system.md +149 -0
  21. package/agentic/orchestrator/prompts/planner.system.md +113 -40
  22. package/agentic/orchestrator/prompts/qa.system.md +73 -18
  23. package/agentic/orchestrator/prompts/reconciler.system.md +119 -0
  24. package/agentic/orchestrator/schemas/agents.schema.json +89 -1
  25. package/agentic/orchestrator/schemas/execution-control.schema.json +242 -0
  26. package/agentic/orchestrator/schemas/index.schema.json +234 -0
  27. package/agentic/orchestrator/schemas/intake.review.schema.json +82 -0
  28. package/agentic/orchestrator/schemas/organizer-ordering-artifact.schema.json +75 -0
  29. package/agentic/orchestrator/schemas/plan.schema.json +44 -0
  30. package/agentic/orchestrator/schemas/policy.schema.json +238 -9
  31. package/agentic/orchestrator/schemas/policy.user.schema.json +129 -1
  32. package/agentic/orchestrator/schemas/spec.manifest.bootstrap.schema.json +101 -0
  33. package/agentic/orchestrator/schemas/spec.manifest.verified.schema.json +80 -0
  34. package/agentic/orchestrator/schemas/state.schema.json +298 -3
  35. package/agentic/orchestrator/tools/catalog.json +145 -15
  36. package/agentic/orchestrator/tools/schemas/input/doctor.run.input.schema.json +18 -0
  37. package/agentic/orchestrator/tools/schemas/input/evidence.latest.input.schema.json +4 -0
  38. package/agentic/orchestrator/tools/schemas/input/evidence.verify_chain.input.schema.json +13 -0
  39. package/agentic/orchestrator/tools/schemas/input/feature.intake_submit.input.schema.json +11 -0
  40. package/agentic/orchestrator/tools/schemas/input/feature.question_answer.input.schema.json +15 -0
  41. package/agentic/orchestrator/tools/schemas/input/feature.question_create.input.schema.json +21 -0
  42. package/agentic/orchestrator/tools/schemas/input/feature.question_list.input.schema.json +13 -0
  43. package/agentic/orchestrator/tools/schemas/input/feature.ready_to_merge.input.schema.json +5 -0
  44. package/agentic/orchestrator/tools/schemas/input/feature.send_message.input.schema.json +1 -1
  45. package/agentic/orchestrator/tools/schemas/input/replay.timeline_get.input.schema.json +32 -0
  46. package/agentic/orchestrator/tools/schemas/input/repo.conflict_abort.input.schema.json +16 -0
  47. package/agentic/orchestrator/tools/schemas/input/repo.conflict_files.input.schema.json +16 -0
  48. package/agentic/orchestrator/tools/schemas/input/repo.reconcile_mainline.input.schema.json +37 -0
  49. package/agentic/orchestrator/tools/schemas/input/repo.resolve_conflict.input.schema.json +40 -0
  50. package/agentic/orchestrator/tools/schemas/input/runtime.execution_request_list.input.schema.json +7 -0
  51. package/agentic/orchestrator/tools/schemas/input/runtime.execution_request_submit.input.schema.json +25 -0
  52. package/agentic/orchestrator/tools/schemas/output/doctor.run.output.schema.json +34 -0
  53. package/agentic/orchestrator/tools/schemas/output/evidence.verify_chain.output.schema.json +23 -0
  54. package/agentic/orchestrator/tools/schemas/output/feature.get_context.output.schema.json +62 -2
  55. package/agentic/orchestrator/tools/schemas/output/feature.intake_submit.output.schema.json +24 -0
  56. package/agentic/orchestrator/tools/schemas/output/feature.question_answer.output.schema.json +21 -0
  57. package/agentic/orchestrator/tools/schemas/output/feature.question_create.output.schema.json +12 -0
  58. package/agentic/orchestrator/tools/schemas/output/feature.question_list.output.schema.json +14 -0
  59. package/agentic/orchestrator/tools/schemas/output/feature.ready_to_merge.output.schema.json +31 -0
  60. package/agentic/orchestrator/tools/schemas/output/feature.send_message.output.schema.json +8 -18
  61. package/agentic/orchestrator/tools/schemas/output/replay.timeline_get.output.schema.json +64 -0
  62. package/agentic/orchestrator/tools/schemas/output/repo.conflict_abort.output.schema.json +16 -0
  63. package/agentic/orchestrator/tools/schemas/output/repo.conflict_files.output.schema.json +22 -0
  64. package/agentic/orchestrator/tools/schemas/output/repo.reconcile_mainline.output.schema.json +61 -0
  65. package/agentic/orchestrator/tools/schemas/output/repo.resolve_conflict.output.schema.json +19 -0
  66. package/agentic/orchestrator/tools/schemas/output/report.dashboard.output.schema.json +26 -0
  67. package/agentic/orchestrator/tools/schemas/output/runtime.execution_request_list.output.schema.json +17 -0
  68. package/agentic/orchestrator/tools/schemas/output/runtime.execution_request_submit.output.schema.json +24 -0
  69. package/agentic/orchestrator/tools.md +13 -0
  70. package/apps/control-plane/scripts/validate-mcp-contracts.ts +1 -1
  71. package/apps/control-plane/src/application/kernel-tool-wiring.ts +140 -2
  72. package/apps/control-plane/src/application/services/activity-monitor-service.ts +44 -1
  73. package/apps/control-plane/src/application/services/bootstrap-manifest-generator-service.ts +251 -0
  74. package/apps/control-plane/src/application/services/checkpoint-service.ts +87 -27
  75. package/apps/control-plane/src/application/services/collision-override-service.ts +906 -0
  76. package/apps/control-plane/src/application/services/collision-queue-service.ts +129 -38
  77. package/apps/control-plane/src/application/services/cost-tracking-service.ts +94 -0
  78. package/apps/control-plane/src/application/services/execution-control-service.ts +599 -0
  79. package/apps/control-plane/src/application/services/feature-deletion-service.ts +37 -1
  80. package/apps/control-plane/src/application/services/feature-lifecycle-service.ts +182 -4
  81. package/apps/control-plane/src/application/services/feature-send-message-service.ts +17 -8
  82. package/apps/control-plane/src/application/services/feature-state-service.ts +191 -6
  83. package/apps/control-plane/src/application/services/gate-service.ts +121 -2
  84. package/apps/control-plane/src/application/services/git-reconciliation-service.ts +1591 -0
  85. package/apps/control-plane/src/application/services/intake-service.ts +1468 -0
  86. package/apps/control-plane/src/application/services/merge-service.ts +308 -17
  87. package/apps/control-plane/src/application/services/notifier-service.ts +3 -1
  88. package/apps/control-plane/src/application/services/performance-analytics-service.ts +75 -0
  89. package/apps/control-plane/src/application/services/plan-service.ts +336 -20
  90. package/apps/control-plane/src/application/services/question-service.ts +693 -0
  91. package/apps/control-plane/src/application/services/reactions-service.ts +73 -17
  92. package/apps/control-plane/src/application/services/replay-timeline-service.ts +295 -0
  93. package/apps/control-plane/src/application/services/reporting-service.ts +194 -10
  94. package/apps/control-plane/src/application/services/run-lease-service.ts +121 -5
  95. package/apps/control-plane/src/application/services/worktree-watchdog-service.ts +95 -8
  96. package/apps/control-plane/src/application/tools/tool-metadata.ts +7 -0
  97. package/apps/control-plane/src/application/usage-types.ts +138 -0
  98. package/apps/control-plane/src/cli/add-command-handler.ts +162 -0
  99. package/apps/control-plane/src/cli/answer-command-handler.ts +113 -0
  100. package/apps/control-plane/src/cli/attach-command-handler.ts +12 -3
  101. package/apps/control-plane/src/cli/cli-argument-parser.ts +133 -11
  102. package/apps/control-plane/src/cli/collision-command-handler.ts +113 -0
  103. package/apps/control-plane/src/cli/command-catalog.ts +479 -0
  104. package/apps/control-plane/src/cli/complete-command-handler.ts +23 -0
  105. package/apps/control-plane/src/cli/completion-command-handler.ts +25 -0
  106. package/apps/control-plane/src/cli/completion-resolver.ts +319 -0
  107. package/apps/control-plane/src/cli/completion-shell-renderer.ts +58 -0
  108. package/apps/control-plane/src/cli/dashboard-command-handler.ts +110 -1
  109. package/apps/control-plane/src/cli/dashboard-runtime-runner.ts +1036 -0
  110. package/apps/control-plane/src/cli/dashboard-runtime.ts +31 -0
  111. package/apps/control-plane/src/cli/help-command-handler.ts +17 -185
  112. package/apps/control-plane/src/cli/init-command-handler.ts +51 -6
  113. package/apps/control-plane/src/cli/merge-command-handler.ts +200 -0
  114. package/apps/control-plane/src/cli/questions-command-handler.ts +70 -0
  115. package/apps/control-plane/src/cli/replay-command-handler.ts +98 -0
  116. package/apps/control-plane/src/cli/resume-command-handler.ts +252 -18
  117. package/apps/control-plane/src/cli/retry-command-handler.ts +229 -17
  118. package/apps/control-plane/src/cli/retry-resume-decision.ts +75 -0
  119. package/apps/control-plane/src/cli/rollback-command-handler.ts +4 -2
  120. package/apps/control-plane/src/cli/run-command-handler.ts +35 -1
  121. package/apps/control-plane/src/cli/spec-ingestion-service.ts +45 -55
  122. package/apps/control-plane/src/cli/spec-preparation.ts +114 -0
  123. package/apps/control-plane/src/cli/spec-utils.ts +90 -11
  124. package/apps/control-plane/src/cli/status-command-handler.ts +122 -0
  125. package/apps/control-plane/src/cli/types.ts +41 -3
  126. package/apps/control-plane/src/core/collisions.ts +150 -31
  127. package/apps/control-plane/src/core/constants.ts +18 -1
  128. package/apps/control-plane/src/core/error-codes.ts +39 -0
  129. package/apps/control-plane/src/core/execution-control.ts +56 -0
  130. package/apps/control-plane/src/core/feature-resume-phase.ts +118 -0
  131. package/apps/control-plane/src/core/gate-freshness.ts +359 -0
  132. package/apps/control-plane/src/core/gate-log-extractor.ts +97 -0
  133. package/apps/control-plane/src/core/gates.ts +90 -1
  134. package/apps/control-plane/src/core/intake-artifacts.ts +295 -0
  135. package/apps/control-plane/src/core/kernel-types.ts +11 -0
  136. package/apps/control-plane/src/core/kernel.ts +604 -16
  137. package/apps/control-plane/src/core/mainline-conflict.ts +22 -0
  138. package/apps/control-plane/src/core/merge-repair.ts +149 -0
  139. package/apps/control-plane/src/core/path-layout.ts +46 -2
  140. package/apps/control-plane/src/core/path-rules.ts +11 -3
  141. package/apps/control-plane/src/core/plan-submit-recovery.ts +130 -0
  142. package/apps/control-plane/src/core/questions.ts +49 -0
  143. package/apps/control-plane/src/core/runtime-sessions.ts +4 -0
  144. package/apps/control-plane/src/core/schemas.ts +40 -1
  145. package/apps/control-plane/src/core/tool-caller.ts +25 -1
  146. package/apps/control-plane/src/core/utils/index-normalizer.ts +25 -4
  147. package/apps/control-plane/src/core/worktree-diff.ts +66 -0
  148. package/apps/control-plane/src/index.ts +29 -1
  149. package/apps/control-plane/src/interfaces/cli/bootstrap.ts +300 -6
  150. package/apps/control-plane/src/mcp/kernel-tool-executor.ts +17 -0
  151. package/apps/control-plane/src/mcp/tool-runtime.ts +63 -4
  152. package/apps/control-plane/src/providers/api-worker-provider.ts +62 -15
  153. package/apps/control-plane/src/providers/cli-worker-provider.ts +1037 -61
  154. package/apps/control-plane/src/providers/output-parsers/generic-output-parser.ts +99 -1
  155. package/apps/control-plane/src/providers/output-parsers/types.ts +2 -0
  156. package/apps/control-plane/src/providers/provider-defaults.ts +116 -7
  157. package/apps/control-plane/src/providers/providers.ts +225 -21
  158. package/apps/control-plane/src/providers/worker-provider-factory.ts +26 -2
  159. package/apps/control-plane/src/supervisor/artifact-stager.ts +52 -0
  160. package/apps/control-plane/src/supervisor/build-wave-executor.ts +477 -166
  161. package/apps/control-plane/src/supervisor/execution-enrollment-service.ts +408 -0
  162. package/apps/control-plane/src/supervisor/organizer-enrollment-scheduler.ts +117 -0
  163. package/apps/control-plane/src/supervisor/organizer-sidecar-service.ts +394 -0
  164. package/apps/control-plane/src/supervisor/plan-conformance-scorer.ts +2 -5
  165. package/apps/control-plane/src/supervisor/planner-phase.ts +85 -0
  166. package/apps/control-plane/src/supervisor/planning-wave-executor.ts +993 -64
  167. package/apps/control-plane/src/supervisor/prompt-bundle-loader.ts +20 -1
  168. package/apps/control-plane/src/supervisor/qa-wave-executor.ts +384 -177
  169. package/apps/control-plane/src/supervisor/run-coordinator.ts +801 -43
  170. package/apps/control-plane/src/supervisor/runtime.ts +485 -9
  171. package/apps/control-plane/src/supervisor/session-orchestrator.ts +220 -1
  172. package/apps/control-plane/src/supervisor/types.ts +152 -1
  173. package/apps/control-plane/src/supervisor/worker-decision-loop.ts +1030 -92
  174. package/apps/control-plane/test/activity-monitor.spec.ts +76 -0
  175. package/apps/control-plane/test/add-command-handler.spec.ts +189 -0
  176. package/apps/control-plane/test/application/services/feature-state-service.spec.ts +208 -0
  177. package/apps/control-plane/test/artifact-stager.spec.ts +93 -0
  178. package/apps/control-plane/test/batch-operations.spec.ts +58 -0
  179. package/apps/control-plane/test/bootstrap-edge-cases.spec.ts +50 -2
  180. package/apps/control-plane/test/bootstrap-manifest-generator-service.spec.ts +99 -0
  181. package/apps/control-plane/test/bootstrap.spec.ts +177 -4
  182. package/apps/control-plane/test/checkpoint-service.spec.ts +977 -29
  183. package/apps/control-plane/test/cli-argument-parser.spec.ts +119 -0
  184. package/apps/control-plane/test/cli-helpers.spec.ts +1202 -12
  185. package/apps/control-plane/test/cli.unit.spec.ts +797 -16
  186. package/apps/control-plane/test/collision-command-handler.spec.ts +182 -0
  187. package/apps/control-plane/test/collision-override-service.spec.ts +878 -0
  188. package/apps/control-plane/test/collision-queue.spec.ts +430 -2
  189. package/apps/control-plane/test/collisions.spec.ts +209 -1
  190. package/apps/control-plane/test/core-utils.spec.ts +61 -0
  191. package/apps/control-plane/test/cost-tracking.spec.ts +224 -0
  192. package/apps/control-plane/test/dashboard-api.integration.spec.ts +185 -5
  193. package/apps/control-plane/test/dashboard-client.spec.ts +948 -0
  194. package/apps/control-plane/test/dashboard-command.spec.ts +138 -6
  195. package/apps/control-plane/test/dashboard-runtime-runner.spec.ts +1550 -0
  196. package/apps/control-plane/test/dashboard-runtime.spec.ts +138 -0
  197. package/apps/control-plane/test/dashboard-ui-utils.spec.ts +56 -12
  198. package/apps/control-plane/test/dependency-scheduler.spec.ts +7 -1
  199. package/apps/control-plane/test/env-file.spec.ts +76 -0
  200. package/apps/control-plane/test/execution-control-service.spec.ts +535 -0
  201. package/apps/control-plane/test/execution-enrollment-service.spec.ts +648 -0
  202. package/apps/control-plane/test/feature-lifecycle.spec.ts +126 -0
  203. package/apps/control-plane/test/feature-resume-phase.spec.ts +164 -0
  204. package/apps/control-plane/test/feature-send-message-service.spec.ts +161 -0
  205. package/apps/control-plane/test/feature-state-service.spec.ts +295 -0
  206. package/apps/control-plane/test/fs.spec.ts +80 -0
  207. package/apps/control-plane/test/gate-freshness.spec.ts +590 -0
  208. package/apps/control-plane/test/gate-log-extractor.spec.ts +170 -0
  209. package/apps/control-plane/test/gates.spec.ts +108 -0
  210. package/apps/control-plane/test/git-reconciliation-service.spec.ts +2307 -0
  211. package/apps/control-plane/test/helpers.ts +65 -0
  212. package/apps/control-plane/test/incremental-gates.spec.ts +271 -0
  213. package/apps/control-plane/test/index-normalizer.spec.ts +98 -0
  214. package/apps/control-plane/test/init-wizard.spec.ts +17 -0
  215. package/apps/control-plane/test/intake-artifacts.spec.ts +203 -0
  216. package/apps/control-plane/test/intake-service.spec.ts +3176 -0
  217. package/apps/control-plane/test/kernel-collision-replay.spec.ts +3 -2
  218. package/apps/control-plane/test/kernel-tool-executor.spec.ts +77 -0
  219. package/apps/control-plane/test/kernel-tool-wiring.spec.ts +279 -0
  220. package/apps/control-plane/test/kernel.branches.spec.ts +15 -2
  221. package/apps/control-plane/test/kernel.coverage.spec.ts +7 -3
  222. package/apps/control-plane/test/kernel.coverage2.spec.ts +731 -2
  223. package/apps/control-plane/test/kernel.spec.ts +464 -2
  224. package/apps/control-plane/test/mainline-conflict.spec.ts +66 -0
  225. package/apps/control-plane/test/mcp-helpers.spec.ts +79 -0
  226. package/apps/control-plane/test/mcp.spec.ts +177 -13
  227. package/apps/control-plane/test/merge-command-handler.spec.ts +531 -0
  228. package/apps/control-plane/test/merge-service.spec.ts +570 -4
  229. package/apps/control-plane/test/notifier-service.spec.ts +26 -0
  230. package/apps/control-plane/test/organizer-enrollment-scheduler.spec.ts +340 -0
  231. package/apps/control-plane/test/organizer-ordering-artifact.spec.ts +95 -0
  232. package/apps/control-plane/test/organizer-sidecar-service.spec.ts +468 -0
  233. package/apps/control-plane/test/output-loop-detector.spec.ts +6 -0
  234. package/apps/control-plane/test/path-layout.spec.ts +70 -0
  235. package/apps/control-plane/test/path-normalizers.spec.ts +41 -0
  236. package/apps/control-plane/test/performance-analytics.spec.ts +124 -0
  237. package/apps/control-plane/test/plan-conformance-scorer.spec.ts +53 -0
  238. package/apps/control-plane/test/plan-service.spec.ts +686 -4
  239. package/apps/control-plane/test/planning-wave-executor.spec.ts +3272 -86
  240. package/apps/control-plane/test/policy-loader-service.spec.ts +5 -0
  241. package/apps/control-plane/test/prompt-overlay.spec.ts +65 -0
  242. package/apps/control-plane/test/provider-command-runner-epipe.spec.ts +64 -0
  243. package/apps/control-plane/test/providers/api-worker-provider.spec.ts +129 -0
  244. package/apps/control-plane/test/providers/cli-worker-provider.spec.ts +148 -0
  245. package/apps/control-plane/test/providers/usage-types.spec.ts +98 -0
  246. package/apps/control-plane/test/providers.spec.ts +293 -16
  247. package/apps/control-plane/test/question-command-handlers.spec.ts +156 -0
  248. package/apps/control-plane/test/question-service.spec.ts +1119 -0
  249. package/apps/control-plane/test/reactions.spec.ts +114 -0
  250. package/apps/control-plane/test/replay-command-handler.spec.ts +144 -0
  251. package/apps/control-plane/test/replay-timeline-service.spec.ts +459 -0
  252. package/apps/control-plane/test/response.spec.ts +31 -0
  253. package/apps/control-plane/test/resume-command.spec.ts +786 -9
  254. package/apps/control-plane/test/retry-resume-decision.spec.ts +133 -0
  255. package/apps/control-plane/test/rollback-command-handler.spec.ts +334 -0
  256. package/apps/control-plane/test/rollback-command.spec.ts +120 -0
  257. package/apps/control-plane/test/run-coordinator.spec.ts +3141 -364
  258. package/apps/control-plane/test/schemas/state.schema.spec.ts +71 -0
  259. package/apps/control-plane/test/service-retry-paths.spec.ts +112 -0
  260. package/apps/control-plane/test/services.spec.ts +472 -2
  261. package/apps/control-plane/test/session-management.spec.ts +346 -1
  262. package/apps/control-plane/test/spec-ingestion.spec.ts +102 -28
  263. package/apps/control-plane/test/spec-preparation.spec.ts +182 -0
  264. package/apps/control-plane/test/supervisor-collaborators.spec.ts +191 -3
  265. package/apps/control-plane/test/supervisor.calltool.spec.ts +198 -0
  266. package/apps/control-plane/test/supervisor.spec.ts +95 -16
  267. package/apps/control-plane/test/supervisor.unit.spec.ts +385 -18
  268. package/apps/control-plane/test/tool-runtime.spec.ts +122 -0
  269. package/apps/control-plane/test/worker-decision-loop.spec.ts +3479 -476
  270. package/apps/control-plane/test/worker-execution-policy.spec.ts +1416 -6
  271. package/apps/control-plane/test/worker-provider-adapters.spec.ts +1894 -37
  272. package/apps/control-plane/test/worker-provider-factory.spec.ts +81 -0
  273. package/apps/control-plane/test/worktree-watchdog-service.spec.ts +125 -0
  274. package/apps/control-plane/vitest.config.ts +5 -0
  275. package/config/agentic/orchestrator/agents.yaml +23 -2
  276. package/config/agentic/orchestrator/gates.yaml +24 -7
  277. package/config/agentic/orchestrator/policy.yaml +23 -1
  278. package/config/agentic/orchestrator/prompts/builder.system.md +69 -20
  279. package/config/agentic/orchestrator/prompts/organizer.system.md +85 -0
  280. package/config/agentic/orchestrator/prompts/overrides/builder.claude.md +28 -0
  281. package/config/agentic/orchestrator/prompts/overrides/builder.codex.md +28 -0
  282. package/config/agentic/orchestrator/prompts/overrides/planner.claude.md +20 -0
  283. package/config/agentic/orchestrator/prompts/overrides/planner.codex.md +20 -0
  284. package/config/agentic/orchestrator/prompts/planner-intake.system.md +149 -0
  285. package/config/agentic/orchestrator/prompts/planner.system.md +113 -40
  286. package/config/agentic/orchestrator/prompts/qa.system.md +75 -18
  287. package/config/agentic/orchestrator/prompts/reconciler.system.md +119 -0
  288. package/dist/apps/control-plane/application/kernel-tool-wiring.d.ts +26 -2
  289. package/dist/apps/control-plane/application/kernel-tool-wiring.js +40 -2
  290. package/dist/apps/control-plane/application/kernel-tool-wiring.js.map +1 -1
  291. package/dist/apps/control-plane/application/services/activity-monitor-service.js +37 -1
  292. package/dist/apps/control-plane/application/services/activity-monitor-service.js.map +1 -1
  293. package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.d.ts +4 -0
  294. package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.js +188 -0
  295. package/dist/apps/control-plane/application/services/bootstrap-manifest-generator-service.js.map +1 -0
  296. package/dist/apps/control-plane/application/services/checkpoint-service.d.ts +5 -0
  297. package/dist/apps/control-plane/application/services/checkpoint-service.js +69 -24
  298. package/dist/apps/control-plane/application/services/checkpoint-service.js.map +1 -1
  299. package/dist/apps/control-plane/application/services/collision-override-service.d.ts +139 -0
  300. package/dist/apps/control-plane/application/services/collision-override-service.js +568 -0
  301. package/dist/apps/control-plane/application/services/collision-override-service.js.map +1 -0
  302. package/dist/apps/control-plane/application/services/collision-queue-service.d.ts +15 -0
  303. package/dist/apps/control-plane/application/services/collision-queue-service.js +92 -33
  304. package/dist/apps/control-plane/application/services/collision-queue-service.js.map +1 -1
  305. package/dist/apps/control-plane/application/services/cost-tracking-service.d.ts +11 -0
  306. package/dist/apps/control-plane/application/services/cost-tracking-service.js +75 -0
  307. package/dist/apps/control-plane/application/services/cost-tracking-service.js.map +1 -1
  308. package/dist/apps/control-plane/application/services/execution-control-service.d.ts +75 -0
  309. package/dist/apps/control-plane/application/services/execution-control-service.js +421 -0
  310. package/dist/apps/control-plane/application/services/execution-control-service.js.map +1 -0
  311. package/dist/apps/control-plane/application/services/feature-deletion-service.d.ts +1 -0
  312. package/dist/apps/control-plane/application/services/feature-deletion-service.js +23 -1
  313. package/dist/apps/control-plane/application/services/feature-deletion-service.js.map +1 -1
  314. package/dist/apps/control-plane/application/services/feature-lifecycle-service.d.ts +24 -1
  315. package/dist/apps/control-plane/application/services/feature-lifecycle-service.js +132 -3
  316. package/dist/apps/control-plane/application/services/feature-lifecycle-service.js.map +1 -1
  317. package/dist/apps/control-plane/application/services/feature-send-message-service.js +16 -8
  318. package/dist/apps/control-plane/application/services/feature-send-message-service.js.map +1 -1
  319. package/dist/apps/control-plane/application/services/feature-state-service.d.ts +36 -0
  320. package/dist/apps/control-plane/application/services/feature-state-service.js +163 -6
  321. package/dist/apps/control-plane/application/services/feature-state-service.js.map +1 -1
  322. package/dist/apps/control-plane/application/services/gate-service.d.ts +2 -1
  323. package/dist/apps/control-plane/application/services/gate-service.js +95 -5
  324. package/dist/apps/control-plane/application/services/gate-service.js.map +1 -1
  325. package/dist/apps/control-plane/application/services/git-reconciliation-service.d.ts +92 -0
  326. package/dist/apps/control-plane/application/services/git-reconciliation-service.js +1097 -0
  327. package/dist/apps/control-plane/application/services/git-reconciliation-service.js.map +1 -0
  328. package/dist/apps/control-plane/application/services/intake-service.d.ts +63 -0
  329. package/dist/apps/control-plane/application/services/intake-service.js +1050 -0
  330. package/dist/apps/control-plane/application/services/intake-service.js.map +1 -0
  331. package/dist/apps/control-plane/application/services/merge-service.d.ts +5 -1
  332. package/dist/apps/control-plane/application/services/merge-service.js +233 -18
  333. package/dist/apps/control-plane/application/services/merge-service.js.map +1 -1
  334. package/dist/apps/control-plane/application/services/notifier-service.d.ts +1 -1
  335. package/dist/apps/control-plane/application/services/notifier-service.js +1 -0
  336. package/dist/apps/control-plane/application/services/notifier-service.js.map +1 -1
  337. package/dist/apps/control-plane/application/services/performance-analytics-service.d.ts +11 -0
  338. package/dist/apps/control-plane/application/services/performance-analytics-service.js +59 -0
  339. package/dist/apps/control-plane/application/services/performance-analytics-service.js.map +1 -1
  340. package/dist/apps/control-plane/application/services/plan-service.d.ts +5 -0
  341. package/dist/apps/control-plane/application/services/plan-service.js +254 -15
  342. package/dist/apps/control-plane/application/services/plan-service.js.map +1 -1
  343. package/dist/apps/control-plane/application/services/question-service.d.ts +72 -0
  344. package/dist/apps/control-plane/application/services/question-service.js +507 -0
  345. package/dist/apps/control-plane/application/services/question-service.js.map +1 -0
  346. package/dist/apps/control-plane/application/services/reactions-service.d.ts +2 -0
  347. package/dist/apps/control-plane/application/services/reactions-service.js +60 -17
  348. package/dist/apps/control-plane/application/services/reactions-service.js.map +1 -1
  349. package/dist/apps/control-plane/application/services/replay-timeline-service.d.ts +39 -0
  350. package/dist/apps/control-plane/application/services/replay-timeline-service.js +205 -0
  351. package/dist/apps/control-plane/application/services/replay-timeline-service.js.map +1 -0
  352. package/dist/apps/control-plane/application/services/reporting-service.d.ts +59 -0
  353. package/dist/apps/control-plane/application/services/reporting-service.js +121 -9
  354. package/dist/apps/control-plane/application/services/reporting-service.js.map +1 -1
  355. package/dist/apps/control-plane/application/services/run-lease-service.d.ts +20 -0
  356. package/dist/apps/control-plane/application/services/run-lease-service.js +81 -4
  357. package/dist/apps/control-plane/application/services/run-lease-service.js.map +1 -1
  358. package/dist/apps/control-plane/application/services/worktree-watchdog-service.d.ts +10 -0
  359. package/dist/apps/control-plane/application/services/worktree-watchdog-service.js +65 -8
  360. package/dist/apps/control-plane/application/services/worktree-watchdog-service.js.map +1 -1
  361. package/dist/apps/control-plane/application/tools/tool-metadata.js +7 -0
  362. package/dist/apps/control-plane/application/tools/tool-metadata.js.map +1 -1
  363. package/dist/apps/control-plane/application/usage-types.d.ts +65 -0
  364. package/dist/apps/control-plane/application/usage-types.js +75 -0
  365. package/dist/apps/control-plane/application/usage-types.js.map +1 -0
  366. package/dist/apps/control-plane/cli/add-command-handler.d.ts +18 -0
  367. package/dist/apps/control-plane/cli/add-command-handler.js +110 -0
  368. package/dist/apps/control-plane/cli/add-command-handler.js.map +1 -0
  369. package/dist/apps/control-plane/cli/answer-command-handler.d.ts +8 -0
  370. package/dist/apps/control-plane/cli/answer-command-handler.js +96 -0
  371. package/dist/apps/control-plane/cli/answer-command-handler.js.map +1 -0
  372. package/dist/apps/control-plane/cli/attach-command-handler.js +8 -3
  373. package/dist/apps/control-plane/cli/attach-command-handler.js.map +1 -1
  374. package/dist/apps/control-plane/cli/cli-argument-parser.js +131 -11
  375. package/dist/apps/control-plane/cli/cli-argument-parser.js.map +1 -1
  376. package/dist/apps/control-plane/cli/collision-command-handler.d.ts +8 -0
  377. package/dist/apps/control-plane/cli/collision-command-handler.js +90 -0
  378. package/dist/apps/control-plane/cli/collision-command-handler.js.map +1 -0
  379. package/dist/apps/control-plane/cli/command-catalog.d.ts +21 -0
  380. package/dist/apps/control-plane/cli/command-catalog.js +416 -0
  381. package/dist/apps/control-plane/cli/command-catalog.js.map +1 -0
  382. package/dist/apps/control-plane/cli/complete-command-handler.d.ts +15 -0
  383. package/dist/apps/control-plane/cli/complete-command-handler.js +26 -0
  384. package/dist/apps/control-plane/cli/complete-command-handler.js.map +1 -0
  385. package/dist/apps/control-plane/cli/completion-command-handler.d.ts +8 -0
  386. package/dist/apps/control-plane/cli/completion-command-handler.js +20 -0
  387. package/dist/apps/control-plane/cli/completion-command-handler.js.map +1 -0
  388. package/dist/apps/control-plane/cli/completion-resolver.d.ts +1 -0
  389. package/dist/apps/control-plane/cli/completion-resolver.js +250 -0
  390. package/dist/apps/control-plane/cli/completion-resolver.js.map +1 -0
  391. package/dist/apps/control-plane/cli/completion-shell-renderer.d.ts +3 -0
  392. package/dist/apps/control-plane/cli/completion-shell-renderer.js +53 -0
  393. package/dist/apps/control-plane/cli/completion-shell-renderer.js.map +1 -0
  394. package/dist/apps/control-plane/cli/dashboard-command-handler.d.ts +1 -0
  395. package/dist/apps/control-plane/cli/dashboard-command-handler.js +83 -1
  396. package/dist/apps/control-plane/cli/dashboard-command-handler.js.map +1 -1
  397. package/dist/apps/control-plane/cli/dashboard-runtime-runner.d.ts +81 -0
  398. package/dist/apps/control-plane/cli/dashboard-runtime-runner.js +724 -0
  399. package/dist/apps/control-plane/cli/dashboard-runtime-runner.js.map +1 -0
  400. package/dist/apps/control-plane/cli/dashboard-runtime.d.ts +1 -0
  401. package/dist/apps/control-plane/cli/dashboard-runtime.js +26 -0
  402. package/dist/apps/control-plane/cli/dashboard-runtime.js.map +1 -0
  403. package/dist/apps/control-plane/cli/help-command-handler.js +13 -172
  404. package/dist/apps/control-plane/cli/help-command-handler.js.map +1 -1
  405. package/dist/apps/control-plane/cli/init-command-handler.js +51 -6
  406. package/dist/apps/control-plane/cli/init-command-handler.js.map +1 -1
  407. package/dist/apps/control-plane/cli/merge-command-handler.d.ts +8 -0
  408. package/dist/apps/control-plane/cli/merge-command-handler.js +139 -0
  409. package/dist/apps/control-plane/cli/merge-command-handler.js.map +1 -0
  410. package/dist/apps/control-plane/cli/questions-command-handler.d.ts +8 -0
  411. package/dist/apps/control-plane/cli/questions-command-handler.js +59 -0
  412. package/dist/apps/control-plane/cli/questions-command-handler.js.map +1 -0
  413. package/dist/apps/control-plane/cli/replay-command-handler.d.ts +15 -0
  414. package/dist/apps/control-plane/cli/replay-command-handler.js +55 -0
  415. package/dist/apps/control-plane/cli/replay-command-handler.js.map +1 -0
  416. package/dist/apps/control-plane/cli/resume-command-handler.d.ts +2 -0
  417. package/dist/apps/control-plane/cli/resume-command-handler.js +196 -19
  418. package/dist/apps/control-plane/cli/resume-command-handler.js.map +1 -1
  419. package/dist/apps/control-plane/cli/retry-command-handler.js +202 -16
  420. package/dist/apps/control-plane/cli/retry-command-handler.js.map +1 -1
  421. package/dist/apps/control-plane/cli/retry-resume-decision.d.ts +26 -0
  422. package/dist/apps/control-plane/cli/retry-resume-decision.js +61 -0
  423. package/dist/apps/control-plane/cli/retry-resume-decision.js.map +1 -0
  424. package/dist/apps/control-plane/cli/rollback-command-handler.js +3 -2
  425. package/dist/apps/control-plane/cli/rollback-command-handler.js.map +1 -1
  426. package/dist/apps/control-plane/cli/run-command-handler.js +26 -2
  427. package/dist/apps/control-plane/cli/run-command-handler.js.map +1 -1
  428. package/dist/apps/control-plane/cli/spec-ingestion-service.d.ts +2 -0
  429. package/dist/apps/control-plane/cli/spec-ingestion-service.js +37 -48
  430. package/dist/apps/control-plane/cli/spec-ingestion-service.js.map +1 -1
  431. package/dist/apps/control-plane/cli/spec-preparation.d.ts +14 -0
  432. package/dist/apps/control-plane/cli/spec-preparation.js +81 -0
  433. package/dist/apps/control-plane/cli/spec-preparation.js.map +1 -0
  434. package/dist/apps/control-plane/cli/spec-utils.d.ts +4 -0
  435. package/dist/apps/control-plane/cli/spec-utils.js +70 -11
  436. package/dist/apps/control-plane/cli/spec-utils.js.map +1 -1
  437. package/dist/apps/control-plane/cli/status-command-handler.js +69 -0
  438. package/dist/apps/control-plane/cli/status-command-handler.js.map +1 -1
  439. package/dist/apps/control-plane/cli/types.d.ts +41 -4
  440. package/dist/apps/control-plane/cli/types.js +9 -1
  441. package/dist/apps/control-plane/cli/types.js.map +1 -1
  442. package/dist/apps/control-plane/core/collisions.d.ts +37 -19
  443. package/dist/apps/control-plane/core/collisions.js +87 -12
  444. package/dist/apps/control-plane/core/collisions.js.map +1 -1
  445. package/dist/apps/control-plane/core/constants.d.ts +17 -1
  446. package/dist/apps/control-plane/core/constants.js +18 -1
  447. package/dist/apps/control-plane/core/constants.js.map +1 -1
  448. package/dist/apps/control-plane/core/error-codes.d.ts +39 -0
  449. package/dist/apps/control-plane/core/error-codes.js +39 -0
  450. package/dist/apps/control-plane/core/error-codes.js.map +1 -1
  451. package/dist/apps/control-plane/core/execution-control.d.ts +45 -0
  452. package/dist/apps/control-plane/core/execution-control.js +2 -0
  453. package/dist/apps/control-plane/core/execution-control.js.map +1 -0
  454. package/dist/apps/control-plane/core/feature-resume-phase.d.ts +3 -0
  455. package/dist/apps/control-plane/core/feature-resume-phase.js +88 -0
  456. package/dist/apps/control-plane/core/feature-resume-phase.js.map +1 -0
  457. package/dist/apps/control-plane/core/gate-freshness.d.ts +48 -0
  458. package/dist/apps/control-plane/core/gate-freshness.js +267 -0
  459. package/dist/apps/control-plane/core/gate-freshness.js.map +1 -0
  460. package/dist/apps/control-plane/core/gate-log-extractor.d.ts +22 -0
  461. package/dist/apps/control-plane/core/gate-log-extractor.js +66 -0
  462. package/dist/apps/control-plane/core/gate-log-extractor.js.map +1 -0
  463. package/dist/apps/control-plane/core/gates.d.ts +11 -2
  464. package/dist/apps/control-plane/core/gates.js +67 -3
  465. package/dist/apps/control-plane/core/gates.js.map +1 -1
  466. package/dist/apps/control-plane/core/intake-artifacts.d.ts +109 -0
  467. package/dist/apps/control-plane/core/intake-artifacts.js +143 -0
  468. package/dist/apps/control-plane/core/intake-artifacts.js.map +1 -0
  469. package/dist/apps/control-plane/core/kernel-types.d.ts +8 -0
  470. package/dist/apps/control-plane/core/kernel.d.ts +256 -8
  471. package/dist/apps/control-plane/core/kernel.js +400 -14
  472. package/dist/apps/control-plane/core/kernel.js.map +1 -1
  473. package/dist/apps/control-plane/core/mainline-conflict.d.ts +7 -0
  474. package/dist/apps/control-plane/core/mainline-conflict.js +20 -0
  475. package/dist/apps/control-plane/core/mainline-conflict.js.map +1 -0
  476. package/dist/apps/control-plane/core/merge-repair.d.ts +35 -0
  477. package/dist/apps/control-plane/core/merge-repair.js +99 -0
  478. package/dist/apps/control-plane/core/merge-repair.js.map +1 -0
  479. package/dist/apps/control-plane/core/path-layout.d.ts +10 -0
  480. package/dist/apps/control-plane/core/path-layout.js +32 -2
  481. package/dist/apps/control-plane/core/path-layout.js.map +1 -1
  482. package/dist/apps/control-plane/core/path-rules.js +9 -3
  483. package/dist/apps/control-plane/core/path-rules.js.map +1 -1
  484. package/dist/apps/control-plane/core/plan-submit-recovery.d.ts +22 -0
  485. package/dist/apps/control-plane/core/plan-submit-recovery.js +78 -0
  486. package/dist/apps/control-plane/core/plan-submit-recovery.js.map +1 -0
  487. package/dist/apps/control-plane/core/questions.d.ts +40 -0
  488. package/dist/apps/control-plane/core/questions.js +2 -0
  489. package/dist/apps/control-plane/core/questions.js.map +1 -0
  490. package/dist/apps/control-plane/core/runtime-sessions.d.ts +4 -0
  491. package/dist/apps/control-plane/core/schemas.d.ts +2 -0
  492. package/dist/apps/control-plane/core/schemas.js +31 -1
  493. package/dist/apps/control-plane/core/schemas.js.map +1 -1
  494. package/dist/apps/control-plane/core/tool-caller.d.ts +18 -1
  495. package/dist/apps/control-plane/core/utils/index-normalizer.js +17 -4
  496. package/dist/apps/control-plane/core/utils/index-normalizer.js.map +1 -1
  497. package/dist/apps/control-plane/core/worktree-diff.d.ts +4 -0
  498. package/dist/apps/control-plane/core/worktree-diff.js +52 -0
  499. package/dist/apps/control-plane/core/worktree-diff.js.map +1 -0
  500. package/dist/apps/control-plane/index.d.ts +10 -2
  501. package/dist/apps/control-plane/index.js +9 -2
  502. package/dist/apps/control-plane/index.js.map +1 -1
  503. package/dist/apps/control-plane/interfaces/cli/bootstrap.js +236 -6
  504. package/dist/apps/control-plane/interfaces/cli/bootstrap.js.map +1 -1
  505. package/dist/apps/control-plane/mcp/kernel-tool-executor.js +16 -0
  506. package/dist/apps/control-plane/mcp/kernel-tool-executor.js.map +1 -1
  507. package/dist/apps/control-plane/mcp/tool-runtime.d.ts +5 -0
  508. package/dist/apps/control-plane/mcp/tool-runtime.js +40 -5
  509. package/dist/apps/control-plane/mcp/tool-runtime.js.map +1 -1
  510. package/dist/apps/control-plane/providers/api-worker-provider.d.ts +2 -2
  511. package/dist/apps/control-plane/providers/api-worker-provider.js +40 -9
  512. package/dist/apps/control-plane/providers/api-worker-provider.js.map +1 -1
  513. package/dist/apps/control-plane/providers/cli-worker-provider.d.ts +59 -3
  514. package/dist/apps/control-plane/providers/cli-worker-provider.js +758 -46
  515. package/dist/apps/control-plane/providers/cli-worker-provider.js.map +1 -1
  516. package/dist/apps/control-plane/providers/output-parsers/generic-output-parser.js +91 -1
  517. package/dist/apps/control-plane/providers/output-parsers/generic-output-parser.js.map +1 -1
  518. package/dist/apps/control-plane/providers/output-parsers/types.d.ts +2 -0
  519. package/dist/apps/control-plane/providers/provider-defaults.d.ts +12 -0
  520. package/dist/apps/control-plane/providers/provider-defaults.js +103 -7
  521. package/dist/apps/control-plane/providers/provider-defaults.js.map +1 -1
  522. package/dist/apps/control-plane/providers/providers.d.ts +50 -4
  523. package/dist/apps/control-plane/providers/providers.js +145 -14
  524. package/dist/apps/control-plane/providers/providers.js.map +1 -1
  525. package/dist/apps/control-plane/providers/worker-provider-factory.d.ts +2 -0
  526. package/dist/apps/control-plane/providers/worker-provider-factory.js +8 -1
  527. package/dist/apps/control-plane/providers/worker-provider-factory.js.map +1 -1
  528. package/dist/apps/control-plane/supervisor/artifact-stager.d.ts +5 -0
  529. package/dist/apps/control-plane/supervisor/artifact-stager.js +45 -0
  530. package/dist/apps/control-plane/supervisor/artifact-stager.js.map +1 -0
  531. package/dist/apps/control-plane/supervisor/build-wave-executor.d.ts +24 -1
  532. package/dist/apps/control-plane/supervisor/build-wave-executor.js +362 -150
  533. package/dist/apps/control-plane/supervisor/build-wave-executor.js.map +1 -1
  534. package/dist/apps/control-plane/supervisor/execution-enrollment-service.d.ts +41 -0
  535. package/dist/apps/control-plane/supervisor/execution-enrollment-service.js +311 -0
  536. package/dist/apps/control-plane/supervisor/execution-enrollment-service.js.map +1 -0
  537. package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.d.ts +15 -0
  538. package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.js +93 -0
  539. package/dist/apps/control-plane/supervisor/organizer-enrollment-scheduler.js.map +1 -0
  540. package/dist/apps/control-plane/supervisor/organizer-sidecar-service.d.ts +44 -0
  541. package/dist/apps/control-plane/supervisor/organizer-sidecar-service.js +311 -0
  542. package/dist/apps/control-plane/supervisor/organizer-sidecar-service.js.map +1 -0
  543. package/dist/apps/control-plane/supervisor/plan-conformance-scorer.js +2 -5
  544. package/dist/apps/control-plane/supervisor/plan-conformance-scorer.js.map +1 -1
  545. package/dist/apps/control-plane/supervisor/planner-phase.d.ts +3 -0
  546. package/dist/apps/control-plane/supervisor/planner-phase.js +70 -0
  547. package/dist/apps/control-plane/supervisor/planner-phase.js.map +1 -0
  548. package/dist/apps/control-plane/supervisor/planning-wave-executor.d.ts +42 -0
  549. package/dist/apps/control-plane/supervisor/planning-wave-executor.js +753 -55
  550. package/dist/apps/control-plane/supervisor/planning-wave-executor.js.map +1 -1
  551. package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js +19 -1
  552. package/dist/apps/control-plane/supervisor/prompt-bundle-loader.js.map +1 -1
  553. package/dist/apps/control-plane/supervisor/qa-wave-executor.d.ts +21 -0
  554. package/dist/apps/control-plane/supervisor/qa-wave-executor.js +287 -156
  555. package/dist/apps/control-plane/supervisor/qa-wave-executor.js.map +1 -1
  556. package/dist/apps/control-plane/supervisor/run-coordinator.d.ts +33 -1
  557. package/dist/apps/control-plane/supervisor/run-coordinator.js +631 -39
  558. package/dist/apps/control-plane/supervisor/run-coordinator.js.map +1 -1
  559. package/dist/apps/control-plane/supervisor/runtime.d.ts +84 -0
  560. package/dist/apps/control-plane/supervisor/runtime.js +393 -3
  561. package/dist/apps/control-plane/supervisor/runtime.js.map +1 -1
  562. package/dist/apps/control-plane/supervisor/session-orchestrator.d.ts +54 -0
  563. package/dist/apps/control-plane/supervisor/session-orchestrator.js +176 -1
  564. package/dist/apps/control-plane/supervisor/session-orchestrator.js.map +1 -1
  565. package/dist/apps/control-plane/supervisor/types.d.ts +142 -1
  566. package/dist/apps/control-plane/supervisor/types.js.map +1 -1
  567. package/dist/apps/control-plane/supervisor/worker-decision-loop.d.ts +68 -2
  568. package/dist/apps/control-plane/supervisor/worker-decision-loop.js +723 -89
  569. package/dist/apps/control-plane/supervisor/worker-decision-loop.js.map +1 -1
  570. package/docs/core/ARCHITECTURE.md +227 -0
  571. package/docs/core/DECISIONS.md +94 -0
  572. package/docs/core/DOMAIN-LOGIC.md +60 -0
  573. package/docs/core/PATTERNS.md +201 -0
  574. package/docs/core/TROUBLESHOOTING.md +347 -0
  575. package/docs/core/intentgraph-dependencies.json +39860 -0
  576. package/docs/core/intentgraph.index.json +46580 -0
  577. package/docs/plans/2026-03-10-gate-failure-targeted-repair-design.md +224 -0
  578. package/docs/plans/2026-03-10-gate-failure-targeted-repair.md +1032 -0
  579. package/docs/superpowers/plans/2026-03-16-provider-cli-config.md +743 -0
  580. package/docs/superpowers/plans/2026-03-23-reconcile-divergence-fix.md +777 -0
  581. package/docs/superpowers/plans/2026-03-28-ordering-agent-implementation.md +1754 -0
  582. package/docs/superpowers/plans/2026-03-29-drop-zone-and-provider-optimization.md +1108 -0
  583. package/docs/superpowers/plans/2026-03-29-merge-target-feature-branch.md +685 -0
  584. package/docs/superpowers/plans/2026-03-29-organizer-sidecar-runtime-loop.md +1289 -0
  585. package/docs/superpowers/specs/2026-03-23-reconcile-divergence-fix-design.md +118 -0
  586. package/docs/superpowers/specs/2026-03-28-ordering-agent-spec-audit-design.md +50 -0
  587. package/docs/superpowers/specs/2026-03-29-drop-zone-and-provider-optimization-design.md +254 -0
  588. package/docs/superpowers/specs/2026-03-29-merge-target-feature-branch-design.md +152 -0
  589. package/docs/superpowers/specs/2026-03-29-organizer-sidecar-runtime-loop-design.md +225 -0
  590. package/package.json +3 -2
  591. package/packages/web-dashboard/package.json +2 -1
  592. package/packages/web-dashboard/src/app/analytics/page.tsx +36 -2
  593. package/packages/web-dashboard/src/app/api/actions/route.ts +274 -63
  594. package/packages/web-dashboard/src/app/api/actions/status/route.ts +35 -0
  595. package/packages/web-dashboard/src/app/api/analytics/provider/route.ts +18 -0
  596. package/packages/web-dashboard/src/app/api/collisions/approve/route.ts +58 -0
  597. package/packages/web-dashboard/src/app/api/features/[id]/checkpoint-diff/route.ts +36 -0
  598. package/packages/web-dashboard/src/app/api/features/[id]/checkpoints/route.ts +29 -0
  599. package/packages/web-dashboard/src/app/api/features/[id]/conflicts/abort/route.ts +29 -0
  600. package/packages/web-dashboard/src/app/api/features/[id]/conflicts/files/route.ts +30 -0
  601. package/packages/web-dashboard/src/app/api/features/[id]/conflicts/resolve/route.ts +51 -0
  602. package/packages/web-dashboard/src/app/api/features/[id]/conflicts/route.ts +75 -0
  603. package/packages/web-dashboard/src/app/api/features/[id]/diff/route.ts +16 -2
  604. package/packages/web-dashboard/src/app/api/features/[id]/files/route.ts +26 -0
  605. package/packages/web-dashboard/src/app/api/features/[id]/gate-history/route.ts +27 -0
  606. package/packages/web-dashboard/src/app/api/features/[id]/genealogy/route.ts +26 -0
  607. package/packages/web-dashboard/src/app/api/features/[id]/history/run/[runId]/route.ts +20 -0
  608. package/packages/web-dashboard/src/app/api/features/[id]/history/runs/route.ts +34 -0
  609. package/packages/web-dashboard/src/app/api/features/[id]/intake-workspace/route.ts +20 -0
  610. package/packages/web-dashboard/src/app/api/features/[id]/live-output/route.ts +74 -0
  611. package/packages/web-dashboard/src/app/api/features/[id]/plan/amend/route.ts +21 -0
  612. package/packages/web-dashboard/src/app/api/features/[id]/plan-progress/route.ts +20 -0
  613. package/packages/web-dashboard/src/app/api/features/[id]/planner-artifacts/[artifact]/route.ts +78 -0
  614. package/packages/web-dashboard/src/app/api/features/[id]/planner-lifecycle/route.ts +20 -0
  615. package/packages/web-dashboard/src/app/api/features/[id]/planning-workspace/route.ts +20 -0
  616. package/packages/web-dashboard/src/app/api/features/[id]/questions/[questionId]/answer/route.ts +27 -0
  617. package/packages/web-dashboard/src/app/api/features/[id]/questions/route.ts +18 -0
  618. package/packages/web-dashboard/src/app/api/features/[id]/review/route.ts +14 -7
  619. package/packages/web-dashboard/src/app/api/features/[id]/route.ts +57 -2
  620. package/packages/web-dashboard/src/app/api/features/[id]/spec/route.ts +30 -0
  621. package/packages/web-dashboard/src/app/api/features/[id]/triage/route.ts +83 -0
  622. package/packages/web-dashboard/src/app/api/features/[id]/worker-events/route.ts +40 -0
  623. package/packages/web-dashboard/src/app/api/launch/preview/route.ts +86 -0
  624. package/packages/web-dashboard/src/app/api/launch/submit/route.ts +180 -0
  625. package/packages/web-dashboard/src/app/api/mainline/status/route.ts +74 -0
  626. package/packages/web-dashboard/src/app/api/merge-queue/route.ts +13 -0
  627. package/packages/web-dashboard/src/app/api/policy/budget/route.ts +14 -0
  628. package/packages/web-dashboard/src/app/api/projects/route.ts +11 -7
  629. package/packages/web-dashboard/src/app/api/reconciler/queue/route.ts +47 -0
  630. package/packages/web-dashboard/src/app/api/run/route.ts +26 -2
  631. package/packages/web-dashboard/src/app/api/runtime/events/route.ts +227 -0
  632. package/packages/web-dashboard/src/app/api/runtime/operations/route.ts +269 -0
  633. package/packages/web-dashboard/src/app/api/runtime/questions/route.ts +11 -0
  634. package/packages/web-dashboard/src/app/api/runtime/runs/route.ts +80 -0
  635. package/packages/web-dashboard/src/app/api/status/route.ts +4 -2
  636. package/packages/web-dashboard/src/app/feature/[id]/page.tsx +32 -42
  637. package/packages/web-dashboard/src/app/globals.css +34 -3
  638. package/packages/web-dashboard/src/app/launch/page.tsx +357 -0
  639. package/packages/web-dashboard/src/app/layout.tsx +23 -1
  640. package/packages/web-dashboard/src/app/page.tsx +263 -272
  641. package/packages/web-dashboard/src/components/dashboard/attention-strip.tsx +52 -0
  642. package/packages/web-dashboard/src/components/dashboard/collision-approval-drawer.tsx +185 -0
  643. package/packages/web-dashboard/src/components/dashboard/command-center-header.tsx +102 -0
  644. package/packages/web-dashboard/src/components/dashboard/mainline-status-banner.tsx +84 -0
  645. package/packages/web-dashboard/src/components/dashboard/merged-archive.tsx +36 -0
  646. package/packages/web-dashboard/src/components/dashboard/prioritized-queues.tsx +98 -0
  647. package/packages/web-dashboard/src/components/dashboard/reconciler-queue-card.tsx +115 -0
  648. package/packages/web-dashboard/src/components/dashboard/secondary-diagnostics-rail.tsx +48 -0
  649. package/packages/web-dashboard/src/components/dashboard/task-filter-bar.tsx +74 -0
  650. package/packages/web-dashboard/src/components/dashboard/triage-drawer.tsx +455 -0
  651. package/packages/web-dashboard/src/components/diff-viewer.tsx +19 -3
  652. package/packages/web-dashboard/src/components/evidence-viewer.tsx +65 -51
  653. package/packages/web-dashboard/src/components/feature-card.tsx +90 -7
  654. package/packages/web-dashboard/src/components/feature-cost-panel.tsx +112 -11
  655. package/packages/web-dashboard/src/components/feature-list-view.tsx +25 -4
  656. package/packages/web-dashboard/src/components/features/runtime-inspector/EventsTimelineView.tsx +260 -0
  657. package/packages/web-dashboard/src/components/features/runtime-inspector/OperationsListView.tsx +172 -0
  658. package/packages/web-dashboard/src/components/features/runtime-inspector/RuntimeInspectorPanel.tsx +896 -0
  659. package/packages/web-dashboard/src/components/filter-bar.tsx +7 -39
  660. package/packages/web-dashboard/src/components/focus/ActionableRiskList.tsx +46 -0
  661. package/packages/web-dashboard/src/components/focus/AgentRolePerformanceCard.tsx +200 -0
  662. package/packages/web-dashboard/src/components/focus/BlockedGuidanceBanner.tsx +149 -0
  663. package/packages/web-dashboard/src/components/focus/CheckpointInspector.tsx +123 -0
  664. package/packages/web-dashboard/src/components/focus/CheckpointRail.tsx +118 -0
  665. package/packages/web-dashboard/src/components/focus/CheckpointScrubber.tsx +249 -0
  666. package/packages/web-dashboard/src/components/focus/CollisionApprovalBanner.tsx +192 -0
  667. package/packages/web-dashboard/src/components/focus/CollisionRadar.tsx +136 -0
  668. package/packages/web-dashboard/src/components/focus/ConflictStatusCard.tsx +52 -0
  669. package/packages/web-dashboard/src/components/focus/ContextSidebar.tsx +108 -0
  670. package/packages/web-dashboard/src/components/focus/DiagnosisPanel.tsx +68 -0
  671. package/packages/web-dashboard/src/components/focus/FeatureDecisionBanner.tsx +68 -0
  672. package/packages/web-dashboard/src/components/focus/FeatureQuestionAnswerPanel.tsx +167 -0
  673. package/packages/web-dashboard/src/components/focus/FocusHeader.tsx +54 -0
  674. package/packages/web-dashboard/src/components/focus/FocusLayout.tsx +283 -0
  675. package/packages/web-dashboard/src/components/focus/GateFlakinessSummary.tsx +144 -0
  676. package/packages/web-dashboard/src/components/focus/GenealogyTree.tsx +34 -0
  677. package/packages/web-dashboard/src/components/focus/HeroBlock.tsx +67 -0
  678. package/packages/web-dashboard/src/components/focus/LiveAgentConsole.tsx +277 -0
  679. package/packages/web-dashboard/src/components/focus/MergeQueueCard.tsx +78 -0
  680. package/packages/web-dashboard/src/components/focus/OperationalSummaryCard.tsx +227 -0
  681. package/packages/web-dashboard/src/components/focus/PinnedActions.tsx +96 -0
  682. package/packages/web-dashboard/src/components/focus/PlanAmendmentPanel.tsx +250 -0
  683. package/packages/web-dashboard/src/components/focus/PlanProgressPanel.tsx +133 -0
  684. package/packages/web-dashboard/src/components/focus/PlannerArtifactViewer.tsx +158 -0
  685. package/packages/web-dashboard/src/components/focus/PlannerLifecycleHeader.tsx +141 -0
  686. package/packages/web-dashboard/src/components/focus/ProgressSnapshotCard.tsx +113 -0
  687. package/packages/web-dashboard/src/components/focus/RecentMaterialChanges.tsx +69 -0
  688. package/packages/web-dashboard/src/components/focus/RoleLogViewer.tsx +436 -0
  689. package/packages/web-dashboard/src/components/focus/RunHistoryBrowser.tsx +62 -0
  690. package/packages/web-dashboard/src/components/focus/SpecViewer.tsx +172 -0
  691. package/packages/web-dashboard/src/components/focus/TabBar.tsx +33 -0
  692. package/packages/web-dashboard/src/components/focus/UsageBurnChart.tsx +212 -0
  693. package/packages/web-dashboard/src/components/focus/VerificationSummaryCard.tsx +122 -0
  694. package/packages/web-dashboard/src/components/focus/tabs/ChangesTab.tsx +325 -0
  695. package/packages/web-dashboard/src/components/focus/tabs/ConflictsTab.tsx +395 -0
  696. package/packages/web-dashboard/src/components/focus/tabs/GatesQaTab.tsx +38 -0
  697. package/packages/web-dashboard/src/components/focus/tabs/HistoryTab.tsx +213 -0
  698. package/packages/web-dashboard/src/components/focus/tabs/IntakeTab.tsx +429 -0
  699. package/packages/web-dashboard/src/components/focus/tabs/OverviewTab.tsx +217 -0
  700. package/packages/web-dashboard/src/components/focus/tabs/PlanningTab.tsx +390 -0
  701. package/packages/web-dashboard/src/components/focus/tabs/ReviewTab.tsx +497 -0
  702. package/packages/web-dashboard/src/components/focus/tabs/RuntimeTab.tsx +213 -0
  703. package/packages/web-dashboard/src/components/focus/tabs/TranscriptTab.tsx +315 -0
  704. package/packages/web-dashboard/src/components/gate-results.tsx +2 -2
  705. package/packages/web-dashboard/src/components/human-input-panel.tsx +33 -57
  706. package/packages/web-dashboard/src/components/kanban-board.tsx +4 -0
  707. package/packages/web-dashboard/src/components/launch/launch-draft-card.tsx +131 -0
  708. package/packages/web-dashboard/src/components/plan-viewer.tsx +147 -69
  709. package/packages/web-dashboard/src/components/quick-launch-panel.tsx +20 -47
  710. package/packages/web-dashboard/src/components/summary-bar.tsx +30 -76
  711. package/packages/web-dashboard/src/lib/aop-client.ts +2484 -36
  712. package/packages/web-dashboard/src/lib/blocked-state-guidance.ts +475 -0
  713. package/packages/web-dashboard/src/lib/collision-radar.ts +136 -0
  714. package/packages/web-dashboard/src/lib/dashboard-action-states.ts +204 -0
  715. package/packages/web-dashboard/src/lib/dashboard-runtime-client.ts +439 -0
  716. package/packages/web-dashboard/src/lib/dashboard-utils.ts +179 -18
  717. package/packages/web-dashboard/src/lib/drop-zone-utils.ts +92 -0
  718. package/packages/web-dashboard/src/lib/focus-detail-derivations.ts +958 -0
  719. package/packages/web-dashboard/src/lib/focus-view.ts +300 -0
  720. package/packages/web-dashboard/src/lib/health-diagnosis.ts +356 -0
  721. package/packages/web-dashboard/src/lib/launch-contracts.ts +77 -0
  722. package/packages/web-dashboard/src/lib/launch-markdown.ts +107 -0
  723. package/packages/web-dashboard/src/lib/launch-page-preview.ts +89 -0
  724. package/packages/web-dashboard/src/lib/live-feed.ts +1 -1
  725. package/packages/web-dashboard/src/lib/multi-project-config.ts +33 -0
  726. package/packages/web-dashboard/src/lib/orchestrator-tools.ts +845 -59
  727. package/packages/web-dashboard/src/lib/planner-workspace.ts +1285 -0
  728. package/packages/web-dashboard/src/lib/review-contracts.ts +5 -3
  729. package/packages/web-dashboard/src/lib/runtime-files.ts +285 -0
  730. package/packages/web-dashboard/src/lib/tool-catalog.ts +51 -0
  731. package/packages/web-dashboard/src/lib/types.ts +731 -3
  732. package/packages/web-dashboard/src/lib/usage-burn.ts +175 -0
  733. package/packages/web-dashboard/src/lib/worktree-diff.ts +128 -0
  734. package/packages/web-dashboard/src/styles/dashboard.module.css +1742 -459
  735. package/packages/web-dashboard/test/api/actions/route.spec.ts +675 -0
  736. package/packages/web-dashboard/test/api/features/diff.route.spec.ts +57 -0
  737. package/packages/web-dashboard/test/api/features/feature.route.spec.ts +99 -0
  738. package/packages/web-dashboard/test/api/features/live-output.route.spec.ts +123 -0
  739. package/packages/web-dashboard/test/api/features/plan-amend.route.spec.ts +95 -0
  740. package/packages/web-dashboard/test/api/features/planner-workspaces.route.spec.ts +162 -0
  741. package/packages/web-dashboard/test/api/features/question-answer.route.spec.ts +99 -0
  742. package/packages/web-dashboard/test/api/features/triage.route.spec.ts +195 -0
  743. package/packages/web-dashboard/test/api/launch/preview.route.spec.ts +149 -0
  744. package/packages/web-dashboard/test/api/launch/submit.route.spec.ts +382 -0
  745. package/packages/web-dashboard/test/api/runtime/events/route.spec.ts +164 -0
  746. package/packages/web-dashboard/test/api/runtime/operations/route.spec.ts +156 -0
  747. package/packages/web-dashboard/test/api/runtime/runs/route.spec.ts +112 -0
  748. package/packages/web-dashboard/test/components/changes-tab.spec.tsx +76 -0
  749. package/packages/web-dashboard/test/components/command-center-root.spec.tsx +87 -0
  750. package/packages/web-dashboard/test/components/diagnosis-panel.spec.tsx +59 -0
  751. package/packages/web-dashboard/test/components/feature-card.spec.tsx +45 -0
  752. package/packages/web-dashboard/test/components/focus-layout.spec.tsx +299 -0
  753. package/packages/web-dashboard/test/components/gate-results.spec.tsx +39 -0
  754. package/packages/web-dashboard/test/components/gates-qa-tab.spec.tsx +118 -0
  755. package/packages/web-dashboard/test/components/human-input-panel.spec.tsx +54 -0
  756. package/packages/web-dashboard/test/components/intake-tab.spec.tsx +210 -0
  757. package/packages/web-dashboard/test/components/kanban-board.spec.tsx +35 -0
  758. package/packages/web-dashboard/test/components/launch-draft-card.spec.tsx +54 -0
  759. package/packages/web-dashboard/test/components/launch-page.spec.tsx +79 -0
  760. package/packages/web-dashboard/test/components/overview-tab.spec.tsx +236 -0
  761. package/packages/web-dashboard/test/components/planning-tab.spec.tsx +202 -0
  762. package/packages/web-dashboard/test/components/review-tab.spec.tsx +169 -0
  763. package/packages/web-dashboard/test/components/role-log-viewer.spec.ts +42 -0
  764. package/packages/web-dashboard/test/components/runtime-inspector.spec.tsx +22 -0
  765. package/packages/web-dashboard/test/components/runtime-tab.spec.tsx +133 -0
  766. package/packages/web-dashboard/test/components/transcript-tab.spec.tsx +46 -0
  767. package/packages/web-dashboard/test/components/triage-drawer.spec.tsx +159 -0
  768. package/packages/web-dashboard/test/lib/aop-client.spec.ts +235 -0
  769. package/packages/web-dashboard/test/lib/dashboard-runtime-client.spec.ts +144 -0
  770. package/packages/web-dashboard/test/lib/focus-detail-derivations.spec.ts +314 -0
  771. package/packages/web-dashboard/test/lib/focus-view.spec.ts +248 -0
  772. package/packages/web-dashboard/test/lib/health-diagnosis.spec.ts +277 -0
  773. package/packages/web-dashboard/test/lib/launch-markdown.spec.ts +36 -0
  774. package/packages/web-dashboard/test/lib/multi-project-config.spec.ts +54 -0
  775. package/packages/web-dashboard/test/lib/orchestrator-tools.spec.ts +352 -0
  776. package/packages/web-dashboard/test/lib/planner-workspace.spec.ts +289 -0
  777. package/packages/web-dashboard/test/lib/worktree-diff.spec.ts +119 -0
  778. package/packages/web-dashboard/vitest.config.ts +2 -0
  779. package/spec-files/completed/agentic_orchestrator_add_feature_to_active_execution_spec.md +557 -0
  780. package/spec-files/completed/agentic_orchestrator_dashboard_command_center_redesign_spec.md +1147 -0
  781. package/spec-files/completed/agentic_orchestrator_execution_mode_spec.md +18 -16
  782. package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_a_spec.md +672 -0
  783. package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_b_spec.md +794 -0
  784. package/spec-files/completed/agentic_orchestrator_feature_focus_view_track_c_decision_centric_remediation_spec.md +1037 -0
  785. package/spec-files/completed/agentic_orchestrator_feature_focus_view_ux_redesign_spec.md +1432 -0
  786. package/spec-files/completed/agentic_orchestrator_focus_plan_tab_intake_planning_workspace_spec.md +921 -0
  787. package/spec-files/completed/agentic_orchestrator_intentional_collision_override_spec.md +584 -0
  788. package/spec-files/completed/agentic_orchestrator_interactive_planning_intake_and_requirements_verification_spec.md +1185 -0
  789. package/spec-files/completed/agentic_orchestrator_reactive_execution_enrollment_spec.md +864 -0
  790. package/spec-files/{outstanding → completed}/agentic_orchestrator_runtime_inspection_spec.md +92 -19
  791. package/spec-files/completed/agentic_orchestrator_scope_aware_run_lease_spec.md +408 -0
  792. package/spec-files/completed/git-reconciliation-engine.md +827 -0
  793. package/spec-files/outstanding/agentic_orchestrator_dashboard_quick_launch_and_control_surface_spec.md +331 -0
  794. package/spec-files/outstanding/agentic_orchestrator_enterprise_governance_dashboard_spec.md +16 -6
  795. package/spec-files/outstanding/agentic_orchestrator_evidence_integrity_doctor_spec.md +60 -9
  796. package/spec-files/outstanding/agentic_orchestrator_focus_plan_tab_execution_contract_workspace_spec.md +616 -0
  797. package/spec-files/outstanding/agentic_orchestrator_headless_standby_dashboard_runtime_spec.md +310 -0
  798. package/spec-files/outstanding/agentic_orchestrator_human_input_interaction_protocol_spec.md +175 -72
  799. package/spec-files/outstanding/agentic_orchestrator_interactive_rename_cleanup_spec.md +197 -0
  800. package/spec-files/outstanding/agentic_orchestrator_interactive_resume_and_reconciliation_disposition_spec.md +412 -0
  801. package/spec-files/outstanding/agentic_orchestrator_knowledge_canary_spec.md +166 -137
  802. package/spec-files/outstanding/agentic_orchestrator_observability_replay_spec.md +3 -3
  803. package/spec-files/outstanding/agentic_orchestrator_phase_specific_agent_profiles_and_token_telemetry_spec.md +303 -0
  804. package/spec-files/outstanding/agentic_orchestrator_planning_review_quality_spec.md +18 -5
  805. package/spec-files/outstanding/agentic_orchestrator_policy_stratification_spec.md +225 -0
  806. package/spec-files/outstanding/agentic_orchestrator_quality_adoption_execution_spec.md +77 -50
  807. package/spec-files/outstanding/agentic_orchestrator_ready_to_merge_branch_handoff_spec.md +724 -0
  808. package/spec-files/outstanding/agentic_orchestrator_remove_deterministic_mode_spec.md +263 -0
  809. package/spec-files/outstanding/agentic_orchestrator_request_more_context_and_dashboard_human_input_spec.md +456 -0
  810. package/spec-files/outstanding/agentic_orchestrator_spec_coverage_and_reconciliation_enforcement_spec.md +1411 -0
  811. package/spec-files/outstanding/agentic_orchestrator_spec_ordering_agent_spec.md +370 -0
  812. package/spec-files/outstanding/shadow_workspace_implementation_spec.md +1 -1
  813. package/spec-files/progress.md +2045 -87
  814. package/specs/001-runtime-inspection/checklists/requirements.md +35 -0
  815. package/specs/001-runtime-inspection/design.md +338 -0
  816. package/specs/001-runtime-inspection/spec.md +95 -0
  817. package/specs/002-scope-aware-lease/checklists/requirements.md +35 -0
  818. package/specs/002-scope-aware-lease/contracts/lease-registry.schema.json +101 -0
  819. package/specs/002-scope-aware-lease/data-model.md +236 -0
  820. package/specs/002-scope-aware-lease/plan.md +766 -0
  821. package/specs/002-scope-aware-lease/quickstart.md +150 -0
  822. package/specs/002-scope-aware-lease/research.md +135 -0
  823. package/specs/002-scope-aware-lease/spec.md +128 -0
  824. package/specs/002-scope-aware-lease/tasks.md +767 -0
  825. package/tsconfig.json +1 -1
  826. package/vitest.config.ts +28 -0
  827. package/ARCHITECTURE_ADHERENCE_ANALYSIS.md +0 -871
  828. package/packages/web-dashboard/next-env.d.ts +0 -6
  829. package/packages/web-dashboard/src/components/detail-panel.tsx +0 -1124
  830. package/packages/web-dashboard/src/components/review-workspace.tsx +0 -1162
  831. /package/spec-files/{outstanding → completed}/agentic_orchestrator_artifact_database_publishing_spec.md +0 -0
  832. /package/spec-files/{outstanding → completed}/agentic_orchestrator_cli_shell_tab_completion_spec.md +0 -0
  833. /package/spec-files/{outstanding → completed}/agentic_orchestrator_dashboard_diff_and_agent_console_spec.md +0 -0
  834. /package/spec-files/{outstanding → completed}/agentic_orchestrator_performance_improvements_spec.md +0 -0
  835. /package/spec-files/{outstanding → completed}/agentic_orchestrator_persistent_worker_runtime_spec.md +0 -0
  836. /package/spec-files/{outstanding → completed}/agentic_orchestrator_provider_auth_bootstrap_spec.md +0 -0
  837. /package/spec-files/{outstanding → completed}/agentic_orchestrator_real_worker_provider_execution_spec.md +0 -0
@@ -0,0 +1,1050 @@
1
+ import fs from 'node:fs/promises';
2
+ import path from 'node:path';
3
+ import { atomicWriteJson, nowIso, readJson } from '../../core/fs.js';
4
+ import { ERROR_CODES } from '../../core/error-codes.js';
5
+ import { normalizeManifestConfidence, obligationsMeetConfidenceThreshold, } from '../../core/intake-artifacts.js';
6
+ import { GATE_RESULT, STATUS } from '../../core/constants.js';
7
+ import { fail } from '../../core/response.js';
8
+ import { BootstrapManifestGeneratorService } from './bootstrap-manifest-generator-service.js';
9
+ const AMBIGUITY_ID_TOKEN_PATTERN = /\bAMB[\s_-]*(\d{1,})\b/gi;
10
+ const OBLIGATION_ID_TOKEN_PATTERN = /\bOBL(?:[\s_-]*V)?[\s_-]*(\d{1,})\b/gi;
11
+ const MANIFEST_REVIEW_AMBIGUITY_ID = 'AMB-MANIFEST-REVIEW';
12
+ const OBLIGATION_KIND_ALIASES = {
13
+ artifact: 'artifact',
14
+ behavior: 'behavior',
15
+ component: 'artifact',
16
+ constraint: 'contract',
17
+ contract: 'contract',
18
+ endpoint: 'endpoint',
19
+ flow: 'workflow',
20
+ integration: 'integration',
21
+ route: 'endpoint',
22
+ schema: 'contract',
23
+ screen: 'artifact',
24
+ test: 'verification',
25
+ ui: 'artifact',
26
+ validation: 'verification',
27
+ verification: 'verification',
28
+ view: 'artifact',
29
+ workflow: 'workflow',
30
+ };
31
+ const VERIFICATION_HINT_ALIASES = {
32
+ must: 'required',
33
+ optional: 'optional',
34
+ required: 'required',
35
+ shall: 'required',
36
+ };
37
+ function asRecord(value) {
38
+ if (!value || typeof value !== 'object' || Array.isArray(value)) {
39
+ return null;
40
+ }
41
+ return value;
42
+ }
43
+ function asString(value) {
44
+ if (typeof value !== 'string') {
45
+ return null;
46
+ }
47
+ const trimmed = value.trim();
48
+ return trimmed.length > 0 ? trimmed : null;
49
+ }
50
+ function asAnswerValue(value) {
51
+ const stringValue = asString(value);
52
+ if (stringValue !== null) {
53
+ return stringValue;
54
+ }
55
+ return asRecord(value);
56
+ }
57
+ function normalizeUniqueStrings(values) {
58
+ return [...new Set(values)].sort((left, right) => left.localeCompare(right));
59
+ }
60
+ function extractCanonicalIdMatches(value, pattern, prefix) {
61
+ if (typeof value === 'string') {
62
+ return Array.from(value.matchAll(new RegExp(pattern.source, 'gi')), (match) => {
63
+ const digits = match[1] ?? '';
64
+ return `${prefix}-${digits.padStart(3, '0')}`;
65
+ });
66
+ }
67
+ if (!Array.isArray(value)) {
68
+ return [];
69
+ }
70
+ return value.flatMap((entry) => extractCanonicalIdMatches(entry, pattern, prefix));
71
+ }
72
+ function normalizeAmbiguityIds(value) {
73
+ return normalizeUniqueStrings(extractCanonicalIdMatches(value, AMBIGUITY_ID_TOKEN_PATTERN, 'AMB'));
74
+ }
75
+ function normalizeObligationIds(value) {
76
+ return normalizeUniqueStrings(extractCanonicalIdMatches(value, OBLIGATION_ID_TOKEN_PATTERN, 'OBL'));
77
+ }
78
+ function normalizeVerificationBasis(value) {
79
+ return value === 'structured_spec' ||
80
+ value === 'questions_resolved' ||
81
+ value === 'policy_approved_auto_promotion' ||
82
+ value === 'human_review_confirmed'
83
+ ? value
84
+ : null;
85
+ }
86
+ function normalizeReviewStatus(value) {
87
+ return value === 'proposed' || value === 'awaiting_input' || value === 'verified'
88
+ ? value
89
+ : 'proposed';
90
+ }
91
+ function readPositiveInteger(value) {
92
+ return typeof value === 'number' && Number.isFinite(value) && value >= 1
93
+ ? Math.floor(value)
94
+ : null;
95
+ }
96
+ function readNonNegativeInteger(value) {
97
+ return typeof value === 'number' && Number.isFinite(value) && value >= 0
98
+ ? Math.floor(value)
99
+ : null;
100
+ }
101
+ function normalizeAmbiguityStatus(value, fallback = 'open') {
102
+ if (value === 'open' || value === 'resolved') {
103
+ return value;
104
+ }
105
+ return fallback;
106
+ }
107
+ function normalizeReviewAmbiguity(value, fallback = null) {
108
+ const record = asRecord(value);
109
+ const id = normalizeAmbiguityIds(record?.id)[0] ??
110
+ normalizeAmbiguityIds(record?.ambiguity_id)[0] ??
111
+ fallback?.id ??
112
+ null;
113
+ const summary = asString(record?.summary) ?? fallback?.summary ?? null;
114
+ if (!id || !summary) {
115
+ return null;
116
+ }
117
+ const fallbackResolution = asString(record?.resolution) ?? asString(asRecord(record?.resolution)?.status);
118
+ const status = normalizeAmbiguityStatus(record?.status ?? fallbackResolution, fallback?.status ?? 'open');
119
+ const obligationIds = normalizeObligationIds(record?.obligation_ids);
120
+ const normalized = {
121
+ id,
122
+ summary,
123
+ status,
124
+ };
125
+ const finalObligationIds = obligationIds.length > 0 ? obligationIds : normalizeObligationIds(fallback?.obligation_ids);
126
+ if (finalObligationIds.length > 0) {
127
+ normalized.obligation_ids = finalObligationIds;
128
+ }
129
+ return normalized;
130
+ }
131
+ function normalizeReviewClarificationAnswer(value, ambiguityStatus) {
132
+ const record = asRecord(value);
133
+ const questionId = asString(record?.question_id);
134
+ const prompt = asString(record?.prompt);
135
+ const answer = asAnswerValue(record?.answer);
136
+ const answeredAt = asString(record?.answered_at);
137
+ const answeredBy = asString(record?.answered_by);
138
+ const ambiguityIds = normalizeAmbiguityIds(record?.ambiguity_ids);
139
+ if (!questionId ||
140
+ !prompt ||
141
+ answer === null ||
142
+ !answeredAt ||
143
+ !answeredBy ||
144
+ ambiguityIds.length === 0) {
145
+ return null;
146
+ }
147
+ const resolutionStatus = record?.resolution_status === 'candidate' || record?.resolution_status === 'applied'
148
+ ? record.resolution_status
149
+ : ambiguityIds.every((ambiguityId) => ambiguityStatus.get(ambiguityId) === 'resolved')
150
+ ? 'applied'
151
+ : 'candidate';
152
+ return {
153
+ question_id: questionId,
154
+ ambiguity_ids: ambiguityIds,
155
+ obligation_ids: normalizeObligationIds(record?.obligation_ids),
156
+ prompt,
157
+ answer,
158
+ answered_at: answeredAt,
159
+ answered_by: answeredBy,
160
+ resolution_status: resolutionStatus,
161
+ };
162
+ }
163
+ function mergeReviewAmbiguities(bootstrapAmbiguities, reviewAmbiguities) {
164
+ const normalizedReview = Array.isArray(reviewAmbiguities)
165
+ ? reviewAmbiguities
166
+ .map((item) => normalizeReviewAmbiguity(item))
167
+ .filter((item) => item !== null)
168
+ : [];
169
+ const reviewById = new Map(normalizedReview.map((item) => [item.id, item]));
170
+ const merged = bootstrapAmbiguities
171
+ .map((item) => normalizeReviewAmbiguity(item, item))
172
+ .filter((item) => item !== null)
173
+ .map((item) => {
174
+ const existing = reviewById.get(item.id);
175
+ return existing
176
+ ? {
177
+ ...item,
178
+ status: existing.status,
179
+ ...(existing.obligation_ids && existing.obligation_ids.length > 0
180
+ ? { obligation_ids: existing.obligation_ids }
181
+ : {}),
182
+ }
183
+ : item;
184
+ });
185
+ const bootstrapIds = new Set(merged.map((item) => item.id));
186
+ const extras = normalizedReview.filter((item) => !bootstrapIds.has(item.id));
187
+ return [...merged, ...extras];
188
+ }
189
+ function normalizeReviewClarificationAnswers(value, ambiguities) {
190
+ const ambiguityStatus = new Map(ambiguities.map((item) => [item.id, item.status]));
191
+ if (!Array.isArray(value)) {
192
+ return [];
193
+ }
194
+ return value
195
+ .map((item) => normalizeReviewClarificationAnswer(item, ambiguityStatus))
196
+ .filter((item) => item !== null)
197
+ .sort((left, right) => {
198
+ if (left.answered_at === right.answered_at) {
199
+ return left.question_id.localeCompare(right.question_id);
200
+ }
201
+ return left.answered_at.localeCompare(right.answered_at);
202
+ });
203
+ }
204
+ function normalizeSubmissionAmbiguities(value, status, bootstrapManifest) {
205
+ if (!Array.isArray(value)) {
206
+ return [];
207
+ }
208
+ const bootstrapById = new Map(bootstrapManifest.ambiguities.map((item) => [item.id, item]));
209
+ const normalized = value
210
+ .map((item) => {
211
+ const raw = asRecord(item);
212
+ const candidateId = normalizeAmbiguityIds(raw?.id)[0] ?? normalizeAmbiguityIds(raw?.ambiguity_id)[0] ?? null;
213
+ const fallback = candidateId ? (bootstrapById.get(candidateId) ?? null) : null;
214
+ const normalizedItem = normalizeReviewAmbiguity(item, fallback);
215
+ if (!normalizedItem) {
216
+ return null;
217
+ }
218
+ return {
219
+ ...normalizedItem,
220
+ status,
221
+ };
222
+ })
223
+ .filter((item) => item !== null);
224
+ return normalized
225
+ .filter((item, index, items) => items.findIndex((candidate) => candidate.id === item.id) === index)
226
+ .sort((left, right) => left.id.localeCompare(right.id));
227
+ }
228
+ function normalizeManifestObligationKind(value) {
229
+ const normalized = asString(value)?.toLowerCase();
230
+ if (!normalized) {
231
+ return null;
232
+ }
233
+ return OBLIGATION_KIND_ALIASES[normalized] ?? null;
234
+ }
235
+ function normalizeManifestVerificationHint(value) {
236
+ const normalized = asString(value)?.toLowerCase();
237
+ if (!normalized) {
238
+ return null;
239
+ }
240
+ return VERIFICATION_HINT_ALIASES[normalized] ?? null;
241
+ }
242
+ function normalizeManifestSourceRef(value) {
243
+ const record = asRecord(value);
244
+ const lineStart = readPositiveInteger(record?.line_start);
245
+ const lineEnd = readPositiveInteger(record?.line_end);
246
+ if (lineStart === null || lineEnd === null) {
247
+ return null;
248
+ }
249
+ return {
250
+ line_start: lineStart,
251
+ line_end: Math.max(lineStart, lineEnd),
252
+ heading: asString(record?.heading),
253
+ };
254
+ }
255
+ function normalizeManifestSourceRefs(value) {
256
+ if (!Array.isArray(value)) {
257
+ return [];
258
+ }
259
+ return value
260
+ .map((item) => normalizeManifestSourceRef(item))
261
+ .filter((item) => item !== null);
262
+ }
263
+ function normalizeSubmittedManifestObligation(value, verificationBasis) {
264
+ const record = asRecord(value);
265
+ if (!record) {
266
+ return null;
267
+ }
268
+ const obligationId = normalizeObligationIds(record.obligation_id)[0] ?? null;
269
+ const kind = normalizeManifestObligationKind(record.kind);
270
+ const name = asString(record.name) ?? asString(record.title);
271
+ const description = asString(record.description) ?? asString(record.summary) ?? name;
272
+ const sourceRefs = normalizeManifestSourceRefs(record.source_refs ?? (record.source_ref ? [record.source_ref] : []));
273
+ const verificationHint = normalizeManifestVerificationHint(record.verification_hint);
274
+ const confidence = normalizeManifestConfidence(record.confidence);
275
+ if (!obligationId ||
276
+ !kind ||
277
+ !name ||
278
+ !description ||
279
+ !verificationHint ||
280
+ !confidence ||
281
+ (sourceRefs.length === 0 && verificationBasis !== 'human_review_confirmed')) {
282
+ return null;
283
+ }
284
+ return {
285
+ obligation_id: obligationId,
286
+ kind,
287
+ name,
288
+ description,
289
+ source_refs: sourceRefs,
290
+ verification_hint: verificationHint,
291
+ confidence,
292
+ };
293
+ }
294
+ function asBootstrapManifest(value) {
295
+ const record = asRecord(value);
296
+ if (!record || record.artifact_type !== 'bootstrap') {
297
+ return null;
298
+ }
299
+ return record;
300
+ }
301
+ function asVerifiedManifest(value) {
302
+ const record = asRecord(value);
303
+ if (!record || record.artifact_type !== 'verified') {
304
+ return null;
305
+ }
306
+ return record;
307
+ }
308
+ function asIntakeReview(value) {
309
+ const record = asRecord(value);
310
+ if (!record || typeof record.feature_id !== 'string') {
311
+ return null;
312
+ }
313
+ const ambiguities = Array.isArray(record.ambiguities)
314
+ ? record.ambiguities
315
+ .map((item) => normalizeReviewAmbiguity(item))
316
+ .filter((item) => item !== null)
317
+ : [];
318
+ const clarificationAnswers = normalizeReviewClarificationAnswers(record.clarification_answers, ambiguities);
319
+ return {
320
+ feature_id: record.feature_id,
321
+ version: readPositiveInteger(record.version) ?? 1,
322
+ status: normalizeReviewStatus(record.status),
323
+ questions_open: readNonNegativeInteger(record.questions_open) ?? 0,
324
+ questions_resolved: readNonNegativeInteger(record.questions_resolved) ?? clarificationAnswers.length,
325
+ ambiguities,
326
+ clarification_answers: clarificationAnswers,
327
+ bootstrap_manifest_version: readPositiveInteger(record.bootstrap_manifest_version),
328
+ verified_manifest_version: readPositiveInteger(record.verified_manifest_version),
329
+ promotion_basis: normalizeVerificationBasis(record.promotion_basis),
330
+ last_updated_at: asString(record.last_updated_at) ?? nowIso(),
331
+ };
332
+ }
333
+ function readIntakeRecord(frontMatter) {
334
+ const intake = asRecord(frontMatter.intake);
335
+ return intake ?? {};
336
+ }
337
+ function readPlanningIntakePolicy(policy) {
338
+ return asRecord(asRecord(policy.planning)?.intake) ?? {};
339
+ }
340
+ function buildDefaultReview(featureId, bootstrapManifest) {
341
+ return {
342
+ feature_id: featureId,
343
+ version: 1,
344
+ status: 'proposed',
345
+ questions_open: 0,
346
+ questions_resolved: 0,
347
+ ambiguities: bootstrapManifest.ambiguities,
348
+ clarification_answers: [],
349
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
350
+ verified_manifest_version: null,
351
+ promotion_basis: null,
352
+ last_updated_at: nowIso(),
353
+ };
354
+ }
355
+ function summarizeIntake(frontMatter, bootstrapManifest, verifiedManifest, review) {
356
+ const intake = readIntakeRecord(frontMatter);
357
+ const normalizedIntakeStatus = intake.status === 'not_started' ||
358
+ intake.status === 'in_progress' ||
359
+ intake.status === 'awaiting_input'
360
+ ? intake.status
361
+ : intake.status === 'verified'
362
+ ? verifiedManifest
363
+ ? 'verified'
364
+ : frontMatter.status === STATUS.AWAITING_INPUT
365
+ ? 'awaiting_input'
366
+ : 'in_progress'
367
+ : null;
368
+ const openAmbiguityCount = typeof intake.open_ambiguity_count === 'number'
369
+ ? Math.max(0, Math.floor(intake.open_ambiguity_count))
370
+ : (review?.ambiguities.filter((item) => item.status === 'open').length ??
371
+ bootstrapManifest?.ambiguities.filter((item) => item.status === 'open').length ??
372
+ 0);
373
+ return {
374
+ status: normalizedIntakeStatus ??
375
+ (verifiedManifest
376
+ ? 'verified'
377
+ : frontMatter.status === STATUS.AWAITING_INPUT
378
+ ? 'awaiting_input'
379
+ : 'in_progress'),
380
+ bootstrap_manifest_version: typeof intake.bootstrap_manifest_version === 'number'
381
+ ? Math.floor(intake.bootstrap_manifest_version)
382
+ : (bootstrapManifest?.manifest_version ?? null),
383
+ verified_manifest_version: verifiedManifest
384
+ ? typeof intake.verified_manifest_version === 'number'
385
+ ? Math.floor(intake.verified_manifest_version)
386
+ : verifiedManifest.manifest_version
387
+ : null,
388
+ open_ambiguity_count: openAmbiguityCount,
389
+ last_verified_at: verifiedManifest
390
+ ? typeof intake.last_verified_at === 'string'
391
+ ? intake.last_verified_at
392
+ : verifiedManifest.verified_at
393
+ : null,
394
+ promotion_basis: verifiedManifest
395
+ ? intake.promotion_basis === 'structured_spec' ||
396
+ intake.promotion_basis === 'questions_resolved' ||
397
+ intake.promotion_basis === 'policy_approved_auto_promotion' ||
398
+ intake.promotion_basis === 'human_review_confirmed'
399
+ ? intake.promotion_basis
400
+ : (review?.promotion_basis ?? null)
401
+ : null,
402
+ };
403
+ }
404
+ function normalizeQuestionEvidence(value) {
405
+ const record = asRecord(value);
406
+ const status = asString(record?.status);
407
+ if (!record || !status) {
408
+ return null;
409
+ }
410
+ return {
411
+ question_id: asString(record.question_id),
412
+ status,
413
+ question_type: asString(record.question_type),
414
+ phase: asString(record.phase),
415
+ resume_status: asString(record.resume_status),
416
+ resume_phase: asString(record.resume_phase),
417
+ prompt: asString(record.prompt),
418
+ answer: asAnswerValue(record.answer),
419
+ answered_at: asString(record.answered_at),
420
+ answered_by: asString(record.answered_by),
421
+ details: asRecord(record.details) ?? {},
422
+ };
423
+ }
424
+ function isAnsweredIntakeQuestion(question, bootstrapManifest) {
425
+ if (question.status !== 'answered' || !question.answered_by || !question.answered_at) {
426
+ return false;
427
+ }
428
+ const answeredAt = Date.parse(question.answered_at);
429
+ const generatedAt = Date.parse(bootstrapManifest.generated_at);
430
+ if (Number.isFinite(answeredAt) && Number.isFinite(generatedAt) && answeredAt < generatedAt) {
431
+ return false;
432
+ }
433
+ return (question.resume_status === STATUS.INTAKE ||
434
+ question.resume_phase === STATUS.INTAKE ||
435
+ question.phase === STATUS.INTAKE);
436
+ }
437
+ function questionReferencesAmbiguity(question, ambiguityId) {
438
+ const singular = normalizeAmbiguityIds(question.details.ambiguity_id)[0] ??
439
+ asString(question.details.ambiguity_id);
440
+ if (singular === ambiguityId) {
441
+ return true;
442
+ }
443
+ return normalizeAmbiguityIds(question.details.ambiguity_ids).includes(ambiguityId);
444
+ }
445
+ function questionConfirmsVerifiedManifest(question) {
446
+ return (asString(question.details.confirmation_kind) === 'manifest_review' ||
447
+ asString(question.details.review_target) === 'verified_manifest' ||
448
+ asString(question.details.ambiguity_id) === MANIFEST_REVIEW_AMBIGUITY_ID);
449
+ }
450
+ function isIntakeQuestion(question) {
451
+ return (question.resume_status === STATUS.INTAKE ||
452
+ question.resume_phase === STATUS.INTAKE ||
453
+ question.phase === STATUS.INTAKE);
454
+ }
455
+ function isOpenIntakeQuestion(question) {
456
+ return question.status === 'open' && isIntakeQuestion(question);
457
+ }
458
+ function isAnsweredIntakeClarification(question) {
459
+ return (question.status === 'answered' &&
460
+ question.question_id !== null &&
461
+ question.prompt !== null &&
462
+ question.answer !== null &&
463
+ question.answered_at !== null &&
464
+ question.answered_by !== null &&
465
+ isIntakeQuestion(question) &&
466
+ normalizeAmbiguityIds(question.details.ambiguity_ids).length > 0);
467
+ }
468
+ function buildClarificationAnswers(review, questions) {
469
+ const ambiguityStatus = new Map(review.ambiguities.map((item) => [item.id, item.status]));
470
+ return questions
471
+ .filter((question) => isAnsweredIntakeClarification(question))
472
+ .map((question) => {
473
+ const ambiguityIds = normalizeAmbiguityIds(question.details.ambiguity_ids);
474
+ const obligationIds = normalizeObligationIds(question.details.obligation_ids);
475
+ const resolutionStatus = ambiguityIds.every((ambiguityId) => ambiguityStatus.get(ambiguityId) === 'resolved')
476
+ ? 'applied'
477
+ : 'candidate';
478
+ return {
479
+ question_id: question.question_id,
480
+ ambiguity_ids: ambiguityIds,
481
+ obligation_ids: obligationIds,
482
+ prompt: question.prompt,
483
+ answer: question.answer,
484
+ answered_at: question.answered_at,
485
+ answered_by: question.answered_by,
486
+ resolution_status: resolutionStatus,
487
+ };
488
+ })
489
+ .sort((left, right) => {
490
+ if (left.answered_at === right.answered_at) {
491
+ return left.question_id.localeCompare(right.question_id);
492
+ }
493
+ return left.answered_at.localeCompare(right.answered_at);
494
+ });
495
+ }
496
+ export class IntakeService {
497
+ port;
498
+ generator;
499
+ constructor(port, generator = new BootstrapManifestGeneratorService()) {
500
+ this.port = port;
501
+ this.generator = generator;
502
+ }
503
+ bootstrapManifestPath(featureId) {
504
+ return path.join(this.port.featurePath(featureId), 'spec.manifest.bootstrap.json');
505
+ }
506
+ verifiedManifestPath(featureId) {
507
+ return path.join(this.port.featurePath(featureId), 'spec.manifest.verified.json');
508
+ }
509
+ intakeReviewPath(featureId) {
510
+ return path.join(this.port.featurePath(featureId), 'intake.review.json');
511
+ }
512
+ questionsPath(featureId) {
513
+ return path.join(this.port.featurePath(featureId), 'questions.json');
514
+ }
515
+ planPath(featureId) {
516
+ return path.join(this.port.featurePath(featureId), 'plan.json');
517
+ }
518
+ planMarkdownPath(featureId) {
519
+ return path.join(this.port.featurePath(featureId), 'plan.md');
520
+ }
521
+ async readBootstrapManifest(featureId) {
522
+ return asBootstrapManifest(await readJson(this.bootstrapManifestPath(featureId), null));
523
+ }
524
+ async readVerifiedManifest(featureId) {
525
+ const rawManifest = await readJson(this.verifiedManifestPath(featureId), null);
526
+ if (!rawManifest) {
527
+ return null;
528
+ }
529
+ const validation = await this.port.validateSchema('spec.manifest.verified.schema.json', rawManifest);
530
+ if (!validation.valid) {
531
+ return null;
532
+ }
533
+ return asVerifiedManifest(rawManifest);
534
+ }
535
+ async readIntakeReview(featureId) {
536
+ return asIntakeReview(await readJson(this.intakeReviewPath(featureId), null));
537
+ }
538
+ normalizeSubmittedVerifiedManifest(featureId, verifiedManifest) {
539
+ const record = asRecord(verifiedManifest);
540
+ if (!record) {
541
+ return {};
542
+ }
543
+ const verificationBasis = normalizeVerificationBasis(record.verification_basis);
544
+ const rawObligations = Array.isArray(record.obligations) ? record.obligations : [];
545
+ const normalizedObligations = rawObligations
546
+ .map((item) => normalizeSubmittedManifestObligation(item, verificationBasis))
547
+ .filter((item) => item !== null);
548
+ const invalidObligations = rawObligations
549
+ .map((item, index) => {
550
+ const obligation = normalizeSubmittedManifestObligation(item, verificationBasis);
551
+ if (obligation) {
552
+ return null;
553
+ }
554
+ const raw = asRecord(item);
555
+ return {
556
+ index,
557
+ obligation_id: asString(raw?.obligation_id),
558
+ kind: asString(raw?.kind),
559
+ name: asString(raw?.name) ?? asString(raw?.title),
560
+ };
561
+ })
562
+ .filter((item) => item !== null);
563
+ if (invalidObligations.length > 0) {
564
+ throw {
565
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest contains malformed obligations that could not be normalized', {
566
+ feature_id: featureId,
567
+ invalid_obligations: invalidObligations,
568
+ retryable: false,
569
+ requires_human: true,
570
+ suggested_next_actions: [
571
+ 'Use canonical obligation ids such as OBL-001 or draft ids such as OBL-V01',
572
+ 'Use only supported obligation kinds or constraint aliases that normalize to contract',
573
+ 'Include source_refs for non-human-review verification bases',
574
+ ],
575
+ }),
576
+ };
577
+ }
578
+ const seenObligationIds = new Set();
579
+ const duplicateObligationIds = normalizedObligations
580
+ .map((obligation) => obligation.obligation_id)
581
+ .filter((obligationId) => {
582
+ if (seenObligationIds.has(obligationId)) {
583
+ return true;
584
+ }
585
+ seenObligationIds.add(obligationId);
586
+ return false;
587
+ });
588
+ if (duplicateObligationIds.length > 0) {
589
+ throw {
590
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest contains duplicate obligation ids after normalization', {
591
+ feature_id: featureId,
592
+ duplicate_obligation_ids: normalizeUniqueStrings(duplicateObligationIds),
593
+ retryable: false,
594
+ requires_human: true,
595
+ }),
596
+ };
597
+ }
598
+ return {
599
+ feature_id: asString(record.feature_id) ?? featureId,
600
+ manifest_version: readPositiveInteger(record.manifest_version) ?? record.manifest_version,
601
+ artifact_type: record.artifact_type === 'verified' ? 'verified' : (record.artifact_type ?? null),
602
+ verification_basis: verificationBasis ?? record.verification_basis,
603
+ verified_at: asString(record.verified_at) ?? record.verified_at,
604
+ source_bootstrap_version: record.source_bootstrap_version === null
605
+ ? null
606
+ : (readPositiveInteger(record.source_bootstrap_version) ??
607
+ record.source_bootstrap_version),
608
+ obligations: normalizedObligations,
609
+ };
610
+ }
611
+ async validateArtifact(schemaName, value, message) {
612
+ const validation = await this.port.validateSchema(schemaName, value);
613
+ if (!validation.valid) {
614
+ throw {
615
+ normalizedResponse: fail(ERROR_CODES.STATE_VALIDATION_FAILED, message, {
616
+ errors: validation.errors,
617
+ retryable: false,
618
+ requires_human: true,
619
+ }),
620
+ };
621
+ }
622
+ }
623
+ async validateSubmittedVerifiedManifest(featureId, verifiedManifest) {
624
+ const validation = await this.port.validateSchema('spec.manifest.verified.schema.json', verifiedManifest);
625
+ if (!validation.valid) {
626
+ throw {
627
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest failed schema validation', {
628
+ feature_id: featureId,
629
+ errors: validation.errors,
630
+ retryable: false,
631
+ requires_human: true,
632
+ suggested_next_actions: [
633
+ 'Normalize obligation ids to OBL-### before emitting INTAKE_SUBMISSION',
634
+ 'Use supported obligation kinds only',
635
+ 'For human-review additions, keep source_refs empty rather than adding unsupported fields',
636
+ ],
637
+ }),
638
+ };
639
+ }
640
+ }
641
+ async syncIntakeState(featureId, patch) {
642
+ await this.port.updateState(featureId, null, (frontMatter, body) => Promise.resolve({
643
+ frontMatter: patch(frontMatter),
644
+ body,
645
+ }));
646
+ }
647
+ isAutoPromotionEnabled() {
648
+ const intake = readPlanningIntakePolicy(this.port.getPolicySnapshot());
649
+ return intake.allow_auto_promotion === true;
650
+ }
651
+ readAutoPromotionMinConfidence() {
652
+ const intake = readPlanningIntakePolicy(this.port.getPolicySnapshot());
653
+ return normalizeManifestConfidence(intake.auto_promotion_min_confidence) ?? 'high';
654
+ }
655
+ canAutoPromoteBootstrapManifest(bootstrapManifest) {
656
+ return (this.isAutoPromotionEnabled() &&
657
+ bootstrapManifest.ambiguities.length === 0 &&
658
+ obligationsMeetConfidenceThreshold(bootstrapManifest.obligations, this.readAutoPromotionMinConfidence()));
659
+ }
660
+ async readQuestionEvidence(featureId) {
661
+ const artifact = await readJson(this.questionsPath(featureId), null);
662
+ const items = Array.isArray(artifact?.items) ? artifact.items : [];
663
+ return items
664
+ .map((item) => normalizeQuestionEvidence(item))
665
+ .filter((item) => item !== null);
666
+ }
667
+ async buildSyncedReview(featureId, bootstrapManifest, verifiedManifest) {
668
+ const existingReview = (await this.readIntakeReview(featureId)) ?? buildDefaultReview(featureId, bootstrapManifest);
669
+ const ambiguities = mergeReviewAmbiguities(bootstrapManifest.ambiguities, existingReview.ambiguities);
670
+ const unverifiedReviewStatus = existingReview.status === 'verified' && !verifiedManifest
671
+ ? 'proposed'
672
+ : existingReview.status;
673
+ const questions = await this.readQuestionEvidence(featureId);
674
+ if (questions.length === 0) {
675
+ return {
676
+ ...existingReview,
677
+ ambiguities,
678
+ clarification_answers: normalizeReviewClarificationAnswers(existingReview.clarification_answers, ambiguities),
679
+ status: verifiedManifest ? 'verified' : unverifiedReviewStatus,
680
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
681
+ verified_manifest_version: verifiedManifest?.manifest_version ?? null,
682
+ promotion_basis: verifiedManifest?.verification_basis ??
683
+ normalizeVerificationBasis(existingReview.promotion_basis) ??
684
+ null,
685
+ };
686
+ }
687
+ const openIntakeQuestions = questions.filter((question) => isOpenIntakeQuestion(question));
688
+ const clarificationAnswers = buildClarificationAnswers({
689
+ ...existingReview,
690
+ ambiguities,
691
+ }, questions);
692
+ return {
693
+ ...existingReview,
694
+ ambiguities,
695
+ status: verifiedManifest
696
+ ? 'verified'
697
+ : openIntakeQuestions.length > 0
698
+ ? 'awaiting_input'
699
+ : 'proposed',
700
+ questions_open: openIntakeQuestions.length,
701
+ questions_resolved: clarificationAnswers.length,
702
+ clarification_answers: clarificationAnswers,
703
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
704
+ verified_manifest_version: verifiedManifest?.manifest_version ?? null,
705
+ promotion_basis: verifiedManifest?.verification_basis ??
706
+ normalizeVerificationBasis(existingReview.promotion_basis) ??
707
+ null,
708
+ last_updated_at: nowIso(),
709
+ };
710
+ }
711
+ async syncReviewFromQuestions(featureId) {
712
+ const bootstrapManifest = await this.readBootstrapManifest(featureId);
713
+ if (!bootstrapManifest) {
714
+ return;
715
+ }
716
+ const verifiedManifest = await this.readVerifiedManifest(featureId);
717
+ const nextReview = await this.buildSyncedReview(featureId, bootstrapManifest, verifiedManifest);
718
+ await this.validateArtifact('intake.review.schema.json', nextReview, 'intake review failed schema validation');
719
+ await atomicWriteJson(this.intakeReviewPath(featureId), nextReview);
720
+ }
721
+ async validateVerificationBasisEvidence(featureId, submission, bootstrapManifest) {
722
+ const verificationBasis = submission.verified_manifest.verification_basis;
723
+ if (verificationBasis === 'policy_approved_auto_promotion') {
724
+ return;
725
+ }
726
+ if (verificationBasis === 'structured_spec' &&
727
+ (bootstrapManifest.ambiguities.length > 0 || submission.resolved_ambiguities.length > 0)) {
728
+ throw {
729
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'structured_spec verification cannot resolve inferred intake ambiguities', {
730
+ feature_id: featureId,
731
+ bootstrap_ambiguity_ids: bootstrapManifest.ambiguities.map((item) => item.id),
732
+ resolved_ambiguity_ids: submission.resolved_ambiguities.map((item) => item.id),
733
+ retryable: false,
734
+ requires_human: true,
735
+ suggested_next_actions: [
736
+ 'Emit REQUEST.action=ask_user_input for the blocking ambiguity',
737
+ 'Use verification_basis=questions_resolved after the operator answers',
738
+ ],
739
+ }),
740
+ };
741
+ }
742
+ if (verificationBasis !== 'questions_resolved' &&
743
+ verificationBasis !== 'human_review_confirmed') {
744
+ return;
745
+ }
746
+ const questions = await this.readQuestionEvidence(featureId);
747
+ const openIntakeQuestions = questions.filter((question) => question.status === 'open' &&
748
+ (question.resume_status === STATUS.INTAKE ||
749
+ question.resume_phase === STATUS.INTAKE ||
750
+ question.phase === STATUS.INTAKE));
751
+ if (openIntakeQuestions.length > 0) {
752
+ throw {
753
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest cannot be promoted while intake questions remain open', {
754
+ feature_id: featureId,
755
+ open_question_count: openIntakeQuestions.length,
756
+ retryable: false,
757
+ requires_human: true,
758
+ suggested_next_actions: [
759
+ 'Wait for the operator to answer the open intake question',
760
+ 'Resubmit INTAKE_SUBMISSION after the answered question is persisted',
761
+ ],
762
+ }),
763
+ };
764
+ }
765
+ const answeredIntakeQuestions = questions.filter((question) => isAnsweredIntakeQuestion(question, bootstrapManifest));
766
+ if (answeredIntakeQuestions.length === 0) {
767
+ throw {
768
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest requires persisted answered intake-question evidence', {
769
+ feature_id: featureId,
770
+ verification_basis: verificationBasis,
771
+ retryable: false,
772
+ requires_human: true,
773
+ suggested_next_actions: [
774
+ 'Emit REQUEST.action=ask_user_input instead of resolving the ambiguity yourself',
775
+ 'Resubmit INTAKE_SUBMISSION only after the operator answer is stored in questions.json',
776
+ ],
777
+ }),
778
+ };
779
+ }
780
+ if (verificationBasis === 'questions_resolved') {
781
+ if (submission.resolved_ambiguities.length === 0) {
782
+ throw {
783
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'questions_resolved verification requires at least one resolved ambiguity', {
784
+ feature_id: featureId,
785
+ retryable: false,
786
+ requires_human: true,
787
+ }),
788
+ };
789
+ }
790
+ const missingEvidence = submission.resolved_ambiguities
791
+ .map((ambiguity) => ambiguity.id)
792
+ .filter((ambiguityId) => !answeredIntakeQuestions.some((question) => questionReferencesAmbiguity(question, ambiguityId)));
793
+ if (missingEvidence.length > 0) {
794
+ throw {
795
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'resolved intake ambiguities must map to answered intake questions', {
796
+ feature_id: featureId,
797
+ verification_basis: verificationBasis,
798
+ missing_ambiguity_evidence_ids: missingEvidence,
799
+ retryable: false,
800
+ requires_human: true,
801
+ suggested_next_actions: [
802
+ 'Include ambiguity_id or ambiguity_ids on the blocking intake question',
803
+ 'Only mark ambiguities resolved after their answered question is persisted',
804
+ ],
805
+ }),
806
+ };
807
+ }
808
+ return;
809
+ }
810
+ if (!answeredIntakeQuestions.some((question) => questionConfirmsVerifiedManifest(question))) {
811
+ throw {
812
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'human_review_confirmed requires an explicit answered manifest-review confirmation question', {
813
+ feature_id: featureId,
814
+ verification_basis: verificationBasis,
815
+ retryable: false,
816
+ requires_human: true,
817
+ suggested_next_actions: [
818
+ 'Use verification_basis=questions_resolved for answered ambiguity questions',
819
+ 'Reserve human_review_confirmed for explicit manifest confirmation responses',
820
+ ],
821
+ }),
822
+ };
823
+ }
824
+ }
825
+ async ensureBootstrapManifest(featureId) {
826
+ const existing = await this.readBootstrapManifest(featureId);
827
+ if (existing) {
828
+ return existing;
829
+ }
830
+ const specText = await fs.readFile(this.port.specPath(featureId), 'utf8').catch(() => '');
831
+ const manifest = this.generator.generate(featureId, specText);
832
+ await this.validateArtifact('spec.manifest.bootstrap.schema.json', manifest, 'bootstrap manifest failed schema validation');
833
+ const persistedManifest = await this.port.withFeatureLock(featureId, async () => {
834
+ const current = await this.readBootstrapManifest(featureId);
835
+ if (current) {
836
+ return current;
837
+ }
838
+ await atomicWriteJson(this.bootstrapManifestPath(featureId), manifest);
839
+ const existingReview = await this.readIntakeReview(featureId);
840
+ if (!existingReview) {
841
+ const review = buildDefaultReview(featureId, manifest);
842
+ await this.validateArtifact('intake.review.schema.json', review, 'intake review failed schema validation');
843
+ await atomicWriteJson(this.intakeReviewPath(featureId), review);
844
+ }
845
+ return manifest;
846
+ });
847
+ await this.syncReviewFromQuestions(featureId);
848
+ await this.syncIntakeState(featureId, (frontMatter) => ({
849
+ ...frontMatter,
850
+ intake: {
851
+ ...readIntakeRecord(frontMatter),
852
+ status: frontMatter.status === STATUS.AWAITING_INPUT ? 'awaiting_input' : 'in_progress',
853
+ bootstrap_manifest_version: persistedManifest.manifest_version,
854
+ verified_manifest_version: typeof readIntakeRecord(frontMatter).verified_manifest_version === 'number'
855
+ ? readIntakeRecord(frontMatter).verified_manifest_version
856
+ : null,
857
+ open_ambiguity_count: persistedManifest.ambiguities.filter((item) => item.status === 'open')
858
+ .length,
859
+ last_verified_at: typeof readIntakeRecord(frontMatter).last_verified_at === 'string'
860
+ ? readIntakeRecord(frontMatter).last_verified_at
861
+ : null,
862
+ promotion_basis: typeof readIntakeRecord(frontMatter).promotion_basis === 'string'
863
+ ? readIntakeRecord(frontMatter).promotion_basis
864
+ : null,
865
+ },
866
+ }));
867
+ return persistedManifest;
868
+ }
869
+ async ensureIntakeArtifacts(featureId) {
870
+ const bootstrapManifest = await this.ensureBootstrapManifest(featureId);
871
+ await this.syncReviewFromQuestions(featureId);
872
+ const [initialVerifiedManifest, initialReview, initialState] = await Promise.all([
873
+ this.readVerifiedManifest(featureId),
874
+ this.readIntakeReview(featureId),
875
+ this.port.readState(featureId),
876
+ ]);
877
+ let verifiedManifest = initialVerifiedManifest;
878
+ let review = initialReview ?? buildDefaultReview(featureId, bootstrapManifest);
879
+ let state = initialState;
880
+ if (!verifiedManifest && this.canAutoPromoteBootstrapManifest(bootstrapManifest)) {
881
+ await this.intakeSubmit(featureId, {
882
+ verified_manifest: {
883
+ feature_id: featureId,
884
+ manifest_version: bootstrapManifest.manifest_version,
885
+ artifact_type: 'verified',
886
+ verification_basis: 'policy_approved_auto_promotion',
887
+ verified_at: nowIso(),
888
+ source_bootstrap_version: bootstrapManifest.manifest_version,
889
+ obligations: bootstrapManifest.obligations,
890
+ },
891
+ open_ambiguities: [],
892
+ resolved_ambiguities: [],
893
+ requires_user_input: false,
894
+ });
895
+ [verifiedManifest, review, state] = await Promise.all([
896
+ this.readVerifiedManifest(featureId),
897
+ this.readIntakeReview(featureId),
898
+ this.port.readState(featureId),
899
+ ]);
900
+ }
901
+ return {
902
+ bootstrapManifest,
903
+ verifiedManifest,
904
+ review: review ?? buildDefaultReview(featureId, bootstrapManifest),
905
+ summary: summarizeIntake(state.frontMatter, bootstrapManifest, verifiedManifest, review),
906
+ };
907
+ }
908
+ async intakeSubmit(featureId, submission) {
909
+ if (!submission || !submission.verified_manifest) {
910
+ throw {
911
+ normalizedResponse: fail(ERROR_CODES.INVALID_ARGUMENT, 'verified_manifest is required for intake submission', {
912
+ retryable: false,
913
+ requires_human: true,
914
+ }),
915
+ };
916
+ }
917
+ const normalizedVerifiedManifest = this.normalizeSubmittedVerifiedManifest(featureId, submission.verified_manifest);
918
+ const verifiedManifest = normalizedVerifiedManifest;
919
+ if (verifiedManifest.feature_id !== featureId) {
920
+ throw {
921
+ normalizedResponse: fail(ERROR_CODES.INVALID_ARGUMENT, 'verified_manifest.feature_id must match feature_id', {
922
+ feature_id: featureId,
923
+ manifest_feature_id: verifiedManifest.feature_id,
924
+ retryable: false,
925
+ requires_human: true,
926
+ }),
927
+ };
928
+ }
929
+ await this.validateSubmittedVerifiedManifest(featureId, normalizedVerifiedManifest);
930
+ const bootstrapManifest = await this.ensureBootstrapManifest(featureId);
931
+ const normalizedSubmission = {
932
+ verified_manifest: verifiedManifest,
933
+ open_ambiguities: normalizeSubmissionAmbiguities(submission.open_ambiguities, 'open', bootstrapManifest),
934
+ resolved_ambiguities: normalizeSubmissionAmbiguities(submission.resolved_ambiguities, 'resolved', bootstrapManifest),
935
+ requires_user_input: submission.requires_user_input === true,
936
+ };
937
+ if (normalizedSubmission.requires_user_input === true ||
938
+ normalizedSubmission.open_ambiguities.some((item) => item.status === 'open')) {
939
+ throw {
940
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest cannot be promoted while intake ambiguities remain unresolved', {
941
+ feature_id: featureId,
942
+ requires_user_input: normalizedSubmission.requires_user_input,
943
+ open_ambiguity_ids: normalizedSubmission.open_ambiguities
944
+ .filter((item) => item.status === 'open')
945
+ .map((item) => item.id),
946
+ retryable: false,
947
+ requires_human: true,
948
+ suggested_next_actions: [
949
+ 'Emit REQUEST.action=ask_user_input for the unresolved ambiguity',
950
+ 'Resubmit INTAKE_SUBMISSION only after the ambiguity is resolved',
951
+ ],
952
+ }),
953
+ };
954
+ }
955
+ if (verifiedManifest.verification_basis === 'policy_approved_auto_promotion' &&
956
+ !this.canAutoPromoteBootstrapManifest(bootstrapManifest)) {
957
+ throw {
958
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'policy-approved auto-promotion is not allowed for this bootstrap manifest', {
959
+ feature_id: featureId,
960
+ allow_auto_promotion: this.isAutoPromotionEnabled(),
961
+ minimum_confidence: this.readAutoPromotionMinConfidence(),
962
+ retryable: false,
963
+ requires_human: true,
964
+ }),
965
+ };
966
+ }
967
+ if (verifiedManifest.source_bootstrap_version !== null &&
968
+ verifiedManifest.source_bootstrap_version !== bootstrapManifest.manifest_version) {
969
+ throw {
970
+ normalizedResponse: fail(ERROR_CODES.INTAKE_SUBMISSION_INVALID, 'verified manifest must reference the current bootstrap manifest version', {
971
+ feature_id: featureId,
972
+ expected_source_bootstrap_version: bootstrapManifest.manifest_version,
973
+ received_source_bootstrap_version: verifiedManifest.source_bootstrap_version,
974
+ retryable: false,
975
+ requires_human: true,
976
+ }),
977
+ };
978
+ }
979
+ await this.validateVerificationBasisEvidence(featureId, normalizedSubmission, bootstrapManifest);
980
+ const result = await this.port.withFeatureLock(featureId, async () => {
981
+ const questionEvidence = await this.readQuestionEvidence(featureId);
982
+ const ambiguities = [
983
+ ...normalizedSubmission.open_ambiguities,
984
+ ...normalizedSubmission.resolved_ambiguities,
985
+ ];
986
+ const clarificationAnswers = buildClarificationAnswers({
987
+ feature_id: featureId,
988
+ version: ((await this.readIntakeReview(featureId))?.version ?? 0) + 1,
989
+ status: 'verified',
990
+ questions_open: 0,
991
+ questions_resolved: 0,
992
+ ambiguities,
993
+ clarification_answers: [],
994
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
995
+ verified_manifest_version: verifiedManifest.manifest_version,
996
+ promotion_basis: verifiedManifest.verification_basis,
997
+ last_updated_at: nowIso(),
998
+ }, questionEvidence);
999
+ const review = {
1000
+ feature_id: featureId,
1001
+ version: ((await this.readIntakeReview(featureId))?.version ?? 0) + 1,
1002
+ status: 'verified',
1003
+ questions_open: 0,
1004
+ questions_resolved: clarificationAnswers.length,
1005
+ ambiguities,
1006
+ clarification_answers: clarificationAnswers,
1007
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
1008
+ verified_manifest_version: verifiedManifest.manifest_version,
1009
+ promotion_basis: verifiedManifest.verification_basis,
1010
+ last_updated_at: nowIso(),
1011
+ };
1012
+ await this.validateArtifact('intake.review.schema.json', review, 'intake review failed schema validation');
1013
+ await atomicWriteJson(this.verifiedManifestPath(featureId), verifiedManifest);
1014
+ await atomicWriteJson(this.intakeReviewPath(featureId), review);
1015
+ await Promise.all([
1016
+ fs.rm(this.planPath(featureId), { force: true }),
1017
+ fs.rm(this.planMarkdownPath(featureId), { force: true }),
1018
+ ]);
1019
+ return {
1020
+ verified_manifest_version: verifiedManifest.manifest_version,
1021
+ };
1022
+ });
1023
+ await this.syncIntakeState(featureId, (frontMatter) => ({
1024
+ ...frontMatter,
1025
+ status: STATUS.PLANNING,
1026
+ gates: {
1027
+ ...(asRecord(frontMatter.gates) ?? {}),
1028
+ plan: GATE_RESULT.NA,
1029
+ },
1030
+ intake: {
1031
+ ...readIntakeRecord(frontMatter),
1032
+ status: 'verified',
1033
+ bootstrap_manifest_version: bootstrapManifest.manifest_version,
1034
+ verified_manifest_version: verifiedManifest.manifest_version,
1035
+ open_ambiguity_count: 0,
1036
+ last_verified_at: verifiedManifest.verified_at,
1037
+ promotion_basis: verifiedManifest.verification_basis,
1038
+ },
1039
+ }));
1040
+ return {
1041
+ data: {
1042
+ feature_id: featureId,
1043
+ accepted: true,
1044
+ feature_status: STATUS.PLANNING,
1045
+ verified_manifest_version: result.verified_manifest_version,
1046
+ },
1047
+ };
1048
+ }
1049
+ }
1050
+ //# sourceMappingURL=intake-service.js.map