soloforge 1.1.30 → 1.1.31

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 (804) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/README.md +33 -18
  3. package/dist/adapters/claude_code/claude_md.d.ts +2 -1
  4. package/dist/adapters/claude_code/claude_md.d.ts.map +1 -1
  5. package/dist/adapters/claude_code/claude_md.js.map +1 -1
  6. package/dist/adapters/codex/codex_rules.d.ts +2 -1
  7. package/dist/adapters/codex/codex_rules.d.ts.map +1 -1
  8. package/dist/adapters/codex/codex_rules.js.map +1 -1
  9. package/dist/adapters/shared/workflow_template.d.ts.map +1 -1
  10. package/dist/adapters/shared/workflow_template.js +0 -1
  11. package/dist/adapters/shared/workflow_template.js.map +1 -1
  12. package/dist/adapters/trae/trae_config.d.ts +17 -1
  13. package/dist/adapters/trae/trae_config.d.ts.map +1 -1
  14. package/dist/adapters/trae/trae_config.js +2 -2
  15. package/dist/adapters/trae/trae_config.js.map +1 -1
  16. package/dist/adapters/trae/trae_rules.d.ts +2 -1
  17. package/dist/adapters/trae/trae_rules.d.ts.map +1 -1
  18. package/dist/adapters/trae/trae_rules.js.map +1 -1
  19. package/dist/bin/args.d.ts +9 -0
  20. package/dist/bin/args.d.ts.map +1 -1
  21. package/dist/bin/args.js +44 -1
  22. package/dist/bin/args.js.map +1 -1
  23. package/dist/bin/commands/audit.d.ts.map +1 -1
  24. package/dist/bin/commands/audit.js +5 -40
  25. package/dist/bin/commands/audit.js.map +1 -1
  26. package/dist/bin/commands/check_bash.d.ts.map +1 -1
  27. package/dist/bin/commands/check_bash.js +28 -6
  28. package/dist/bin/commands/check_bash.js.map +1 -1
  29. package/dist/bin/commands/check_write.d.ts +2 -1
  30. package/dist/bin/commands/check_write.d.ts.map +1 -1
  31. package/dist/bin/commands/check_write.js +14 -45
  32. package/dist/bin/commands/check_write.js.map +1 -1
  33. package/dist/bin/commands/hooks.d.ts.map +1 -1
  34. package/dist/bin/commands/hooks.js +7 -3
  35. package/dist/bin/commands/hooks.js.map +1 -1
  36. package/dist/bin/commands/init.d.ts +19 -2
  37. package/dist/bin/commands/init.d.ts.map +1 -1
  38. package/dist/bin/commands/init.js +97 -72
  39. package/dist/bin/commands/init.js.map +1 -1
  40. package/dist/bin/commands/status.d.ts.map +1 -1
  41. package/dist/bin/commands/status.js +49 -65
  42. package/dist/bin/commands/status.js.map +1 -1
  43. package/dist/bin/commands/sync.d.ts.map +1 -1
  44. package/dist/bin/commands/sync.js +18 -26
  45. package/dist/bin/commands/sync.js.map +1 -1
  46. package/dist/bin/commands/validate.d.ts +1 -1
  47. package/dist/bin/commands/validate.d.ts.map +1 -1
  48. package/dist/bin/commands/validate.js +47 -58
  49. package/dist/bin/commands/validate.js.map +1 -1
  50. package/dist/bin/config_commands.d.ts +1 -1
  51. package/dist/bin/config_commands.d.ts.map +1 -1
  52. package/dist/bin/config_commands.js +40 -26
  53. package/dist/bin/config_commands.js.map +1 -1
  54. package/dist/bin/soloforge.js +30 -3
  55. package/dist/bin/soloforge.js.map +1 -1
  56. package/dist/engine/audit/audit_pool.d.ts.map +1 -1
  57. package/dist/engine/audit/audit_pool.js +2 -1
  58. package/dist/engine/audit/audit_pool.js.map +1 -1
  59. package/dist/engine/audit/audit_sampler.d.ts +2 -0
  60. package/dist/engine/audit/audit_sampler.d.ts.map +1 -1
  61. package/dist/engine/audit/audit_sampler.js.map +1 -1
  62. package/dist/engine/audit/code_reviewer.d.ts +1 -1
  63. package/dist/engine/audit/code_reviewer.d.ts.map +1 -1
  64. package/dist/engine/audit/code_reviewer.js +9 -21
  65. package/dist/engine/audit/code_reviewer.js.map +1 -1
  66. package/dist/engine/audit/core_experience_principle.js +1 -1
  67. package/dist/engine/audit/core_experience_principle.js.map +1 -1
  68. package/dist/engine/audit/debt_reporter.d.ts +3 -0
  69. package/dist/engine/audit/debt_reporter.d.ts.map +1 -1
  70. package/dist/engine/audit/debt_reporter.js.map +1 -1
  71. package/dist/engine/audit/debt_tracker.d.ts.map +1 -1
  72. package/dist/engine/audit/debt_tracker.js +12 -5
  73. package/dist/engine/audit/debt_tracker.js.map +1 -1
  74. package/dist/engine/audit/debugger.d.ts +3 -0
  75. package/dist/engine/audit/debugger.d.ts.map +1 -1
  76. package/dist/engine/audit/debugger.js.map +1 -1
  77. package/dist/engine/audit/delivery.d.ts +1 -1
  78. package/dist/engine/audit/delivery.d.ts.map +1 -1
  79. package/dist/engine/audit/delivery.js +7 -4
  80. package/dist/engine/audit/delivery.js.map +1 -1
  81. package/dist/engine/audit/delivery_readiness.d.ts +2 -0
  82. package/dist/engine/audit/delivery_readiness.d.ts.map +1 -1
  83. package/dist/engine/audit/delivery_readiness.js +2 -0
  84. package/dist/engine/audit/delivery_readiness.js.map +1 -1
  85. package/dist/engine/audit/developer_sovereignty.d.ts +5 -43
  86. package/dist/engine/audit/developer_sovereignty.d.ts.map +1 -1
  87. package/dist/engine/audit/developer_sovereignty.js +2 -6
  88. package/dist/engine/audit/developer_sovereignty.js.map +1 -1
  89. package/dist/engine/audit/evolver.js +5 -5
  90. package/dist/engine/audit/evolver.js.map +1 -1
  91. package/dist/engine/audit/failure_classifier.d.ts.map +1 -1
  92. package/dist/engine/audit/governance_report.d.ts +1 -1
  93. package/dist/engine/audit/governance_report.d.ts.map +1 -1
  94. package/dist/engine/audit/governance_report.js +1 -1
  95. package/dist/engine/audit/governance_report.js.map +1 -1
  96. package/dist/engine/audit/main_path_integration_contract/gates.d.ts +2 -1
  97. package/dist/engine/audit/main_path_integration_contract/gates.d.ts.map +1 -1
  98. package/dist/engine/audit/main_path_integration_contract/gates.js.map +1 -1
  99. package/dist/engine/audit/main_path_integration_contract/queries.d.ts +2 -2
  100. package/dist/engine/audit/main_path_integration_contract/queries.d.ts.map +1 -1
  101. package/dist/engine/audit/main_path_integration_contract/queries.js +2 -2
  102. package/dist/engine/audit/main_path_integration_contract/queries.js.map +1 -1
  103. package/dist/engine/audit/main_path_integration_contract/scanning.d.ts.map +1 -1
  104. package/dist/engine/audit/main_path_integration_contract/scanning.js +2 -2
  105. package/dist/engine/audit/main_path_integration_contract/scanning.js.map +1 -1
  106. package/dist/engine/audit/main_path_integration_contract/scanning_infra.d.ts.map +1 -1
  107. package/dist/engine/audit/main_path_integration_contract/scanning_infra.js +3 -2
  108. package/dist/engine/audit/main_path_integration_contract/scanning_infra.js.map +1 -1
  109. package/dist/engine/audit/mutation_audit.d.ts +4 -22
  110. package/dist/engine/audit/mutation_audit.d.ts.map +1 -1
  111. package/dist/engine/audit/mutation_audit.js.map +1 -1
  112. package/dist/engine/audit/observability.d.ts.map +1 -1
  113. package/dist/engine/audit/observability.js +4 -2
  114. package/dist/engine/audit/observability.js.map +1 -1
  115. package/dist/engine/audit/privacy_grants.d.ts +108 -0
  116. package/dist/engine/audit/privacy_grants.d.ts.map +1 -0
  117. package/dist/engine/audit/privacy_grants.js +171 -0
  118. package/dist/engine/audit/privacy_grants.js.map +1 -0
  119. package/dist/engine/audit/privacy_patterns.d.ts +24 -0
  120. package/dist/engine/audit/privacy_patterns.d.ts.map +1 -0
  121. package/dist/engine/audit/privacy_patterns.js +143 -0
  122. package/dist/engine/audit/privacy_patterns.js.map +1 -0
  123. package/dist/engine/audit/privacy_scanning.d.ts +153 -0
  124. package/dist/engine/audit/privacy_scanning.d.ts.map +1 -0
  125. package/dist/engine/audit/privacy_scanning.js +567 -0
  126. package/dist/engine/audit/privacy_scanning.js.map +1 -0
  127. package/dist/engine/audit/privacy_secret_contract.d.ts +9 -317
  128. package/dist/engine/audit/privacy_secret_contract.d.ts.map +1 -1
  129. package/dist/engine/audit/privacy_secret_contract.js +12 -873
  130. package/dist/engine/audit/privacy_secret_contract.js.map +1 -1
  131. package/dist/engine/audit/privacy_types.d.ts +48 -0
  132. package/dist/engine/audit/privacy_types.d.ts.map +1 -0
  133. package/dist/engine/audit/privacy_types.js +14 -0
  134. package/dist/engine/audit/privacy_types.js.map +1 -0
  135. package/dist/engine/audit/risk_sampler.d.ts +2 -0
  136. package/dist/engine/audit/risk_sampler.d.ts.map +1 -1
  137. package/dist/engine/audit/risk_sampler.js +2 -0
  138. package/dist/engine/audit/risk_sampler.js.map +1 -1
  139. package/dist/engine/audit/semantic_evidence.d.ts +5 -1
  140. package/dist/engine/audit/semantic_evidence.d.ts.map +1 -1
  141. package/dist/engine/audit/semantic_evidence.js +2 -0
  142. package/dist/engine/audit/semantic_evidence.js.map +1 -1
  143. package/dist/engine/audit/test_generator.d.ts.map +1 -1
  144. package/dist/engine/audit/test_generator.js +4 -1
  145. package/dist/engine/audit/test_generator.js.map +1 -1
  146. package/dist/engine/audit/test_quality.d.ts +3 -0
  147. package/dist/engine/audit/test_quality.d.ts.map +1 -1
  148. package/dist/engine/audit/test_quality.js +1 -71
  149. package/dist/engine/audit/test_quality.js.map +1 -1
  150. package/dist/engine/change_coordinator.d.ts +1 -1
  151. package/dist/engine/change_coordinator.d.ts.map +1 -1
  152. package/dist/engine/change_coordinator.js +30 -27
  153. package/dist/engine/change_coordinator.js.map +1 -1
  154. package/dist/engine/cognitive_anchor.d.ts.map +1 -1
  155. package/dist/engine/cognitive_anchor.js +6 -7
  156. package/dist/engine/cognitive_anchor.js.map +1 -1
  157. package/dist/engine/config/config_auto_repair.d.ts +2 -1
  158. package/dist/engine/config/config_auto_repair.d.ts.map +1 -1
  159. package/dist/engine/config/config_auto_repair.js +18 -13
  160. package/dist/engine/config/config_auto_repair.js.map +1 -1
  161. package/dist/engine/config/config_precedence_contract/field_class.d.ts +11 -0
  162. package/dist/engine/config/config_precedence_contract/field_class.d.ts.map +1 -0
  163. package/dist/engine/config/config_precedence_contract/field_class.js +10 -0
  164. package/dist/engine/config/config_precedence_contract/field_class.js.map +1 -0
  165. package/dist/engine/config/config_precedence_contract/index.d.ts +1 -0
  166. package/dist/engine/config/config_precedence_contract/index.d.ts.map +1 -1
  167. package/dist/engine/config/config_precedence_contract/index.js.map +1 -1
  168. package/dist/engine/config/config_precedence_contract/project_config.d.ts.map +1 -1
  169. package/dist/engine/config/config_precedence_contract/project_config.js +17 -9
  170. package/dist/engine/config/config_precedence_contract/project_config.js.map +1 -1
  171. package/dist/engine/config/config_precedence_contract/resolution.d.ts +1 -1
  172. package/dist/engine/config/config_precedence_contract/resolution.d.ts.map +1 -1
  173. package/dist/engine/config/config_precedence_contract/resolution.js +9 -0
  174. package/dist/engine/config/config_precedence_contract/resolution.js.map +1 -1
  175. package/dist/engine/config/config_precedence_contract/types.d.ts +4 -26
  176. package/dist/engine/config/config_precedence_contract/types.d.ts.map +1 -1
  177. package/dist/engine/config/config_precedence_contract/types.js +2 -0
  178. package/dist/engine/config/config_precedence_contract/types.js.map +1 -1
  179. package/dist/engine/config/config_precedence_contract.d.ts +3 -1
  180. package/dist/engine/config/config_precedence_contract.d.ts.map +1 -1
  181. package/dist/engine/config/config_precedence_contract.js +7 -1
  182. package/dist/engine/config/config_precedence_contract.js.map +1 -1
  183. package/dist/engine/config/config_write_boundary.d.ts.map +1 -1
  184. package/dist/engine/config/config_write_boundary.js +16 -0
  185. package/dist/engine/config/config_write_boundary.js.map +1 -1
  186. package/dist/engine/config/regression_matrix.d.ts.map +1 -1
  187. package/dist/engine/config/regression_matrix.js +3 -3
  188. package/dist/engine/config/regression_matrix.js.map +1 -1
  189. package/dist/engine/config/zero_config_init.d.ts +30 -5
  190. package/dist/engine/config/zero_config_init.d.ts.map +1 -1
  191. package/dist/engine/config/zero_config_init.js +26 -15
  192. package/dist/engine/config/zero_config_init.js.map +1 -1
  193. package/dist/engine/contracts/architecture_design_contract.d.ts.map +1 -1
  194. package/dist/engine/contracts/architecture_design_contract.js.map +1 -1
  195. package/dist/engine/contracts/artifact_contract_registry.d.ts +1 -1
  196. package/dist/engine/contracts/artifact_contract_registry.d.ts.map +1 -1
  197. package/dist/engine/contracts/artifact_contract_registry.js +1 -1
  198. package/dist/engine/contracts/artifact_contract_registry.js.map +1 -1
  199. package/dist/engine/contracts/backend_implementation_contract.js +4 -4
  200. package/dist/engine/contracts/backend_implementation_contract.js.map +1 -1
  201. package/dist/engine/contracts/brainstorm_contract.d.ts +1 -1
  202. package/dist/engine/contracts/brainstorm_contract.d.ts.map +1 -1
  203. package/dist/engine/contracts/brainstorm_contract.js +1 -1
  204. package/dist/engine/contracts/brainstorm_contract.js.map +1 -1
  205. package/dist/engine/contracts/capability_state_store.d.ts +2 -0
  206. package/dist/engine/contracts/capability_state_store.d.ts.map +1 -1
  207. package/dist/engine/contracts/capability_state_store.js +11 -1
  208. package/dist/engine/contracts/capability_state_store.js.map +1 -1
  209. package/dist/engine/contracts/code_maintainability_observability_contract.js +5 -5
  210. package/dist/engine/contracts/code_maintainability_observability_contract.js.map +1 -1
  211. package/dist/engine/contracts/coding_readiness_gate.d.ts +1 -1
  212. package/dist/engine/contracts/coding_readiness_gate.d.ts.map +1 -1
  213. package/dist/engine/contracts/coding_readiness_gate.js +1 -1
  214. package/dist/engine/contracts/coding_readiness_gate.js.map +1 -1
  215. package/dist/engine/contracts/command_execution_contract.d.ts +1 -11
  216. package/dist/engine/contracts/command_execution_contract.d.ts.map +1 -1
  217. package/dist/engine/contracts/command_execution_contract.js +1 -11
  218. package/dist/engine/contracts/command_execution_contract.js.map +1 -1
  219. package/dist/engine/contracts/contract_guard.d.ts +1 -1
  220. package/dist/engine/contracts/contract_guard.d.ts.map +1 -1
  221. package/dist/engine/contracts/contract_registry/registry.d.ts.map +1 -1
  222. package/dist/engine/contracts/contract_registry/registry.js +2 -2
  223. package/dist/engine/contracts/contract_registry/registry.js.map +1 -1
  224. package/dist/engine/contracts/contract_registry/validation.js.map +1 -1
  225. package/dist/engine/contracts/contract_state_store.d.ts +2 -0
  226. package/dist/engine/contracts/contract_state_store.d.ts.map +1 -1
  227. package/dist/engine/contracts/contract_state_store.js +4 -1
  228. package/dist/engine/contracts/contract_state_store.js.map +1 -1
  229. package/dist/engine/contracts/control_plane_contract.d.ts.map +1 -1
  230. package/dist/engine/contracts/control_plane_contract.js +5 -4
  231. package/dist/engine/contracts/control_plane_contract.js.map +1 -1
  232. package/dist/engine/contracts/decision_contract.js +1 -1
  233. package/dist/engine/contracts/decision_contract.js.map +1 -1
  234. package/dist/engine/contracts/decision_workshop.d.ts.map +1 -1
  235. package/dist/engine/contracts/decision_workshop.js.map +1 -1
  236. package/dist/engine/contracts/design_artifact_pack.d.ts +3 -40
  237. package/dist/engine/contracts/design_artifact_pack.d.ts.map +1 -1
  238. package/dist/engine/contracts/design_artifact_pack.js.map +1 -1
  239. package/dist/engine/contracts/detail_discipline.d.ts.map +1 -1
  240. package/dist/engine/contracts/detail_discipline.js.map +1 -1
  241. package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js +1 -1
  242. package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js.map +1 -1
  243. package/dist/engine/contracts/enforcement_guard.d.ts +2 -1
  244. package/dist/engine/contracts/enforcement_guard.d.ts.map +1 -1
  245. package/dist/engine/contracts/enforcement_guard.js +1 -1
  246. package/dist/engine/contracts/enforcement_guard.js.map +1 -1
  247. package/dist/engine/contracts/escape_report.d.ts.map +1 -1
  248. package/dist/engine/contracts/escape_report.js +2 -1
  249. package/dist/engine/contracts/escape_report.js.map +1 -1
  250. package/dist/engine/contracts/evidence_grounding_contract.d.ts +2 -4
  251. package/dist/engine/contracts/evidence_grounding_contract.d.ts.map +1 -1
  252. package/dist/engine/contracts/evidence_grounding_contract.js +3 -9
  253. package/dist/engine/contracts/evidence_grounding_contract.js.map +1 -1
  254. package/dist/engine/contracts/evolution_regression_gate.d.ts +2 -0
  255. package/dist/engine/contracts/evolution_regression_gate.d.ts.map +1 -1
  256. package/dist/engine/contracts/evolution_regression_gate.js +2 -0
  257. package/dist/engine/contracts/evolution_regression_gate.js.map +1 -1
  258. package/dist/engine/contracts/existing_system_analysis.d.ts.map +1 -1
  259. package/dist/engine/contracts/existing_system_analysis.js.map +1 -1
  260. package/dist/engine/contracts/existing_system_analyzer.d.ts +9 -9
  261. package/dist/engine/contracts/existing_system_analyzer.d.ts.map +1 -1
  262. package/dist/engine/contracts/existing_system_analyzer.js +83 -80
  263. package/dist/engine/contracts/existing_system_analyzer.js.map +1 -1
  264. package/dist/engine/contracts/extension_contract.d.ts +2 -2
  265. package/dist/engine/contracts/extension_contract.d.ts.map +1 -1
  266. package/dist/engine/contracts/extension_contract.js +2 -2
  267. package/dist/engine/contracts/extension_contract.js.map +1 -1
  268. package/dist/engine/contracts/extension_scenario_definitions.d.ts +10 -0
  269. package/dist/engine/contracts/extension_scenario_definitions.d.ts.map +1 -0
  270. package/dist/engine/contracts/extension_scenario_definitions.js +112 -0
  271. package/dist/engine/contracts/extension_scenario_definitions.js.map +1 -0
  272. package/dist/engine/contracts/extension_scenario_registry.d.ts +1 -7
  273. package/dist/engine/contracts/extension_scenario_registry.d.ts.map +1 -1
  274. package/dist/engine/contracts/extension_scenario_registry.js +5 -257
  275. package/dist/engine/contracts/extension_scenario_registry.js.map +1 -1
  276. package/dist/engine/contracts/first_principles.d.ts.map +1 -1
  277. package/dist/engine/contracts/first_principles.js.map +1 -1
  278. package/dist/engine/contracts/instruction_contract.d.ts.map +1 -1
  279. package/dist/engine/contracts/instruction_contract.js +0 -6
  280. package/dist/engine/contracts/instruction_contract.js.map +1 -1
  281. package/dist/engine/contracts/local_docker_acceptance.d.ts +1 -1
  282. package/dist/engine/contracts/local_docker_acceptance.d.ts.map +1 -1
  283. package/dist/engine/contracts/local_docker_acceptance.js +4 -4
  284. package/dist/engine/contracts/local_docker_acceptance.js.map +1 -1
  285. package/dist/engine/contracts/mechanism_health_check.d.ts +2 -0
  286. package/dist/engine/contracts/mechanism_health_check.d.ts.map +1 -1
  287. package/dist/engine/contracts/mechanism_health_check.js +2 -0
  288. package/dist/engine/contracts/mechanism_health_check.js.map +1 -1
  289. package/dist/engine/contracts/metric_governance.d.ts.map +1 -1
  290. package/dist/engine/contracts/metric_governance.js.map +1 -1
  291. package/dist/engine/contracts/ood_solid_contract.js +2 -2
  292. package/dist/engine/contracts/ood_solid_contract.js.map +1 -1
  293. package/dist/engine/contracts/platform_context.d.ts +2 -0
  294. package/dist/engine/contracts/platform_context.d.ts.map +1 -1
  295. package/dist/engine/contracts/platform_context.js +2 -0
  296. package/dist/engine/contracts/platform_context.js.map +1 -1
  297. package/dist/engine/contracts/project_knowledge_contract.d.ts.map +1 -1
  298. package/dist/engine/contracts/project_knowledge_contract.js +3 -0
  299. package/dist/engine/contracts/project_knowledge_contract.js.map +1 -1
  300. package/dist/engine/contracts/route_decision_contract_verifier.js +1 -1
  301. package/dist/engine/contracts/route_decision_contract_verifier.js.map +1 -1
  302. package/dist/engine/contracts/technology_decision.d.ts.map +1 -1
  303. package/dist/engine/contracts/technology_decision.js.map +1 -1
  304. package/dist/engine/contracts/tool_invocation_contract_registry.d.ts +3 -62
  305. package/dist/engine/contracts/tool_invocation_contract_registry.d.ts.map +1 -1
  306. package/dist/engine/contracts/tool_invocation_contract_registry.js +2 -0
  307. package/dist/engine/contracts/tool_invocation_contract_registry.js.map +1 -1
  308. package/dist/engine/contracts/traceability.d.ts +2 -1
  309. package/dist/engine/contracts/traceability.d.ts.map +1 -1
  310. package/dist/engine/contracts/traceability.js +5 -5
  311. package/dist/engine/contracts/traceability.js.map +1 -1
  312. package/dist/engine/contracts/user_feedback_contract.js +2 -2
  313. package/dist/engine/contracts/user_feedback_contract.js.map +1 -1
  314. package/dist/engine/contracts/workflow_template_pack.js +1 -1
  315. package/dist/engine/contracts/workflow_template_pack.js.map +1 -1
  316. package/dist/engine/core/config_defaults.d.ts +11 -0
  317. package/dist/engine/core/config_defaults.d.ts.map +1 -0
  318. package/dist/engine/core/config_defaults.js +11 -0
  319. package/dist/engine/core/config_defaults.js.map +1 -0
  320. package/dist/engine/core/env.d.ts +12 -0
  321. package/dist/engine/core/env.d.ts.map +1 -0
  322. package/dist/engine/core/env.js +12 -0
  323. package/dist/engine/core/env.js.map +1 -0
  324. package/dist/engine/core/errors.d.ts +21 -0
  325. package/dist/engine/core/errors.d.ts.map +1 -0
  326. package/dist/engine/core/errors.js +35 -0
  327. package/dist/engine/core/errors.js.map +1 -0
  328. package/dist/engine/core/exit_codes.d.ts +14 -0
  329. package/dist/engine/core/exit_codes.d.ts.map +1 -0
  330. package/dist/engine/core/exit_codes.js +14 -0
  331. package/dist/engine/core/exit_codes.js.map +1 -0
  332. package/dist/engine/core/helpers.d.ts +15 -0
  333. package/dist/engine/core/helpers.d.ts.map +1 -1
  334. package/dist/engine/core/helpers.js +31 -0
  335. package/dist/engine/core/helpers.js.map +1 -1
  336. package/dist/engine/core/index.d.ts +15 -0
  337. package/dist/engine/core/index.d.ts.map +1 -0
  338. package/dist/engine/core/index.js +22 -0
  339. package/dist/engine/core/index.js.map +1 -0
  340. package/dist/engine/core/io_controller.d.ts +1 -0
  341. package/dist/engine/core/io_controller.d.ts.map +1 -1
  342. package/dist/engine/core/io_controller.js +18 -2
  343. package/dist/engine/core/io_controller.js.map +1 -1
  344. package/dist/engine/core/llm_gateway.d.ts +20 -3
  345. package/dist/engine/core/llm_gateway.d.ts.map +1 -1
  346. package/dist/engine/core/llm_gateway.js +95 -13
  347. package/dist/engine/core/llm_gateway.js.map +1 -1
  348. package/dist/engine/core/log_governance.d.ts.map +1 -1
  349. package/dist/engine/core/log_governance.js +4 -9
  350. package/dist/engine/core/log_governance.js.map +1 -1
  351. package/dist/engine/core/logger.d.ts.map +1 -1
  352. package/dist/engine/core/logger.js +5 -2
  353. package/dist/engine/core/logger.js.map +1 -1
  354. package/dist/engine/core/path_scope_utils.d.ts +1 -1
  355. package/dist/engine/core/path_scope_utils.d.ts.map +1 -1
  356. package/dist/engine/core/path_scope_utils.js +1 -1
  357. package/dist/engine/core/path_scope_utils.js.map +1 -1
  358. package/dist/engine/core/paths.d.ts +86 -0
  359. package/dist/engine/core/paths.d.ts.map +1 -0
  360. package/dist/engine/core/paths.js +103 -0
  361. package/dist/engine/core/paths.js.map +1 -0
  362. package/dist/engine/core/write_file_atomic.d.ts +25 -0
  363. package/dist/engine/core/write_file_atomic.d.ts.map +1 -0
  364. package/dist/engine/core/write_file_atomic.js +63 -0
  365. package/dist/engine/core/write_file_atomic.js.map +1 -0
  366. package/dist/engine/dependency_scanner.d.ts.map +1 -1
  367. package/dist/engine/dependency_scanner.js +14 -16
  368. package/dist/engine/dependency_scanner.js.map +1 -1
  369. package/dist/engine/exploration.d.ts.map +1 -1
  370. package/dist/engine/exploration.js +9 -8
  371. package/dist/engine/exploration.js.map +1 -1
  372. package/dist/engine/knowledge/chinese_semantic_priority.d.ts.map +1 -1
  373. package/dist/engine/knowledge/chinese_semantic_priority.js.map +1 -1
  374. package/dist/engine/knowledge/drift_classifier.d.ts +26 -0
  375. package/dist/engine/knowledge/drift_classifier.d.ts.map +1 -0
  376. package/dist/engine/knowledge/drift_classifier.js +82 -0
  377. package/dist/engine/knowledge/drift_classifier.js.map +1 -0
  378. package/dist/engine/knowledge/knowledge_asset_audit.d.ts.map +1 -1
  379. package/dist/engine/knowledge/knowledge_asset_audit.js.map +1 -1
  380. package/dist/engine/knowledge/knowledge_asset_consumer.d.ts.map +1 -1
  381. package/dist/engine/knowledge/knowledge_asset_consumer.js +0 -4
  382. package/dist/engine/knowledge/knowledge_asset_consumer.js.map +1 -1
  383. package/dist/engine/knowledge/knowledge_asset_generation_gate.d.ts.map +1 -1
  384. package/dist/engine/knowledge/knowledge_asset_generation_gate.js.map +1 -1
  385. package/dist/engine/knowledge/knowledge_asset_schema.d.ts.map +1 -1
  386. package/dist/engine/knowledge/knowledge_asset_schema.js +0 -3
  387. package/dist/engine/knowledge/knowledge_asset_schema.js.map +1 -1
  388. package/dist/engine/knowledge/knowledge_evolution.d.ts +1 -17
  389. package/dist/engine/knowledge/knowledge_evolution.d.ts.map +1 -1
  390. package/dist/engine/knowledge/knowledge_evolution.js +2 -74
  391. package/dist/engine/knowledge/knowledge_evolution.js.map +1 -1
  392. package/dist/engine/knowledge/knowledge_health.d.ts +44 -0
  393. package/dist/engine/knowledge/knowledge_health.d.ts.map +1 -0
  394. package/dist/engine/knowledge/knowledge_health.js +303 -0
  395. package/dist/engine/knowledge/knowledge_health.js.map +1 -0
  396. package/dist/engine/knowledge/knowledge_injection_boundary.d.ts +1 -1
  397. package/dist/engine/knowledge/knowledge_injection_boundary.d.ts.map +1 -1
  398. package/dist/engine/knowledge/knowledge_injection_boundary.js +21 -5
  399. package/dist/engine/knowledge/knowledge_injection_boundary.js.map +1 -1
  400. package/dist/engine/knowledge/knowledge_lifecycle.d.ts +4 -2
  401. package/dist/engine/knowledge/knowledge_lifecycle.d.ts.map +1 -1
  402. package/dist/engine/knowledge/knowledge_lifecycle.js +37 -27
  403. package/dist/engine/knowledge/knowledge_lifecycle.js.map +1 -1
  404. package/dist/engine/knowledge/knowledge_manager.d.ts +2 -148
  405. package/dist/engine/knowledge/knowledge_manager.d.ts.map +1 -1
  406. package/dist/engine/knowledge/knowledge_manager.js +4 -933
  407. package/dist/engine/knowledge/knowledge_manager.js.map +1 -1
  408. package/dist/engine/knowledge/knowledge_scenario_registry.d.ts +1 -1
  409. package/dist/engine/knowledge/knowledge_scenario_registry.d.ts.map +1 -1
  410. package/dist/engine/knowledge/knowledge_scenario_registry.js +6 -6
  411. package/dist/engine/knowledge/knowledge_scenario_registry.js.map +1 -1
  412. package/dist/engine/knowledge/knowledge_sovereignty.js +2 -2
  413. package/dist/engine/knowledge/knowledge_sovereignty.js.map +1 -1
  414. package/dist/engine/knowledge/knowledge_writer.d.ts +108 -0
  415. package/dist/engine/knowledge/knowledge_writer.d.ts.map +1 -0
  416. package/dist/engine/knowledge/knowledge_writer.js +637 -0
  417. package/dist/engine/knowledge/knowledge_writer.js.map +1 -0
  418. package/dist/engine/knowledge/language_policy.d.ts +1 -1
  419. package/dist/engine/knowledge/language_policy.js +1 -1
  420. package/dist/engine/knowledge/release_compatibility.d.ts.map +1 -1
  421. package/dist/engine/knowledge/release_compatibility.js.map +1 -1
  422. package/dist/engine/migration_guard.js +4 -4
  423. package/dist/engine/migration_guard.js.map +1 -1
  424. package/dist/engine/onboarding.d.ts +1 -1
  425. package/dist/engine/onboarding.d.ts.map +1 -1
  426. package/dist/engine/onboarding.js +4 -1
  427. package/dist/engine/onboarding.js.map +1 -1
  428. package/dist/engine/pipeline/conflict_gate.js +1 -1
  429. package/dist/engine/pipeline/conflict_gate.js.map +1 -1
  430. package/dist/engine/pipeline/diff_ownership.d.ts.map +1 -1
  431. package/dist/engine/pipeline/diff_ownership.js +7 -0
  432. package/dist/engine/pipeline/diff_ownership.js.map +1 -1
  433. package/dist/engine/pipeline/diff_ownership_store.d.ts.map +1 -1
  434. package/dist/engine/pipeline/diff_ownership_store.js +8 -6
  435. package/dist/engine/pipeline/diff_ownership_store.js.map +1 -1
  436. package/dist/engine/pipeline/expand_pipeline.d.ts +2 -1
  437. package/dist/engine/pipeline/expand_pipeline.d.ts.map +1 -1
  438. package/dist/engine/pipeline/expand_pipeline.js.map +1 -1
  439. package/dist/engine/pipeline/input_material_contract_registry.d.ts +1 -1
  440. package/dist/engine/pipeline/input_material_contract_registry.d.ts.map +1 -1
  441. package/dist/engine/pipeline/input_material_contract_registry.js +44 -43
  442. package/dist/engine/pipeline/input_material_contract_registry.js.map +1 -1
  443. package/dist/engine/pipeline/input_material_extractor.js +3 -3
  444. package/dist/engine/pipeline/input_material_extractor.js.map +1 -1
  445. package/dist/engine/pipeline/intent_expander/expand.d.ts +6 -6
  446. package/dist/engine/pipeline/intent_expander/expand.d.ts.map +1 -1
  447. package/dist/engine/pipeline/intent_expander/expand.js +57 -50
  448. package/dist/engine/pipeline/intent_expander/expand.js.map +1 -1
  449. package/dist/engine/pipeline/intent_expander/helpers.d.ts +6 -4
  450. package/dist/engine/pipeline/intent_expander/helpers.d.ts.map +1 -1
  451. package/dist/engine/pipeline/intent_expander/helpers.js +4 -4
  452. package/dist/engine/pipeline/intent_expander/helpers.js.map +1 -1
  453. package/dist/engine/pipeline/intent_expander/index.d.ts +4 -4
  454. package/dist/engine/pipeline/intent_expander/index.js +8 -8
  455. package/dist/engine/pipeline/intent_expander/index.js.map +1 -1
  456. package/dist/engine/pipeline/intent_expander/knowledge.d.ts.map +1 -1
  457. package/dist/engine/pipeline/intent_expander/knowledge.js.map +1 -1
  458. package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts +12 -9
  459. package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts.map +1 -1
  460. package/dist/engine/pipeline/intent_expander/knowledge_resolution.js +11 -11
  461. package/dist/engine/pipeline/intent_expander/knowledge_resolution.js.map +1 -1
  462. package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts +68 -6
  463. package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts.map +1 -1
  464. package/dist/engine/pipeline/intent_expander/privacy_gates.js +94 -21
  465. package/dist/engine/pipeline/intent_expander/privacy_gates.js.map +1 -1
  466. package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts +37 -3
  467. package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts.map +1 -1
  468. package/dist/engine/pipeline/intent_expander/scope_acceptance.js +1 -1
  469. package/dist/engine/pipeline/intent_expander/scope_acceptance.js.map +1 -1
  470. package/dist/engine/pipeline/intent_expander/templates.d.ts +2 -1
  471. package/dist/engine/pipeline/intent_expander/templates.d.ts.map +1 -1
  472. package/dist/engine/pipeline/intent_expander/templates.js.map +1 -1
  473. package/dist/engine/pipeline/intent_expander/types.d.ts +35 -5
  474. package/dist/engine/pipeline/intent_expander/types.d.ts.map +1 -1
  475. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts +4 -3
  476. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts.map +1 -1
  477. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js +1 -1
  478. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js.map +1 -1
  479. package/dist/engine/pipeline/intent_expander.d.ts +2 -2
  480. package/dist/engine/pipeline/intent_expander.js +6 -6
  481. package/dist/engine/pipeline/intent_expander.js.map +1 -1
  482. package/dist/engine/pipeline/intent_route_scorer.d.ts +2 -2
  483. package/dist/engine/pipeline/intent_route_scorer.d.ts.map +1 -1
  484. package/dist/engine/pipeline/intent_route_scorer.js +3 -3
  485. package/dist/engine/pipeline/intent_route_scorer.js.map +1 -1
  486. package/dist/engine/pipeline/intent_router.d.ts +4 -5
  487. package/dist/engine/pipeline/intent_router.d.ts.map +1 -1
  488. package/dist/engine/pipeline/intent_router.js +64 -112
  489. package/dist/engine/pipeline/intent_router.js.map +1 -1
  490. package/dist/engine/pipeline/intent_signal_extractor.d.ts +18 -0
  491. package/dist/engine/pipeline/intent_signal_extractor.d.ts.map +1 -1
  492. package/dist/engine/pipeline/intent_signal_extractor.js +8 -8
  493. package/dist/engine/pipeline/intent_signal_extractor.js.map +1 -1
  494. package/dist/engine/pipeline/job_manager.d.ts.map +1 -1
  495. package/dist/engine/pipeline/job_manager.js +18 -4
  496. package/dist/engine/pipeline/job_manager.js.map +1 -1
  497. package/dist/engine/pipeline/plan_proposal_gate.d.ts.map +1 -1
  498. package/dist/engine/pipeline/plan_proposal_gate.js +0 -1
  499. package/dist/engine/pipeline/plan_proposal_gate.js.map +1 -1
  500. package/dist/engine/pipeline/route_types.d.ts +10 -0
  501. package/dist/engine/pipeline/route_types.d.ts.map +1 -0
  502. package/dist/engine/pipeline/route_types.js +9 -0
  503. package/dist/engine/pipeline/route_types.js.map +1 -0
  504. package/dist/engine/pipeline/scope_controller.d.ts +1 -1
  505. package/dist/engine/pipeline/scope_controller.d.ts.map +1 -1
  506. package/dist/engine/pipeline/scope_controller.js +18 -17
  507. package/dist/engine/pipeline/scope_controller.js.map +1 -1
  508. package/dist/engine/pipeline/scope_lease.d.ts.map +1 -1
  509. package/dist/engine/pipeline/scope_lease.js +3 -1
  510. package/dist/engine/pipeline/scope_lease.js.map +1 -1
  511. package/dist/engine/pipeline/slice_executor.d.ts +1 -1
  512. package/dist/engine/pipeline/slice_executor.d.ts.map +1 -1
  513. package/dist/engine/pipeline/slice_executor.js +1 -1
  514. package/dist/engine/pipeline/slice_executor.js.map +1 -1
  515. package/dist/engine/pipeline/stage_gate_engine.d.ts +2 -0
  516. package/dist/engine/pipeline/stage_gate_engine.d.ts.map +1 -1
  517. package/dist/engine/pipeline/stage_gate_engine.js +9 -3
  518. package/dist/engine/pipeline/stage_gate_engine.js.map +1 -1
  519. package/dist/engine/pipeline/stale_current_task_detector.d.ts.map +1 -1
  520. package/dist/engine/pipeline/stale_current_task_detector.js +8 -5
  521. package/dist/engine/pipeline/stale_current_task_detector.js.map +1 -1
  522. package/dist/engine/pipeline/task_context/cleanup.d.ts.map +1 -1
  523. package/dist/engine/pipeline/task_context/cleanup.js +4 -1
  524. package/dist/engine/pipeline/task_context/cleanup.js.map +1 -1
  525. package/dist/engine/pipeline/task_context/expansion_privacy.d.ts +1 -3
  526. package/dist/engine/pipeline/task_context/expansion_privacy.d.ts.map +1 -1
  527. package/dist/engine/pipeline/task_context/expansion_privacy.js +1 -1
  528. package/dist/engine/pipeline/task_context/expansion_privacy.js.map +1 -1
  529. package/dist/engine/pipeline/task_context/manager.d.ts +4 -4
  530. package/dist/engine/pipeline/task_context/manager.d.ts.map +1 -1
  531. package/dist/engine/pipeline/task_context/manager.js +25 -13
  532. package/dist/engine/pipeline/task_context/manager.js.map +1 -1
  533. package/dist/engine/pipeline/task_context/manager_setters.d.ts +3 -3
  534. package/dist/engine/pipeline/task_context/manager_setters.d.ts.map +1 -1
  535. package/dist/engine/pipeline/task_context/manager_setters.js.map +1 -1
  536. package/dist/engine/pipeline/task_context/status_transitions.d.ts.map +1 -1
  537. package/dist/engine/pipeline/task_context/status_transitions.js +4 -3
  538. package/dist/engine/pipeline/task_context/status_transitions.js.map +1 -1
  539. package/dist/engine/pipeline/task_planner.js +3 -4
  540. package/dist/engine/pipeline/task_planner.js.map +1 -1
  541. package/dist/engine/pipeline/workspace_lease.d.ts +10 -1
  542. package/dist/engine/pipeline/workspace_lease.d.ts.map +1 -1
  543. package/dist/engine/pipeline/workspace_lease.js +29 -3
  544. package/dist/engine/pipeline/workspace_lease.js.map +1 -1
  545. package/dist/engine/pipeline/workspace_resumer.d.ts.map +1 -1
  546. package/dist/engine/pipeline/workspace_resumer.js +3 -0
  547. package/dist/engine/pipeline/workspace_resumer.js.map +1 -1
  548. package/dist/engine/release/foundation_scenario_registry.d.ts +1 -1
  549. package/dist/engine/release/foundation_scenario_registry.d.ts.map +1 -1
  550. package/dist/engine/release/foundation_scenario_registry.js +3 -2
  551. package/dist/engine/release/foundation_scenario_registry.js.map +1 -1
  552. package/dist/engine/release/foundation_scenario_runners.d.ts.map +1 -1
  553. package/dist/engine/release/foundation_scenario_runners.js +40 -33
  554. package/dist/engine/release/foundation_scenario_runners.js.map +1 -1
  555. package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts +2 -2
  556. package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts.map +1 -1
  557. package/dist/engine/release/gate_checks/checkControlPlaneTrust.js +3 -2
  558. package/dist/engine/release/gate_checks/checkControlPlaneTrust.js.map +1 -1
  559. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.d.ts.map +1 -1
  560. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js +3 -3
  561. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js.map +1 -1
  562. package/dist/engine/release/gate_checks/checkDependencyAudit.d.ts.map +1 -1
  563. package/dist/engine/release/gate_checks/checkDependencyAudit.js +8 -3
  564. package/dist/engine/release/gate_checks/checkDependencyAudit.js.map +1 -1
  565. package/dist/engine/release/gate_checks/checkDistFreshness.d.ts.map +1 -1
  566. package/dist/engine/release/gate_checks/checkDistFreshness.js +4 -2
  567. package/dist/engine/release/gate_checks/checkDistFreshness.js.map +1 -1
  568. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts +1 -1
  569. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts.map +1 -1
  570. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js +1 -1
  571. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js.map +1 -1
  572. package/dist/engine/release/gate_checks/checkMainlineConsumption.js +2 -2
  573. package/dist/engine/release/gate_checks/checkMainlineConsumption.js.map +1 -1
  574. package/dist/engine/release/gate_checks/{check_npm_pack.d.ts → checkNpmPack.d.ts} +1 -1
  575. package/dist/engine/release/gate_checks/checkNpmPack.d.ts.map +1 -0
  576. package/dist/engine/release/gate_checks/{check_npm_pack.js → checkNpmPack.js} +5 -7
  577. package/dist/engine/release/gate_checks/checkNpmPack.js.map +1 -0
  578. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.d.ts.map +1 -1
  579. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js +4 -3
  580. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js.map +1 -1
  581. package/dist/engine/release/gate_checks/checkWorkflowNavigation.d.ts.map +1 -1
  582. package/dist/engine/release/gate_checks/checkWorkflowNavigation.js +58 -4
  583. package/dist/engine/release/gate_checks/checkWorkflowNavigation.js.map +1 -1
  584. package/dist/engine/release/gate_checks/helpers.d.ts.map +1 -1
  585. package/dist/engine/release/gate_checks/helpers.js +2 -1
  586. package/dist/engine/release/gate_checks/helpers.js.map +1 -1
  587. package/dist/engine/release/index.d.ts +6 -0
  588. package/dist/engine/release/index.d.ts.map +1 -0
  589. package/dist/engine/release/index.js +6 -0
  590. package/dist/engine/release/index.js.map +1 -0
  591. package/dist/engine/release/release_gate_scenario_registry.d.ts.map +1 -1
  592. package/dist/engine/release/release_gate_scenario_registry.js.map +1 -1
  593. package/dist/engine/release/release_issue_scenario_registry/registry.d.ts.map +1 -1
  594. package/dist/engine/release/release_issue_scenario_registry/registry.js +4 -1
  595. package/dist/engine/release/release_issue_scenario_registry/registry.js.map +1 -1
  596. package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js +38 -19
  597. package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js.map +1 -1
  598. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.d.ts.map +1 -1
  599. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js +3 -2
  600. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js.map +1 -1
  601. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.d.ts.map +1 -1
  602. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js +50 -26
  603. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js.map +1 -1
  604. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.d.ts.map +1 -1
  605. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js +12 -6
  606. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js.map +1 -1
  607. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.d.ts.map +1 -1
  608. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js +26 -13
  609. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js.map +1 -1
  610. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.d.ts.map +1 -1
  611. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js +14 -8
  612. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js.map +1 -1
  613. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts +12 -0
  614. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts.map +1 -0
  615. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js +147 -0
  616. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js.map +1 -0
  617. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts +24 -40
  618. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts.map +1 -1
  619. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js +12 -6
  620. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js.map +1 -1
  621. package/dist/engine/release/release_readiness_gate.d.ts +3 -1
  622. package/dist/engine/release/release_readiness_gate.d.ts.map +1 -1
  623. package/dist/engine/release/release_readiness_gate.js +47 -4
  624. package/dist/engine/release/release_readiness_gate.js.map +1 -1
  625. package/dist/engine/release/release_tool_harness.d.ts +18 -5
  626. package/dist/engine/release/release_tool_harness.d.ts.map +1 -1
  627. package/dist/engine/release/release_tool_harness.js +15 -7
  628. package/dist/engine/release/release_tool_harness.js.map +1 -1
  629. package/dist/engine/release/types.d.ts +81 -0
  630. package/dist/engine/release/types.d.ts.map +1 -0
  631. package/dist/engine/release/types.js +7 -0
  632. package/dist/engine/release/types.js.map +1 -0
  633. package/dist/engine/release/verifier.d.ts.map +1 -1
  634. package/dist/engine/release/verifier.js +1 -1
  635. package/dist/engine/release/verifier.js.map +1 -1
  636. package/dist/engine/team_awareness.d.ts +1 -1
  637. package/dist/engine/team_awareness.d.ts.map +1 -1
  638. package/dist/engine/team_awareness.js.map +1 -1
  639. package/dist/engine/templates/asset_manifest.d.ts +1 -1
  640. package/dist/engine/templates/asset_manifest.d.ts.map +1 -1
  641. package/dist/engine/templates/asset_manifest.js +1 -2
  642. package/dist/engine/templates/asset_manifest.js.map +1 -1
  643. package/dist/engine/templates/consumption_trace_store.d.ts +2 -1
  644. package/dist/engine/templates/consumption_trace_store.d.ts.map +1 -1
  645. package/dist/engine/templates/consumption_trace_store.js +0 -6
  646. package/dist/engine/templates/consumption_trace_store.js.map +1 -1
  647. package/dist/engine/templates/explicit_asset_registry/index.js +14 -14
  648. package/dist/engine/templates/explicit_asset_registry/index.js.map +1 -1
  649. package/dist/engine/templates/observed_consumption.d.ts.map +1 -1
  650. package/dist/engine/templates/observed_consumption.js +1 -1
  651. package/dist/engine/templates/observed_consumption.js.map +1 -1
  652. package/dist/engine/templates/scaffolder.js +2 -2
  653. package/dist/engine/templates/scaffolder.js.map +1 -1
  654. package/dist/engine/templates/standard_asset_coverage.js +1 -1
  655. package/dist/engine/templates/standard_asset_coverage.js.map +1 -1
  656. package/dist/engine/templates/template_asset_contract_registry.d.ts +1 -1
  657. package/dist/engine/templates/template_asset_contract_registry.d.ts.map +1 -1
  658. package/dist/engine/templates/template_asset_contract_registry.js +1 -2
  659. package/dist/engine/templates/template_asset_contract_registry.js.map +1 -1
  660. package/dist/engine/templates/template_asset_visibility.js +0 -17
  661. package/dist/engine/templates/template_asset_visibility.js.map +1 -1
  662. package/dist/engine/templates/template_init_sync.d.ts.map +1 -1
  663. package/dist/engine/templates/template_init_sync.js +9 -11
  664. package/dist/engine/templates/template_init_sync.js.map +1 -1
  665. package/dist/engine/templates/template_manifest_io.d.ts.map +1 -1
  666. package/dist/engine/templates/template_manifest_io.js +3 -2
  667. package/dist/engine/templates/template_manifest_io.js.map +1 -1
  668. package/dist/engine/templates/template_sync.d.ts.map +1 -1
  669. package/dist/engine/templates/template_sync.js.map +1 -1
  670. package/dist/engine/templates/workflow_rule_generator.d.ts +1 -1
  671. package/dist/engine/templates/workflow_rule_generator.d.ts.map +1 -1
  672. package/dist/engine/templates/workflow_rule_generator.js +1 -1
  673. package/dist/engine/templates/workflow_rule_generator.js.map +1 -1
  674. package/dist/engine/workflow/index.d.ts +10 -0
  675. package/dist/engine/workflow/index.d.ts.map +1 -0
  676. package/dist/engine/workflow/index.js +12 -0
  677. package/dist/engine/workflow/index.js.map +1 -0
  678. package/dist/engine/workflow/legacy_type_migration.d.ts +4 -3
  679. package/dist/engine/workflow/legacy_type_migration.d.ts.map +1 -1
  680. package/dist/engine/workflow/legacy_type_migration.js +6 -5
  681. package/dist/engine/workflow/legacy_type_migration.js.map +1 -1
  682. package/dist/engine/workflow/next_action_planner.d.ts +2 -2
  683. package/dist/engine/workflow/next_action_planner.d.ts.map +1 -1
  684. package/dist/engine/workflow/next_action_planner.js +70 -21
  685. package/dist/engine/workflow/next_action_planner.js.map +1 -1
  686. package/dist/engine/workflow/project_stage_detector.d.ts.map +1 -1
  687. package/dist/engine/workflow/project_stage_detector.js +28 -13
  688. package/dist/engine/workflow/project_stage_detector.js.map +1 -1
  689. package/dist/engine/workflow/workflow_navigation_contract.d.ts +8 -1
  690. package/dist/engine/workflow/workflow_navigation_contract.d.ts.map +1 -1
  691. package/dist/engine/workflow/workflow_navigation_contract.js +0 -1
  692. package/dist/engine/workflow/workflow_navigation_contract.js.map +1 -1
  693. package/dist/{engine/core → git}/git_deps.d.ts +3 -1
  694. package/dist/git/git_deps.d.ts.map +1 -0
  695. package/dist/{engine/core → git}/git_deps.js +2 -2
  696. package/dist/git/git_deps.js.map +1 -0
  697. package/dist/index.js +6 -2
  698. package/dist/index.js.map +1 -1
  699. package/dist/knowledge/conflict_detector.d.ts +14 -0
  700. package/dist/knowledge/conflict_detector.d.ts.map +1 -1
  701. package/dist/knowledge/conflict_detector.js +67 -0
  702. package/dist/knowledge/conflict_detector.js.map +1 -1
  703. package/dist/knowledge/health_checker.d.ts.map +1 -1
  704. package/dist/knowledge/health_checker.js +17 -8
  705. package/dist/knowledge/health_checker.js.map +1 -1
  706. package/dist/knowledge/index_manager.d.ts +3 -0
  707. package/dist/knowledge/index_manager.d.ts.map +1 -1
  708. package/dist/knowledge/index_manager.js +82 -40
  709. package/dist/knowledge/index_manager.js.map +1 -1
  710. package/dist/knowledge/loader.d.ts.map +1 -1
  711. package/dist/knowledge/loader.js +14 -5
  712. package/dist/knowledge/loader.js.map +1 -1
  713. package/dist/knowledge/writer.d.ts.map +1 -1
  714. package/dist/knowledge/writer.js +2 -1
  715. package/dist/knowledge/writer.js.map +1 -1
  716. package/dist/server/index.d.ts +2 -2
  717. package/dist/server/index.d.ts.map +1 -1
  718. package/dist/server/index.js +14 -18
  719. package/dist/server/index.js.map +1 -1
  720. package/dist/server/lifecycle.d.ts +4 -2
  721. package/dist/server/lifecycle.d.ts.map +1 -1
  722. package/dist/server/lifecycle.js +6 -11
  723. package/dist/server/lifecycle.js.map +1 -1
  724. package/dist/server/tools/cep_assessment.d.ts.map +1 -1
  725. package/dist/server/tools/cep_assessment.js +6 -6
  726. package/dist/server/tools/cep_assessment.js.map +1 -1
  727. package/dist/server/tools/gate_checks.d.ts +4 -2
  728. package/dist/server/tools/gate_checks.d.ts.map +1 -1
  729. package/dist/server/tools/gate_checks.js.map +1 -1
  730. package/dist/server/tools/index.d.ts.map +1 -1
  731. package/dist/server/tools/index.js +37 -1
  732. package/dist/server/tools/index.js.map +1 -1
  733. package/dist/server/tools/lazy_loaders.d.ts +1 -1
  734. package/dist/server/tools/lazy_loaders.d.ts.map +1 -1
  735. package/dist/server/tools/lazy_loaders.js +2 -2
  736. package/dist/server/tools/lazy_loaders.js.map +1 -1
  737. package/dist/server/tools/middleware.d.ts +22 -2
  738. package/dist/server/tools/middleware.d.ts.map +1 -1
  739. package/dist/server/tools/middleware.js +55 -22
  740. package/dist/server/tools/middleware.js.map +1 -1
  741. package/dist/server/tools/schemas.d.ts +2 -2
  742. package/dist/server/tools/tool_groups/admin.d.ts.map +1 -1
  743. package/dist/server/tools/tool_groups/admin.js +5 -4
  744. package/dist/server/tools/tool_groups/admin.js.map +1 -1
  745. package/dist/server/tools/tool_groups/auxiliary.js +4 -4
  746. package/dist/server/tools/tool_groups/auxiliary.js.map +1 -1
  747. package/dist/server/tools/tool_groups/classify_expand.d.ts.map +1 -1
  748. package/dist/server/tools/tool_groups/classify_expand.js +4 -869
  749. package/dist/server/tools/tool_groups/classify_expand.js.map +1 -1
  750. package/dist/server/tools/tool_groups/classify_handler.d.ts +3 -0
  751. package/dist/server/tools/tool_groups/classify_handler.d.ts.map +1 -0
  752. package/dist/server/tools/tool_groups/classify_handler.js +65 -0
  753. package/dist/server/tools/tool_groups/classify_handler.js.map +1 -0
  754. package/dist/server/tools/tool_groups/expand_handler.d.ts +3 -0
  755. package/dist/server/tools/tool_groups/expand_handler.d.ts.map +1 -0
  756. package/dist/server/tools/tool_groups/expand_handler.js +819 -0
  757. package/dist/server/tools/tool_groups/expand_handler.js.map +1 -0
  758. package/dist/server/tools/tool_groups/knowledge.js +2 -2
  759. package/dist/server/tools/tool_groups/knowledge.js.map +1 -1
  760. package/dist/server/tools/tool_groups/scaffold_accept_deliver.js +1 -1
  761. package/dist/server/tools/tool_groups/scaffold_accept_deliver.js.map +1 -1
  762. package/dist/server/tools/tool_groups/status_plan_analyze_review.js +5 -5
  763. package/dist/server/tools/tool_groups/status_plan_analyze_review.js.map +1 -1
  764. package/dist/server/tools/tool_groups/verify_learn.d.ts.map +1 -1
  765. package/dist/server/tools/tool_groups/verify_learn.js +6 -11
  766. package/dist/server/tools/tool_groups/verify_learn.js.map +1 -1
  767. package/dist/server/tools/tool_names.d.ts +55 -0
  768. package/dist/server/tools/tool_names.d.ts.map +1 -0
  769. package/dist/server/tools/tool_names.js +62 -0
  770. package/dist/server/tools/tool_names.js.map +1 -0
  771. package/dist/server/tools/utils.d.ts.map +1 -1
  772. package/dist/server/tools/utils.js +5 -11
  773. package/dist/server/tools/utils.js.map +1 -1
  774. package/dist/types/base.d.ts +2 -0
  775. package/dist/types/base.d.ts.map +1 -1
  776. package/dist/types/config.d.ts +2 -0
  777. package/dist/types/config.d.ts.map +1 -1
  778. package/dist/types/delivery.d.ts +44 -1
  779. package/dist/types/delivery.d.ts.map +1 -1
  780. package/dist/types/knowledge.d.ts +3 -1
  781. package/dist/types/knowledge.d.ts.map +1 -1
  782. package/dist/types/knowledge.js.map +1 -1
  783. package/dist/types/pipeline.d.ts +151 -14
  784. package/dist/types/pipeline.d.ts.map +1 -1
  785. package/dist/types/task.d.ts +103 -38
  786. package/dist/types/task.d.ts.map +1 -1
  787. package/package.json +7 -3
  788. package/templates/internal/rules//351/205/215/347/275/256/344/274/230/345/205/210/347/272/247/350/247/204/345/210/231.md +11 -1
  789. package/dist/engine/audit/audit_verifier.d.ts +0 -52
  790. package/dist/engine/audit/audit_verifier.d.ts.map +0 -1
  791. package/dist/engine/audit/audit_verifier.js +0 -101
  792. package/dist/engine/audit/audit_verifier.js.map +0 -1
  793. package/dist/engine/contracts/policy_drift_detector.d.ts +0 -72
  794. package/dist/engine/contracts/policy_drift_detector.d.ts.map +0 -1
  795. package/dist/engine/contracts/policy_drift_detector.js +0 -277
  796. package/dist/engine/contracts/policy_drift_detector.js.map +0 -1
  797. package/dist/engine/core/git_deps.d.ts.map +0 -1
  798. package/dist/engine/core/git_deps.js.map +0 -1
  799. package/dist/engine/release/gate_checks/check_npm_pack.d.ts.map +0 -1
  800. package/dist/engine/release/gate_checks/check_npm_pack.js.map +0 -1
  801. package/dist/engine/state_update_bypass.d.ts +0 -19
  802. package/dist/engine/state_update_bypass.d.ts.map +0 -1
  803. package/dist/engine/state_update_bypass.js +0 -17
  804. package/dist/engine/state_update_bypass.js.map +0 -1
