soloforge 1.1.30 → 1.1.32

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