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.
- package/CHANGELOG.md +27 -0
- package/README.md +33 -18
- package/dist/adapters/claude_code/claude_md.d.ts +2 -1
- package/dist/adapters/claude_code/claude_md.d.ts.map +1 -1
- package/dist/adapters/claude_code/claude_md.js.map +1 -1
- package/dist/adapters/codex/codex_rules.d.ts +2 -1
- package/dist/adapters/codex/codex_rules.d.ts.map +1 -1
- package/dist/adapters/codex/codex_rules.js.map +1 -1
- package/dist/adapters/shared/workflow_template.d.ts.map +1 -1
- package/dist/adapters/shared/workflow_template.js +0 -1
- package/dist/adapters/shared/workflow_template.js.map +1 -1
- package/dist/adapters/trae/trae_config.d.ts +17 -1
- package/dist/adapters/trae/trae_config.d.ts.map +1 -1
- package/dist/adapters/trae/trae_config.js +2 -2
- package/dist/adapters/trae/trae_config.js.map +1 -1
- package/dist/adapters/trae/trae_rules.d.ts +2 -1
- package/dist/adapters/trae/trae_rules.d.ts.map +1 -1
- package/dist/adapters/trae/trae_rules.js.map +1 -1
- package/dist/bin/args.d.ts +9 -0
- package/dist/bin/args.d.ts.map +1 -1
- package/dist/bin/args.js +44 -1
- package/dist/bin/args.js.map +1 -1
- package/dist/bin/commands/audit.d.ts.map +1 -1
- package/dist/bin/commands/audit.js +5 -40
- package/dist/bin/commands/audit.js.map +1 -1
- package/dist/bin/commands/check_bash.d.ts.map +1 -1
- package/dist/bin/commands/check_bash.js +28 -6
- package/dist/bin/commands/check_bash.js.map +1 -1
- package/dist/bin/commands/check_write.d.ts +2 -1
- package/dist/bin/commands/check_write.d.ts.map +1 -1
- package/dist/bin/commands/check_write.js +14 -45
- package/dist/bin/commands/check_write.js.map +1 -1
- package/dist/bin/commands/hooks.d.ts.map +1 -1
- package/dist/bin/commands/hooks.js +7 -3
- package/dist/bin/commands/hooks.js.map +1 -1
- package/dist/bin/commands/init.d.ts +19 -2
- package/dist/bin/commands/init.d.ts.map +1 -1
- package/dist/bin/commands/init.js +97 -72
- package/dist/bin/commands/init.js.map +1 -1
- package/dist/bin/commands/status.d.ts.map +1 -1
- package/dist/bin/commands/status.js +49 -65
- package/dist/bin/commands/status.js.map +1 -1
- package/dist/bin/commands/sync.d.ts.map +1 -1
- package/dist/bin/commands/sync.js +18 -26
- package/dist/bin/commands/sync.js.map +1 -1
- package/dist/bin/commands/validate.d.ts +1 -1
- package/dist/bin/commands/validate.d.ts.map +1 -1
- package/dist/bin/commands/validate.js +47 -58
- package/dist/bin/commands/validate.js.map +1 -1
- package/dist/bin/config_commands.d.ts +1 -1
- package/dist/bin/config_commands.d.ts.map +1 -1
- package/dist/bin/config_commands.js +40 -26
- package/dist/bin/config_commands.js.map +1 -1
- package/dist/bin/soloforge.js +30 -3
- package/dist/bin/soloforge.js.map +1 -1
- package/dist/engine/audit/audit_pool.d.ts.map +1 -1
- package/dist/engine/audit/audit_pool.js +2 -1
- package/dist/engine/audit/audit_pool.js.map +1 -1
- package/dist/engine/audit/audit_sampler.d.ts +2 -0
- package/dist/engine/audit/audit_sampler.d.ts.map +1 -1
- package/dist/engine/audit/audit_sampler.js.map +1 -1
- package/dist/engine/audit/code_reviewer.d.ts +1 -1
- package/dist/engine/audit/code_reviewer.d.ts.map +1 -1
- package/dist/engine/audit/code_reviewer.js +9 -21
- package/dist/engine/audit/code_reviewer.js.map +1 -1
- package/dist/engine/audit/core_experience_principle.js +1 -1
- package/dist/engine/audit/core_experience_principle.js.map +1 -1
- package/dist/engine/audit/debt_reporter.d.ts +3 -0
- package/dist/engine/audit/debt_reporter.d.ts.map +1 -1
- package/dist/engine/audit/debt_reporter.js.map +1 -1
- package/dist/engine/audit/debt_tracker.d.ts.map +1 -1
- package/dist/engine/audit/debt_tracker.js +12 -5
- package/dist/engine/audit/debt_tracker.js.map +1 -1
- package/dist/engine/audit/debugger.d.ts +3 -0
- package/dist/engine/audit/debugger.d.ts.map +1 -1
- package/dist/engine/audit/debugger.js.map +1 -1
- package/dist/engine/audit/delivery.d.ts +1 -1
- package/dist/engine/audit/delivery.d.ts.map +1 -1
- package/dist/engine/audit/delivery.js +7 -4
- package/dist/engine/audit/delivery.js.map +1 -1
- package/dist/engine/audit/delivery_readiness.d.ts +2 -0
- package/dist/engine/audit/delivery_readiness.d.ts.map +1 -1
- package/dist/engine/audit/delivery_readiness.js +2 -0
- package/dist/engine/audit/delivery_readiness.js.map +1 -1
- package/dist/engine/audit/developer_sovereignty.d.ts +5 -43
- package/dist/engine/audit/developer_sovereignty.d.ts.map +1 -1
- package/dist/engine/audit/developer_sovereignty.js +2 -6
- package/dist/engine/audit/developer_sovereignty.js.map +1 -1
- package/dist/engine/audit/evolver.js +5 -5
- package/dist/engine/audit/evolver.js.map +1 -1
- package/dist/engine/audit/failure_classifier.d.ts.map +1 -1
- package/dist/engine/audit/governance_report.d.ts +1 -1
- package/dist/engine/audit/governance_report.d.ts.map +1 -1
- package/dist/engine/audit/governance_report.js +1 -1
- package/dist/engine/audit/governance_report.js.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/gates.d.ts +2 -1
- package/dist/engine/audit/main_path_integration_contract/gates.d.ts.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/gates.js.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/queries.d.ts +2 -2
- package/dist/engine/audit/main_path_integration_contract/queries.d.ts.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/queries.js +2 -2
- package/dist/engine/audit/main_path_integration_contract/queries.js.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/scanning.d.ts.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/scanning.js +2 -2
- package/dist/engine/audit/main_path_integration_contract/scanning.js.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/scanning_infra.d.ts.map +1 -1
- package/dist/engine/audit/main_path_integration_contract/scanning_infra.js +3 -2
- package/dist/engine/audit/main_path_integration_contract/scanning_infra.js.map +1 -1
- package/dist/engine/audit/mutation_audit.d.ts +4 -22
- package/dist/engine/audit/mutation_audit.d.ts.map +1 -1
- package/dist/engine/audit/mutation_audit.js.map +1 -1
- package/dist/engine/audit/observability.d.ts.map +1 -1
- package/dist/engine/audit/observability.js +4 -2
- package/dist/engine/audit/observability.js.map +1 -1
- package/dist/engine/audit/privacy_grants.d.ts +108 -0
- package/dist/engine/audit/privacy_grants.d.ts.map +1 -0
- package/dist/engine/audit/privacy_grants.js +171 -0
- package/dist/engine/audit/privacy_grants.js.map +1 -0
- package/dist/engine/audit/privacy_patterns.d.ts +24 -0
- package/dist/engine/audit/privacy_patterns.d.ts.map +1 -0
- package/dist/engine/audit/privacy_patterns.js +143 -0
- package/dist/engine/audit/privacy_patterns.js.map +1 -0
- package/dist/engine/audit/privacy_scanning.d.ts +153 -0
- package/dist/engine/audit/privacy_scanning.d.ts.map +1 -0
- package/dist/engine/audit/privacy_scanning.js +567 -0
- package/dist/engine/audit/privacy_scanning.js.map +1 -0
- package/dist/engine/audit/privacy_secret_contract.d.ts +9 -317
- package/dist/engine/audit/privacy_secret_contract.d.ts.map +1 -1
- package/dist/engine/audit/privacy_secret_contract.js +12 -873
- package/dist/engine/audit/privacy_secret_contract.js.map +1 -1
- package/dist/engine/audit/privacy_types.d.ts +48 -0
- package/dist/engine/audit/privacy_types.d.ts.map +1 -0
- package/dist/engine/audit/privacy_types.js +14 -0
- package/dist/engine/audit/privacy_types.js.map +1 -0
- package/dist/engine/audit/risk_sampler.d.ts +2 -0
- package/dist/engine/audit/risk_sampler.d.ts.map +1 -1
- package/dist/engine/audit/risk_sampler.js +2 -0
- package/dist/engine/audit/risk_sampler.js.map +1 -1
- package/dist/engine/audit/semantic_evidence.d.ts +5 -1
- package/dist/engine/audit/semantic_evidence.d.ts.map +1 -1
- package/dist/engine/audit/semantic_evidence.js +2 -0
- package/dist/engine/audit/semantic_evidence.js.map +1 -1
- package/dist/engine/audit/test_generator.d.ts.map +1 -1
- package/dist/engine/audit/test_generator.js +4 -1
- package/dist/engine/audit/test_generator.js.map +1 -1
- package/dist/engine/audit/test_quality.d.ts +3 -0
- package/dist/engine/audit/test_quality.d.ts.map +1 -1
- package/dist/engine/audit/test_quality.js +1 -71
- package/dist/engine/audit/test_quality.js.map +1 -1
- package/dist/engine/change_coordinator.d.ts +1 -1
- package/dist/engine/change_coordinator.d.ts.map +1 -1
- package/dist/engine/change_coordinator.js +30 -27
- package/dist/engine/change_coordinator.js.map +1 -1
- package/dist/engine/cognitive_anchor.d.ts.map +1 -1
- package/dist/engine/cognitive_anchor.js +6 -7
- package/dist/engine/cognitive_anchor.js.map +1 -1
- package/dist/engine/config/config_auto_repair.d.ts +2 -1
- package/dist/engine/config/config_auto_repair.d.ts.map +1 -1
- package/dist/engine/config/config_auto_repair.js +18 -13
- package/dist/engine/config/config_auto_repair.js.map +1 -1
- package/dist/engine/config/config_precedence_contract/field_class.d.ts +11 -0
- package/dist/engine/config/config_precedence_contract/field_class.d.ts.map +1 -0
- package/dist/engine/config/config_precedence_contract/field_class.js +10 -0
- package/dist/engine/config/config_precedence_contract/field_class.js.map +1 -0
- package/dist/engine/config/config_precedence_contract/index.d.ts +1 -0
- package/dist/engine/config/config_precedence_contract/index.d.ts.map +1 -1
- package/dist/engine/config/config_precedence_contract/index.js.map +1 -1
- package/dist/engine/config/config_precedence_contract/project_config.d.ts.map +1 -1
- package/dist/engine/config/config_precedence_contract/project_config.js +17 -9
- package/dist/engine/config/config_precedence_contract/project_config.js.map +1 -1
- package/dist/engine/config/config_precedence_contract/resolution.d.ts +1 -1
- package/dist/engine/config/config_precedence_contract/resolution.d.ts.map +1 -1
- package/dist/engine/config/config_precedence_contract/resolution.js +9 -0
- package/dist/engine/config/config_precedence_contract/resolution.js.map +1 -1
- package/dist/engine/config/config_precedence_contract/types.d.ts +4 -26
- package/dist/engine/config/config_precedence_contract/types.d.ts.map +1 -1
- package/dist/engine/config/config_precedence_contract/types.js +2 -0
- package/dist/engine/config/config_precedence_contract/types.js.map +1 -1
- package/dist/engine/config/config_precedence_contract.d.ts +3 -1
- package/dist/engine/config/config_precedence_contract.d.ts.map +1 -1
- package/dist/engine/config/config_precedence_contract.js +7 -1
- package/dist/engine/config/config_precedence_contract.js.map +1 -1
- package/dist/engine/config/config_write_boundary.d.ts.map +1 -1
- package/dist/engine/config/config_write_boundary.js +16 -0
- package/dist/engine/config/config_write_boundary.js.map +1 -1
- package/dist/engine/config/regression_matrix.d.ts.map +1 -1
- package/dist/engine/config/regression_matrix.js +3 -3
- package/dist/engine/config/regression_matrix.js.map +1 -1
- package/dist/engine/config/zero_config_init.d.ts +30 -5
- package/dist/engine/config/zero_config_init.d.ts.map +1 -1
- package/dist/engine/config/zero_config_init.js +26 -15
- package/dist/engine/config/zero_config_init.js.map +1 -1
- package/dist/engine/contracts/architecture_design_contract.d.ts.map +1 -1
- package/dist/engine/contracts/architecture_design_contract.js.map +1 -1
- package/dist/engine/contracts/artifact_contract_registry.d.ts +1 -1
- package/dist/engine/contracts/artifact_contract_registry.d.ts.map +1 -1
- package/dist/engine/contracts/artifact_contract_registry.js +1 -1
- package/dist/engine/contracts/artifact_contract_registry.js.map +1 -1
- package/dist/engine/contracts/backend_implementation_contract.js +4 -4
- package/dist/engine/contracts/backend_implementation_contract.js.map +1 -1
- package/dist/engine/contracts/brainstorm_contract.d.ts +1 -1
- package/dist/engine/contracts/brainstorm_contract.d.ts.map +1 -1
- package/dist/engine/contracts/brainstorm_contract.js +1 -1
- package/dist/engine/contracts/brainstorm_contract.js.map +1 -1
- package/dist/engine/contracts/capability_state_store.d.ts +2 -0
- package/dist/engine/contracts/capability_state_store.d.ts.map +1 -1
- package/dist/engine/contracts/capability_state_store.js +11 -1
- package/dist/engine/contracts/capability_state_store.js.map +1 -1
- package/dist/engine/contracts/code_maintainability_observability_contract.js +5 -5
- package/dist/engine/contracts/code_maintainability_observability_contract.js.map +1 -1
- package/dist/engine/contracts/coding_readiness_gate.d.ts +1 -1
- package/dist/engine/contracts/coding_readiness_gate.d.ts.map +1 -1
- package/dist/engine/contracts/coding_readiness_gate.js +1 -1
- package/dist/engine/contracts/coding_readiness_gate.js.map +1 -1
- package/dist/engine/contracts/command_execution_contract.d.ts +1 -11
- package/dist/engine/contracts/command_execution_contract.d.ts.map +1 -1
- package/dist/engine/contracts/command_execution_contract.js +1 -11
- package/dist/engine/contracts/command_execution_contract.js.map +1 -1
- package/dist/engine/contracts/contract_guard.d.ts +1 -1
- package/dist/engine/contracts/contract_guard.d.ts.map +1 -1
- package/dist/engine/contracts/contract_registry/registry.d.ts.map +1 -1
- package/dist/engine/contracts/contract_registry/registry.js +2 -2
- package/dist/engine/contracts/contract_registry/registry.js.map +1 -1
- package/dist/engine/contracts/contract_registry/validation.js.map +1 -1
- package/dist/engine/contracts/contract_state_store.d.ts +2 -0
- package/dist/engine/contracts/contract_state_store.d.ts.map +1 -1
- package/dist/engine/contracts/contract_state_store.js +4 -1
- package/dist/engine/contracts/contract_state_store.js.map +1 -1
- package/dist/engine/contracts/control_plane_contract.d.ts.map +1 -1
- package/dist/engine/contracts/control_plane_contract.js +5 -4
- package/dist/engine/contracts/control_plane_contract.js.map +1 -1
- package/dist/engine/contracts/decision_contract.js +1 -1
- package/dist/engine/contracts/decision_contract.js.map +1 -1
- package/dist/engine/contracts/decision_workshop.d.ts.map +1 -1
- package/dist/engine/contracts/decision_workshop.js.map +1 -1
- package/dist/engine/contracts/design_artifact_pack.d.ts +3 -40
- package/dist/engine/contracts/design_artifact_pack.d.ts.map +1 -1
- package/dist/engine/contracts/design_artifact_pack.js.map +1 -1
- package/dist/engine/contracts/detail_discipline.d.ts.map +1 -1
- package/dist/engine/contracts/detail_discipline.js.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js.map +1 -1
- package/dist/engine/contracts/enforcement_guard.d.ts +2 -1
- package/dist/engine/contracts/enforcement_guard.d.ts.map +1 -1
- package/dist/engine/contracts/enforcement_guard.js +1 -1
- package/dist/engine/contracts/enforcement_guard.js.map +1 -1
- package/dist/engine/contracts/escape_report.d.ts.map +1 -1
- package/dist/engine/contracts/escape_report.js +2 -1
- package/dist/engine/contracts/escape_report.js.map +1 -1
- package/dist/engine/contracts/evidence_grounding_contract.d.ts +2 -4
- package/dist/engine/contracts/evidence_grounding_contract.d.ts.map +1 -1
- package/dist/engine/contracts/evidence_grounding_contract.js +3 -9
- package/dist/engine/contracts/evidence_grounding_contract.js.map +1 -1
- package/dist/engine/contracts/evolution_regression_gate.d.ts +2 -0
- package/dist/engine/contracts/evolution_regression_gate.d.ts.map +1 -1
- package/dist/engine/contracts/evolution_regression_gate.js +2 -0
- package/dist/engine/contracts/evolution_regression_gate.js.map +1 -1
- package/dist/engine/contracts/existing_system_analysis.d.ts.map +1 -1
- package/dist/engine/contracts/existing_system_analysis.js.map +1 -1
- package/dist/engine/contracts/existing_system_analyzer.d.ts +9 -9
- package/dist/engine/contracts/existing_system_analyzer.d.ts.map +1 -1
- package/dist/engine/contracts/existing_system_analyzer.js +83 -80
- package/dist/engine/contracts/existing_system_analyzer.js.map +1 -1
- package/dist/engine/contracts/extension_contract.d.ts +2 -2
- package/dist/engine/contracts/extension_contract.d.ts.map +1 -1
- package/dist/engine/contracts/extension_contract.js +2 -2
- package/dist/engine/contracts/extension_contract.js.map +1 -1
- package/dist/engine/contracts/extension_scenario_definitions.d.ts +10 -0
- package/dist/engine/contracts/extension_scenario_definitions.d.ts.map +1 -0
- package/dist/engine/contracts/extension_scenario_definitions.js +112 -0
- package/dist/engine/contracts/extension_scenario_definitions.js.map +1 -0
- package/dist/engine/contracts/extension_scenario_registry.d.ts +1 -7
- package/dist/engine/contracts/extension_scenario_registry.d.ts.map +1 -1
- package/dist/engine/contracts/extension_scenario_registry.js +5 -257
- package/dist/engine/contracts/extension_scenario_registry.js.map +1 -1
- package/dist/engine/contracts/first_principles.d.ts.map +1 -1
- package/dist/engine/contracts/first_principles.js.map +1 -1
- package/dist/engine/contracts/instruction_contract.d.ts.map +1 -1
- package/dist/engine/contracts/instruction_contract.js +0 -6
- package/dist/engine/contracts/instruction_contract.js.map +1 -1
- package/dist/engine/contracts/local_docker_acceptance.d.ts +1 -1
- package/dist/engine/contracts/local_docker_acceptance.d.ts.map +1 -1
- package/dist/engine/contracts/local_docker_acceptance.js +4 -4
- package/dist/engine/contracts/local_docker_acceptance.js.map +1 -1
- package/dist/engine/contracts/mechanism_health_check.d.ts +2 -0
- package/dist/engine/contracts/mechanism_health_check.d.ts.map +1 -1
- package/dist/engine/contracts/mechanism_health_check.js +2 -0
- package/dist/engine/contracts/mechanism_health_check.js.map +1 -1
- package/dist/engine/contracts/metric_governance.d.ts.map +1 -1
- package/dist/engine/contracts/metric_governance.js.map +1 -1
- package/dist/engine/contracts/ood_solid_contract.js +2 -2
- package/dist/engine/contracts/ood_solid_contract.js.map +1 -1
- package/dist/engine/contracts/platform_context.d.ts +2 -0
- package/dist/engine/contracts/platform_context.d.ts.map +1 -1
- package/dist/engine/contracts/platform_context.js +2 -0
- package/dist/engine/contracts/platform_context.js.map +1 -1
- package/dist/engine/contracts/project_knowledge_contract.d.ts.map +1 -1
- package/dist/engine/contracts/project_knowledge_contract.js +3 -0
- package/dist/engine/contracts/project_knowledge_contract.js.map +1 -1
- package/dist/engine/contracts/route_decision_contract_verifier.js +1 -1
- package/dist/engine/contracts/route_decision_contract_verifier.js.map +1 -1
- package/dist/engine/contracts/technology_decision.d.ts.map +1 -1
- package/dist/engine/contracts/technology_decision.js.map +1 -1
- package/dist/engine/contracts/tool_invocation_contract_registry.d.ts +3 -62
- package/dist/engine/contracts/tool_invocation_contract_registry.d.ts.map +1 -1
- package/dist/engine/contracts/tool_invocation_contract_registry.js +2 -0
- package/dist/engine/contracts/tool_invocation_contract_registry.js.map +1 -1
- package/dist/engine/contracts/traceability.d.ts +2 -1
- package/dist/engine/contracts/traceability.d.ts.map +1 -1
- package/dist/engine/contracts/traceability.js +5 -5
- package/dist/engine/contracts/traceability.js.map +1 -1
- package/dist/engine/contracts/user_feedback_contract.js +2 -2
- package/dist/engine/contracts/user_feedback_contract.js.map +1 -1
- package/dist/engine/contracts/workflow_template_pack.js +1 -1
- package/dist/engine/contracts/workflow_template_pack.js.map +1 -1
- package/dist/engine/core/config_defaults.d.ts +11 -0
- package/dist/engine/core/config_defaults.d.ts.map +1 -0
- package/dist/engine/core/config_defaults.js +11 -0
- package/dist/engine/core/config_defaults.js.map +1 -0
- package/dist/engine/core/env.d.ts +12 -0
- package/dist/engine/core/env.d.ts.map +1 -0
- package/dist/engine/core/env.js +12 -0
- package/dist/engine/core/env.js.map +1 -0
- package/dist/engine/core/errors.d.ts +21 -0
- package/dist/engine/core/errors.d.ts.map +1 -0
- package/dist/engine/core/errors.js +35 -0
- package/dist/engine/core/errors.js.map +1 -0
- package/dist/engine/core/exit_codes.d.ts +14 -0
- package/dist/engine/core/exit_codes.d.ts.map +1 -0
- package/dist/engine/core/exit_codes.js +14 -0
- package/dist/engine/core/exit_codes.js.map +1 -0
- package/dist/engine/core/helpers.d.ts +15 -0
- package/dist/engine/core/helpers.d.ts.map +1 -1
- package/dist/engine/core/helpers.js +31 -0
- package/dist/engine/core/helpers.js.map +1 -1
- package/dist/engine/core/index.d.ts +15 -0
- package/dist/engine/core/index.d.ts.map +1 -0
- package/dist/engine/core/index.js +22 -0
- package/dist/engine/core/index.js.map +1 -0
- package/dist/engine/core/io_controller.d.ts +1 -0
- package/dist/engine/core/io_controller.d.ts.map +1 -1
- package/dist/engine/core/io_controller.js +18 -2
- package/dist/engine/core/io_controller.js.map +1 -1
- package/dist/engine/core/llm_gateway.d.ts +20 -3
- package/dist/engine/core/llm_gateway.d.ts.map +1 -1
- package/dist/engine/core/llm_gateway.js +95 -13
- package/dist/engine/core/llm_gateway.js.map +1 -1
- package/dist/engine/core/log_governance.d.ts.map +1 -1
- package/dist/engine/core/log_governance.js +4 -9
- package/dist/engine/core/log_governance.js.map +1 -1
- package/dist/engine/core/logger.d.ts.map +1 -1
- package/dist/engine/core/logger.js +5 -2
- package/dist/engine/core/logger.js.map +1 -1
- package/dist/engine/core/path_scope_utils.d.ts +1 -1
- package/dist/engine/core/path_scope_utils.d.ts.map +1 -1
- package/dist/engine/core/path_scope_utils.js +1 -1
- package/dist/engine/core/path_scope_utils.js.map +1 -1
- package/dist/engine/core/paths.d.ts +86 -0
- package/dist/engine/core/paths.d.ts.map +1 -0
- package/dist/engine/core/paths.js +103 -0
- package/dist/engine/core/paths.js.map +1 -0
- package/dist/engine/core/write_file_atomic.d.ts +25 -0
- package/dist/engine/core/write_file_atomic.d.ts.map +1 -0
- package/dist/engine/core/write_file_atomic.js +63 -0
- package/dist/engine/core/write_file_atomic.js.map +1 -0
- package/dist/engine/dependency_scanner.d.ts.map +1 -1
- package/dist/engine/dependency_scanner.js +14 -16
- package/dist/engine/dependency_scanner.js.map +1 -1
- package/dist/engine/exploration.d.ts.map +1 -1
- package/dist/engine/exploration.js +9 -8
- package/dist/engine/exploration.js.map +1 -1
- package/dist/engine/knowledge/chinese_semantic_priority.d.ts.map +1 -1
- package/dist/engine/knowledge/chinese_semantic_priority.js.map +1 -1
- package/dist/engine/knowledge/drift_classifier.d.ts +26 -0
- package/dist/engine/knowledge/drift_classifier.d.ts.map +1 -0
- package/dist/engine/knowledge/drift_classifier.js +82 -0
- package/dist/engine/knowledge/drift_classifier.js.map +1 -0
- package/dist/engine/knowledge/knowledge_asset_audit.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_audit.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_consumer.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_consumer.js +0 -4
- package/dist/engine/knowledge/knowledge_asset_consumer.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_generation_gate.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_generation_gate.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_schema.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_schema.js +0 -3
- package/dist/engine/knowledge/knowledge_asset_schema.js.map +1 -1
- package/dist/engine/knowledge/knowledge_evolution.d.ts +1 -17
- package/dist/engine/knowledge/knowledge_evolution.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_evolution.js +2 -74
- package/dist/engine/knowledge/knowledge_evolution.js.map +1 -1
- package/dist/engine/knowledge/knowledge_health.d.ts +44 -0
- package/dist/engine/knowledge/knowledge_health.d.ts.map +1 -0
- package/dist/engine/knowledge/knowledge_health.js +303 -0
- package/dist/engine/knowledge/knowledge_health.js.map +1 -0
- package/dist/engine/knowledge/knowledge_injection_boundary.d.ts +1 -1
- package/dist/engine/knowledge/knowledge_injection_boundary.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_injection_boundary.js +21 -5
- package/dist/engine/knowledge/knowledge_injection_boundary.js.map +1 -1
- package/dist/engine/knowledge/knowledge_lifecycle.d.ts +4 -2
- package/dist/engine/knowledge/knowledge_lifecycle.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_lifecycle.js +37 -27
- package/dist/engine/knowledge/knowledge_lifecycle.js.map +1 -1
- package/dist/engine/knowledge/knowledge_manager.d.ts +2 -148
- package/dist/engine/knowledge/knowledge_manager.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_manager.js +4 -933
- package/dist/engine/knowledge/knowledge_manager.js.map +1 -1
- package/dist/engine/knowledge/knowledge_scenario_registry.d.ts +1 -1
- package/dist/engine/knowledge/knowledge_scenario_registry.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_scenario_registry.js +6 -6
- package/dist/engine/knowledge/knowledge_scenario_registry.js.map +1 -1
- package/dist/engine/knowledge/knowledge_sovereignty.js +2 -2
- package/dist/engine/knowledge/knowledge_sovereignty.js.map +1 -1
- package/dist/engine/knowledge/knowledge_writer.d.ts +108 -0
- package/dist/engine/knowledge/knowledge_writer.d.ts.map +1 -0
- package/dist/engine/knowledge/knowledge_writer.js +637 -0
- package/dist/engine/knowledge/knowledge_writer.js.map +1 -0
- package/dist/engine/knowledge/language_policy.d.ts +1 -1
- package/dist/engine/knowledge/language_policy.js +1 -1
- package/dist/engine/knowledge/release_compatibility.d.ts.map +1 -1
- package/dist/engine/knowledge/release_compatibility.js.map +1 -1
- package/dist/engine/migration_guard.js +4 -4
- package/dist/engine/migration_guard.js.map +1 -1
- package/dist/engine/onboarding.d.ts +1 -1
- package/dist/engine/onboarding.d.ts.map +1 -1
- package/dist/engine/onboarding.js +4 -1
- package/dist/engine/onboarding.js.map +1 -1
- package/dist/engine/pipeline/conflict_gate.js +1 -1
- package/dist/engine/pipeline/conflict_gate.js.map +1 -1
- package/dist/engine/pipeline/diff_ownership.d.ts.map +1 -1
- package/dist/engine/pipeline/diff_ownership.js +7 -0
- package/dist/engine/pipeline/diff_ownership.js.map +1 -1
- package/dist/engine/pipeline/diff_ownership_store.d.ts.map +1 -1
- package/dist/engine/pipeline/diff_ownership_store.js +8 -6
- package/dist/engine/pipeline/diff_ownership_store.js.map +1 -1
- package/dist/engine/pipeline/expand_pipeline.d.ts +2 -1
- package/dist/engine/pipeline/expand_pipeline.d.ts.map +1 -1
- package/dist/engine/pipeline/expand_pipeline.js.map +1 -1
- package/dist/engine/pipeline/input_material_contract_registry.d.ts +1 -1
- package/dist/engine/pipeline/input_material_contract_registry.d.ts.map +1 -1
- package/dist/engine/pipeline/input_material_contract_registry.js +44 -43
- package/dist/engine/pipeline/input_material_contract_registry.js.map +1 -1
- package/dist/engine/pipeline/input_material_extractor.js +3 -3
- package/dist/engine/pipeline/input_material_extractor.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/expand.d.ts +6 -6
- package/dist/engine/pipeline/intent_expander/expand.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/expand.js +57 -50
- package/dist/engine/pipeline/intent_expander/expand.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/helpers.d.ts +6 -4
- package/dist/engine/pipeline/intent_expander/helpers.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/helpers.js +4 -4
- package/dist/engine/pipeline/intent_expander/helpers.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/index.d.ts +4 -4
- package/dist/engine/pipeline/intent_expander/index.js +8 -8
- package/dist/engine/pipeline/intent_expander/index.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts +12 -9
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.js +11 -11
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts +68 -6
- package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/privacy_gates.js +94 -21
- package/dist/engine/pipeline/intent_expander/privacy_gates.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts +37 -3
- package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.js +1 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/templates.d.ts +2 -1
- package/dist/engine/pipeline/intent_expander/templates.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/templates.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/types.d.ts +35 -5
- package/dist/engine/pipeline/intent_expander/types.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts +4 -3
- package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js +1 -1
- package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js.map +1 -1
- package/dist/engine/pipeline/intent_expander.d.ts +2 -2
- package/dist/engine/pipeline/intent_expander.js +6 -6
- package/dist/engine/pipeline/intent_expander.js.map +1 -1
- package/dist/engine/pipeline/intent_route_scorer.d.ts +2 -2
- package/dist/engine/pipeline/intent_route_scorer.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_route_scorer.js +3 -3
- package/dist/engine/pipeline/intent_route_scorer.js.map +1 -1
- package/dist/engine/pipeline/intent_router.d.ts +4 -5
- package/dist/engine/pipeline/intent_router.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_router.js +64 -112
- package/dist/engine/pipeline/intent_router.js.map +1 -1
- package/dist/engine/pipeline/intent_signal_extractor.d.ts +18 -0
- package/dist/engine/pipeline/intent_signal_extractor.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_signal_extractor.js +8 -8
- package/dist/engine/pipeline/intent_signal_extractor.js.map +1 -1
- package/dist/engine/pipeline/job_manager.d.ts.map +1 -1
- package/dist/engine/pipeline/job_manager.js +18 -4
- package/dist/engine/pipeline/job_manager.js.map +1 -1
- package/dist/engine/pipeline/plan_proposal_gate.d.ts.map +1 -1
- package/dist/engine/pipeline/plan_proposal_gate.js +0 -1
- package/dist/engine/pipeline/plan_proposal_gate.js.map +1 -1
- package/dist/engine/pipeline/route_types.d.ts +10 -0
- package/dist/engine/pipeline/route_types.d.ts.map +1 -0
- package/dist/engine/pipeline/route_types.js +9 -0
- package/dist/engine/pipeline/route_types.js.map +1 -0
- package/dist/engine/pipeline/scope_controller.d.ts +1 -1
- package/dist/engine/pipeline/scope_controller.d.ts.map +1 -1
- package/dist/engine/pipeline/scope_controller.js +18 -17
- package/dist/engine/pipeline/scope_controller.js.map +1 -1
- package/dist/engine/pipeline/scope_lease.d.ts.map +1 -1
- package/dist/engine/pipeline/scope_lease.js +3 -1
- package/dist/engine/pipeline/scope_lease.js.map +1 -1
- package/dist/engine/pipeline/slice_executor.d.ts +1 -1
- package/dist/engine/pipeline/slice_executor.d.ts.map +1 -1
- package/dist/engine/pipeline/slice_executor.js +1 -1
- package/dist/engine/pipeline/slice_executor.js.map +1 -1
- package/dist/engine/pipeline/stage_gate_engine.d.ts +2 -0
- package/dist/engine/pipeline/stage_gate_engine.d.ts.map +1 -1
- package/dist/engine/pipeline/stage_gate_engine.js +9 -3
- package/dist/engine/pipeline/stage_gate_engine.js.map +1 -1
- package/dist/engine/pipeline/stale_current_task_detector.d.ts.map +1 -1
- package/dist/engine/pipeline/stale_current_task_detector.js +8 -5
- package/dist/engine/pipeline/stale_current_task_detector.js.map +1 -1
- package/dist/engine/pipeline/task_context/cleanup.d.ts.map +1 -1
- package/dist/engine/pipeline/task_context/cleanup.js +4 -1
- package/dist/engine/pipeline/task_context/cleanup.js.map +1 -1
- package/dist/engine/pipeline/task_context/expansion_privacy.d.ts +1 -3
- package/dist/engine/pipeline/task_context/expansion_privacy.d.ts.map +1 -1
- package/dist/engine/pipeline/task_context/expansion_privacy.js +1 -1
- package/dist/engine/pipeline/task_context/expansion_privacy.js.map +1 -1
- package/dist/engine/pipeline/task_context/manager.d.ts +4 -4
- package/dist/engine/pipeline/task_context/manager.d.ts.map +1 -1
- package/dist/engine/pipeline/task_context/manager.js +25 -13
- package/dist/engine/pipeline/task_context/manager.js.map +1 -1
- package/dist/engine/pipeline/task_context/manager_setters.d.ts +3 -3
- package/dist/engine/pipeline/task_context/manager_setters.d.ts.map +1 -1
- package/dist/engine/pipeline/task_context/manager_setters.js.map +1 -1
- package/dist/engine/pipeline/task_context/status_transitions.d.ts.map +1 -1
- package/dist/engine/pipeline/task_context/status_transitions.js +4 -3
- package/dist/engine/pipeline/task_context/status_transitions.js.map +1 -1
- package/dist/engine/pipeline/task_planner.js +3 -4
- package/dist/engine/pipeline/task_planner.js.map +1 -1
- package/dist/engine/pipeline/workspace_lease.d.ts +10 -1
- package/dist/engine/pipeline/workspace_lease.d.ts.map +1 -1
- package/dist/engine/pipeline/workspace_lease.js +29 -3
- package/dist/engine/pipeline/workspace_lease.js.map +1 -1
- package/dist/engine/pipeline/workspace_resumer.d.ts.map +1 -1
- package/dist/engine/pipeline/workspace_resumer.js +3 -0
- package/dist/engine/pipeline/workspace_resumer.js.map +1 -1
- package/dist/engine/release/foundation_scenario_registry.d.ts +1 -1
- package/dist/engine/release/foundation_scenario_registry.d.ts.map +1 -1
- package/dist/engine/release/foundation_scenario_registry.js +3 -2
- package/dist/engine/release/foundation_scenario_registry.js.map +1 -1
- package/dist/engine/release/foundation_scenario_runners.d.ts.map +1 -1
- package/dist/engine/release/foundation_scenario_runners.js +40 -33
- package/dist/engine/release/foundation_scenario_runners.js.map +1 -1
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts +2 -2
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.js +3 -2
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.js.map +1 -1
- package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js +3 -3
- package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js.map +1 -1
- package/dist/engine/release/gate_checks/checkDependencyAudit.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkDependencyAudit.js +8 -3
- package/dist/engine/release/gate_checks/checkDependencyAudit.js.map +1 -1
- package/dist/engine/release/gate_checks/checkDistFreshness.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkDistFreshness.js +4 -2
- package/dist/engine/release/gate_checks/checkDistFreshness.js.map +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js.map +1 -1
- package/dist/engine/release/gate_checks/checkMainlineConsumption.js +2 -2
- package/dist/engine/release/gate_checks/checkMainlineConsumption.js.map +1 -1
- package/dist/engine/release/gate_checks/{check_npm_pack.d.ts → checkNpmPack.d.ts} +1 -1
- package/dist/engine/release/gate_checks/checkNpmPack.d.ts.map +1 -0
- package/dist/engine/release/gate_checks/{check_npm_pack.js → checkNpmPack.js} +5 -7
- package/dist/engine/release/gate_checks/checkNpmPack.js.map +1 -0
- package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js +4 -3
- package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js.map +1 -1
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.js +58 -4
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.js.map +1 -1
- package/dist/engine/release/gate_checks/helpers.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/helpers.js +2 -1
- package/dist/engine/release/gate_checks/helpers.js.map +1 -1
- package/dist/engine/release/index.d.ts +6 -0
- package/dist/engine/release/index.d.ts.map +1 -0
- package/dist/engine/release/index.js +6 -0
- package/dist/engine/release/index.js.map +1 -0
- package/dist/engine/release/release_gate_scenario_registry.d.ts.map +1 -1
- package/dist/engine/release/release_gate_scenario_registry.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/registry.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/registry.js +4 -1
- package/dist/engine/release/release_issue_scenario_registry/registry.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js +38 -19
- package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js +3 -2
- package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js +50 -26
- package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js +12 -6
- package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js +26 -13
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js +14 -8
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts +12 -0
- package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts.map +1 -0
- package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js +147 -0
- package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js.map +1 -0
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts +24 -40
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js +12 -6
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js.map +1 -1
- package/dist/engine/release/release_readiness_gate.d.ts +3 -1
- package/dist/engine/release/release_readiness_gate.d.ts.map +1 -1
- package/dist/engine/release/release_readiness_gate.js +47 -4
- package/dist/engine/release/release_readiness_gate.js.map +1 -1
- package/dist/engine/release/release_tool_harness.d.ts +18 -5
- package/dist/engine/release/release_tool_harness.d.ts.map +1 -1
- package/dist/engine/release/release_tool_harness.js +15 -7
- package/dist/engine/release/release_tool_harness.js.map +1 -1
- package/dist/engine/release/types.d.ts +81 -0
- package/dist/engine/release/types.d.ts.map +1 -0
- package/dist/engine/release/types.js +7 -0
- package/dist/engine/release/types.js.map +1 -0
- package/dist/engine/release/verifier.d.ts.map +1 -1
- package/dist/engine/release/verifier.js +1 -1
- package/dist/engine/release/verifier.js.map +1 -1
- package/dist/engine/team_awareness.d.ts +1 -1
- package/dist/engine/team_awareness.d.ts.map +1 -1
- package/dist/engine/team_awareness.js.map +1 -1
- package/dist/engine/templates/asset_manifest.d.ts +1 -1
- package/dist/engine/templates/asset_manifest.d.ts.map +1 -1
- package/dist/engine/templates/asset_manifest.js +1 -2
- package/dist/engine/templates/asset_manifest.js.map +1 -1
- package/dist/engine/templates/consumption_trace_store.d.ts +2 -1
- package/dist/engine/templates/consumption_trace_store.d.ts.map +1 -1
- package/dist/engine/templates/consumption_trace_store.js +0 -6
- package/dist/engine/templates/consumption_trace_store.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/index.js +14 -14
- package/dist/engine/templates/explicit_asset_registry/index.js.map +1 -1
- package/dist/engine/templates/observed_consumption.d.ts.map +1 -1
- package/dist/engine/templates/observed_consumption.js +1 -1
- package/dist/engine/templates/observed_consumption.js.map +1 -1
- package/dist/engine/templates/scaffolder.js +2 -2
- package/dist/engine/templates/scaffolder.js.map +1 -1
- package/dist/engine/templates/standard_asset_coverage.js +1 -1
- package/dist/engine/templates/standard_asset_coverage.js.map +1 -1
- package/dist/engine/templates/template_asset_contract_registry.d.ts +1 -1
- package/dist/engine/templates/template_asset_contract_registry.d.ts.map +1 -1
- package/dist/engine/templates/template_asset_contract_registry.js +1 -2
- package/dist/engine/templates/template_asset_contract_registry.js.map +1 -1
- package/dist/engine/templates/template_asset_visibility.js +0 -17
- package/dist/engine/templates/template_asset_visibility.js.map +1 -1
- package/dist/engine/templates/template_init_sync.d.ts.map +1 -1
- package/dist/engine/templates/template_init_sync.js +9 -11
- package/dist/engine/templates/template_init_sync.js.map +1 -1
- package/dist/engine/templates/template_manifest_io.d.ts.map +1 -1
- package/dist/engine/templates/template_manifest_io.js +3 -2
- package/dist/engine/templates/template_manifest_io.js.map +1 -1
- package/dist/engine/templates/template_sync.d.ts.map +1 -1
- package/dist/engine/templates/template_sync.js.map +1 -1
- package/dist/engine/templates/workflow_rule_generator.d.ts +1 -1
- package/dist/engine/templates/workflow_rule_generator.d.ts.map +1 -1
- package/dist/engine/templates/workflow_rule_generator.js +1 -1
- package/dist/engine/templates/workflow_rule_generator.js.map +1 -1
- package/dist/engine/workflow/index.d.ts +10 -0
- package/dist/engine/workflow/index.d.ts.map +1 -0
- package/dist/engine/workflow/index.js +12 -0
- package/dist/engine/workflow/index.js.map +1 -0
- package/dist/engine/workflow/legacy_type_migration.d.ts +4 -3
- package/dist/engine/workflow/legacy_type_migration.d.ts.map +1 -1
- package/dist/engine/workflow/legacy_type_migration.js +6 -5
- package/dist/engine/workflow/legacy_type_migration.js.map +1 -1
- package/dist/engine/workflow/next_action_planner.d.ts +2 -2
- package/dist/engine/workflow/next_action_planner.d.ts.map +1 -1
- package/dist/engine/workflow/next_action_planner.js +70 -21
- package/dist/engine/workflow/next_action_planner.js.map +1 -1
- package/dist/engine/workflow/project_stage_detector.d.ts.map +1 -1
- package/dist/engine/workflow/project_stage_detector.js +28 -13
- package/dist/engine/workflow/project_stage_detector.js.map +1 -1
- package/dist/engine/workflow/workflow_navigation_contract.d.ts +8 -1
- package/dist/engine/workflow/workflow_navigation_contract.d.ts.map +1 -1
- package/dist/engine/workflow/workflow_navigation_contract.js +0 -1
- package/dist/engine/workflow/workflow_navigation_contract.js.map +1 -1
- package/dist/{engine/core → git}/git_deps.d.ts +3 -1
- package/dist/git/git_deps.d.ts.map +1 -0
- package/dist/{engine/core → git}/git_deps.js +2 -2
- package/dist/git/git_deps.js.map +1 -0
- package/dist/index.js +6 -2
- package/dist/index.js.map +1 -1
- package/dist/knowledge/conflict_detector.d.ts +14 -0
- package/dist/knowledge/conflict_detector.d.ts.map +1 -1
- package/dist/knowledge/conflict_detector.js +67 -0
- package/dist/knowledge/conflict_detector.js.map +1 -1
- package/dist/knowledge/health_checker.d.ts.map +1 -1
- package/dist/knowledge/health_checker.js +17 -8
- package/dist/knowledge/health_checker.js.map +1 -1
- package/dist/knowledge/index_manager.d.ts +3 -0
- package/dist/knowledge/index_manager.d.ts.map +1 -1
- package/dist/knowledge/index_manager.js +82 -40
- package/dist/knowledge/index_manager.js.map +1 -1
- package/dist/knowledge/loader.d.ts.map +1 -1
- package/dist/knowledge/loader.js +14 -5
- package/dist/knowledge/loader.js.map +1 -1
- package/dist/knowledge/writer.d.ts.map +1 -1
- package/dist/knowledge/writer.js +2 -1
- package/dist/knowledge/writer.js.map +1 -1
- package/dist/server/index.d.ts +2 -2
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +14 -18
- package/dist/server/index.js.map +1 -1
- package/dist/server/lifecycle.d.ts +4 -2
- package/dist/server/lifecycle.d.ts.map +1 -1
- package/dist/server/lifecycle.js +6 -11
- package/dist/server/lifecycle.js.map +1 -1
- package/dist/server/tools/cep_assessment.d.ts.map +1 -1
- package/dist/server/tools/cep_assessment.js +6 -6
- package/dist/server/tools/cep_assessment.js.map +1 -1
- package/dist/server/tools/gate_checks.d.ts +4 -2
- package/dist/server/tools/gate_checks.d.ts.map +1 -1
- package/dist/server/tools/gate_checks.js.map +1 -1
- package/dist/server/tools/index.d.ts.map +1 -1
- package/dist/server/tools/index.js +37 -1
- package/dist/server/tools/index.js.map +1 -1
- package/dist/server/tools/lazy_loaders.d.ts +1 -1
- package/dist/server/tools/lazy_loaders.d.ts.map +1 -1
- package/dist/server/tools/lazy_loaders.js +2 -2
- package/dist/server/tools/lazy_loaders.js.map +1 -1
- package/dist/server/tools/middleware.d.ts +22 -2
- package/dist/server/tools/middleware.d.ts.map +1 -1
- package/dist/server/tools/middleware.js +55 -22
- package/dist/server/tools/middleware.js.map +1 -1
- package/dist/server/tools/schemas.d.ts +2 -2
- package/dist/server/tools/tool_groups/admin.d.ts.map +1 -1
- package/dist/server/tools/tool_groups/admin.js +5 -4
- package/dist/server/tools/tool_groups/admin.js.map +1 -1
- package/dist/server/tools/tool_groups/auxiliary.js +4 -4
- package/dist/server/tools/tool_groups/auxiliary.js.map +1 -1
- package/dist/server/tools/tool_groups/classify_expand.d.ts.map +1 -1
- package/dist/server/tools/tool_groups/classify_expand.js +4 -869
- package/dist/server/tools/tool_groups/classify_expand.js.map +1 -1
- package/dist/server/tools/tool_groups/classify_handler.d.ts +3 -0
- package/dist/server/tools/tool_groups/classify_handler.d.ts.map +1 -0
- package/dist/server/tools/tool_groups/classify_handler.js +65 -0
- package/dist/server/tools/tool_groups/classify_handler.js.map +1 -0
- package/dist/server/tools/tool_groups/expand_handler.d.ts +3 -0
- package/dist/server/tools/tool_groups/expand_handler.d.ts.map +1 -0
- package/dist/server/tools/tool_groups/expand_handler.js +819 -0
- package/dist/server/tools/tool_groups/expand_handler.js.map +1 -0
- package/dist/server/tools/tool_groups/knowledge.js +2 -2
- package/dist/server/tools/tool_groups/knowledge.js.map +1 -1
- package/dist/server/tools/tool_groups/scaffold_accept_deliver.js +1 -1
- package/dist/server/tools/tool_groups/scaffold_accept_deliver.js.map +1 -1
- package/dist/server/tools/tool_groups/status_plan_analyze_review.js +5 -5
- package/dist/server/tools/tool_groups/status_plan_analyze_review.js.map +1 -1
- package/dist/server/tools/tool_groups/verify_learn.d.ts.map +1 -1
- package/dist/server/tools/tool_groups/verify_learn.js +6 -11
- package/dist/server/tools/tool_groups/verify_learn.js.map +1 -1
- package/dist/server/tools/tool_names.d.ts +55 -0
- package/dist/server/tools/tool_names.d.ts.map +1 -0
- package/dist/server/tools/tool_names.js +62 -0
- package/dist/server/tools/tool_names.js.map +1 -0
- package/dist/server/tools/utils.d.ts.map +1 -1
- package/dist/server/tools/utils.js +5 -11
- package/dist/server/tools/utils.js.map +1 -1
- package/dist/types/base.d.ts +2 -0
- package/dist/types/base.d.ts.map +1 -1
- package/dist/types/config.d.ts +2 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/delivery.d.ts +44 -1
- package/dist/types/delivery.d.ts.map +1 -1
- package/dist/types/knowledge.d.ts +3 -1
- package/dist/types/knowledge.d.ts.map +1 -1
- package/dist/types/knowledge.js.map +1 -1
- package/dist/types/pipeline.d.ts +151 -14
- package/dist/types/pipeline.d.ts.map +1 -1
- package/dist/types/task.d.ts +103 -38
- package/dist/types/task.d.ts.map +1 -1
- package/package.json +7 -3
- 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
- package/dist/engine/audit/audit_verifier.d.ts +0 -52
- package/dist/engine/audit/audit_verifier.d.ts.map +0 -1
- package/dist/engine/audit/audit_verifier.js +0 -101
- package/dist/engine/audit/audit_verifier.js.map +0 -1
- package/dist/engine/contracts/policy_drift_detector.d.ts +0 -72
- package/dist/engine/contracts/policy_drift_detector.d.ts.map +0 -1
- package/dist/engine/contracts/policy_drift_detector.js +0 -277
- package/dist/engine/contracts/policy_drift_detector.js.map +0 -1
- package/dist/engine/core/git_deps.d.ts.map +0 -1
- package/dist/engine/core/git_deps.js.map +0 -1
- package/dist/engine/release/gate_checks/check_npm_pack.d.ts.map +0 -1
- package/dist/engine/release/gate_checks/check_npm_pack.js.map +0 -1
- package/dist/engine/state_update_bypass.d.ts +0 -19
- package/dist/engine/state_update_bypass.d.ts.map +0 -1
- package/dist/engine/state_update_bypass.js +0 -17
- 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
|