@@ -0,0 +1,819 @@
1
+ // ── sf_expand 工具处理器 ──
2
+ // 从 classify_expand.ts 第 116-965 行提取。
3
+ // 系统中最复杂的工具处理器集合。
4
+ import path from "node:path";
5
+ import { promises as fsp } from "node:fs";
6
+ import { createToolRegistrar } from "../middleware.js";
7
+ import { ExpandSchema } from "../schemas.js";
8
+ import { lazyExpander, lazyDesignArtifactPack, lazyDecisionWorkshop, lazyOodSolid, lazyBackendImplementation, lazyCodeObservability, lazyTraceability, lazyInputMaterial, lazyDecision, } from "../lazy_loaders.js";
9
+ import { parseContractObject, CONTRACT_OBJECT_FIELDS, hasArchitectureIntentSignal, } from "../utils.js";
10
+ import { checkArchitectureDecisionWorkshopGate, checkArchitectureDesignGate, checkExistingSystemAnalysisGate, } from "../gate_checks.js";
11
+ import { checkDecisionSovereigntyGate, checkDetailDisciplineGate, checkFirstPrinciplesGate, checkBrainstormGate, } from "../cep_assessment.js";
12
+ import { TOOL_DIAGNOSTIC_CODES } from "../../../engine/audit/diagnostic_registry.js";
13
+ import { normalizePathCandidate } from "../../../engine/pipeline/input_material_extractor.js";
14
+ import { isSameOrDescendantPath } from "../../../engine/core/path_scope_utils.js";
15
+ import { errorMessage } from "../../../engine/core/helpers.js";
16
+ export async function registerExpandTool(ctx) {
17
+ const { registerSafeTool } = createToolRegistrar(ctx);
18
+ const { taskContext, config, knowledgeIndex, projectPath, gateway, ioController } = ctx;
19
+ // ── sf_expand: 意图膨胀,生成结构化 prompt 并注入计划上下文 ──
20
+ registerSafeTool("sf_expand", "将意图膨胀为结构化 prompt,包含 scope、验收标准和知识匹配。当存在计划时自动注入当前阶段上下文和输出模板", ExpandSchema, async (args) => {
21
+ const ctx = await taskContext.load(args.task_id);
22
+ if (!ctx || !ctx.classification) {
23
+ return { result: { error: "任务不存在或尚未分类,请先调用 sf_classify" } };
24
+ }
25
+ // 合并校验 + 应用:ctx 已存储值 → args 覆盖值,统一解析和规范化
26
+ let needsSave = false;
27
+ for (const field of CONTRACT_OBJECT_FIELDS) {
28
+ // args 优先,其次 ctx 已存储值
29
+ const raw = args[field] ?? ctx[field];
30
+ if (!raw)
31
+ continue;
32
+ const parsed = parseContractObject(raw, field);
33
+ if (parsed.error)
34
+ return { result: { error: parsed.error, status: "invalid_input" } };
35
+ if (parsed.value) {
36
+ ctx[field] = field === "decision_workshop"
37
+ ? ((await lazyDecisionWorkshop()).normalizeDecisionWorkshopContract(parsed.value, args.task_id) ?? parsed.value)
38
+ : parsed.value;
39
+ needsSave = true;
40
+ }
41
+ }
42
+ if (needsSave)
43
+ await taskContext.save(ctx);
44
+ // 状态守卫:classifying/expanding/clarifying/failed → expanding
45
+ if (ctx.status === "classifying" || ctx.status === "clarifying" || ctx.status === "failed") {
46
+ await taskContext.updateStatus(args.task_id, "expanding");
47
+ ctx.status = "expanding";
48
+ }
49
+ else if (ctx.status !== "expanding") {
50
+ return {
51
+ result: { error: `任务状态 ${ctx.status} 不可膨胀,需要 classifying 或 expanding`, status: ctx.status },
52
+ };
53
+ }
54
+ // 构建计划上下文(如果存在计划)
55
+ let planContext;
56
+ if (ctx.planning && ctx.planning.sub_tasks.length > 0 && ctx.planning.current_step_index < ctx.planning.sub_tasks.length) {
57
+ const currentStep = ctx.planning.sub_tasks[ctx.planning.current_step_index];
58
+ const previousOutputs = {};
59
+ // 读取前序步骤的产出文件(P3: 产物系统)
60
+ for (let i = 0; i < ctx.planning.current_step_index; i++) {
61
+ const step = ctx.planning.sub_tasks[i];
62
+ if (step.output_path) {
63
+ try {
64
+ const fs = await import("node:fs/promises");
65
+ const content = await fs.readFile(step.output_path, "utf-8");
66
+ previousOutputs[step.title] = content;
67
+ }
68
+ catch {
69
+ // 文件不存在则跳过
70
+ }
71
+ }
72
+ }
73
+ planContext = { current_step: currentStep, previous_outputs: previousOutputs };
74
+ }
75
+ // H1: Token 预算检查 — advisory 模式,仅警告不阻断
76
+ gateway.beginTask(args.task_id);
77
+ let h1Warning;
78
+ try {
79
+ const gateResult = gateway.request("solution_brainstorm");
80
+ if (!gateResult.allowed) {
81
+ h1Warning = { warning: `H1 advisory: ${gateResult.reason}`, budget_remaining: gateResult.remaining_budget };
82
+ }
83
+ }
84
+ catch (e) {
85
+ h1Warning = { warning: `H1 advisory: ${errorMessage(e)}`, budget_remaining: 0 };
86
+ }
87
+ // H4: advisory-only — 不获取持久锁,仅检查当前锁定状态
88
+ let h4LockWarning;
89
+ const lockStatus = await ioController.isLocked();
90
+ if (lockStatus.locked && lockStatus.task_id !== args.task_id) {
91
+ h4LockWarning = `H4 advisory: 工作区已被任务 ${lockStatus.task_id} 锁定(${lockStatus.reason ?? "未知"}),当前 H4 未进入强制层`;
92
+ }
93
+ let expansion;
94
+ try {
95
+ expansion = await (await lazyExpander()).expand({
96
+ intent: ctx.intent,
97
+ classification: ctx.classification,
98
+ projectPath,
99
+ config,
100
+ knowledgeIndex,
101
+ clarificationAnswers: args.clarification_answers,
102
+ route_decision: ctx.classification?.route_decision,
103
+ plan_context: planContext,
104
+ input_material_confirmations: args.input_material_confirmations,
105
+ task_id: args.task_id,
106
+ brainstorm_session: ctx.brainstorm_session ?? undefined,
107
+ });
108
+ }
109
+ catch (expandErr) {
110
+ // 尝试回退到 failed 状态,避免任务停留在 expanding
111
+ try {
112
+ await taskContext.updateStatus(args.task_id, "failed");
113
+ }
114
+ catch {
115
+ // 状态转换非法(如已非 expanding),忽略
116
+ }
117
+ throw expandErr;
118
+ }
119
+ finally {
120
+ if (!h1Warning)
121
+ gateway.completeOperation();
122
+ gateway.endTask();
123
+ }
124
+ expansion.task_id = args.task_id;
125
+ const projectRoot = await fsp.realpath(projectPath);
126
+ const referencedMaterialPaths = new Set((expansion.input_materials ?? [])
127
+ .map((material) => material.path_or_ref)
128
+ .filter((materialPath) => typeof materialPath === "string" && materialPath.length > 0)
129
+ .map((materialPath) => path.resolve(projectRoot, normalizePathCandidate(materialPath))));
130
+ const _confirmedCandidates = (args.input_material_confirmations ?? [])
131
+ .map((materialPath) => path.resolve(projectRoot, normalizePathCandidate(materialPath)))
132
+ .filter((absolutePath) => isSameOrDescendantPath(absolutePath, projectRoot, { caseSensitive: false }))
133
+ .filter((absolutePath) => referencedMaterialPaths.has(absolutePath));
134
+ const confirmedProjectSourcePaths = [];
135
+ for (const absolutePath of _confirmedCandidates) {
136
+ try {
137
+ if ((await fsp.stat(absolutePath)).isFile()
138
+ && (await fsp.realpath(absolutePath)).startsWith(`${projectRoot}${path.sep}`)) {
139
+ confirmedProjectSourcePaths.push(absolutePath);
140
+ }
141
+ }
142
+ catch {
143
+ // 跳过无效路径
144
+ }
145
+ }
146
+ const registerConfirmedProjectSources = (registry) => {
147
+ for (const absolutePath of confirmedProjectSourcePaths) {
148
+ const sourceRef = path.relative(projectRoot, absolutePath);
149
+ registry.register({
150
+ source_type: "project_file",
151
+ evidence_role: "project_source_file",
152
+ authority: "authoritative",
153
+ freshness: "current",
154
+ permission: "allowed",
155
+ scope: "confirmed_input_material",
156
+ description: `已确认项目输入材料: ${sourceRef}`,
157
+ source_ref: sourceRef,
158
+ });
159
+ }
160
+ };
161
+ const workflowIntent = ctx.route_decision?.workflow_intent ?? ctx.classification.route_decision?.workflow_intent;
162
+ // 问题六十: 高风险项目事实声明先过证据门,避免后续架构研讨门遮蔽无证据问题。
163
+ let evidenceGateAlreadyChecked = false;
164
+ {
165
+ const evRoute = ctx.route_decision?.route ?? ctx.classification?.route_decision?.route;
166
+ const evWorkflowIntent = ctx.route_decision?.workflow_intent ?? ctx.classification?.route_decision?.workflow_intent;
167
+ const evRisk = (await import("../../../engine/contracts/evidence_grounding_contract.js")).assessTaskRisk(ctx.classification?.task_type, evRoute, ctx.intent);
168
+ const isArchitectureContext = evWorkflowIntent === "architecture_design"
169
+ || evWorkflowIntent === "existing_system_gap_analysis"
170
+ || evRoute === "artifact_generation"
171
+ || hasArchitectureIntentSignal(ctx.intent);
172
+ if (isArchitectureContext && (evRisk === "high" || evRisk === "critical")) {
173
+ const { createEvidenceGroundingSystem } = await import("../../../engine/contracts/evidence_grounding_contract.js");
174
+ const evg = createEvidenceGroundingSystem();
175
+ evg.registry.register({
176
+ source_type: "task_context",
177
+ evidence_role: "classification",
178
+ authority: "authoritative",
179
+ freshness: "current",
180
+ permission: "allowed",
181
+ scope: "classification",
182
+ description: "任务分类结果",
183
+ source_ref: `task:${args.task_id}`,
184
+ });
185
+ if (knowledgeIndex) {
186
+ const { project } = knowledgeIndex.getAllEntries();
187
+ for (const entry of project) {
188
+ if (entry.status !== "active")
189
+ continue;
190
+ evg.registry.register({
191
+ source_type: "knowledge_asset",
192
+ evidence_role: "template_guidance",
193
+ authority: "trusted",
194
+ freshness: "current",
195
+ permission: "allowed",
196
+ scope: entry.scope?.join(",") ?? "knowledge",
197
+ description: entry.name,
198
+ source_ref: entry.file_path,
199
+ });
200
+ }
201
+ }
202
+ const tdc = ctx.technology_decision_contract;
203
+ if (tdc?.human_gate_evidence) {
204
+ evg.registry.register({
205
+ source_type: "user_confirmation",
206
+ evidence_role: "user_confirmation",
207
+ authority: "authoritative",
208
+ freshness: "current",
209
+ permission: "allowed",
210
+ scope: "technology_decision",
211
+ description: `技术决策确认: ${tdc.decision_scope ?? "general"}`,
212
+ source_ref: `decision:${tdc.decision_id ?? args.task_id}`,
213
+ });
214
+ }
215
+ registerConfirmedProjectSources(evg.registry);
216
+ const evClaims = [
217
+ {
218
+ id: "claim-expand-0",
219
+ category: "user_confirmation",
220
+ claim_text: "任务路由和执行范围已确认",
221
+ evidence_ids: evg.registry.query({ source_type: "task_context" }).map((e) => e.id),
222
+ is_uncertain: false,
223
+ risk_level: evRisk,
224
+ },
225
+ {
226
+ id: "claim-expand-1",
227
+ category: "architecture",
228
+ claim_text: "技术方案基于现有系统分析",
229
+ evidence_ids: evg.registry.query({}).filter((e) => e.evidence_role && e.evidence_role !== "template_guidance" && e.evidence_role !== "classification").map((e) => e.id),
230
+ is_uncertain: false,
231
+ risk_level: evRisk,
232
+ },
233
+ ];
234
+ const evMatrix = evg.builder.buildContext(evClaims, {
235
+ target_claims: evClaims.map((c) => c.claim_text),
236
+ source_types: [],
237
+ keywords: [],
238
+ max_results: 10,
239
+ });
240
+ evMatrix.task_id = args.task_id;
241
+ const evGate = evg.gate.evaluate(evMatrix, evRisk);
242
+ await taskContext.setEvidenceGroundingResult(args.task_id, {
243
+ evidence_matrix: evMatrix,
244
+ evidence_gate_result: evGate,
245
+ unsupported_claims: evGate.unsupported_claims,
246
+ conflict_resolutions: evMatrix.conflicts,
247
+ });
248
+ if (!evGate.allowed) {
249
+ return {
250
+ result: {
251
+ error: `证据驱动门禁阻断: ${evGate.reason_zh}`,
252
+ diagnostic_code: evGate.diagnostic_code,
253
+ reason_zh: evGate.reason_zh,
254
+ unsupported_claims: evGate.unsupported_claims,
255
+ missing_evidence: evGate.missing_evidence,
256
+ status: "blocked",
257
+ recovery: "请提供项目文件、命令输出或其他权威证据支撑关键声明后重新 sf_expand",
258
+ },
259
+ };
260
+ }
261
+ evidenceGateAlreadyChecked = true;
262
+ }
263
+ }
264
+ // 问题六十一: 架构设计前的六域研讨门独立执行,不得被施工指令契约有无绕过。
265
+ let existingSourceRoot = false;
266
+ for (const candidate of ["src", "backend", "frontend", "apps", "services"]) {
267
+ if (await fsp.access(path.join(projectPath, candidate)).then(() => true, () => false)) {
268
+ existingSourceRoot = true;
269
+ break;
270
+ }
271
+ }
272
+ let existingManifest = false;
273
+ for (const candidate of ["package.json", "pom.xml", "build.gradle", "settings.gradle"]) {
274
+ if (await fsp.access(path.join(projectPath, candidate)).then(() => true, () => false)) {
275
+ existingManifest = true;
276
+ break;
277
+ }
278
+ }
279
+ const detectedArchitectureContext = existingSourceRoot && existingManifest
280
+ ? "existing_system"
281
+ : (!existingSourceRoot && !existingManifest ? "empty_project" : "new_system");
282
+ const workshopGate = await checkArchitectureDecisionWorkshopGate({
283
+ ctx,
284
+ workflowIntent,
285
+ projectContext: detectedArchitectureContext,
286
+ });
287
+ await taskContext.save(ctx);
288
+ if (!workshopGate.allowed) {
289
+ return {
290
+ result: {
291
+ error: "架构设计前必须先完成六类架构决策研讨与用户确认",
292
+ status: "awaiting_confirmation",
293
+ architecture_decision_workshop: workshopGate.contract,
294
+ blocking_findings: workshopGate.findings,
295
+ next_domain: workshopGate.next_domain,
296
+ recovery: "请从当前待讨论域开始,提供候选方案、推荐理由、风险和用户确认后重新调用 sf_expand",
297
+ },
298
+ };
299
+ }
300
+ // 六域决策闭合后创建设计产物生命周期;正式设计与后续实现必须以其复验结果为准。
301
+ if (workflowIntent === "architecture_design" && !ctx.design_artifact_pack) {
302
+ const designModule = await lazyDesignArtifactPack();
303
+ ctx.design_artifact_pack = designModule.createDesignArtifactPack(args.task_id);
304
+ ctx.design_artifact_pack.status = "awaiting_decisions";
305
+ ctx.design_artifact_pack.decision_workshop_ref = `task:${args.task_id}:architecture_decision_workshop`;
306
+ ctx.design_artifact_pack.user_confirmation_ref = ctx.architecture_decision_workshop?.document_output_confirmation_ref;
307
+ await taskContext.save(ctx);
308
+ }
309
+ // 问题六十一(通用): 可组合决策包门禁
310
+ const dwModule = await lazyDecisionWorkshop();
311
+ const packMatch = dwModule.matchDecisionPacks({
312
+ workflow_intent: workflowIntent,
313
+ intent: ctx.intent,
314
+ task_type: ctx.classification?.task_type,
315
+ });
316
+ // 过滤掉架构(架构由上面的专用子包处理)
317
+ const nonArchPacks = packMatch.packs.filter((p) => p !== "architecture");
318
+ if (nonArchPacks.length > 0) {
319
+ const dwContract = ctx.decision_workshop ?? dwModule.createDecisionWorkshop(args.task_id, nonArchPacks, detectedArchitectureContext, packMatch.reasons.join(";"));
320
+ const dwGate = dwModule.evaluateDecisionWorkshop(dwContract);
321
+ ctx.decision_workshop = dwModule.applyDecisionWorkshopGate(dwContract);
322
+ await taskContext.save(ctx);
323
+ if (!dwGate.allowed) {
324
+ return {
325
+ result: {
326
+ error: `${packMatch.reasons.join(";")},必须先完成决策研讨与用户确认`,
327
+ status: "awaiting_confirmation",
328
+ decision_workshop: ctx.decision_workshop,
329
+ blocking_findings: dwGate.blocking_findings,
330
+ next_domain: dwGate.next_domain,
331
+ activated_packs: nonArchPacks,
332
+ recovery: "请从当前待讨论域开始,提供候选方案、推荐理由、风险和用户确认后重新调用 sf_expand",
333
+ },
334
+ };
335
+ }
336
+ }
337
+ // 问题四十九/五十: 已有架构合同或现有系统证据的进一步审查。
338
+ const expansionRoute = expansion?.workflow_trace
339
+ ? expansion?.workflow_trace?.route
340
+ : undefined;
341
+ const hasInstructionContract = !!ctx?.instruction_contract;
342
+ if (hasInstructionContract) {
343
+ if (expansionRoute === "artifact_generation" || expansionRoute === "analysis") {
344
+ const archGate = await checkArchitectureDesignGate({ ctx, route: expansionRoute });
345
+ if (!archGate.allowed) {
346
+ return {
347
+ result: {
348
+ error: archGate.reason_zh,
349
+ architecture_gate_findings: archGate.findings,
350
+ status: "blocked",
351
+ recovery: "架构设计审查未通过,请补充缺失项后重新 sf_expand",
352
+ },
353
+ };
354
+ }
355
+ }
356
+ if (expansionRoute === "code_change" || expansionRoute === "artifact_generation") {
357
+ const analysisGate = await checkExistingSystemAnalysisGate({
358
+ hasExistingCode: !!config?.tech_stack,
359
+ hasPackageJson: !!projectPath,
360
+ hasSrcDir: true,
361
+ hasAnalysis: !!ctx.existing_system_analysis,
362
+ hasGapAnalysis: !!ctx.requirement_gap_analysis,
363
+ });
364
+ if (!analysisGate.allowed) {
365
+ return {
366
+ result: {
367
+ error: `现有系统分析门禁未通过: ${analysisGate.reason_zh}`,
368
+ missing_analysis: analysisGate.missing_analysis,
369
+ status: "blocked",
370
+ recovery: "请先对现有项目执行系统分析和差距分析,再继续架构设计或编码",
371
+ },
372
+ };
373
+ }
374
+ }
375
+ }
376
+ // ── S4 gates: 轻量路径(acceptance/review/read_only)整体跳过 ──
377
+ const isLightweightRoute = expansionRoute === "acceptance" || expansionRoute === "review"
378
+ || expansionRoute === "direct_answer" || expansionRoute === "analysis";
379
+ if (!isLightweightRoute) {
380
+ // ── S4 gates: 独立于 hasInstructionContract,由 requires* 触发判定 ──
381
+ // 问题十六: 技术选型决策主权 gate — 高影响技术决策缺证据时 blocked
382
+ {
383
+ const decisionGate = await checkDecisionSovereigntyGate({ ctx, route: expansionRoute });
384
+ if (!decisionGate.allowed) {
385
+ return {
386
+ result: {
387
+ error: decisionGate.reason_zh,
388
+ status: "blocked",
389
+ expected_schema: decisionGate.expected_schema,
390
+ recovery: decisionGate.requires_human_gate ? "请提供技术决策确认证据(human_gate_evidence)" : "技术选型决策校验失败,请按照 expected_schema 格式提供 technology_decision_contract",
391
+ },
392
+ };
393
+ }
394
+ }
395
+ // 问题二十六: 细节纪律 gate — 复杂任务缺关键细节时 blocked
396
+ {
397
+ const detailGate = await checkDetailDisciplineGate({ ctx, route: expansionRoute });
398
+ if (!detailGate.allowed) {
399
+ return {
400
+ result: {
401
+ error: detailGate.reason_zh,
402
+ missing_details: detailGate.missing_details,
403
+ status: "blocked",
404
+ recovery: "多步骤/复杂任务缺 detail_discipline_contract,请提供后重新 sf_expand",
405
+ },
406
+ };
407
+ }
408
+ }
409
+ // 问题二十七: 第一性原理 gate — 高影响任务缺推理时 blocked
410
+ {
411
+ const fpGate = await checkFirstPrinciplesGate({ ctx, route: expansionRoute });
412
+ if (!fpGate.allowed) {
413
+ return {
414
+ result: {
415
+ error: fpGate.reason_zh,
416
+ failures: fpGate.failures,
417
+ expected_schema: fpGate.expected_schema,
418
+ status: "blocked",
419
+ recovery: "高影响任务缺 first_principles_frame,请按照 expected_schema 格式提供后重新 sf_expand",
420
+ },
421
+ };
422
+ }
423
+ }
424
+ // 问题四十二(brainstorm): 脑暴契约 gate — 不确定项缺方案探索时 blocked
425
+ {
426
+ const brainstormGate = await checkBrainstormGate({ ctx, route: expansionRoute });
427
+ if (!brainstormGate.allowed) {
428
+ return {
429
+ result: {
430
+ error: brainstormGate.reason_zh,
431
+ violations: brainstormGate.violations,
432
+ expected_schema: brainstormGate.expected_schema,
433
+ status: "blocked",
434
+ recovery: "不确定项/方案选择缺 brainstorm_session,请按照 expected_schema 格式提供后重新 sf_expand",
435
+ },
436
+ };
437
+ }
438
+ }
439
+ // 问题六十六/六十七/六十八: 编码前工程约束必须聚合返回。
440
+ // 不能让 OOD 或后端工程门禁抢先返回,遮蔽用户项目的注释/日志契约。
441
+ {
442
+ const preImplementationBlocks = [];
443
+ const preImplementationPayload = {};
444
+ const artifactDesignIntent = expansionRoute === "artifact_generation"
445
+ || ["architecture_design", "detailed_design", "database_design", "api_design"].includes(String(workflowIntent))
446
+ || /(?:架构|数据库|API|接口|OpenAPI).{0,12}(?:设计|规格|文档)|(?:设计|规格|文档).{0,12}(?:API|接口|OpenAPI)/i.test(ctx.intent);
447
+ const isImplementationRoute = !artifactDesignIntent && (expansionRoute === "code_change"
448
+ || String(workflowIntent) === "backend_api_implementation"
449
+ || String(workflowIntent) === "frontend_business_logic"
450
+ || /编码|实现|开发|controller|service|component/i.test(ctx.intent));
451
+ const traceabilityModule = await lazyTraceability();
452
+ const traceReport = isImplementationRoute
453
+ ? traceabilityModule.auditDesignImplementationTraceability(projectPath)
454
+ : {
455
+ passed: true,
456
+ matrix_exists: false,
457
+ findings: [],
458
+ checked_files: [],
459
+ matrix_path: traceabilityModule.DEFAULT_DESIGN_IMPLEMENTATION_TRACEABILITY_PATH,
460
+ };
461
+ if (isImplementationRoute && !traceReport.passed) {
462
+ ctx.traceability_binding = {
463
+ requirement_ids: [],
464
+ prototype_ids: [],
465
+ architecture_ids: [],
466
+ detail_design_ids: [],
467
+ phase_ids: [],
468
+ slice_ids: [],
469
+ acceptance_ids: [],
470
+ status: "needs_backfill",
471
+ findings: traceReport.findings.map((finding) => `${finding.code}: ${finding.message_zh}`),
472
+ };
473
+ await taskContext.save(ctx);
474
+ return {
475
+ result: {
476
+ error: "需求/原型/设计/切片/验收追踪链路未闭合,不得进入编码实现",
477
+ status: "blocked",
478
+ diagnostic_code: TOOL_DIAGNOSTIC_CODES.traceabilityMissing,
479
+ traceability_findings: traceReport.findings,
480
+ checked_files: traceReport.checked_files,
481
+ matrix_path: traceReport.matrix_path,
482
+ template_path: traceabilityModule.DESIGN_IMPLEMENTATION_TRACEABILITY_TEMPLATE_PATH,
483
+ recovery_command: traceabilityModule.DESIGN_IMPLEMENTATION_TRACEABILITY_RECOVERY_COMMAND,
484
+ recovery: `${traceabilityModule.DESIGN_IMPLEMENTATION_TRACEABILITY_RECOVERY_GUIDANCE}。不得取消任务后直接写代码,不得改用 Bash 绕过追踪矩阵。`,
485
+ },
486
+ };
487
+ }
488
+ const traceBindingIds = traceabilityModule.extractTraceabilityBindingIds(ctx);
489
+ if (traceReport.matrix_exists && isImplementationRoute) {
490
+ const missingPrefixes = ["PHASE", "SLICE", "DD", "AC"].filter((prefix) => !traceBindingIds.some((id) => id.startsWith(`${prefix}-`)));
491
+ if (missingPrefixes.length > 0) {
492
+ ctx.traceability_binding = {
493
+ requirement_ids: traceBindingIds.filter((id) => id.startsWith("REQ-")),
494
+ prototype_ids: traceBindingIds.filter((id) => id.startsWith("PROTO-")),
495
+ architecture_ids: traceBindingIds.filter((id) => id.startsWith("ARCH-")),
496
+ detail_design_ids: traceBindingIds.filter((id) => id.startsWith("DD-")),
497
+ phase_ids: traceBindingIds.filter((id) => id.startsWith("PHASE-")),
498
+ slice_ids: traceBindingIds.filter((id) => id.startsWith("SLICE-")),
499
+ acceptance_ids: traceBindingIds.filter((id) => id.startsWith("AC-")),
500
+ status: "missing",
501
+ findings: missingPrefixes.map((prefix) => `编码前缺少 ${prefix}-* 绑定`),
502
+ };
503
+ await taskContext.save(ctx);
504
+ return {
505
+ result: {
506
+ error: "编码任务必须先绑定阶段、切片、详细设计和验收 ID",
507
+ status: "awaiting_traceability_binding",
508
+ diagnostic_code: TOOL_DIAGNOSTIC_CODES.traceabilityBindingMissing,
509
+ missing_prefixes: missingPrefixes,
510
+ matrix_path: traceReport.matrix_path,
511
+ template_path: traceabilityModule.DESIGN_IMPLEMENTATION_TRACEABILITY_TEMPLATE_PATH,
512
+ recovery_command: "sf_expand",
513
+ recovery: "在任务上下文或指令中明确本次实现对应的 PHASE-*、SLICE-*、DD-*、AC-*,再重新调用 sf_expand;不得脱离已确认设计直接编码,不得取消任务后改用 Bash/Edit/Write 直接实现",
514
+ },
515
+ };
516
+ }
517
+ ctx.traceability_binding = {
518
+ requirement_ids: traceBindingIds.filter((id) => id.startsWith("REQ-")),
519
+ prototype_ids: traceBindingIds.filter((id) => id.startsWith("PROTO-")),
520
+ architecture_ids: traceBindingIds.filter((id) => id.startsWith("ARCH-")),
521
+ detail_design_ids: traceBindingIds.filter((id) => id.startsWith("DD-")),
522
+ phase_ids: traceBindingIds.filter((id) => id.startsWith("PHASE-")),
523
+ slice_ids: traceBindingIds.filter((id) => id.startsWith("SLICE-")),
524
+ acceptance_ids: traceBindingIds.filter((id) => id.startsWith("AC-")),
525
+ status: "bound",
526
+ findings: [],
527
+ };
528
+ preImplementationPayload.traceability_binding = ctx.traceability_binding;
529
+ }
530
+ const oodModule = await lazyOodSolid();
531
+ const oodGate = oodModule.evaluateOodDesignGate({
532
+ task_id: args.task_id,
533
+ intent: ctx.intent,
534
+ route: expansionRoute,
535
+ summary: ctx.ood_solid_summary,
536
+ });
537
+ if (oodGate.applicable) {
538
+ ctx.ood_solid_summary = oodGate.required_summary;
539
+ preImplementationPayload.ood_solid_summary = oodGate.required_summary;
540
+ }
541
+ if (!oodGate.allowed) {
542
+ preImplementationBlocks.push({
543
+ code: TOOL_DIAGNOSTIC_CODES.oodMissingSummary,
544
+ reason_zh: oodGate.reason_zh,
545
+ });
546
+ }
547
+ const backendModule = await lazyBackendImplementation();
548
+ const backendGate = backendModule.evaluateBackendImplementationGate({
549
+ task_id: args.task_id,
550
+ intent: ctx.intent,
551
+ route: expansionRoute,
552
+ work_package: ctx.backend_implementation_work_package,
553
+ });
554
+ if (backendGate.applicable) {
555
+ ctx.backend_implementation_work_package = backendGate.work_package;
556
+ preImplementationPayload.backend_implementation_work_package = backendGate.work_package;
557
+ }
558
+ if (!backendGate.allowed) {
559
+ preImplementationBlocks.push({
560
+ code: TOOL_DIAGNOSTIC_CODES.backendMissingSummary,
561
+ reason_zh: backendGate.reason_zh,
562
+ });
563
+ }
564
+ if (ctx.classification.task_type !== "scaffold") {
565
+ const obsModule = await lazyCodeObservability();
566
+ const obsGate = obsModule.evaluateCodeObservabilityGate({
567
+ task_id: args.task_id,
568
+ intent: ctx.intent,
569
+ route: expansionRoute,
570
+ changed_files: ctx.execution?.changed_files,
571
+ work_package: ctx.code_observability_work_package,
572
+ });
573
+ if (obsGate.applicable) {
574
+ ctx.code_observability_work_package = obsGate.work_package;
575
+ preImplementationPayload.code_observability_work_package = obsGate.work_package;
576
+ }
577
+ if (!obsGate.allowed) {
578
+ preImplementationBlocks.push({
579
+ code: TOOL_DIAGNOSTIC_CODES.codeObservabilityWorkPackage,
580
+ reason_zh: obsGate.reason_zh,
581
+ });
582
+ }
583
+ }
584
+ if (Object.keys(preImplementationPayload).length > 0) {
585
+ await taskContext.save(ctx);
586
+ }
587
+ if (preImplementationBlocks.length > 0) {
588
+ return {
589
+ result: {
590
+ error: "编码前工程契约未全部确认,不得开始实现",
591
+ status: "awaiting_implementation_contracts",
592
+ diagnostic_codes: preImplementationBlocks.map((b) => b.code),
593
+ blocking_findings: preImplementationBlocks,
594
+ ...preImplementationPayload,
595
+ recovery: "请同时确认 OOD/SOLID、后端工程边界、代码注释与日志契约后重新调用 sf_expand",
596
+ },
597
+ };
598
+ }
599
+ }
600
+ } // end if (!isLightweightRoute) — 轻量路径跳过 S4 gates + 编码前工程约束
601
+ // Input Material Contract: 处理 hard-blocking 结果
602
+ // Privacy Gate: 隐私/敏感信息策略阻断
603
+ const isBlocked = expansion.prompt.startsWith("## 阻塞:输入材料禁止读取")
604
+ || expansion.prompt.startsWith("## 阻塞:隐私/敏感信息策略");
605
+ if (expansion.prompt.startsWith("## 澄清请求") && expansion.input_materials) {
606
+ for (const m of expansion.input_materials) {
607
+ if (m.access_mode !== "forbidden" && (await lazyInputMaterial()).classifyIngestionStatus(m.path_or_ref) === "requires_confirmation") {
608
+ break;
609
+ }
610
+ }
611
+ }
612
+ // 注入 H1/H4 advisory warnings
613
+ const advisories = {};
614
+ if (h1Warning)
615
+ advisories.h1_advisory = h1Warning;
616
+ if (h4LockWarning)
617
+ advisories.h4_advisory = h4LockWarning;
618
+ // 问题六十:证据驱动门禁 — 高风险任务必须阻断无证据声明(跳过已被上方架构早期门禁处理的场景)
619
+ if (!evidenceGateAlreadyChecked) {
620
+ const _evRoute = ctx.route_decision?.route ?? ctx.classification?.route_decision?.route;
621
+ const _evRisk = (await import("../../../engine/contracts/evidence_grounding_contract.js")).assessTaskRisk(ctx.classification?.task_type, _evRoute, ctx.intent);
622
+ if (_evRisk === "high" || _evRisk === "critical") {
623
+ const { createEvidenceGroundingSystem } = await import("../../../engine/contracts/evidence_grounding_contract.js");
624
+ const _evg = createEvidenceGroundingSystem();
625
+ if (ctx.classification) {
626
+ _evg.registry.register({
627
+ source_type: "task_context",
628
+ evidence_role: "classification",
629
+ authority: "authoritative",
630
+ freshness: "current",
631
+ permission: "allowed",
632
+ scope: "classification",
633
+ description: "任务分类结果",
634
+ source_ref: `task:${args.task_id}`,
635
+ });
636
+ }
637
+ // 注册知识索引中的项目知识作为证据(仅项目级,不含全局通用规则)
638
+ // 所有知识索引条目都是 template_guidance 角色,不得支撑项目事实声明
639
+ if (knowledgeIndex) {
640
+ const { project } = knowledgeIndex.getAllEntries();
641
+ for (const entry of project) {
642
+ if (entry.status !== "active")
643
+ continue;
644
+ _evg.registry.register({
645
+ source_type: "knowledge_asset",
646
+ evidence_role: "template_guidance",
647
+ authority: "trusted",
648
+ freshness: "current",
649
+ permission: "allowed",
650
+ scope: entry.scope?.join(",") ?? "knowledge",
651
+ description: entry.name,
652
+ source_ref: entry.file_path,
653
+ });
654
+ }
655
+ }
656
+ // 技术决策契约含 human_gate_evidence → 注册为 user_confirmation(真实项目证据)
657
+ const _tdc = ctx.technology_decision_contract;
658
+ if (_tdc?.human_gate_evidence) {
659
+ _evg.registry.register({
660
+ source_type: "user_confirmation",
661
+ evidence_role: "user_confirmation",
662
+ authority: "authoritative",
663
+ freshness: "current",
664
+ permission: "allowed",
665
+ scope: "technology_decision",
666
+ description: `技术决策确认: ${_tdc.decision_scope ?? "general"}`,
667
+ source_ref: `decision:${_tdc.decision_id ?? args.task_id}`,
668
+ });
669
+ }
670
+ registerConfirmedProjectSources(_evg.registry);
671
+ const _evClaims = [
672
+ {
673
+ id: "claim-expand-0",
674
+ category: "user_confirmation",
675
+ claim_text: "任务路由和执行范围已确认",
676
+ evidence_ids: _evg.registry.query({ source_type: "task_context" }).map((e) => e.id),
677
+ is_uncertain: false,
678
+ risk_level: _evRisk,
679
+ },
680
+ ];
681
+ // 只在架构设计/现有系统分析场景生成 architecture claim
682
+ const _evWorkflowIntent = ctx.route_decision?.workflow_intent ?? ctx.classification?.route_decision?.workflow_intent;
683
+ const _isArchitectureContext = _evWorkflowIntent === "architecture_design"
684
+ || _evWorkflowIntent === "existing_system_gap_analysis"
685
+ || _evRoute === "artifact_generation"
686
+ || hasArchitectureIntentSignal(ctx.intent);
687
+ if (_isArchitectureContext) {
688
+ _evClaims.push({
689
+ id: "claim-expand-1",
690
+ category: "architecture",
691
+ claim_text: "技术方案基于现有系统分析",
692
+ evidence_ids: _evg.registry.query({}).filter((e) => e.evidence_role && e.evidence_role !== "template_guidance" && e.evidence_role !== "classification").map((e) => e.id),
693
+ is_uncertain: false,
694
+ risk_level: _evRisk,
695
+ });
696
+ }
697
+ const _evMatrix = _evg.builder.buildContext(_evClaims, {
698
+ target_claims: _evClaims.map((c) => c.claim_text),
699
+ source_types: [], keywords: [], max_results: 10,
700
+ });
701
+ _evMatrix.task_id = args.task_id;
702
+ const _evGate = _evg.gate.evaluate(_evMatrix, _evRisk);
703
+ // 写回 TaskContext(blocked 也保存)
704
+ await taskContext.setEvidenceGroundingResult(args.task_id, {
705
+ evidence_matrix: _evMatrix,
706
+ evidence_gate_result: _evGate,
707
+ unsupported_claims: _evGate.unsupported_claims,
708
+ conflict_resolutions: _evMatrix.conflicts,
709
+ });
710
+ if (!_evGate.allowed) {
711
+ return {
712
+ result: {
713
+ error: `证据驱动门禁阻断: ${_evGate.reason_zh}`,
714
+ diagnostic_code: _evGate.diagnostic_code,
715
+ reason_zh: _evGate.reason_zh,
716
+ unsupported_claims: _evGate.unsupported_claims,
717
+ missing_evidence: _evGate.missing_evidence,
718
+ status: "blocked",
719
+ recovery: "请提供项目文件、命令输出或其他权威证据支撑关键声明后重新 sf_expand",
720
+ },
721
+ };
722
+ }
723
+ if (_evGate.requires_user_confirmation.length > 0) {
724
+ advisories.evidence_advisory = {
725
+ level: "requires_confirmation",
726
+ items: _evGate.requires_user_confirmation,
727
+ diagnostic_code: _evGate.diagnostic_code,
728
+ };
729
+ }
730
+ }
731
+ else {
732
+ // 低风险通用问答:标注为通用建议
733
+ advisories.evidence_advisory = "通用建议,非项目事实;证据驱动门禁低风险放行";
734
+ }
735
+ } // end if (!evidenceGateAlreadyChecked)
736
+ // 配置优先级警告
737
+ if (expansion.config_resolution_reports && expansion.config_resolution_reports.length > 0) {
738
+ const configWarnings = expansion.config_resolution_reports
739
+ .filter(r => r.conflicts.length > 0)
740
+ .map(r => r.conflicts.map(c => `${c.reason}`).join("; "));
741
+ if (configWarnings.length > 0) {
742
+ advisories.config_precedence_warnings = configWarnings;
743
+ }
744
+ }
745
+ // 决策契约 advisory: 校验 expand 输出是否包含默认决策字段
746
+ const decisionContract = (await lazyDecision()).validateDecisionOutput(expansion);
747
+ if (!decisionContract.passed) {
748
+ advisories.decision_contract_advisory = decisionContract.advisory;
749
+ }
750
+ // 统一持久化:load 一次,所有修改共享同一个 ctx,最后 save 一次
751
+ // 避免 setExpansion/updateStatus/setPlanProposalGate 各自 load-save 互相覆盖
752
+ try {
753
+ const freshCtx = await taskContext.load(args.task_id);
754
+ if (freshCtx) {
755
+ // 1. 写入 expansion
756
+ await taskContext.setExpansion(args.task_id, expansion, freshCtx);
757
+ // 2. 写入 artifact(共享同一 ctx,不会重新 load)
758
+ if (expansion.output_artifact_record) {
759
+ await taskContext.setArtifact(args.task_id, expansion.output_artifact_record, freshCtx);
760
+ }
761
+ // 3. 状态转换(共享 ctx,校验通过后 save)
762
+ const nextStatus = isBlocked ? "failed"
763
+ : expansion.prompt.startsWith("## 澄清请求") ? "clarifying"
764
+ : "executing";
765
+ await taskContext.updateStatus(args.task_id, nextStatus, freshCtx);
766
+ // 4. 设置 plan_proposal_gate(共享 ctx,最后一次 save)
767
+ {
768
+ const { evaluatePlanProposalGate, inferPlanGateTaskType } = await import("../../../engine/pipeline/plan_proposal_gate.js");
769
+ const routeForGate = expansion?.workflow_trace?.route ?? expansionRoute ?? "code_change";
770
+ const taskTypeForGate = inferPlanGateTaskType(ctx.intent);
771
+ const isLightweight = routeForGate === "acceptance" || routeForGate === "review"
772
+ || routeForGate === "direct_answer" || routeForGate === "analysis"
773
+ || taskTypeForGate === "local_acceptance";
774
+ if (isLightweight) {
775
+ await taskContext.setPlanProposalGate(args.task_id, {
776
+ passed: true,
777
+ plan_gate_status: "passed",
778
+ required_level: "brief_plan",
779
+ reason_zh: "轻量路径自动通过",
780
+ violations: [],
781
+ evidence_refs: [],
782
+ blocked_actions: [],
783
+ }, freshCtx);
784
+ }
785
+ else {
786
+ const gateResult = evaluatePlanProposalGate({
787
+ task_id: args.task_id,
788
+ task_type: taskTypeForGate,
789
+ user_intent: ctx.intent,
790
+ plan_level: "execution_plan",
791
+ plan_summary_zh: ctx.intent.slice(0, 200),
792
+ proposed_steps: [expansionRoute ?? "execute"],
793
+ verification_plan: (expansion.acceptance?.automated ?? []).map((a) => a.description ?? String(a)),
794
+ risks: [],
795
+ evidence_refs: expansion.matched_knowledge ?? [],
796
+ });
797
+ await taskContext.setPlanProposalGate(args.task_id, gateResult, freshCtx);
798
+ }
799
+ }
800
+ }
801
+ }
802
+ catch (persistErr) {
803
+ try {
804
+ await taskContext.updateStatus(args.task_id, "failed");
805
+ }
806
+ catch {
807
+ // 状态转换非法,忽略
808
+ }
809
+ throw persistErr;
810
+ }
811
+ const expandPayload = Object.keys(advisories).length > 0
812
+ ? { ...expansion, advisories }
813
+ : expansion;
814
+ return {
815
+ result: expandPayload,
816
+ };
817
+ });
818
+ }
819
+ //# sourceMappingURL=expand_handler.js.map