soloforge 1.4.15 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +76 -3
- package/dist/adapters/claude_code/claude_md.d.ts +1 -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/claude_code/pre_prompt_contract.d.ts +4 -59
- package/dist/adapters/claude_code/pre_prompt_contract.d.ts.map +1 -1
- package/dist/adapters/claude_code/pre_prompt_contract.js +3 -111
- package/dist/adapters/claude_code/pre_prompt_contract.js.map +1 -1
- package/dist/adapters/claude_code/server.d.ts +1 -1
- package/dist/adapters/claude_code/server.d.ts.map +1 -1
- package/dist/adapters/claude_code/server.js.map +1 -1
- package/dist/adapters/claude_code/tools.d.ts +1 -1
- package/dist/adapters/claude_code/tools.d.ts.map +1 -1
- package/dist/adapters/claude_code/tools.js +71 -47
- package/dist/adapters/claude_code/tools.js.map +1 -1
- package/dist/adapters/codex/codex_rules.d.ts +1 -1
- package/dist/adapters/codex/codex_rules.d.ts.map +1 -1
- package/dist/adapters/codex/codex_rules.js +1 -24
- package/dist/adapters/codex/codex_rules.js.map +1 -1
- package/dist/adapters/shared/workflow_template.d.ts +8 -12
- package/dist/adapters/shared/workflow_template.d.ts.map +1 -1
- package/dist/adapters/shared/workflow_template.js +16 -78
- package/dist/adapters/shared/workflow_template.js.map +1 -1
- package/dist/adapters/trae/trae_rules.d.ts +1 -1
- package/dist/adapters/trae/trae_rules.d.ts.map +1 -1
- package/dist/adapters/trae/trae_rules.js +1 -10
- package/dist/adapters/trae/trae_rules.js.map +1 -1
- package/dist/bin/soloforge.d.ts.map +1 -1
- package/dist/bin/soloforge.js +53 -100
- package/dist/bin/soloforge.js.map +1 -1
- package/dist/engine/asset_manifest.d.ts.map +1 -1
- package/dist/engine/asset_manifest.js +118 -120
- package/dist/engine/asset_manifest.js.map +1 -1
- package/dist/engine/audit_pool.js.map +1 -1
- package/dist/engine/capability_registry.js +25 -25
- package/dist/engine/capability_registry.js.map +1 -1
- package/dist/engine/capability_state_store.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.map +1 -1
- package/dist/engine/classifier.d.ts +1 -1
- package/dist/engine/classifier.d.ts.map +1 -1
- package/dist/engine/classifier.js +1 -1
- package/dist/engine/classifier.js.map +1 -1
- package/dist/engine/code_reviewer.d.ts +1 -1
- package/dist/engine/code_reviewer.d.ts.map +1 -1
- package/dist/engine/code_reviewer.js +1 -1
- package/dist/engine/code_reviewer.js.map +1 -1
- package/dist/engine/confidence_scorer.d.ts +1 -1
- package/dist/engine/confidence_scorer.d.ts.map +1 -1
- package/dist/engine/config_auto_repair.js.map +1 -1
- package/dist/engine/config_precedence_contract.js.map +1 -1
- package/dist/engine/consumable_asset_registry.d.ts +1 -1
- package/dist/engine/consumable_asset_registry.d.ts.map +1 -1
- package/dist/engine/consumable_asset_registry.js +236 -126
- package/dist/engine/consumable_asset_registry.js.map +1 -1
- package/dist/engine/consumption_trace_store.d.ts +40 -6
- package/dist/engine/consumption_trace_store.d.ts.map +1 -1
- package/dist/engine/consumption_trace_store.js +90 -47
- package/dist/engine/consumption_trace_store.js.map +1 -1
- package/dist/engine/contract_guard.d.ts +1 -1
- package/dist/engine/contract_guard.d.ts.map +1 -1
- package/dist/engine/contract_guard.js +9 -8
- package/dist/engine/contract_guard.js.map +1 -1
- package/dist/engine/contract_registry.d.ts.map +1 -1
- package/dist/engine/contract_registry.js +9 -11
- package/dist/engine/contract_registry.js.map +1 -1
- package/dist/engine/control_plane_contract.d.ts.map +1 -1
- package/dist/engine/control_plane_contract.js +7 -3
- package/dist/engine/control_plane_contract.js.map +1 -1
- package/dist/engine/convention_detector.js.map +1 -1
- package/dist/engine/core_engineering_principles.d.ts +1 -1
- package/dist/engine/core_engineering_principles.d.ts.map +1 -1
- package/dist/engine/core_engineering_principles.js +6 -6
- package/dist/engine/core_engineering_principles.js.map +1 -1
- package/dist/engine/core_experience_principle.d.ts +2 -2
- package/dist/engine/core_experience_principle.d.ts.map +1 -1
- package/dist/engine/core_experience_principle.js +4 -4
- package/dist/engine/core_experience_principle.js.map +1 -1
- package/dist/engine/debt_reporter.d.ts +1 -1
- package/dist/engine/debt_reporter.d.ts.map +1 -1
- package/dist/engine/debt_tracker.d.ts +1 -1
- package/dist/engine/debt_tracker.d.ts.map +1 -1
- package/dist/engine/debt_tracker.js.map +1 -1
- package/dist/engine/debugger.d.ts +1 -1
- package/dist/engine/debugger.d.ts.map +1 -1
- package/dist/engine/delivery.d.ts +1 -1
- package/dist/engine/delivery.d.ts.map +1 -1
- package/dist/engine/delivery.js.map +1 -1
- package/dist/engine/delivery_readiness.d.ts +2 -2
- package/dist/engine/delivery_readiness.d.ts.map +1 -1
- package/dist/engine/delivery_readiness.js.map +1 -1
- package/dist/engine/dependency_scanner.d.ts +1 -1
- package/dist/engine/dependency_scanner.d.ts.map +1 -1
- package/dist/engine/design_lifecycle_contract.js +2 -2
- package/dist/engine/design_lifecycle_contract.js.map +1 -1
- package/dist/engine/developer_sovereignty.d.ts +1 -1
- package/dist/engine/developer_sovereignty.d.ts.map +1 -1
- package/dist/engine/developer_sovereignty.js.map +1 -1
- package/dist/engine/diff_ownership_store.js.map +1 -1
- package/dist/engine/dual_layer_mechanism_registry.d.ts +1 -1
- package/dist/engine/dual_layer_mechanism_registry.d.ts.map +1 -1
- package/dist/engine/dual_layer_mechanism_registry.js +206 -84
- package/dist/engine/dual_layer_mechanism_registry.js.map +1 -1
- package/dist/engine/evolution_regression_gate.d.ts +2 -2
- package/dist/engine/evolution_regression_gate.js +3 -3
- package/dist/engine/evolution_regression_gate.js.map +1 -1
- package/dist/engine/evolver.d.ts +1 -1
- package/dist/engine/evolver.d.ts.map +1 -1
- package/dist/engine/evolver.js +1 -1
- package/dist/engine/evolver.js.map +1 -1
- package/dist/engine/expand_pipeline.d.ts +1 -1
- package/dist/engine/expand_pipeline.d.ts.map +1 -1
- package/dist/engine/explicit_asset_registry.d.ts.map +1 -1
- package/dist/engine/explicit_asset_registry.js +641 -268
- package/dist/engine/explicit_asset_registry.js.map +1 -1
- package/dist/engine/exploration.d.ts +1 -1
- package/dist/engine/exploration.d.ts.map +1 -1
- package/dist/engine/extension_platform_contracts.d.ts +2 -4
- package/dist/engine/extension_platform_contracts.d.ts.map +1 -1
- package/dist/engine/extension_platform_contracts.js +2 -3
- package/dist/engine/extension_platform_contracts.js.map +1 -1
- package/dist/engine/extension_scenario_registry.d.ts.map +1 -1
- package/dist/engine/extension_scenario_registry.js +5 -18
- package/dist/engine/extension_scenario_registry.js.map +1 -1
- package/dist/engine/failure_classifier.d.ts +1 -1
- package/dist/engine/failure_classifier.d.ts.map +1 -1
- package/dist/engine/feasibility_checker.d.ts +1 -1
- package/dist/engine/feasibility_checker.d.ts.map +1 -1
- package/dist/engine/foundation_scenario_registry.d.ts +3 -35
- package/dist/engine/foundation_scenario_registry.d.ts.map +1 -1
- package/dist/engine/foundation_scenario_registry.js +4 -181
- package/dist/engine/foundation_scenario_registry.js.map +1 -1
- package/dist/engine/foundation_scenario_runners.js +5 -5
- package/dist/engine/foundation_scenario_runners.js.map +1 -1
- package/dist/engine/gate_checks/checkAdapterLayerConsistency.d.ts +6 -0
- package/dist/engine/gate_checks/checkAdapterLayerConsistency.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkAdapterLayerConsistency.js +117 -0
- package/dist/engine/gate_checks/checkAdapterLayerConsistency.js.map +1 -0
- package/dist/engine/gate_checks/checkCodeObservability.d.ts +6 -0
- package/dist/engine/gate_checks/checkCodeObservability.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkCodeObservability.js +252 -0
- package/dist/engine/gate_checks/checkCodeObservability.js.map +1 -0
- package/dist/engine/gate_checks/checkCodeStyleEnforcement.d.ts +7 -0
- package/dist/engine/gate_checks/checkCodeStyleEnforcement.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkCodeStyleEnforcement.js +73 -0
- package/dist/engine/gate_checks/checkCodeStyleEnforcement.js.map +1 -0
- package/dist/engine/gate_checks/checkControlPlaneTrust.d.ts +9 -0
- package/dist/engine/gate_checks/checkControlPlaneTrust.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkControlPlaneTrust.js +111 -0
- package/dist/engine/gate_checks/checkControlPlaneTrust.js.map +1 -0
- package/dist/engine/gate_checks/checkCriticalProblemConsumption.d.ts +6 -0
- package/dist/engine/gate_checks/checkCriticalProblemConsumption.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkCriticalProblemConsumption.js +476 -0
- package/dist/engine/gate_checks/checkCriticalProblemConsumption.js.map +1 -0
- package/dist/engine/gate_checks/checkDependencyAudit.d.ts +6 -0
- package/dist/engine/gate_checks/checkDependencyAudit.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkDependencyAudit.js +40 -0
- package/dist/engine/gate_checks/checkDependencyAudit.js.map +1 -0
- package/dist/engine/gate_checks/checkDeprecatedCode.d.ts +6 -0
- package/dist/engine/gate_checks/checkDeprecatedCode.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkDeprecatedCode.js +262 -0
- package/dist/engine/gate_checks/checkDeprecatedCode.js.map +1 -0
- package/dist/engine/gate_checks/checkDiagnosticCentralization.d.ts +9 -0
- package/dist/engine/gate_checks/checkDiagnosticCentralization.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkDiagnosticCentralization.js +24 -0
- package/dist/engine/gate_checks/checkDiagnosticCentralization.js.map +1 -0
- package/dist/engine/gate_checks/checkDistFreshness.d.ts +6 -0
- package/dist/engine/gate_checks/checkDistFreshness.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkDistFreshness.js +57 -0
- package/dist/engine/gate_checks/checkDistFreshness.js.map +1 -0
- package/dist/engine/gate_checks/checkDualLayerSemantics.d.ts +6 -0
- package/dist/engine/gate_checks/checkDualLayerSemantics.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkDualLayerSemantics.js +88 -0
- package/dist/engine/gate_checks/checkDualLayerSemantics.js.map +1 -0
- package/dist/engine/gate_checks/checkImplementationContract.d.ts +6 -0
- package/dist/engine/gate_checks/checkImplementationContract.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkImplementationContract.js +90 -0
- package/dist/engine/gate_checks/checkImplementationContract.js.map +1 -0
- package/dist/engine/gate_checks/checkKnowledgeAssetSchemaP0.d.ts +6 -0
- package/dist/engine/gate_checks/checkKnowledgeAssetSchemaP0.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkKnowledgeAssetSchemaP0.js +30 -0
- package/dist/engine/gate_checks/checkKnowledgeAssetSchemaP0.js.map +1 -0
- package/dist/engine/gate_checks/checkKnowledgeLayer.d.ts +6 -0
- package/dist/engine/gate_checks/checkKnowledgeLayer.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkKnowledgeLayer.js +163 -0
- package/dist/engine/gate_checks/checkKnowledgeLayer.js.map +1 -0
- package/dist/engine/gate_checks/checkLongTermMechanization.d.ts +6 -0
- package/dist/engine/gate_checks/checkLongTermMechanization.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkLongTermMechanization.js +55 -0
- package/dist/engine/gate_checks/checkLongTermMechanization.js.map +1 -0
- package/dist/engine/gate_checks/checkMainlineConsumption.d.ts +6 -0
- package/dist/engine/gate_checks/checkMainlineConsumption.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkMainlineConsumption.js +312 -0
- package/dist/engine/gate_checks/checkMainlineConsumption.js.map +1 -0
- package/dist/engine/gate_checks/checkMechanismChain.d.ts +6 -0
- package/dist/engine/gate_checks/checkMechanismChain.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkMechanismChain.js +196 -0
- package/dist/engine/gate_checks/checkMechanismChain.js.map +1 -0
- package/dist/engine/gate_checks/checkMechanismIdentity.d.ts +6 -0
- package/dist/engine/gate_checks/checkMechanismIdentity.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkMechanismIdentity.js +125 -0
- package/dist/engine/gate_checks/checkMechanismIdentity.js.map +1 -0
- package/dist/engine/gate_checks/checkReleaseIssueDesignPath.d.ts +6 -0
- package/dist/engine/gate_checks/checkReleaseIssueDesignPath.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkReleaseIssueDesignPath.js +736 -0
- package/dist/engine/gate_checks/checkReleaseIssueDesignPath.js.map +1 -0
- package/dist/engine/gate_checks/checkStandardAssetCoverage.d.ts +6 -0
- package/dist/engine/gate_checks/checkStandardAssetCoverage.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkStandardAssetCoverage.js +34 -0
- package/dist/engine/gate_checks/checkStandardAssetCoverage.js.map +1 -0
- package/dist/engine/gate_checks/checkStateChainHealth.d.ts +6 -0
- package/dist/engine/gate_checks/checkStateChainHealth.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkStateChainHealth.js +147 -0
- package/dist/engine/gate_checks/checkStateChainHealth.js.map +1 -0
- package/dist/engine/gate_checks/checkTemplateKnowledgeHygiene.d.ts +10 -0
- package/dist/engine/gate_checks/checkTemplateKnowledgeHygiene.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkTemplateKnowledgeHygiene.js +314 -0
- package/dist/engine/gate_checks/checkTemplateKnowledgeHygiene.js.map +1 -0
- package/dist/engine/gate_checks/checkTestPollution.d.ts +6 -0
- package/dist/engine/gate_checks/checkTestPollution.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkTestPollution.js +67 -0
- package/dist/engine/gate_checks/checkTestPollution.js.map +1 -0
- package/dist/engine/gate_checks/checkWorkflowNavigation.d.ts +6 -0
- package/dist/engine/gate_checks/checkWorkflowNavigation.d.ts.map +1 -0
- package/dist/engine/gate_checks/checkWorkflowNavigation.js +168 -0
- package/dist/engine/gate_checks/checkWorkflowNavigation.js.map +1 -0
- package/dist/engine/gate_checks/helpers.d.ts +28 -0
- package/dist/engine/gate_checks/helpers.d.ts.map +1 -0
- package/dist/engine/gate_checks/helpers.js +91 -0
- package/dist/engine/gate_checks/helpers.js.map +1 -0
- package/dist/engine/gate_checks/types.d.ts +38 -0
- package/dist/engine/gate_checks/types.d.ts.map +1 -0
- package/dist/engine/gate_checks/types.js +5 -0
- package/dist/engine/gate_checks/types.js.map +1 -0
- package/dist/engine/governance_report.d.ts +1 -1
- package/dist/engine/governance_report.d.ts.map +1 -1
- package/dist/engine/helpers.d.ts +9 -0
- package/dist/engine/helpers.d.ts.map +1 -0
- package/dist/engine/helpers.js +13 -0
- package/dist/engine/helpers.js.map +1 -0
- package/dist/engine/hook_context_types.d.ts +66 -0
- package/dist/engine/hook_context_types.d.ts.map +1 -0
- package/dist/engine/hook_context_types.js +118 -0
- package/dist/engine/hook_context_types.js.map +1 -0
- package/dist/engine/impact_analyzer.d.ts +1 -1
- package/dist/engine/impact_analyzer.d.ts.map +1 -1
- package/dist/engine/impact_analyzer.js.map +1 -1
- package/dist/engine/input_material_extractor.d.ts.map +1 -1
- package/dist/engine/input_material_extractor.js +10 -9
- package/dist/engine/input_material_extractor.js.map +1 -1
- package/dist/engine/instruction_contract.d.ts +6 -0
- package/dist/engine/instruction_contract.d.ts.map +1 -1
- package/dist/engine/instruction_contract.js +2 -3
- package/dist/engine/instruction_contract.js.map +1 -1
- package/dist/engine/intent_expander.d.ts +10 -1
- package/dist/engine/intent_expander.d.ts.map +1 -1
- package/dist/engine/intent_expander.js +49 -9
- package/dist/engine/intent_expander.js.map +1 -1
- package/dist/engine/intent_router.d.ts +2 -0
- package/dist/engine/intent_router.d.ts.map +1 -1
- package/dist/engine/intent_router.js +1 -1
- package/dist/engine/intent_router.js.map +1 -1
- package/dist/engine/job_manager.js.map +1 -1
- package/dist/engine/knowledge_acceptance_registry.d.ts.map +1 -1
- package/dist/engine/knowledge_acceptance_registry.js +0 -10
- package/dist/engine/knowledge_acceptance_registry.js.map +1 -1
- package/dist/engine/knowledge_asset_consumer.d.ts +1 -1
- package/dist/engine/knowledge_asset_consumer.js +11 -11
- package/dist/engine/knowledge_asset_consumer.js.map +1 -1
- package/dist/engine/knowledge_asset_schema.d.ts +1 -1
- package/dist/engine/knowledge_asset_schema.js +1 -1
- package/dist/engine/knowledge_config_loader.d.ts.map +1 -1
- package/dist/engine/knowledge_config_loader.js +35 -4
- package/dist/engine/knowledge_config_loader.js.map +1 -1
- package/dist/engine/knowledge_injection_boundary.d.ts +1 -1
- package/dist/engine/knowledge_injection_boundary.d.ts.map +1 -1
- package/dist/engine/knowledge_injection_boundary.js +10 -4
- package/dist/engine/knowledge_injection_boundary.js.map +1 -1
- package/dist/engine/knowledge_manager.d.ts +1 -1
- package/dist/engine/knowledge_manager.d.ts.map +1 -1
- package/dist/engine/knowledge_scenario_registry.d.ts.map +1 -1
- package/dist/engine/knowledge_scenario_registry.js +0 -8
- package/dist/engine/knowledge_scenario_registry.js.map +1 -1
- package/dist/engine/knowledge_sovereignty.js.map +1 -1
- package/dist/engine/knowledge_template_contracts.d.ts +0 -1
- package/dist/engine/knowledge_template_contracts.d.ts.map +1 -1
- package/dist/engine/knowledge_template_contracts.js.map +1 -1
- package/dist/engine/legacy_type_migration.d.ts +63 -0
- package/dist/engine/legacy_type_migration.d.ts.map +1 -0
- package/dist/engine/legacy_type_migration.js +227 -0
- package/dist/engine/legacy_type_migration.js.map +1 -0
- package/dist/engine/lifecycle_knowledge_contract.d.ts +1 -1
- package/dist/engine/lifecycle_knowledge_contract.d.ts.map +1 -1
- package/dist/engine/local_docker_acceptance.js.map +1 -1
- package/dist/engine/log_governance.js +1 -1
- package/dist/engine/log_governance.js.map +1 -1
- package/dist/engine/main_path_integration_contract.js.map +1 -1
- package/dist/engine/mechanism_contract_registry.d.ts.map +1 -1
- package/dist/engine/mechanism_contract_registry.js +79 -14
- package/dist/engine/mechanism_contract_registry.js.map +1 -1
- package/dist/engine/mechanism_health_check.d.ts.map +1 -1
- package/dist/engine/mechanism_health_check.js +2 -3
- package/dist/engine/mechanism_health_check.js.map +1 -1
- package/dist/engine/migration_guard.d.ts +1 -1
- package/dist/engine/migration_guard.d.ts.map +1 -1
- package/dist/engine/mutation_audit.d.ts +1 -1
- package/dist/engine/mutation_audit.d.ts.map +1 -1
- package/dist/engine/next_action_planner.d.ts +1 -1
- package/dist/engine/next_action_planner.d.ts.map +1 -1
- package/dist/engine/next_action_planner.js +32 -36
- package/dist/engine/next_action_planner.js.map +1 -1
- package/dist/engine/observability.d.ts +1 -1
- package/dist/engine/observability.d.ts.map +1 -1
- package/dist/engine/observability.js.map +1 -1
- package/dist/engine/observed_consumption.d.ts.map +1 -1
- package/dist/engine/observed_consumption.js +5 -2
- package/dist/engine/observed_consumption.js.map +1 -1
- package/dist/engine/onboarding.d.ts +1 -1
- package/dist/engine/onboarding.d.ts.map +1 -1
- package/dist/engine/privacy_secret_contract.js +1 -1
- package/dist/engine/privacy_secret_contract.js.map +1 -1
- package/dist/engine/project_knowledge_contract.d.ts +1 -1
- package/dist/engine/project_knowledge_contract.d.ts.map +1 -1
- package/dist/engine/project_knowledge_contract.js +2 -1
- package/dist/engine/project_knowledge_contract.js.map +1 -1
- package/dist/engine/project_stage_detector.js.map +1 -1
- package/dist/engine/regression_matrix.js.map +1 -1
- package/dist/engine/release_issue_scenario_registry.d.ts +1 -3
- package/dist/engine/release_issue_scenario_registry.d.ts.map +1 -1
- package/dist/engine/release_issue_scenario_registry.js +7 -49
- package/dist/engine/release_issue_scenario_registry.js.map +1 -1
- package/dist/engine/release_readiness_gate.d.ts +25 -39
- package/dist/engine/release_readiness_gate.d.ts.map +1 -1
- package/dist/engine/release_readiness_gate.js +129 -3353
- package/dist/engine/release_readiness_gate.js.map +1 -1
- package/dist/engine/release_tool_harness.d.ts +2 -2
- package/dist/engine/release_tool_harness.d.ts.map +1 -1
- package/dist/engine/release_tool_harness.js +1 -1
- package/dist/engine/rollback_router.d.ts +35 -0
- package/dist/engine/rollback_router.d.ts.map +1 -0
- package/dist/engine/rollback_router.js +50 -0
- package/dist/engine/rollback_router.js.map +1 -0
- package/dist/engine/scaffolder.d.ts +1 -1
- package/dist/engine/scaffolder.d.ts.map +1 -1
- package/dist/engine/scope_controller.d.ts +1 -1
- package/dist/engine/scope_controller.d.ts.map +1 -1
- package/dist/engine/scope_controller.js +1 -1
- package/dist/engine/scope_controller.js.map +1 -1
- package/dist/engine/scope_resolver.d.ts +1 -1
- package/dist/engine/scope_resolver.d.ts.map +1 -1
- package/dist/engine/semantic_evidence.d.ts +1 -1
- package/dist/engine/semantic_evidence.d.ts.map +1 -1
- package/dist/engine/slice_executor.d.ts +79 -0
- package/dist/engine/slice_executor.d.ts.map +1 -0
- package/dist/engine/slice_executor.js +100 -0
- package/dist/engine/slice_executor.js.map +1 -0
- package/dist/engine/source_code_matcher.js +1 -1
- package/dist/engine/source_code_matcher.js.map +1 -1
- package/dist/engine/stage_gate_engine.d.ts +32 -0
- package/dist/engine/stage_gate_engine.d.ts.map +1 -0
- package/dist/engine/stage_gate_engine.js +105 -0
- package/dist/engine/stage_gate_engine.js.map +1 -0
- package/dist/engine/stale_current_task_detector.js.map +1 -1
- package/dist/engine/standard_asset_contract.d.ts +1 -1
- package/dist/engine/standard_asset_contract.d.ts.map +1 -1
- package/dist/engine/standard_asset_contract.js +7 -7
- package/dist/engine/standard_asset_contract.js.map +1 -1
- package/dist/engine/standard_asset_coverage.js +19 -19
- package/dist/engine/standard_asset_coverage.js.map +1 -1
- package/dist/engine/task_context.d.ts +6 -6
- package/dist/engine/task_context.d.ts.map +1 -1
- package/dist/engine/task_context.js +22 -20
- package/dist/engine/task_context.js.map +1 -1
- package/dist/engine/task_planner.d.ts +2 -2
- package/dist/engine/task_planner.d.ts.map +1 -1
- package/dist/engine/task_planner.js.map +1 -1
- package/dist/engine/task_stage_detector.d.ts +7 -1
- package/dist/engine/task_stage_detector.d.ts.map +1 -1
- package/dist/engine/task_stage_detector.js +82 -123
- package/dist/engine/task_stage_detector.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/template_asset_contract_registry.d.ts +2 -2
- package/dist/engine/template_asset_contract_registry.d.ts.map +1 -1
- package/dist/engine/template_asset_contract_registry.js +37 -10
- package/dist/engine/template_asset_contract_registry.js.map +1 -1
- package/dist/engine/template_asset_visibility.js +1 -1
- package/dist/engine/template_asset_visibility.js.map +1 -1
- package/dist/engine/template_init_sync.d.ts +29 -0
- package/dist/engine/template_init_sync.d.ts.map +1 -1
- package/dist/engine/template_init_sync.js +246 -69
- package/dist/engine/template_init_sync.js.map +1 -1
- package/dist/engine/template_manifest_io.d.ts +1 -1
- package/dist/engine/template_manifest_io.d.ts.map +1 -1
- package/dist/engine/template_manifest_io.js +13 -9
- package/dist/engine/template_manifest_io.js.map +1 -1
- package/dist/engine/template_mechanism_auditor.d.ts +1 -1
- package/dist/engine/template_mechanism_auditor.d.ts.map +1 -1
- package/dist/engine/template_mechanism_auditor.js +10 -10
- package/dist/engine/template_mechanism_auditor.js.map +1 -1
- package/dist/engine/test_generator.d.ts +1 -1
- package/dist/engine/test_generator.d.ts.map +1 -1
- package/dist/engine/test_quality.d.ts +1 -1
- package/dist/engine/test_quality.d.ts.map +1 -1
- package/dist/engine/tool_invocation_contract_registry.js +7 -7
- package/dist/engine/tool_invocation_contract_registry.js.map +1 -1
- package/dist/engine/traceability.d.ts +3 -3
- package/dist/engine/traceability.d.ts.map +1 -1
- package/dist/engine/traceability.js +1 -1
- package/dist/engine/traceability.js.map +1 -1
- package/dist/engine/user_feedback_contract.d.ts +1 -1
- package/dist/engine/user_feedback_contract.d.ts.map +1 -1
- package/dist/engine/user_feedback_contract.js +5 -5
- package/dist/engine/user_feedback_contract.js.map +1 -1
- package/dist/engine/verifier.d.ts +1 -1
- package/dist/engine/verifier.d.ts.map +1 -1
- package/dist/engine/verifier.js +1 -1
- package/dist/engine/verifier.js.map +1 -1
- package/dist/engine/workflow_contract_registry.d.ts +80 -42
- package/dist/engine/workflow_contract_registry.d.ts.map +1 -1
- package/dist/engine/workflow_contract_registry.js +341 -152
- package/dist/engine/workflow_contract_registry.js.map +1 -1
- package/dist/engine/workflow_navigation_contract.d.ts +17 -3
- package/dist/engine/workflow_navigation_contract.d.ts.map +1 -1
- package/dist/engine/workflow_navigation_contract.js +8 -16
- package/dist/engine/workflow_navigation_contract.js.map +1 -1
- package/dist/engine/workflow_rule_generator.d.ts +22 -0
- package/dist/engine/workflow_rule_generator.d.ts.map +1 -0
- package/dist/engine/workflow_rule_generator.js +83 -0
- package/dist/engine/workflow_rule_generator.js.map +1 -0
- package/dist/engine/zero_config_init.js.map +1 -1
- package/dist/knowledge/conflict_detector.d.ts +1 -1
- package/dist/knowledge/conflict_detector.d.ts.map +1 -1
- package/dist/knowledge/conflict_detector.js +2 -1
- package/dist/knowledge/conflict_detector.js.map +1 -1
- package/dist/knowledge/health_checker.d.ts +1 -1
- package/dist/knowledge/health_checker.d.ts.map +1 -1
- package/dist/knowledge/index_manager.d.ts +1 -1
- package/dist/knowledge/index_manager.d.ts.map +1 -1
- package/dist/knowledge/index_manager.js +7 -5
- package/dist/knowledge/index_manager.js.map +1 -1
- package/dist/knowledge/loader.d.ts +1 -1
- package/dist/knowledge/loader.d.ts.map +1 -1
- package/dist/knowledge/loader.js +7 -5
- package/dist/knowledge/loader.js.map +1 -1
- package/dist/knowledge/writer.d.ts +1 -1
- package/dist/knowledge/writer.d.ts.map +1 -1
- package/dist/types/analysis.d.ts +353 -0
- package/dist/types/analysis.d.ts.map +1 -0
- package/dist/types/analysis.js +2 -0
- package/dist/types/analysis.js.map +1 -0
- package/dist/types/base.d.ts +11 -0
- package/dist/types/base.d.ts.map +1 -0
- package/dist/{types.js → types/base.js} +1 -1
- package/dist/types/base.js.map +1 -0
- package/dist/types/config.d.ts +128 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/delivery.d.ts +261 -0
- package/dist/types/delivery.d.ts.map +1 -0
- package/dist/types/delivery.js +2 -0
- package/dist/types/delivery.js.map +1 -0
- package/dist/types/dual_layer.d.ts +97 -0
- package/dist/types/dual_layer.d.ts.map +1 -0
- package/dist/types/dual_layer.js +3 -0
- package/dist/types/dual_layer.js.map +1 -0
- package/dist/types/evidence.d.ts +41 -0
- package/dist/types/evidence.d.ts.map +1 -0
- package/dist/types/evidence.js +3 -0
- package/dist/types/evidence.js.map +1 -0
- package/dist/types/execution.d.ts +31 -0
- package/dist/types/execution.d.ts.map +1 -0
- package/dist/types/execution.js +3 -0
- package/dist/types/execution.js.map +1 -0
- package/dist/types/index.d.ts +13 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +13 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/knowledge.d.ts +105 -0
- package/dist/types/knowledge.d.ts.map +1 -0
- package/dist/types/knowledge.js +5 -0
- package/dist/types/knowledge.js.map +1 -0
- package/dist/types/phase.d.ts +50 -0
- package/dist/types/phase.d.ts.map +1 -0
- package/dist/types/phase.js +3 -0
- package/dist/types/phase.js.map +1 -0
- package/dist/types/pipeline.d.ts +353 -0
- package/dist/types/pipeline.d.ts.map +1 -0
- package/dist/types/pipeline.js +2 -0
- package/dist/types/pipeline.js.map +1 -0
- package/dist/types/review.d.ts +149 -0
- package/dist/types/review.d.ts.map +1 -0
- package/dist/types/review.js +2 -0
- package/dist/types/review.js.map +1 -0
- package/dist/types/task.d.ts +203 -0
- package/dist/types/task.d.ts.map +1 -0
- package/dist/types/task.js +2 -0
- package/dist/types/task.js.map +1 -0
- package/package.json +3 -6
- package/templates/artifacts/existing-system//344/270/200/351/224/256/345/274/200/345/205/263/351/205/215/347/275/256/346/250/241/347/211/210.json +24 -0
- package/templates/artifacts/existing-system//345/216/206/345/217/262/346/225/260/346/215/256/346/270/205/346/264/227/350/204/232/346/234/254/346/250/241/347/211/210.md +44 -0
- package/templates/artifacts/existing-system//345/216/206/345/217/262/351/201/227/347/225/231/351/233/267/345/214/272/346/270/205/345/215/225/346/250/241/347/211/210.md +43 -0
- package/templates/artifacts/existing-system//345/220/221/345/220/216/345/205/274/345/256/271/346/200/247/345/220/210/350/247/204/346/212/245/345/221/212/346/250/241/347/211/210.md +36 -0
- package/templates/artifacts/existing-system//345/242/236/351/207/217/350/276/271/347/225/214/347/225/214/345/256/232/346/226/207/346/241/243/346/250/241/347/211/210.md +36 -0
- package/templates/artifacts/existing-system//346/224/271/351/200/240/345/275/261/345/223/215/350/214/203/345/233/264/350/257/204/344/274/260/346/250/241/347/211/210.md +39 -0
- package/templates/artifacts/existing-system//346/225/260/346/215/256/350/241/200/347/274/230/345/233/276/346/250/241/347/211/210.md +36 -0
- package/templates/artifacts/existing-system//346/226/260/350/200/201/351/200/273/350/276/221/346/257/224/345/257/271/346/227/245/345/277/227/346/250/241/347/211/210.md +29 -0
- package/templates/artifacts/existing-system//347/264/247/346/200/245/345/233/236/346/273/232/346/211/213/345/206/214/346/250/241/347/211/210.md +38 -0
- package/templates/artifacts/existing-system//351/232/224/347/246/273/351/200/202/351/205/215/345/231/250/346/226/271/346/241/210/346/250/241/347/211/210.md +34 -0
- package/templates/artifacts/shared/ADR/346/250/241/347/211/210.md +41 -0
- package/templates/{knowledge/acceptance_templates → artifacts/shared}/API/346/216/245/345/217/243/350/247/204/346/240/274/346/226/207/346/241/243/346/250/241/347/211/210.md +25 -0
- package/templates/artifacts/shared//344/273/243/347/240/201/345/256/241/346/237/245/346/212/245/345/221/212/346/250/241/347/211/210.md +33 -0
- package/templates/artifacts/shared//345/210/207/347/211/207/350/256/241/345/210/222/346/250/241/347/211/210.md +45 -0
- package/templates/{knowledge/acceptance_templates → artifacts/shared}//345/216/237/345/236/213/350/257/264/346/230/216/346/250/241/347/211/210.md +2 -0
- package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/236/266/346/236/204/350/256/276/350/256/241/346/250/241/347/211/210.md +7 -0
- package/templates/gates/existing-system/gate-/347/216/260/346/234/211/347/263/273/347/273/237/345/210/206/346/236/220.yaml +13 -0
- package/templates/gates/existing-system/gate-/347/274/226/347/240/201/344/270/216/345/215/225/345/205/203/346/265/213/350/257/225.yaml +18 -0
- package/templates/gates/existing-system/gate-/350/257/225/350/277/220/350/241/214.yaml +21 -0
- package/templates/gates/shared/gate-/344/273/273/345/212/241/350/247/204/345/210/222.yaml +18 -0
- package/templates/gates/shared/gate-/347/274/226/347/240/201/344/270/216/345/215/225/345/205/203/346/265/213/350/257/225.yaml +14 -0
- package/templates/{knowledge/rules//346/225/217/346/204/237/344/277/241/346/201/257/346/227/245/345/277/227 → internal/rules//346/225/217/346/204/237/344/277/241/346/201/257/345/244/204/347/220/206}/350/247/204/345/210/231.md +42 -19
- package/templates/{knowledge → internal}/rules//346/274/224/350/277/233/345/233/236/345/275/222/351/227/250/346/216/247/350/247/204/345/210/231.md +2 -0
- package/templates/{knowledge/procedures → procedures}//346/236/266/346/236/204/350/256/276/350/256/241/345/267/245/344/275/234/346/265/201.md +1 -1
- package/templates/{knowledge/procedures → procedures}//347/264/247/346/200/245/344/277/256/345/244/215/346/265/201/346/260/264/347/272/277.md +1 -1
- package/templates/{knowledge/procedures → procedures}//350/260/203/350/257/225/346/216/222/346/237/245/346/265/201/347/250/213.md +1 -1
- package/templates/{knowledge/procedures → procedures}//351/252/214/346/224/266/346/265/213/350/257/225/350/247/204/345/210/222.md +1 -1
- package/templates/rules/existing-system//345/205/274/345/256/271/346/200/247/346/243/200/346/237/245/350/247/204/345/210/231.md +33 -0
- package/templates/rules/existing-system//350/200/246/345/220/210/346/243/200/346/265/213/350/247/204/345/210/231.md +35 -0
- package/templates/rules/existing-system//350/257/225/350/277/220/350/241/214/347/206/224/346/226/255/350/247/204/345/210/231.md +39 -0
- package/templates/rules/existing-system//351/230/262/345/276/241/346/200/247/347/274/226/347/240/201/350/247/204/345/210/231.md +35 -0
- package/templates/rules/existing-system//351/233/267/345/214/272/345/217/215/346/250/241/345/274/217/346/270/205/345/215/225.md +34 -0
- package/templates/rules/new-system//350/201/224/350/260/203/350/256/276/350/256/241/347/274/272/351/231/267/345/210/244/345/256/232/350/247/204/345/210/231.md +36 -0
- package/templates/rules/shared//344/270/200/350/207/264/346/200/247/346/240/241/351/252/214/350/247/204/345/210/231.md +21 -0
- package/templates/rules/shared//350/201/224/350/260/203/351/252/214/350/257/201/346/270/205/345/215/225.md +29 -0
- package/templates/rules/shared//350/246/206/347/233/226/347/216/207/346/240/207/345/207/206.md +26 -0
- package/dist/engine/deprecated_contract.d.ts +0 -21
- package/dist/engine/deprecated_contract.d.ts.map +0 -1
- package/dist/engine/deprecated_contract.js +0 -14
- package/dist/engine/deprecated_contract.js.map +0 -1
- package/dist/engine/historical_issue_mechanization_matrix.d.ts +0 -28
- package/dist/engine/historical_issue_mechanization_matrix.d.ts.map +0 -1
- package/dist/engine/historical_issue_mechanization_matrix.js +0 -134
- package/dist/engine/historical_issue_mechanization_matrix.js.map +0 -1
- package/dist/engine/implementation_roadmap_registry.d.ts +0 -105
- package/dist/engine/implementation_roadmap_registry.d.ts.map +0 -1
- package/dist/engine/implementation_roadmap_registry.js +0 -1340
- package/dist/engine/implementation_roadmap_registry.js.map +0 -1
- package/dist/engine/mechanism_family_registry.d.ts +0 -48
- package/dist/engine/mechanism_family_registry.d.ts.map +0 -1
- package/dist/engine/mechanism_family_registry.js +0 -197
- package/dist/engine/mechanism_family_registry.js.map +0 -1
- package/dist/engine/project_knowledge_system_regression_matrix.d.ts +0 -27
- package/dist/engine/project_knowledge_system_regression_matrix.d.ts.map +0 -1
- package/dist/engine/project_knowledge_system_regression_matrix.js +0 -295
- package/dist/engine/project_knowledge_system_regression_matrix.js.map +0 -1
- package/dist/engine/release_gate.d.ts +0 -29
- package/dist/engine/release_gate.d.ts.map +0 -1
- package/dist/engine/release_gate.js +0 -675
- package/dist/engine/release_gate.js.map +0 -1
- package/dist/types.d.ts +0 -1737
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js.map +0 -1
- package/templates/knowledge/acceptance_templates//346/216/245/345/217/243/350/256/276/350/256/241/346/250/241/347/211/210.md +0 -82
- package/templates/knowledge/procedures//346/236/266/346/236/204/350/256/276/350/256/241/346/265/201/347/250/213.md +0 -57
- package/templates/knowledge/procedures//347/264/247/346/200/245/344/277/256/345/244/215/346/265/201/347/250/213.md +0 -60
- package/templates/knowledge/procedures//347/274/272/351/231/267/344/277/256/345/244/215/346/265/201/346/260/264/347/272/277.md +0 -55
- package/templates/knowledge/procedures//351/252/214/350/257/201/350/256/241/345/210/222/346/265/201/347/250/213.md +0 -59
- package/templates/knowledge/rules//346/225/217/346/204/237/344/277/241/346/201/257/345/244/204/347/220/206/350/247/204/345/210/231.md +0 -56
- package/templates/knowledge/rules//346/274/224/350/277/233/345/233/236/345/275/222/350/247/204/345/210/231.md +0 -51
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}/Bug/345/210/206/346/236/220/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}/OOD/350/256/276/350/256/241/346/221/230/350/246/201/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}/POC/347/273/223/350/256/272/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//344/273/243/347/240/201/346/263/250/351/207/212/344/270/216/346/227/245/345/277/227/351/252/214/346/224/266/346/250/241/346/235/277.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//345/211/215/347/253/257/351/241/265/351/235/242/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//345/220/216/347/253/257API/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//345/220/216/347/253/257/345/256/236/347/216/260/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//345/256/211/345/205/250/345/256/241/350/256/241/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/templates → artifacts/shared}//345/256/241/346/237/245/346/221/230/350/246/201.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/200/247/350/203/275/345/210/206/346/236/220/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/212/200/346/234/257/351/200/211/345/236/213/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/216/245/345/217/243/345/257/271/346/216/245/346/226/271/346/241/210/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/225/205/351/232/234/345/244/215/347/233/230/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/225/260/346/215/256/345/272/223/345/217/230/346/233/264/346/226/271/346/241/210/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/225/260/346/215/256/345/272/223/345/217/230/346/233/264/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/225/260/346/215/256/345/272/223/350/256/276/350/256/241/346/226/207/346/241/243/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//346/265/213/350/257/225/350/256/241/345/210/222/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//350/256/276/350/256/241/344/270/200/350/207/264/346/200/247/351/252/214/346/224/266/346/212/245/345/221/212/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//350/257/246/347/273/206/350/256/276/350/256/241/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//350/277/201/347/247/273/350/257/204/344/274/260/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//351/200/232/347/224/250/350/264/250/351/207/217/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//351/207/215/346/236/204/346/226/271/346/241/210/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//351/234/200/346/261/202/345/210/206/346/236/220/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/acceptance_templates → artifacts/shared}//351/234/200/346/261/202/345/216/237/345/236/213/350/256/276/350/256/241/345/256/236/347/216/260/350/277/275/350/270/252/347/237/251/351/230/265/346/250/241/347/211/210.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//344/270/273/351/223/276/350/267/257/346/216/245/345/205/245/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//344/274/232/350/257/235/346/201/242/345/244/215.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//345/267/245/344/275/234/346/265/201/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//346/240/270/345/277/203/345/267/245/347/250/213/346/211/247/350/241/214/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//347/237/245/350/257/206/346/263/250/345/205/245/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//351/232/220/347/247/201/345/256/241/346/237/245/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/checklists → checklists}//351/252/214/350/257/201/351/252/214/346/224/266/346/270/205/345/215/225.md" +0 -0
- /package/templates/{knowledge/domain → domain}//345/244/232/347/247/237/346/210/267.md" +0 -0
- /package/templates/{knowledge/domain → domain}//345/256/241/350/256/241/346/227/245/345/277/227.md" +0 -0
- /package/templates/{knowledge/domain → domain}//345/257/274/345/205/245/345/257/274/345/207/272/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/domain → domain}//345/267/245/344/275/234/346/265/201/345/274/225/346/223/216.md" +0 -0
- /package/templates/{knowledge/domain → domain}//346/212/245/350/241/250/347/273/237/350/256/241.md" +0 -0
- /package/templates/{knowledge/domain → domain}//346/224/257/344/273/230/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/domain → domain}//346/225/260/346/215/256/346/235/203/351/231/220.md" +0 -0
- /package/templates/{knowledge/domain → domain}//351/200/232/347/224/250/346/234/272/346/242/260/346/235/241/346/254/276.md" +0 -0
- /package/templates/{knowledge/domain → domain}//351/200/232/347/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}/Diff/345/275/222/345/261/236/350/277/275/350/270/252.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}/Java/350/264/250/351/207/217/351/227/250/347/246/201.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}/LLM/351/242/204/347/256/227/347/275/221/345/205/263.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//344/273/273/345/212/241/344/270/212/344/270/213/346/226/207/347/224/237/345/221/275/345/221/250/346/234/237.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//344/273/273/345/212/241/347/256/241/347/220/206/345/231/250.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//344/275/234/347/224/250/345/237/237/344/270/216/345/257/206/351/222/245/346/213/246/346/210/252.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//344/275/234/347/224/250/345/237/237/347/247/237/347/272/246.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/206/262/347/252/201/351/227/250/347/246/201.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/206/263/347/255/226/347/275/221/345/205/263.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/217/230/345/274/202/345/256/241/350/256/241.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/233/236/345/275/222/347/237/251/351/230/265.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/267/245/344/275/234/345/214/272/344/272/222/346/226/245/351/224/201.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/267/245/344/275/234/345/214/272/345/224/244/351/206/222.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/271/266/345/217/221/351/224/201.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//345/274/200/345/217/221/350/200/205/345/256/252/346/263/225.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//346/225/217/346/204/237/344/277/241/346/201/257/346/211/253/346/217/217.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//346/262/273/347/220/206/350/277/220/350/241/214/346/227/266/345/276/252/347/216/257.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//346/265/201/345/274/217/345/277/203/350/267/263.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//347/237/245/350/257/206/344/270/273/346/235/203.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//350/257/255/344/271/211/350/257/201/346/215/256.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//350/277/220/350/241/214/345/256/211/345/205/250/345/214/205.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//351/233/266/351/205/215/347/275/256/345/210/235/345/247/213/345/214/226.md" +0 -0
- /package/templates/{knowledge/patterns/core → internal/patterns}//351/252/214/350/257/201/345/221/275/344/273/244/347/224/237/346/210/220.md" +0 -0
- /package/templates/{knowledge → internal}/rules/OOD/344/270/216SOLID/350/256/276/350/256/241/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//344/272/247/347/211/251/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//344/273/243/347/240/201/346/263/250/351/207/212/344/270/216/346/227/245/345/277/227/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//344/273/273/345/212/241/344/270/212/344/270/213/346/226/207/347/224/237/345/221/275/345/221/250/346/234/237/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/220/216/347/253/257/345/256/236/347/216/260/345/267/245/347/250/213/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/221/275/344/273/244/346/211/247/350/241/214/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/267/245/344/275/234/346/265/201/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/267/245/344/275/234/346/265/201/345/257/274/350/210/252/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/267/245/344/275/234/346/265/201/346/250/241/346/235/277/345/214/205/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//345/267/245/345/205/267/350/260/203/347/224/250/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/204/217/345/233/276/350/267/257/347/224/261/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/211/247/350/241/214/345/256/210/345/215/253/350/257/204/344/274/260/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/211/251/345/261/225/347/224/237/345/221/275/345/221/250/346/234/237/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/212/200/346/234/257/345/206/263/347/255/226/344/270/273/346/235/203/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/226/275/345/267/245/346/214/207/344/273/244/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/227/245/345/277/227/346/262/273/347/220/206/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/234/272/345/210/266/350/207/252/346/262/273/347/220/206/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/236/266/346/236/204/345/206/263/347/255/226/347/240/224/350/256/250/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/240/207/345/207/206/350/265/204/344/272/247/350/246/206/347/233/226/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/240/270/345/277/203/344/275/223/351/252/214/345/216/237/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/240/270/345/277/203/345/267/245/347/250/213/346/211/247/350/241/214/345/216/237/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/250/241/346/235/277/350/265/204/344/272/247/345/217/257/350/247/201/346/200/247/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//346/263/250/345/206/214/350/241/250/345/237/272/347/241/200/350/256/276/346/226/275/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/224/250/346/210/267/345/217/215/351/246/210/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/237/245/350/257/206/346/262/273/347/220/206/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/237/245/350/257/206/346/263/250/345/205/245/350/276/271/347/225/214/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/237/245/350/257/206/350/265/204/344/272/247/346/262/273/347/220/206/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/254/254/344/270/200/346/200/247/345/216/237/347/220/206/346/216/250/347/220/206/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//347/273/206/350/212/202/347/272/252/345/276/213/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/204/221/346/232/264/344/270/216/346/226/271/346/241/210/346/216/242/347/264/242/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/256/241/345/210/222/345/211/215/347/275/256/351/227/250/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/256/276/350/256/241/344/272/247/347/211/251/345/214/205/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/257/201/346/215/256/351/251/261/345/212/250/344/270/216/345/217/215/345/271/273/350/247/211/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/267/250/345/271/263/345/217/260/350/267/257/345/276/204/345/256/211/345/205/250/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//350/276/223/345/205/245/346/235/220/346/226/231/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/200/232/347/224/250/345/206/263/347/255/226/347/240/224/350/256/250/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/205/215/347/275/256/344/274/230/345/205/210/347/272/247/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/205/215/347/275/256/350/220/275/347/233/230/350/276/271/347/225/214/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/230/262/345/255/244/345/262/233/345/256/236/347/216/260/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/233/266/351/205/215/347/275/256/345/210/235/345/247/213/345/214/226/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/252/214/346/224/266/346/250/241/346/235/277/350/276/223/345/207/272/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge → internal}/rules//351/252/214/350/257/201/345/245/221/347/272/246/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}/OOD/350/256/276/350/256/241/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}/Schema/345/217/230/346/233/264/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//344/270/273/351/223/276/350/267/257/346/216/245/345/205/245/351/252/214/350/257/201/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//344/273/243/347/240/201/351/227/250/347/246/201/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//344/273/273/345/212/241/346/213/206/350/247/243/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/205/250/347/224/237/345/221/275/345/221/250/346/234/237/345/267/245/344/275/234/346/265/201/345/257/274/350/210/252.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/212/237/350/203/275/345/274/200/345/217/221/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/220/216/347/253/257/346/216/245/345/217/243/345/256/236/347/216/260/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/221/275/344/273/244/346/211/247/350/241/214/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/256/211/345/205/250/345/212/240/345/233/272/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//345/267/245/345/205/267/350/260/203/347/224/250/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/200/247/350/203/275/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/204/217/345/233/276/350/267/257/347/224/261/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/216/245/345/217/243/351/233/206/346/210/220/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/225/260/346/215/256/345/272/223/350/277/201/347/247/273/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/234/254/345/234/260/346/265/217/350/247/210/345/231/250/351/252/214/346/224/266/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/236/266/346/236/204/345/206/263/347/255/226/347/240/224/350/256/250/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/246/202/345/277/265/351/252/214/350/257/201/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/265/213/350/257/225/344/274/230/345/205/210/347/274/226/347/240/201/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//346/272/220/347/240/201/345/216/237/345/236/213/344/272/244/344/273/230/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//347/216/260/346/234/211/347/263/273/347/273/237/345/267/256/350/267/235/345/210/206/346/236/220/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//347/237/245/350/257/206/347/273/264/346/212/244/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//347/274/226/347/240/201/345/211/215/346/276/204/346/270/205/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//350/207/252/344/270/273/351/200/211/345/236/213/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//350/256/276/350/256/241/344/272/247/347/211/251/347/224/237/346/210/220/344/270/216/345/244/215/351/252/214/345/267/245/344/275/234/346/265/201.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//350/257/246/347/273/206/350/256/276/350/256/241/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//350/277/201/347/247/273/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//351/203/250/347/275/262/345/217/221/345/270/203/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//351/207/215/346/236/204/346/265/201/346/260/264/347/272/277.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//351/233/206/346/210/220/351/252/214/350/257/201/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/procedures → procedures}//351/234/200/346/261/202/346/276/204/346/270/205/346/265/201/347/250/213.md" +0 -0
- /package/templates/{knowledge/product_profiles → profiles}/b2b-internal.yaml +0 -0
- /package/templates/{knowledge/product_profiles → profiles}/b2c.yaml +0 -0
- /package/templates/{knowledge/product_profiles → profiles}/saas.yaml +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}/SOLID/344/273/243/347/240/201/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//344/272/244/344/273/230/345/256/214/345/244/207/346/200/247/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review → rules/shared}//344/273/243/347/240/201/345/217/257/347/273/264/346/212/244/346/200/247/344/270/216/345/217/257/350/247/202/346/265/213/346/200/247/345/256/241/346/237/245.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//345/220/216/347/253/257/345/256/236/347/216/260/345/267/245/347/250/213/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//345/256/211/345/205/250/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//345/271/266/345/217/221/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//346/200/247/350/203/275/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//346/216/245/345/217/243/345/245/221/347/272/246/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//346/236/266/346/236/204/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
- /package/templates/{knowledge/review_rules → rules/shared}//350/264/250/351/207/217/345/256/241/346/237/245/350/247/204/345/210/231.md" +0 -0
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 门禁检查模块 — Phase 22: MCP 控制面可信与受控生成链路验证。
|
|
3
|
+
*
|
|
4
|
+
* 验证控制面矩阵完整性、旁路拦截、工具契约有效性、
|
|
5
|
+
* 受控生成链路 must-pass/must-fail、CLI 入口与反旁路硬规则。
|
|
6
|
+
*/
|
|
7
|
+
import path from "node:path";
|
|
8
|
+
import { safeReadCached } from "./helpers.js";
|
|
9
|
+
export async function check(ctx, hardFail) {
|
|
10
|
+
try {
|
|
11
|
+
const control = await import("../control_plane_contract.js");
|
|
12
|
+
const toolContracts = await import("../tool_invocation_contract_registry.js");
|
|
13
|
+
const matrix = control.CONTROL_PLANE_MATRIX ?? [];
|
|
14
|
+
const branchDetails = control.CONTROL_PLANE_BRANCH_DETAILS ?? [];
|
|
15
|
+
if (matrix.length !== 15) {
|
|
16
|
+
hardFail("CONTROL_PLANE_MATRIX_INCOMPLETE", `控制面矩阵数量应为 15,实际为 ${matrix.length}`, ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不覆盖 MCP 控制面可用性与旁路", "补齐控制面矩阵");
|
|
17
|
+
}
|
|
18
|
+
if (branchDetails.length < 30) {
|
|
19
|
+
hardFail("CONTROL_PLANE_BRANCH_DETAILS_INCOMPLETE", `控制面枝叶细节至少 30 条,实际为 ${branchDetails.length}`, ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不覆盖枝叶防回归细节", "补齐枝叶细节");
|
|
20
|
+
}
|
|
21
|
+
if (!control.isSoloforgeStateBypassCommand("rm -rf .soloforge/state/current-task.json")) {
|
|
22
|
+
hardFail("CONTROL_PLANE_BYPASS_GUARD_FALSE_NEGATIVE", "Bash 直接删除 .soloforge/state 未被识别为旁路", ["src/engine/control_plane_contract.ts", "src/bin/soloforge.ts"], "problem-72", "旧 gate 不验证 Bash/Edit/Write 旁路", "修复旁路拦截");
|
|
23
|
+
}
|
|
24
|
+
if (control.isSoloforgeStateBypassCommand("cat .soloforge/state/current-task.json")) {
|
|
25
|
+
hardFail("CONTROL_PLANE_BYPASS_GUARD_FALSE_POSITIVE", "只读查看 .soloforge/state 被误判为写旁路", ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不检查旁路误拦", "修复旁路判断");
|
|
26
|
+
}
|
|
27
|
+
const contractFindings = control.validateControlPlaneToolContracts(toolContracts.listToolInvocationContracts());
|
|
28
|
+
const hardContractFindings = contractFindings.filter((finding) => finding.severity === "hard_fail");
|
|
29
|
+
if (hardContractFindings.length > 0) {
|
|
30
|
+
hardFail("CONTROL_PLANE_TOOL_CONTRACT_INVALID", `工具控制面契约存在 ${hardContractFindings.length} 个 hard_fail: ${hardContractFindings.map((f) => f.code).join(", ")}`, ["src/engine/tool_invocation_contract_registry.ts"], "problem-72", "旧 gate 不检查工具错标和死链路", "修复工具契约");
|
|
31
|
+
}
|
|
32
|
+
const fakeContractFindings = control.validateControlPlaneToolContracts([{
|
|
33
|
+
tool_name: "sf_fake_readonly_writer",
|
|
34
|
+
category: "read_only_bypass",
|
|
35
|
+
side_effects: ["task_context_write"],
|
|
36
|
+
requires_authorization: false,
|
|
37
|
+
requires_workflow: false,
|
|
38
|
+
description: "错误契约",
|
|
39
|
+
default_next_tools: [],
|
|
40
|
+
forbidden_next_tools: [],
|
|
41
|
+
}]);
|
|
42
|
+
if (!fakeContractFindings.some((finding) => finding.code === "CONTROL_PLANE_READ_ONLY_HAS_SIDE_EFFECT")) {
|
|
43
|
+
hardFail("CONTROL_PLANE_TOOL_CONTRACT_FALSE_PASS", "read_only_bypass 写状态的假契约未被阻断", ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不验证契约错标 must-fail", "修复工具契约验证");
|
|
44
|
+
}
|
|
45
|
+
const bypassAssessment = control.assessControlledGenerationChain({
|
|
46
|
+
changed_files: ["src/Foo.java"],
|
|
47
|
+
verified_files: ["src/Foo.java"],
|
|
48
|
+
traces: [{ tool_name: "Bash", status: "passed", evidence_kind: "command_execution" }],
|
|
49
|
+
delivery_status: "delivered",
|
|
50
|
+
});
|
|
51
|
+
if (bypassAssessment.accepted || !bypassAssessment.findings.some((finding) => finding.code === "CONTROLLED_GENERATION_MISSING_MCP_PROVENANCE")) {
|
|
52
|
+
hardFail("CONTROLLED_GENERATION_BYPASS_FALSE_PASS", "非 MCP 生成代码被错误接受为完整可信交付", ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不验证来源归因", "修复受控生成链路");
|
|
53
|
+
}
|
|
54
|
+
const partialAssessment = control.assessControlledGenerationChain({
|
|
55
|
+
changed_files: ["src/Foo.java", "src/Bar.java"],
|
|
56
|
+
verified_files: ["src/Foo.java"],
|
|
57
|
+
traces: [
|
|
58
|
+
{ tool_name: "sf_classify", task_id: "t1", status: "passed" },
|
|
59
|
+
{ tool_name: "sf_expand", task_id: "t1", status: "passed" },
|
|
60
|
+
{ tool_name: "sf_verify", task_id: "t1", status: "passed", evidence_kind: "command_execution" },
|
|
61
|
+
],
|
|
62
|
+
delivery_status: "delivered",
|
|
63
|
+
});
|
|
64
|
+
if (partialAssessment.accepted || !partialAssessment.findings.some((finding) => finding.code === "CONTROLLED_GENERATION_CHANGED_FILE_UNVERIFIED")) {
|
|
65
|
+
hardFail("CONTROLLED_GENERATION_SCOPE_FALSE_PASS", "changed_files 子集验证被错误接受", ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不验证范围完整性", "修复验证范围对账");
|
|
66
|
+
}
|
|
67
|
+
const passAssessment = control.assessControlledGenerationChain({
|
|
68
|
+
changed_files: ["src/Foo.java"],
|
|
69
|
+
verified_files: ["src/Foo.java"],
|
|
70
|
+
traces: [
|
|
71
|
+
{ tool_name: "sf_classify", task_id: "t1", status: "passed" },
|
|
72
|
+
{ tool_name: "sf_expand", task_id: "t1", status: "passed" },
|
|
73
|
+
{ tool_name: "sf_verify", task_id: "t1", status: "passed", evidence_kind: "command_execution" },
|
|
74
|
+
{ tool_name: "sf_deliver", task_id: "t1", status: "passed" },
|
|
75
|
+
],
|
|
76
|
+
delivery_status: "delivered",
|
|
77
|
+
});
|
|
78
|
+
if (!passAssessment.accepted || passAssessment.confidence !== "full") {
|
|
79
|
+
hardFail("CONTROLLED_GENERATION_VALID_CHAIN_BLOCKED", "完整 MCP 受控生成链路被误阻断", ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不验证 must-pass", "修复受控生成链路");
|
|
80
|
+
}
|
|
81
|
+
const cliText = safeReadCached(path.join(ctx.rootDir, "src", "bin", "soloforge.ts"), ctx.readCache) ?? "";
|
|
82
|
+
if (!cliText.includes("case \"doctor\"") || !cliText.includes("auditControlPlaneProject")) {
|
|
83
|
+
hardFail("CONTROL_PLANE_DOCTOR_MISSING", "CLI 未提供 soloforge doctor 控制面诊断入口", ["src/bin/soloforge.ts"], "problem-72", "旧 gate 没有 MCP 控制面恢复入口", "补 soloforge doctor");
|
|
84
|
+
}
|
|
85
|
+
if (!cliText.includes("仍处于 ${currentTask.status}") ||
|
|
86
|
+
!cliText.includes("缺少 design_artifact_pack") ||
|
|
87
|
+
!cliText.includes("没有受控 SoloForge 任务") ||
|
|
88
|
+
!cliText.includes("不得取消/归档当前任务后改用 Bash/Edit/Write") ||
|
|
89
|
+
!cliText.includes("禁止通过 Bash 直接写业务实现文件")) {
|
|
90
|
+
hardFail("CONTROLLED_IMPLEMENTATION_WRITE_GATE_MISSING", "check-write/check-bash 未覆盖 expanding 卡死、设计产物存在但缺 design_artifact_pack、无受控任务和 Bash 直接编码旁路", ["src/bin/soloforge.ts"], "problem-72", "旧 gate 只在交付层发现非 MCP 来源,未在写入入口阻断真实用户项目旁路", "在 check-write/check-bash 对业务实现文件增加受控任务与设计产物包前置门");
|
|
91
|
+
}
|
|
92
|
+
const assetManifestText = safeReadCached(path.join(ctx.rootDir, "src", "engine", "asset_manifest.ts"), ctx.readCache) ?? "";
|
|
93
|
+
const workflowRuleText = safeReadCached(path.join(ctx.rootDir, "templates", "internal", "rules", "工作流导航契约规则.md"), ctx.readCache) ?? "";
|
|
94
|
+
const lifecycleProcedureText = safeReadCached(path.join(ctx.rootDir, "templates", "procedures", "全生命周期工作流导航.md"), ctx.readCache) ?? "";
|
|
95
|
+
const antiBypassNeedles = [
|
|
96
|
+
"不得建议取消任务后直接写",
|
|
97
|
+
"不得建议\u201C先用 Bash 直接修改业务代码\u201D",
|
|
98
|
+
"不得手动删除 `.soloforge/state`",
|
|
99
|
+
"归档后仍必须重新 `sf_classify -> sf_expand`",
|
|
100
|
+
];
|
|
101
|
+
const antiBypassText = `${assetManifestText}\n${workflowRuleText}\n${lifecycleProcedureText}`;
|
|
102
|
+
const missingAntiBypassNeedles = antiBypassNeedles.filter((needle) => !antiBypassText.includes(needle));
|
|
103
|
+
if (missingAntiBypassNeedles.length > 0) {
|
|
104
|
+
hardFail("CONTROL_PLANE_BLOCKED_RECOVERY_PROMPT_MISSING", `适配器/知识规则缺少阻断恢复反旁路硬规则: ${missingAntiBypassNeedles.join(", ")}`, ["src/engine/asset_manifest.ts", "templates/internal/rules/工作流导航契约规则.md", "templates/procedures/全生命周期工作流导航.md"], "problem-72", "运行时 hook 能拦截写入,但模型仍可能口头建议取消任务、Bash 直写或手动清状态", "把阻断恢复反旁路协议注入 adapter workflow 和工作流导航知识资产");
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
catch (e) {
|
|
108
|
+
hardFail("CONTROL_PLANE_BEHAVIOR_EXCEPTION", `控制面可信行为验证异常: ${e.message}`, ["src/engine/control_plane_contract.ts"], "problem-72", "旧 gate 不验证控制面可信", "修复控制面契约模块");
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=checkControlPlaneTrust.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkControlPlaneTrust.js","sourceRoot":"","sources":["../../../src/engine/gate_checks/checkControlPlaneTrust.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase 8: 关键问题消费验证 (problem-17/38/57/60)
|
|
3
|
+
*/
|
|
4
|
+
import type { GateContext, HardFailCallback, InfoCallback } from "./types.js";
|
|
5
|
+
export declare function check(ctx: GateContext, hardFail: HardFailCallback, info?: InfoCallback): Promise<void>;
|
|
6
|
+
//# sourceMappingURL=checkCriticalProblemConsumption.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkCriticalProblemConsumption.d.ts","sourceRoot":"","sources":["../../../src/engine/gate_checks/checkCriticalProblemConsumption.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAI9E,wBAAsB,KAAK,CACzB,GAAG,EAAE,WAAW,EAChB,QAAQ,EAAE,gBAAgB,EAC1B,IAAI,CAAC,EAAE,YAAY,GAClB,OAAO,CAAC,IAAI,CAAC,CAomBf"}
|
|
@@ -0,0 +1,476 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase 8: 关键问题消费验证 (problem-17/38/57/60)
|
|
3
|
+
*/
|
|
4
|
+
import fs from "node:fs";
|
|
5
|
+
import path from "node:path";
|
|
6
|
+
import { safeReadCached } from "./helpers.js";
|
|
7
|
+
import { sourceContainsIdentifier } from "../source_code_matcher.js";
|
|
8
|
+
export async function check(ctx, hardFail, info) {
|
|
9
|
+
const rootDir = ctx.rootDir;
|
|
10
|
+
const taskContextPath = path.join(rootDir, "src/engine/task_context.ts");
|
|
11
|
+
const cliPath = path.join(rootDir, "src/bin/soloforge.ts");
|
|
12
|
+
// problem-17: StateFact 分区 — save() 必须调用 validateStateFactPartition,hard_fail 必须 throw
|
|
13
|
+
const stateFactPath = path.join(rootDir, "src/engine/state_fact_classifier.ts");
|
|
14
|
+
if (!fs.existsSync(stateFactPath)) {
|
|
15
|
+
hardFail("CRITICAL_PROBLEM_FILE_MISSING", "problem-17: state_fact_classifier.ts 不存在", ["src/engine/state_fact_classifier.ts"], "problem-17", "发布门禁不检查 problem-17 实现", "创建 state_fact_classifier.ts");
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
const sfContent = safeReadCached(stateFactPath, ctx.readCache);
|
|
19
|
+
const tcContent = safeReadCached(taskContextPath, ctx.readCache);
|
|
20
|
+
if (!sfContent || !sourceContainsIdentifier(sfContent, "validateStateFactPartition")) {
|
|
21
|
+
hardFail("CRITICAL_PROBLEM_EXPORT_MISSING", "problem-17: state_fact_classifier.ts 未导出 validateStateFactPartition", ["src/engine/state_fact_classifier.ts"], "problem-17", "StateFact 分类器缺少核心导出函数", "添加 validateStateFactPartition 导出");
|
|
22
|
+
}
|
|
23
|
+
if (!tcContent || !sourceContainsIdentifier(tcContent, "validateStateFactPartition")) {
|
|
24
|
+
hardFail("CRITICAL_PROBLEM_NOT_CONSUMED", "problem-17: task_context.ts save() 未调用 validateStateFactPartition", ["src/engine/task_context.ts", "src/engine/state_fact_classifier.ts"], "problem-17", "StateFact 分区定义存在但未接入 TaskContext 保存路径", "在 task_context.ts save() 中接入 validateStateFactPartition");
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
// 验证 hard_fail 时 throw(不是静默跳过)
|
|
28
|
+
const tcLines = tcContent.split("\n");
|
|
29
|
+
const vspLine = tcLines.findIndex(l => l.includes("validateStateFactPartition"));
|
|
30
|
+
if (vspLine === -1) {
|
|
31
|
+
hardFail("CRITICAL_PROBLEM_NOT_CONSUMED", "problem-17: task_context.ts save() 未调用 validateStateFactPartition", ["src/engine/task_context.ts"], "problem-17", "StateFact 分区定义存在但未接入 TaskContext 保存路径", "接入 validateStateFactPartition");
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
// 检查调用后有 hard_fail throw 路径
|
|
35
|
+
const afterVsp = tcLines.slice(vspLine, vspLine + 15).join("\n");
|
|
36
|
+
if (!(afterVsp.includes("throw") || afterVsp.includes("hardFails") || afterVsp.includes("hard_fail"))) {
|
|
37
|
+
hardFail("CRITICAL_PROBLEM_SOFT_ENFORCEMENT", "problem-17: task_context.ts 中 validateStateFactPartition 调用后缺少 hard_fail throw 路径", ["src/engine/task_context.ts"], "problem-17", "StateFact 校验结果被忽略而非阻断", "校验 hard_fail 时 throw Error");
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
// problem-38: Retention Policy — cleanup 必须调用 evaluateCleanup/checkForbiddenContent,存在 referenced evidence 保护
|
|
43
|
+
const retentionPath = path.join(rootDir, "src/engine/retention_policy.ts");
|
|
44
|
+
if (!fs.existsSync(retentionPath)) {
|
|
45
|
+
hardFail("CRITICAL_PROBLEM_FILE_MISSING", "problem-38: retention_policy.ts 不存在", ["src/engine/retention_policy.ts"], "problem-38", "发布门禁不检查 problem-38 实现", "创建 retention_policy.ts");
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
const retContent = safeReadCached(retentionPath, ctx.readCache);
|
|
49
|
+
if (!retContent || !retContent.includes("evaluateCleanup") || !retContent.includes("checkForbiddenContent")) {
|
|
50
|
+
hardFail("CRITICAL_PROBLEM_EXPORT_MISSING", "problem-38: retention_policy.ts 未导出 evaluateCleanup 或 checkForbiddenContent", ["src/engine/retention_policy.ts"], "problem-38", "Retention Policy 缺少核心清理函数", "添加 evaluateCleanup 和 checkForbiddenContent 导出");
|
|
51
|
+
}
|
|
52
|
+
const tcContent = safeReadCached(taskContextPath, ctx.readCache);
|
|
53
|
+
const cliContent = safeReadCached(cliPath, ctx.readCache);
|
|
54
|
+
const tcHasCleanup = tcContent?.includes("evaluateCleanup") ?? false;
|
|
55
|
+
const cliHasCleanup = cliContent?.includes("evaluateCleanup") ?? false;
|
|
56
|
+
const cliHasCheck = cliContent?.includes("checkForbiddenContent") ?? false;
|
|
57
|
+
if (!tcHasCleanup && !cliHasCleanup) {
|
|
58
|
+
hardFail("CRITICAL_PROBLEM_NOT_CONSUMED", "problem-38: evaluateCleanup 未被 task_context.ts 或 soloforge.ts 调用", ["src/engine/task_context.ts", "src/bin/soloforge.ts", "src/engine/retention_policy.ts"], "problem-38", "Retention Policy 定义存在但无清理消费者", "将 evaluateCleanup 接入 TaskContext cleanup 或 CLI cleanup 命令");
|
|
59
|
+
}
|
|
60
|
+
// 验证 CLI cleanup 中有 referenced evidence 保护逻辑
|
|
61
|
+
if (cliContent) {
|
|
62
|
+
const cliLines = cliContent.split("\n");
|
|
63
|
+
const cleanupFn = cliLines.findIndex(l => l.match(/^(async\s+)?function\s+cmdCleanup/));
|
|
64
|
+
if (cleanupFn !== -1) {
|
|
65
|
+
// 搜索到下一个顶层函数或文件末尾
|
|
66
|
+
let cleanupEnd = cliLines.length;
|
|
67
|
+
for (let i = cleanupFn + 3; i < cliLines.length; i++) {
|
|
68
|
+
if (cliLines[i].match(/^async function\s+\w+|^function\s+\w+/)) {
|
|
69
|
+
cleanupEnd = i;
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
const cleanupBody = cliLines.slice(cleanupFn, cleanupEnd).join("\n");
|
|
74
|
+
if (!cleanupBody.includes("referencedEvidenceIds") || !cleanupBody.includes("is_referenced")) {
|
|
75
|
+
hardFail("CRITICAL_PROBLEM_SOFT_ENFORCEMENT", "problem-38: CLI cleanup 缺少真实 evidence 引用扫描(无 referencedEvidenceIds 或 is_referenced 逻辑)", ["src/bin/soloforge.ts"], "problem-38", "cleanup 未扫描 task context / governance report 中的 evidence 引用", "添加真实引用扫描");
|
|
76
|
+
}
|
|
77
|
+
// 验证策略异常导致非零退出
|
|
78
|
+
if (!cleanupBody.includes("process.exit(1)")) {
|
|
79
|
+
hardFail("CRITICAL_PROBLEM_SOFT_ENFORCEMENT", "problem-38: CLI cleanup 策略异常时未非零退出", ["src/bin/soloforge.ts"], "problem-38", "策略异常被吞而非阻断", "添加 process.exit(1) 在 catch 中");
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// problem-57: Knowledge Asset Audit — audit-template-mechanisms 必须调用 auditKnowledgeAssets 且 hard_fail/异常 process.exit(1)
|
|
85
|
+
const kaAuditPath = path.join(rootDir, "src/engine/knowledge_asset_audit.ts");
|
|
86
|
+
if (!fs.existsSync(kaAuditPath)) {
|
|
87
|
+
hardFail("CRITICAL_PROBLEM_FILE_MISSING", "problem-57: knowledge_asset_audit.ts 不存在", ["src/engine/knowledge_asset_audit.ts"], "problem-57", "发布门禁不检查 problem-57 实现", "创建 knowledge_asset_audit.ts");
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
const kaContent = safeReadCached(kaAuditPath, ctx.readCache);
|
|
91
|
+
if (!kaContent || !kaContent.includes("auditKnowledgeAssets")) {
|
|
92
|
+
hardFail("CRITICAL_PROBLEM_EXPORT_MISSING", "problem-57: knowledge_asset_audit.ts 未导出 auditKnowledgeAssets", ["src/engine/knowledge_asset_audit.ts"], "problem-57", "Knowledge Asset Audit 缺少核心审计函数", "添加 auditKnowledgeAssets 导出");
|
|
93
|
+
}
|
|
94
|
+
const cliContent = safeReadCached(cliPath, ctx.readCache);
|
|
95
|
+
if (!cliContent?.includes("auditKnowledgeAssets")) {
|
|
96
|
+
hardFail("CRITICAL_PROBLEM_NOT_CONSUMED", "problem-57: auditKnowledgeAssets 未被 soloforge.ts CLI 消费", ["src/bin/soloforge.ts", "src/engine/knowledge_asset_audit.ts"], "problem-57", "Knowledge Asset Audit 定义存在但未接入 CLI", "将 auditKnowledgeAssets 接入 audit-template-mechanisms 命令");
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
// 验证 hard_fail 阻断路径
|
|
100
|
+
const cliLines = cliContent.split("\n");
|
|
101
|
+
const kaCallLine = cliLines.findIndex(l => l.includes("auditKnowledgeAssets") && l.includes("await"));
|
|
102
|
+
if (kaCallLine !== -1) {
|
|
103
|
+
// 搜索到函数末尾(下一个 async function 或文件末尾)
|
|
104
|
+
let kaEnd = cliLines.length;
|
|
105
|
+
for (let i = kaCallLine + 1; i < cliLines.length; i++) {
|
|
106
|
+
if (cliLines[i].match(/^async function\s+\w+|^function\s+\w+/)) {
|
|
107
|
+
kaEnd = i;
|
|
108
|
+
break;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
const afterKaCall = cliLines.slice(kaCallLine, kaEnd).join("\n");
|
|
112
|
+
if (!afterKaCall.includes("hard_fail_count") || !afterKaCall.includes("process.exit(1)")) {
|
|
113
|
+
hardFail("CRITICAL_PROBLEM_SOFT_ENFORCEMENT", "problem-57: auditKnowledgeAssets 调用后 hard_fail 未阻断(缺少 process.exit(1))", ["src/bin/soloforge.ts"], "problem-57", "知识资产审计 hard_fail 未阻断命令", "添加 hard_fail_count > 0 时 process.exit(1)");
|
|
114
|
+
}
|
|
115
|
+
// 验证异常也阻断(搜索整个函数体中的 catch 块)
|
|
116
|
+
const catchBlocks = afterKaCall.match(/catch\s*\(e[^)]*\)\s*\{[^}]+\}/g);
|
|
117
|
+
const hasKaAudit = afterKaCall.includes("auditKnowledgeAssets");
|
|
118
|
+
if (catchBlocks && hasKaAudit) {
|
|
119
|
+
for (const cb of catchBlocks) {
|
|
120
|
+
// 只检查紧跟 auditKnowledgeAssets 的 catch
|
|
121
|
+
if (cb.includes("process.exit(1)"))
|
|
122
|
+
continue;
|
|
123
|
+
// 检查是否是 auditKnowledgeAssets 的 catch(通过位置判断)
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
// 简化: 检查 auditKnowledgeAssets 后面的 catch 块中是否有 process.exit(1)
|
|
127
|
+
const kaCatchIdx = afterKaCall.lastIndexOf("catch");
|
|
128
|
+
if (kaCatchIdx !== -1) {
|
|
129
|
+
const afterCatch = afterKaCall.slice(kaCatchIdx);
|
|
130
|
+
if (!afterCatch.includes("process.exit(1)")) {
|
|
131
|
+
hardFail("CRITICAL_PROBLEM_SOFT_ENFORCEMENT", "problem-57: auditKnowledgeAssets 异常时未阻断(catch 中缺少 process.exit(1))", ["src/bin/soloforge.ts"], "problem-57", "知识资产审计异常被吞而非阻断", "catch 中添加 process.exit(1)");
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
info?.(" problem-17/38/57 消费验证完成");
|
|
138
|
+
// 问题六十:证据驱动与反幻觉契约 — 行为级检查
|
|
139
|
+
{
|
|
140
|
+
const evidenceGroundingPath = path.join(rootDir, "src/engine/evidence_grounding_contract.ts");
|
|
141
|
+
if (!fs.existsSync(evidenceGroundingPath)) {
|
|
142
|
+
hardFail("CRITICAL_PROBLEM_FILE_MISSING", "problem-60: evidence_grounding_contract.ts 不存在", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "发布门禁不检查 problem-60 实现", "创建 evidence_grounding_contract.ts");
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
// 行为级检查:动态导入并验证核心门禁行为
|
|
146
|
+
try {
|
|
147
|
+
const eg = await import(path.join(rootDir, "dist/engine/evidence_grounding_contract.js"));
|
|
148
|
+
const sys = eg.createEvidenceGroundingSystem();
|
|
149
|
+
// 检查 1:无证据高风险 claim 必须被 blocked
|
|
150
|
+
{
|
|
151
|
+
const noEvClaims = [{
|
|
152
|
+
id: "gate-test-no-ev", claim_text: "项目使用 React", category: "project_fact",
|
|
153
|
+
evidence_ids: [], is_uncertain: false, risk_level: "high",
|
|
154
|
+
}];
|
|
155
|
+
const noEvResult = sys.verifier.verify(noEvClaims, "high");
|
|
156
|
+
if (noEvResult.unsupported.length === 0) {
|
|
157
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: 无证据高风险 claim 未被 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 未阻断无证据声明", "验证 classify 逻辑");
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
// 检查 2:generated_inference 单独支撑 project_fact 必须被 blocked
|
|
161
|
+
{
|
|
162
|
+
const infEv = sys.registry.register({
|
|
163
|
+
source_type: "generated_inference", authority: "weak", freshness: "unknown",
|
|
164
|
+
permission: "allowed", scope: "test", description: "推理",
|
|
165
|
+
});
|
|
166
|
+
const infClaims = [{
|
|
167
|
+
id: "gate-test-inference", claim_text: "项目使用 Vue", category: "tech_stack",
|
|
168
|
+
evidence_ids: [infEv.id], is_uncertain: false, risk_level: "high",
|
|
169
|
+
}];
|
|
170
|
+
const infResult = sys.verifier.verify(infClaims, "high");
|
|
171
|
+
if (infResult.unsupported.length === 0) {
|
|
172
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: generated_inference 单独支撑 project_fact 未被 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 未阻断推理自证", "验证 isSelfAttestation 逻辑");
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
// 检查 3:validation_plan 冒充 validation_result 必须被 blocked
|
|
176
|
+
{
|
|
177
|
+
const planEv = sys.registry.register({
|
|
178
|
+
source_type: "generated_inference", authority: "weak", freshness: "unknown",
|
|
179
|
+
permission: "allowed", scope: "test", description: "验证计划",
|
|
180
|
+
});
|
|
181
|
+
const planClaims = [{
|
|
182
|
+
id: "gate-test-plan-as-result", claim_text: "验证已通过",
|
|
183
|
+
category: "validation_result",
|
|
184
|
+
evidence_ids: [planEv.id], is_uncertain: false, risk_level: "high",
|
|
185
|
+
}];
|
|
186
|
+
const planResult = sys.verifier.verify(planClaims, "high");
|
|
187
|
+
if (planResult.unsupported.length === 0) {
|
|
188
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: validation_plan 冒充 validation_result 未被 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 未阻断验证计划冒充", "验证 validation_result 检查逻辑");
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
// 检查 4:forbidden source 必须被 blocked
|
|
192
|
+
{
|
|
193
|
+
const matrix = sys.builder.buildContext([], {
|
|
194
|
+
target_claims: [], source_types: [], keywords: [], max_results: 10,
|
|
195
|
+
});
|
|
196
|
+
matrix.evidence.push({
|
|
197
|
+
id: "ev-forbidden-test", source_type: "project_file",
|
|
198
|
+
authority: "authoritative", freshness: "current",
|
|
199
|
+
permission: "forbidden", scope: "sensitive",
|
|
200
|
+
description: "敏感数据", timestamp: new Date().toISOString(),
|
|
201
|
+
});
|
|
202
|
+
matrix.risk_summary = { low: 0, medium: 0, high: 0, critical: 1 };
|
|
203
|
+
const forbiddenResult = sys.gate.evaluate(matrix, "high");
|
|
204
|
+
if (forbiddenResult.allowed) {
|
|
205
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: forbidden source 未被 UnsupportedClaimGate 阻断", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "UnsupportedClaimGate 允许 forbidden 证据通过", "验证 forbidden 检查逻辑");
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
// 检查 5:conflict unresolved 必须被 blocked(高风险)
|
|
209
|
+
{
|
|
210
|
+
const confMatrix = sys.builder.buildContext([], {
|
|
211
|
+
target_claims: [], source_types: [], keywords: [], max_results: 10,
|
|
212
|
+
});
|
|
213
|
+
confMatrix.conflicts.push({
|
|
214
|
+
claim_id: "claim-conflict-test",
|
|
215
|
+
conflicting_evidence_ids: ["ev-a", "ev-b"],
|
|
216
|
+
description: "矛盾",
|
|
217
|
+
resolution_status: "unresolved",
|
|
218
|
+
});
|
|
219
|
+
confMatrix.risk_summary = { low: 0, medium: 0, high: 1, critical: 0 };
|
|
220
|
+
const confResult = sys.gate.evaluate(confMatrix, "high");
|
|
221
|
+
if (confResult.allowed) {
|
|
222
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: unresolved conflict 未被 UnsupportedClaimGate 阻断", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "UnsupportedClaimGate 允许未裁决冲突通过", "验证 conflict 检查逻辑");
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
// 检查 6:classification-only 证据不得支撑 architecture 声明
|
|
226
|
+
{
|
|
227
|
+
sys.registry.clear();
|
|
228
|
+
const clsOnlyEv = sys.registry.register({
|
|
229
|
+
source_type: "task_context", authority: "authoritative", freshness: "current",
|
|
230
|
+
permission: "allowed", scope: "classification", description: "任务分类结果",
|
|
231
|
+
});
|
|
232
|
+
const clsOnlyClaims = [{
|
|
233
|
+
id: "gate-test-cls-only", claim_text: "技术方案基于现有系统分析",
|
|
234
|
+
category: "architecture",
|
|
235
|
+
evidence_ids: [clsOnlyEv.id], is_uncertain: false, risk_level: "high",
|
|
236
|
+
}];
|
|
237
|
+
const clsOnlyResult = sys.verifier.verify(clsOnlyClaims, "high");
|
|
238
|
+
if (clsOnlyResult.unsupported.length === 0) {
|
|
239
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: classification-only 证据支撑 architecture 声明未被 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 允许 task_context:classification 支撑项目事实声明", "验证 CATEGORY_REQUIRED_SOURCES 逻辑");
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
// 检查 7:project_file + project_source_file 证据可以支撑 architecture 声明
|
|
243
|
+
{
|
|
244
|
+
sys.registry.clear();
|
|
245
|
+
const pfEv = sys.registry.register({
|
|
246
|
+
source_type: "project_file", evidence_role: "project_source_file",
|
|
247
|
+
authority: "authoritative", freshness: "current",
|
|
248
|
+
permission: "allowed", scope: "src/", description: "项目源码文件",
|
|
249
|
+
});
|
|
250
|
+
const pfClaims = [{
|
|
251
|
+
id: "gate-test-pf-ok", claim_text: "技术方案基于现有系统分析",
|
|
252
|
+
category: "architecture",
|
|
253
|
+
evidence_ids: [pfEv.id], is_uncertain: false, risk_level: "high",
|
|
254
|
+
}];
|
|
255
|
+
const pfResult = sys.verifier.verify(pfClaims, "high");
|
|
256
|
+
if (pfResult.unsupported.length > 0) {
|
|
257
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: project_source_file 证据支撑 architecture 声明被错误 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 误阻断了有效证据", "验证 CATEGORY_REQUIRED_ROLES 逻辑");
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
// 检查 8:template_guidance 证据不得支撑 architecture 声明
|
|
261
|
+
{
|
|
262
|
+
sys.registry.clear();
|
|
263
|
+
const tgEv = sys.registry.register({
|
|
264
|
+
source_type: "knowledge_asset", evidence_role: "template_guidance",
|
|
265
|
+
authority: "trusted", freshness: "current",
|
|
266
|
+
permission: "allowed", scope: "knowledge", description: "默认模板",
|
|
267
|
+
});
|
|
268
|
+
const tgClaims = [{
|
|
269
|
+
id: "gate-test-tg-block", claim_text: "技术方案基于现有系统分析",
|
|
270
|
+
category: "architecture",
|
|
271
|
+
evidence_ids: [tgEv.id], is_uncertain: false, risk_level: "high",
|
|
272
|
+
}];
|
|
273
|
+
const tgResult = sys.verifier.verify(tgClaims, "high");
|
|
274
|
+
if (tgResult.unsupported.length === 0) {
|
|
275
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: template_guidance 证据支撑 architecture 声明未被 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 允许 template_guidance 支撑项目事实声明", "验证 CATEGORY_REQUIRED_ROLES 逻辑");
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
// 检查 9:project_source_file 证据角色可以支撑 architecture 声明
|
|
279
|
+
{
|
|
280
|
+
sys.registry.clear();
|
|
281
|
+
const psfEv = sys.registry.register({
|
|
282
|
+
source_type: "project_file", evidence_role: "project_source_file",
|
|
283
|
+
authority: "authoritative", freshness: "current",
|
|
284
|
+
permission: "allowed", scope: "src/", description: "项目源码文件",
|
|
285
|
+
});
|
|
286
|
+
const psfClaims = [{
|
|
287
|
+
id: "gate-test-psf-ok", claim_text: "技术方案基于现有系统分析",
|
|
288
|
+
category: "architecture",
|
|
289
|
+
evidence_ids: [psfEv.id], is_uncertain: false, risk_level: "high",
|
|
290
|
+
}];
|
|
291
|
+
const psfResult = sys.verifier.verify(psfClaims, "high");
|
|
292
|
+
if (psfResult.unsupported.length > 0) {
|
|
293
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: project_source_file 角色支撑 architecture 声明被错误 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 误阻断了有效 project_source_file 证据", "验证 CATEGORY_REQUIRED_ROLES 逻辑");
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
// 检查 10:普通 code_change 不应因无 project_source_file 被 blocked(无 architecture claim 时)
|
|
297
|
+
{
|
|
298
|
+
sys.registry.clear();
|
|
299
|
+
const clsEv = sys.registry.register({
|
|
300
|
+
source_type: "task_context", evidence_role: "classification",
|
|
301
|
+
authority: "authoritative", freshness: "current",
|
|
302
|
+
permission: "allowed", scope: "classification", description: "任务分类结果",
|
|
303
|
+
});
|
|
304
|
+
// 普通 code_change 只有 user_confirmation claim(无 architecture claim)
|
|
305
|
+
const ccClaims = [{
|
|
306
|
+
id: "gate-test-cc-ok", claim_text: "任务路由和执行范围已确认",
|
|
307
|
+
category: "user_confirmation",
|
|
308
|
+
evidence_ids: [clsEv.id], is_uncertain: false, risk_level: "high",
|
|
309
|
+
}];
|
|
310
|
+
const ccResult = sys.verifier.verify(ccClaims, "high");
|
|
311
|
+
if (ccResult.unsupported.length > 0) {
|
|
312
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: 普通 code_change 的 user_confirmation claim 被 classification 证据错误 blocked", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 误阻断了不需要项目事实的普通任务", "验证 claim 语义逻辑");
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
// 检查 11:architecture_design 无真实项目证据必须 blocked
|
|
316
|
+
{
|
|
317
|
+
sys.registry.clear();
|
|
318
|
+
const clsOnlyEv = sys.registry.register({
|
|
319
|
+
source_type: "task_context", evidence_role: "classification",
|
|
320
|
+
authority: "authoritative", freshness: "current",
|
|
321
|
+
permission: "allowed", scope: "classification", description: "任务分类结果",
|
|
322
|
+
});
|
|
323
|
+
const tgOnlyEv = sys.registry.register({
|
|
324
|
+
source_type: "knowledge_asset", evidence_role: "template_guidance",
|
|
325
|
+
authority: "trusted", freshness: "current",
|
|
326
|
+
permission: "allowed", scope: "knowledge", description: "默认模板",
|
|
327
|
+
});
|
|
328
|
+
const archClaims = [{
|
|
329
|
+
id: "gate-test-arch-block", claim_text: "技术方案基于现有系统分析",
|
|
330
|
+
category: "architecture",
|
|
331
|
+
evidence_ids: [clsOnlyEv.id, tgOnlyEv.id], is_uncertain: false, risk_level: "high",
|
|
332
|
+
}];
|
|
333
|
+
const archResult = sys.verifier.verify(archClaims, "high");
|
|
334
|
+
if (archResult.unsupported.length === 0) {
|
|
335
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", "problem-60: architecture_design 无真实项目证据未被 blocked(classification + template_guidance 不够)", ["src/engine/evidence_grounding_contract.ts"], "problem-60", "FactClaimVerifier 允许非项目证据支撑架构声明", "验证 CATEGORY_REQUIRED_ROLES + claim 语义逻辑");
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
catch (behaviorErr) {
|
|
340
|
+
hardFail("CRITICAL_PROBLEM_BEHAVIOR", `problem-60: 行为级检查执行失败: ${behaviorErr?.message ?? behaviorErr}`, ["src/engine/evidence_grounding_contract.ts"], "problem-60", "证据驱动机制行为检查不可执行", "修复 import 或机制代码");
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
// 静态检查:导出完整性
|
|
344
|
+
const egContent = safeReadCached(evidenceGroundingPath, ctx.readCache);
|
|
345
|
+
if (egContent) {
|
|
346
|
+
const requiredExports = ["createEvidenceGroundingSystem", "assessTaskRisk", "EvidenceSourceRegistry", "FactClaimVerifier", "UnsupportedClaimGate"];
|
|
347
|
+
for (const exp of requiredExports) {
|
|
348
|
+
if (!egContent.includes(exp)) {
|
|
349
|
+
hardFail("CRITICAL_PROBLEM_EXPORT_MISSING", `problem-60: evidence_grounding_contract.ts 缺少导出: ${exp}`, ["src/engine/evidence_grounding_contract.ts"], "problem-60", "证据驱动机制缺少核心导出", `添加 ${exp} 导出`);
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
// 静态检查:InstructionContract schema 必须包含 evidence 字段
|
|
354
|
+
const instrContractPath = path.join(rootDir, "src/engine/instruction_contract.ts");
|
|
355
|
+
const instrContent = safeReadCached(instrContractPath, ctx.readCache);
|
|
356
|
+
if (instrContent) {
|
|
357
|
+
const evidenceFields = ["evidence_matrix", "unsupported_claim_policy", "uncertainty_policy", "conflict_resolution_policy"];
|
|
358
|
+
for (const field of evidenceFields) {
|
|
359
|
+
if (!instrContent.includes(field)) {
|
|
360
|
+
hardFail("CRITICAL_PROBLEM_SCHEMA_INCOMPLETE", `problem-60: instruction_contract.ts schema 缺少证据字段: ${field}`, ["src/engine/instruction_contract.ts"], "problem-60", "施工指令契约缺少证据驱动字段", `添加 ${field} 字段`);
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
// 静态检查:主链路必须有 runtime 阻断(不能只是 advisory)
|
|
365
|
+
const toolsPath = path.join(rootDir, "src/adapters/claude_code/tools.ts");
|
|
366
|
+
const toolsContent = safeReadCached(toolsPath, ctx.readCache);
|
|
367
|
+
if (!toolsContent?.includes("evidence_grounding_contract")) {
|
|
368
|
+
hardFail("CRITICAL_PROBLEM_NOT_CONSUMED", "problem-60: tools.ts 未消费 evidence_grounding_contract", ["src/adapters/claude_code/tools.ts"], "problem-60", "证据驱动机制未接入主链路", "在 sf_expand/sf_verify/sf_deliver 中接入");
|
|
369
|
+
}
|
|
370
|
+
// sf_expand 必须有 blocked/manual_required 分支
|
|
371
|
+
if (toolsContent && !toolsContent.includes("_evGate.allowed") && !toolsContent.includes("evidence_blocked")) {
|
|
372
|
+
hardFail("CRITICAL_PROBLEM_ADVISORY_ONLY", "problem-60: sf_expand 证据检查只有 advisory,缺少 blocked 分支", ["src/adapters/claude_code/tools.ts"], "problem-60", "sf_expand 证据门禁不阻断", "添加 evidence gate blocked 分支");
|
|
373
|
+
}
|
|
374
|
+
// sf_verify: 验证计划描述行中不得包含 source_type: "validation_result"
|
|
375
|
+
if (toolsContent) {
|
|
376
|
+
// 找到 sf_verify handler 中问题六十部分
|
|
377
|
+
const verifyStart = toolsContent.indexOf("问题六十:验证结论必须经过 FactClaimVerifier");
|
|
378
|
+
const verifyEnd = toolsContent.indexOf("// 验证后核心体验评估", verifyStart);
|
|
379
|
+
if (verifyStart >= 0 && verifyEnd >= 0) {
|
|
380
|
+
const verifySection = toolsContent.substring(verifyStart, verifyEnd);
|
|
381
|
+
// 检查验证计划注册调用中是否使用了 validation_result
|
|
382
|
+
const planRegMatch = verifySection.match(/register\(\{[^}]*验证计划:[^}]*\}\)/s);
|
|
383
|
+
if (planRegMatch && planRegMatch[0].includes("source_type: \"validation_result\"")) {
|
|
384
|
+
hardFail("CRITICAL_PROBLEM_PLAN_AS_RESULT", "problem-60: sf_verify 把验证计划注册为 validation_result", ["src/adapters/claude_code/tools.ts"], "problem-60", "验证计划冒充验证结果", "验证计划应注册为 task_context 类型");
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
// 静态检查:负向测试
|
|
389
|
+
const testPath = path.join(rootDir, "tests/engine/evidence_grounding_contract.test.ts");
|
|
390
|
+
if (!fs.existsSync(testPath)) {
|
|
391
|
+
hardFail("CRITICAL_PROBLEM_TEST_MISSING", "problem-60: 缺少负向测试文件", ["tests/engine/evidence_grounding_contract.test.ts"], "problem-60", "证据驱动机制缺少测试覆盖", "创建 evidence_grounding_contract.test.ts");
|
|
392
|
+
}
|
|
393
|
+
// 静态检查:知识规则
|
|
394
|
+
const kaRulePath = path.join(rootDir, "templates/internal/rules/证据驱动与反幻觉规则.md");
|
|
395
|
+
if (!fs.existsSync(kaRulePath)) {
|
|
396
|
+
hardFail("CRITICAL_PROBLEM_ASSET_MISSING", "problem-60: 缺少知识规则文件 证据驱动与反幻觉规则.md", ["templates/internal/rules/证据驱动与反幻觉规则.md"], "problem-60", "证据驱动知识规则缺失", "创建知识规则文件");
|
|
397
|
+
}
|
|
398
|
+
// 静态检查:workflow_template 或 workflow_rule_generator(规则已提取至 engine 层)
|
|
399
|
+
const wfPath = path.join(rootDir, "src/adapters/shared/workflow_template.ts");
|
|
400
|
+
const wrgPath = path.join(rootDir, "src/engine/workflow_rule_generator.ts");
|
|
401
|
+
const wfContent = (safeReadCached(wfPath, ctx.readCache) ?? "") + (safeReadCached(wrgPath, ctx.readCache) ?? "");
|
|
402
|
+
if (!wfContent.includes("wf-evidence-grounding")) {
|
|
403
|
+
hardFail("CRITICAL_PROBLEM_TEMPLATE_MISSING", "problem-60: workflow_template.ts 缺少 wf-evidence-grounding 硬规则", ["src/adapters/shared/workflow_template.ts"], "problem-60", "工作流模板未包含证据驱动规则", "添加 wf-evidence-grounding 硬规则");
|
|
404
|
+
}
|
|
405
|
+
// 静态检查:TaskContext 类型必须有证据字段
|
|
406
|
+
const typesPath = path.join(rootDir, "src/types/task.ts");
|
|
407
|
+
const typesContent = safeReadCached(typesPath, ctx.readCache);
|
|
408
|
+
if (typesContent && !typesContent.includes("evidence_matrix?:") && !typesContent.includes("evidence_gate_result?:")) {
|
|
409
|
+
hardFail("CRITICAL_PROBLEM_TASKCTX_MISSING", "problem-60: TaskContext 缺少 evidence_matrix/evidence_gate_result 字段", ["src/types/task.ts"], "problem-60", "TaskContext 未保存证据结果", "添加 evidence_matrix 和 evidence_gate_result 字段");
|
|
410
|
+
}
|
|
411
|
+
// 静态检查:task_context.ts 必须有 setEvidenceGroundingResult 写入方法
|
|
412
|
+
const tcPath = path.join(rootDir, "src/engine/task_context.ts");
|
|
413
|
+
const tcContent = safeReadCached(tcPath, ctx.readCache);
|
|
414
|
+
if (tcContent && !sourceContainsIdentifier(tcContent, "setEvidenceGroundingResult")) {
|
|
415
|
+
hardFail("CRITICAL_PROBLEM_NO_WRITEBACK", "problem-60: task_context.ts 缺少 setEvidenceGroundingResult 写入方法", ["src/engine/task_context.ts"], "problem-60", "TaskContext 只有类型字段没有写入方法", "添加 setEvidenceGroundingResult 方法");
|
|
416
|
+
}
|
|
417
|
+
// 静态检查:tools.ts 主链路必须调用 setEvidenceGroundingResult
|
|
418
|
+
if (toolsContent && !toolsContent.includes("setEvidenceGroundingResult")) {
|
|
419
|
+
hardFail("CRITICAL_PROBLEM_NO_RUNTIME_WRITEBACK", "problem-60: tools.ts 未调用 setEvidenceGroundingResult 写回 TaskContext", ["src/adapters/claude_code/tools.ts"], "problem-60", "主链路不写回证据结果到 TaskContext", "在 sf_expand/sf_verify/sf_deliver 中调用 setEvidenceGroundingResult");
|
|
420
|
+
}
|
|
421
|
+
// 静态检查:tools.ts 不得出现 registry.query({}).map() 无差别证据绑定
|
|
422
|
+
if (toolsContent) {
|
|
423
|
+
const toolsLines = toolsContent.split("\n");
|
|
424
|
+
for (let i = 0; i < toolsLines.length; i++) {
|
|
425
|
+
if (/registry\.query\(\{\}\)\.map/.test(toolsLines[i])) {
|
|
426
|
+
hardFail("CRITICAL_PROBLEM_INDISCRIMINATE_BINDING", `problem-60: tools.ts:${i + 1} 使用 registry.query({}).map() 无差别绑定证据到所有 claim`, ["src/adapters/claude_code/tools.ts"], "problem-60", "所有 registry 证据被无差别绑定到所有 claim,不区分语义", "按 claim 语义筛选 evidence_ids");
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
}
|
|
430
|
+
// 行为检查:setEvidenceGroundingResult 写入后 load 能读回
|
|
431
|
+
try {
|
|
432
|
+
const tcModule = await import(path.join(rootDir, "dist/engine/task_context.js"));
|
|
433
|
+
const tmpStateDir = path.join(rootDir, ".soloforge", "state");
|
|
434
|
+
const fsModule = await import("node:fs");
|
|
435
|
+
if (!fsModule.existsSync(tmpStateDir)) {
|
|
436
|
+
fsModule.mkdirSync(tmpStateDir, { recursive: true });
|
|
437
|
+
}
|
|
438
|
+
const tmpMgr = new tcModule.TaskContextManager(tmpStateDir);
|
|
439
|
+
const tmpCtx = await tmpMgr.create("gate-evidence-writeback-test", "test");
|
|
440
|
+
const testMatrix = {
|
|
441
|
+
task_id: tmpCtx.task_id, claims: [], evidence: [],
|
|
442
|
+
conflicts: [], unsupported_claims: ["test-claim"],
|
|
443
|
+
risk_summary: { low: 0, medium: 0, high: 1, critical: 0 },
|
|
444
|
+
created_at: new Date().toISOString(),
|
|
445
|
+
};
|
|
446
|
+
const testGate = {
|
|
447
|
+
allowed: false, reason_zh: "测试", diagnostic_code: "SF-EVIDENCE-TEST",
|
|
448
|
+
unsupported_claims: ["test-claim"], unresolved_conflicts: [],
|
|
449
|
+
missing_evidence: [], risk_level: "high",
|
|
450
|
+
requires_user_confirmation: [],
|
|
451
|
+
};
|
|
452
|
+
await tmpMgr.setEvidenceGroundingResult(tmpCtx.task_id, {
|
|
453
|
+
evidence_matrix: testMatrix,
|
|
454
|
+
evidence_gate_result: testGate,
|
|
455
|
+
unsupported_claims: ["test-claim"],
|
|
456
|
+
});
|
|
457
|
+
const loaded = await tmpMgr.load(tmpCtx.task_id);
|
|
458
|
+
if (!loaded?.evidence_matrix || !loaded?.evidence_gate_result) {
|
|
459
|
+
hardFail("CRITICAL_PROBLEM_WRITEBACK_FAILED", "problem-60: setEvidenceGroundingResult 写入后 load 无法读回", ["src/engine/task_context.ts"], "problem-60", "TaskContext 写入方法不工作", "修复 setEvidenceGroundingResult 或 save/load");
|
|
460
|
+
}
|
|
461
|
+
if (loaded.evidence_gate_result?.allowed !== false) {
|
|
462
|
+
hardFail("CRITICAL_PROBLEM_WRITEBACK_CORRUPT", "problem-60: setEvidenceGroundingResult 写入的 gate result 数据损坏", ["src/engine/task_context.ts"], "problem-60", "写入的 allowed=false 被读回为 true", "检查序列化逻辑");
|
|
463
|
+
}
|
|
464
|
+
// 清理测试任务
|
|
465
|
+
try {
|
|
466
|
+
fsModule.rmSync(path.join(tmpStateDir, `${tmpCtx.task_id}.json`), { force: true });
|
|
467
|
+
}
|
|
468
|
+
catch { }
|
|
469
|
+
}
|
|
470
|
+
catch (wbErr) {
|
|
471
|
+
hardFail("CRITICAL_PROBLEM_WRITEBACK_ERROR", `problem-60: setEvidenceGroundingResult 行为检查失败: ${wbErr?.message ?? wbErr}`, ["src/engine/task_context.ts"], "problem-60", "TaskContext 写入方法不可用", "修复 import 或方法实现");
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
info?.(" problem-60 证据驱动消费验证完成");
|
|
475
|
+
}
|
|
476
|
+
//# sourceMappingURL=checkCriticalProblemConsumption.js.map
|