soloforge 1.1.38 → 1.1.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +149 -149
- package/README.md +73 -49
- package/dist/adapters/shared/workflow_template.js +1 -1
- package/dist/bin/commands/analyze.d.ts +7 -0
- package/dist/bin/commands/analyze.d.ts.map +1 -0
- package/dist/bin/commands/analyze.js +52 -0
- package/dist/bin/commands/analyze.js.map +1 -0
- package/dist/bin/commands/audit.d.ts.map +1 -1
- package/dist/bin/commands/audit.js +104 -83
- package/dist/bin/commands/audit.js.map +1 -1
- package/dist/bin/commands/check_bash.d.ts.map +1 -1
- package/dist/bin/commands/check_bash.js +38 -18
- package/dist/bin/commands/check_bash.js.map +1 -1
- package/dist/bin/commands/check_write.d.ts +9 -0
- package/dist/bin/commands/check_write.d.ts.map +1 -1
- package/dist/bin/commands/check_write.js +105 -61
- package/dist/bin/commands/check_write.js.map +1 -1
- package/dist/bin/commands/init.d.ts +2 -5
- package/dist/bin/commands/init.d.ts.map +1 -1
- package/dist/bin/commands/init.js +116 -137
- package/dist/bin/commands/init.js.map +1 -1
- package/dist/bin/commands/modify.d.ts +7 -0
- package/dist/bin/commands/modify.d.ts.map +1 -0
- package/dist/bin/commands/modify.js +74 -0
- package/dist/bin/commands/modify.js.map +1 -0
- package/dist/bin/commands/reasoning.d.ts +14 -0
- package/dist/bin/commands/reasoning.d.ts.map +1 -0
- package/dist/bin/commands/reasoning.js +158 -0
- package/dist/bin/commands/reasoning.js.map +1 -0
- package/dist/bin/commands/review.d.ts +7 -0
- package/dist/bin/commands/review.d.ts.map +1 -0
- package/dist/bin/commands/review.js +79 -0
- package/dist/bin/commands/review.js.map +1 -0
- package/dist/bin/commands/status.d.ts +6 -5
- package/dist/bin/commands/status.d.ts.map +1 -1
- package/dist/bin/commands/status.js +63 -120
- package/dist/bin/commands/status.js.map +1 -1
- package/dist/bin/commands/sync.d.ts +1 -1
- package/dist/bin/commands/sync.js +7 -7
- package/dist/bin/commands/sync.js.map +1 -1
- package/dist/bin/commands/validate.d.ts +4 -1
- package/dist/bin/commands/validate.d.ts.map +1 -1
- package/dist/bin/commands/validate.js +65 -95
- package/dist/bin/commands/validate.js.map +1 -1
- package/dist/bin/config_commands.d.ts +21 -20
- package/dist/bin/config_commands.d.ts.map +1 -1
- package/dist/bin/config_commands.js +209 -236
- package/dist/bin/config_commands.js.map +1 -1
- package/dist/bin/soloforge.js +60 -22
- package/dist/bin/soloforge.js.map +1 -1
- package/dist/engine/audit/evolver.d.ts.map +1 -1
- package/dist/engine/audit/evolver.js +0 -2
- package/dist/engine/audit/evolver.js.map +1 -1
- package/dist/engine/audit/governance_report.d.ts +9 -8
- package/dist/engine/audit/governance_report.d.ts.map +1 -1
- package/dist/engine/audit/governance_report.js +17 -16
- package/dist/engine/audit/governance_report.js.map +1 -1
- package/dist/engine/change_coordinator.d.ts.map +1 -1
- package/dist/engine/change_coordinator.js +1 -4
- package/dist/engine/change_coordinator.js.map +1 -1
- package/dist/engine/config/conflicts.d.ts +39 -0
- package/dist/engine/config/conflicts.d.ts.map +1 -0
- package/dist/engine/config/conflicts.js +79 -0
- package/dist/engine/config/conflicts.js.map +1 -0
- package/dist/engine/config/detector/blueprint.d.ts +25 -0
- package/dist/engine/config/detector/blueprint.d.ts.map +1 -0
- package/dist/engine/config/detector/blueprint.js +47 -0
- package/dist/engine/config/detector/blueprint.js.map +1 -0
- package/dist/engine/config/detector/fingerprint.d.ts +67 -0
- package/dist/engine/config/detector/fingerprint.d.ts.map +1 -0
- package/dist/engine/config/detector/fingerprint.js +160 -0
- package/dist/engine/config/detector/fingerprint.js.map +1 -0
- package/dist/engine/config/detector/framework_map.d.ts +89 -0
- package/dist/engine/config/detector/framework_map.d.ts.map +1 -0
- package/dist/engine/config/detector/framework_map.js +406 -0
- package/dist/engine/config/detector/framework_map.js.map +1 -0
- package/dist/engine/config/detector/index.d.ts +12 -0
- package/dist/engine/config/detector/index.d.ts.map +1 -0
- package/dist/engine/config/detector/index.js +12 -0
- package/dist/engine/config/detector/index.js.map +1 -0
- package/dist/engine/config/detector/verify.d.ts +32 -0
- package/dist/engine/config/detector/verify.d.ts.map +1 -0
- package/dist/engine/config/detector/verify.js +107 -0
- package/dist/engine/config/detector/verify.js.map +1 -0
- package/dist/engine/config/intent.d.ts +26 -0
- package/dist/engine/config/intent.d.ts.map +1 -0
- package/dist/engine/config/intent.js +81 -0
- package/dist/engine/config/intent.js.map +1 -0
- package/dist/engine/config/intent_schema.d.ts +873 -0
- package/dist/engine/config/intent_schema.d.ts.map +1 -0
- package/dist/engine/config/intent_schema.js +98 -0
- package/dist/engine/config/intent_schema.js.map +1 -0
- package/dist/engine/config/regression_matrix.d.ts.map +1 -1
- package/dist/engine/config/regression_matrix.js +19 -14
- package/dist/engine/config/regression_matrix.js.map +1 -1
- package/dist/engine/config/resolver.d.ts +136 -0
- package/dist/engine/config/resolver.d.ts.map +1 -0
- package/dist/engine/config/resolver.js +251 -0
- package/dist/engine/config/resolver.js.map +1 -0
- package/dist/engine/context_engine/bootstrap.d.ts +12 -0
- package/dist/engine/context_engine/bootstrap.d.ts.map +1 -0
- package/dist/engine/context_engine/bootstrap.js +28 -0
- package/dist/engine/context_engine/bootstrap.js.map +1 -0
- package/dist/engine/context_engine/companion_injector.d.ts +49 -0
- package/dist/engine/context_engine/companion_injector.d.ts.map +1 -0
- package/dist/engine/context_engine/companion_injector.js +157 -0
- package/dist/engine/context_engine/companion_injector.js.map +1 -0
- package/dist/engine/context_engine/context_resolver.d.ts +46 -0
- package/dist/engine/context_engine/context_resolver.d.ts.map +1 -0
- package/dist/engine/context_engine/context_resolver.js +139 -0
- package/dist/engine/context_engine/context_resolver.js.map +1 -0
- package/dist/engine/context_engine/index.d.ts +25 -0
- package/dist/engine/context_engine/index.d.ts.map +1 -0
- package/dist/engine/context_engine/index.js +25 -0
- package/dist/engine/context_engine/index.js.map +1 -0
- package/dist/engine/context_engine/view_registry.d.ts +45 -0
- package/dist/engine/context_engine/view_registry.d.ts.map +1 -0
- package/dist/engine/context_engine/view_registry.js +36 -0
- package/dist/engine/context_engine/view_registry.js.map +1 -0
- package/dist/engine/context_engine/views/change_impact.d.ts +34 -0
- package/dist/engine/context_engine/views/change_impact.d.ts.map +1 -0
- package/dist/engine/context_engine/views/change_impact.js +288 -0
- package/dist/engine/context_engine/views/change_impact.js.map +1 -0
- package/dist/engine/context_engine/views/coverage_gap.d.ts +45 -0
- package/dist/engine/context_engine/views/coverage_gap.d.ts.map +1 -0
- package/dist/engine/context_engine/views/coverage_gap.js +238 -0
- package/dist/engine/context_engine/views/coverage_gap.js.map +1 -0
- package/dist/engine/context_engine/views/dependency_graph.d.ts +45 -0
- package/dist/engine/context_engine/views/dependency_graph.d.ts.map +1 -0
- package/dist/engine/context_engine/views/dependency_graph.js +358 -0
- package/dist/engine/context_engine/views/dependency_graph.js.map +1 -0
- package/dist/engine/context_engine/views/file_impact.d.ts +46 -0
- package/dist/engine/context_engine/views/file_impact.d.ts.map +1 -0
- package/dist/engine/context_engine/views/file_impact.js +181 -0
- package/dist/engine/context_engine/views/file_impact.js.map +1 -0
- package/dist/engine/context_engine/views/knowledge_ref.d.ts +37 -0
- package/dist/engine/context_engine/views/knowledge_ref.d.ts.map +1 -0
- package/dist/engine/context_engine/views/knowledge_ref.js +264 -0
- package/dist/engine/context_engine/views/knowledge_ref.js.map +1 -0
- package/dist/engine/context_engine/views/reference_trace.d.ts +49 -0
- package/dist/engine/context_engine/views/reference_trace.d.ts.map +1 -0
- package/dist/engine/context_engine/views/reference_trace.js +227 -0
- package/dist/engine/context_engine/views/reference_trace.js.map +1 -0
- package/dist/engine/contracts/artifact_schema_registry.d.ts +2 -0
- package/dist/engine/contracts/artifact_schema_registry.d.ts.map +1 -1
- package/dist/engine/contracts/artifact_schema_registry.js +31 -1
- package/dist/engine/contracts/artifact_schema_registry.js.map +1 -1
- package/dist/engine/contracts/capability_registry.d.ts.map +1 -1
- package/dist/engine/contracts/capability_registry.js +2 -28
- package/dist/engine/contracts/capability_registry.js.map +1 -1
- package/dist/engine/contracts/contract_guard.js +8 -0
- package/dist/engine/contracts/contract_guard.js.map +1 -1
- package/dist/engine/contracts/contract_registry/builtin_contracts_core.d.ts.map +1 -1
- package/dist/engine/contracts/contract_registry/builtin_contracts_core.js +1 -19
- package/dist/engine/contracts/contract_registry/builtin_contracts_core.js.map +1 -1
- package/dist/engine/contracts/design_lifecycle_contract.d.ts.map +1 -1
- package/dist/engine/contracts/design_lifecycle_contract.js +14 -8
- package/dist/engine/contracts/design_lifecycle_contract.js.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_audit_tail.d.ts.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_audit_tail.js +0 -37
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_audit_tail.js.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_infra.d.ts.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_infra.js +2 -78
- package/dist/engine/contracts/dual_layer_mechanism_registry/mechanisms_infra.js.map +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/shared.js +1 -1
- package/dist/engine/contracts/dual_layer_mechanism_registry/shared.js.map +1 -1
- package/dist/engine/contracts/error_path_verifier.js +2 -2
- package/dist/engine/contracts/error_path_verifier.js.map +1 -1
- package/dist/engine/contracts/first_principles.d.ts +47 -0
- package/dist/engine/contracts/first_principles.d.ts.map +1 -1
- package/dist/engine/contracts/first_principles.js +56 -0
- package/dist/engine/contracts/first_principles.js.map +1 -1
- package/dist/engine/contracts/mechanism_contract_registry/contracts-audit.d.ts +1 -1
- package/dist/engine/contracts/mechanism_contract_registry/contracts-audit.d.ts.map +1 -1
- package/dist/engine/contracts/mechanism_contract_registry/contracts-audit.js +2 -19
- package/dist/engine/contracts/mechanism_contract_registry/contracts-audit.js.map +1 -1
- package/dist/engine/contracts/mechanism_contract_registry/contracts-platform.d.ts +2 -2
- package/dist/engine/contracts/mechanism_contract_registry/contracts-platform.d.ts.map +1 -1
- package/dist/engine/contracts/mechanism_contract_registry/contracts-platform.js +4 -42
- package/dist/engine/contracts/mechanism_contract_registry/contracts-platform.js.map +1 -1
- package/dist/engine/contracts/project_knowledge_contract.d.ts +1 -0
- package/dist/engine/contracts/project_knowledge_contract.d.ts.map +1 -1
- package/dist/engine/contracts/project_knowledge_contract.js +5 -4
- package/dist/engine/contracts/project_knowledge_contract.js.map +1 -1
- package/dist/engine/contracts/slice_fix_loop.d.ts +86 -0
- package/dist/engine/contracts/slice_fix_loop.d.ts.map +1 -0
- package/dist/engine/contracts/slice_fix_loop.js +98 -0
- package/dist/engine/contracts/slice_fix_loop.js.map +1 -0
- package/dist/engine/contracts/state_machine_contracts.js +2 -2
- package/dist/engine/contracts/state_machine_contracts.js.map +1 -1
- package/dist/engine/contracts/tool_invocation_contract_registry.d.ts.map +1 -1
- package/dist/engine/contracts/tool_invocation_contract_registry.js +44 -2
- package/dist/engine/contracts/tool_invocation_contract_registry.js.map +1 -1
- package/dist/engine/contracts/user_promise.js +2 -2
- package/dist/engine/contracts/user_promise.js.map +1 -1
- package/dist/engine/core/errors.d.ts +1 -1
- package/dist/engine/core/errors.js +1 -1
- package/dist/engine/core/fail_closed.d.ts +39 -0
- package/dist/engine/core/fail_closed.d.ts.map +1 -0
- package/dist/engine/core/fail_closed.js +38 -0
- package/dist/engine/core/fail_closed.js.map +1 -0
- package/dist/engine/core/index.d.ts +3 -1
- package/dist/engine/core/index.d.ts.map +1 -1
- package/dist/engine/core/index.js +3 -1
- package/dist/engine/core/index.js.map +1 -1
- package/dist/engine/core/paths.d.ts +6 -2
- package/dist/engine/core/paths.d.ts.map +1 -1
- package/dist/engine/core/paths.js +8 -2
- package/dist/engine/core/paths.js.map +1 -1
- package/dist/engine/dependency_scanner.js +1 -1
- package/dist/engine/dependency_scanner.js.map +1 -1
- package/dist/engine/exploration.js +1 -1
- package/dist/engine/exploration.js.map +1 -1
- package/dist/engine/feasibility_checker.js +1 -1
- package/dist/engine/impact_analyzer.js +1 -1
- package/dist/engine/impact_analyzer.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_audit.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_audit.js +1 -2
- package/dist/engine/knowledge/knowledge_asset_audit.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_consumer.d.ts +8 -2
- package/dist/engine/knowledge/knowledge_asset_consumer.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_consumer.js +10 -7
- package/dist/engine/knowledge/knowledge_asset_consumer.js.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_schema.d.ts +6 -2
- package/dist/engine/knowledge/knowledge_asset_schema.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_asset_schema.js +3 -4
- package/dist/engine/knowledge/knowledge_asset_schema.js.map +1 -1
- package/dist/engine/knowledge/knowledge_consumption_snapshot.js +2 -2
- package/dist/engine/knowledge/knowledge_consumption_snapshot.js.map +1 -1
- package/dist/engine/knowledge/knowledge_health.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_health.js +6 -4
- package/dist/engine/knowledge/knowledge_health.js.map +1 -1
- package/dist/engine/knowledge/knowledge_injection_boundary.d.ts +2 -1
- package/dist/engine/knowledge/knowledge_injection_boundary.d.ts.map +1 -1
- package/dist/engine/knowledge/knowledge_injection_boundary.js +35 -43
- package/dist/engine/knowledge/knowledge_injection_boundary.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge.js +4 -2
- package/dist/engine/pipeline/intent_expander/knowledge.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts +2 -2
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.js +1 -0
- package/dist/engine/pipeline/intent_expander/knowledge_resolution.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts +2 -0
- package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts.map +1 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.js +5 -1
- package/dist/engine/pipeline/intent_expander/scope_acceptance.js.map +1 -1
- package/dist/engine/pipeline/intent_expander/types.d.ts +1 -1
- package/dist/engine/pipeline/intent_expander/types.d.ts.map +1 -1
- package/dist/engine/pipeline/scope_lease.d.ts.map +1 -1
- package/dist/engine/pipeline/scope_lease.js +1 -3
- package/dist/engine/pipeline/scope_lease.js.map +1 -1
- package/dist/engine/pipeline/scope_resolver.js +1 -1
- package/dist/engine/pipeline/scope_resolver.js.map +1 -1
- package/dist/engine/pipeline/state_machine/audit_logger.d.ts.map +1 -1
- package/dist/engine/pipeline/state_machine/audit_logger.js +7 -1
- package/dist/engine/pipeline/state_machine/audit_logger.js.map +1 -1
- package/dist/engine/pipeline/state_machine/certainty_gate.d.ts.map +1 -1
- package/dist/engine/pipeline/state_machine/certainty_gate.js +81 -7
- package/dist/engine/pipeline/state_machine/certainty_gate.js.map +1 -1
- package/dist/engine/pipeline/state_machine/command_state_verifier.js +1 -1
- package/dist/engine/pipeline/state_machine/command_state_verifier.js.map +1 -1
- package/dist/engine/pipeline/state_machine/hook_classifier.d.ts +14 -1
- package/dist/engine/pipeline/state_machine/hook_classifier.d.ts.map +1 -1
- package/dist/engine/pipeline/state_machine/hook_classifier.js +35 -12
- package/dist/engine/pipeline/state_machine/hook_classifier.js.map +1 -1
- package/dist/engine/pipeline/state_machine/pipeline_state_machine.d.ts +6 -2
- package/dist/engine/pipeline/state_machine/pipeline_state_machine.d.ts.map +1 -1
- package/dist/engine/pipeline/state_machine/pipeline_state_machine.js +158 -50
- package/dist/engine/pipeline/state_machine/pipeline_state_machine.js.map +1 -1
- package/dist/engine/pipeline/state_machine/sf_command_parser.d.ts.map +1 -1
- package/dist/engine/pipeline/state_machine/sf_command_parser.js +1 -0
- package/dist/engine/pipeline/state_machine/sf_command_parser.js.map +1 -1
- package/dist/engine/pipeline/state_machine/state_self_diagnostic.js +3 -3
- package/dist/engine/pipeline/state_machine/state_self_diagnostic.js.map +1 -1
- package/dist/engine/pipeline/task_context/manager.js.map +1 -1
- package/dist/engine/pipeline/task_context/manager_setters.js +1 -1
- package/dist/engine/pipeline/task_context/manager_setters.js.map +1 -1
- package/dist/engine/pipeline/task_planner.d.ts.map +1 -1
- package/dist/engine/pipeline/task_planner.js +1 -1
- package/dist/engine/pipeline/task_planner.js.map +1 -1
- package/dist/engine/release/foundation_scenario_registry.js +2 -2
- package/dist/engine/release/foundation_scenario_registry.js.map +1 -1
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.js +1 -0
- package/dist/engine/release/gate_checks/checkControlPlaneTrust.js.map +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js +1 -1
- package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js.map +1 -1
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.d.ts.map +1 -1
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.js +27 -60
- package/dist/engine/release/gate_checks/checkWorkflowNavigation.js.map +1 -1
- package/dist/engine/release/release_gate_scenario_registry.js +9 -9
- package/dist/engine/release/release_gate_scenario_registry.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js +17 -17
- package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js +3 -3
- package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js +18 -18
- package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js +10 -10
- package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js +3 -3
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js +13 -13
- package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts +1 -1
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts.map +1 -1
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js +14 -3
- package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js.map +1 -1
- package/dist/engine/retention_policy.js +1 -1
- package/dist/engine/retention_policy.js.map +1 -1
- package/dist/engine/templates/consumable_asset_registry/builtin_assets_core.js +2 -2
- package/dist/engine/templates/consumable_asset_registry/builtin_assets_core.js.map +1 -1
- package/dist/engine/templates/consumable_asset_registry/builtin_assets_dual_layer_core.d.ts.map +1 -1
- package/dist/engine/templates/consumable_asset_registry/builtin_assets_dual_layer_core.js +2 -22
- package/dist/engine/templates/consumable_asset_registry/builtin_assets_dual_layer_core.js.map +1 -1
- package/dist/engine/templates/consumption_trace_store.js +2 -2
- package/dist/engine/templates/consumption_trace_store.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/artifacts_shared_part2.js +1 -1
- package/dist/engine/templates/explicit_asset_registry/artifacts_shared_part2.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/gates.d.ts.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/gates.js +50 -0
- package/dist/engine/templates/explicit_asset_registry/gates.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/procedures_part1.d.ts.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/procedures_part1.js +16 -0
- package/dist/engine/templates/explicit_asset_registry/procedures_part1.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/procedures_part2.d.ts.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/procedures_part2.js +35 -2
- package/dist/engine/templates/explicit_asset_registry/procedures_part2.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/rules_pipeline.d.ts.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/rules_pipeline.js +16 -0
- package/dist/engine/templates/explicit_asset_registry/rules_pipeline.js.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/rules_shared.d.ts.map +1 -1
- package/dist/engine/templates/explicit_asset_registry/rules_shared.js +288 -0
- package/dist/engine/templates/explicit_asset_registry/rules_shared.js.map +1 -1
- package/dist/engine/templates/workflow_rule_generator.d.ts +1 -1
- package/dist/engine/templates/workflow_rule_generator.js +2 -2
- package/dist/engine/workflow/next_action_planner.d.ts.map +1 -1
- package/dist/engine/workflow/next_action_planner.js +21 -27
- package/dist/engine/workflow/next_action_planner.js.map +1 -1
- package/dist/engine/workflow/project_stage_detector.d.ts.map +1 -1
- package/dist/engine/workflow/project_stage_detector.js +6 -4
- package/dist/engine/workflow/project_stage_detector.js.map +1 -1
- package/dist/git/git_deps.d.ts +1 -0
- package/dist/git/git_deps.d.ts.map +1 -1
- package/dist/git/operations.d.ts +1 -0
- package/dist/git/operations.d.ts.map +1 -1
- package/dist/git/operations.js +2 -0
- package/dist/git/operations.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +10 -1
- package/dist/index.js.map +1 -1
- package/dist/knowledge/conflict_detector.d.ts.map +1 -1
- package/dist/knowledge/conflict_detector.js +13 -2
- package/dist/knowledge/conflict_detector.js.map +1 -1
- package/dist/knowledge/health_checker.d.ts.map +1 -1
- package/dist/knowledge/health_checker.js +5 -3
- package/dist/knowledge/health_checker.js.map +1 -1
- package/dist/knowledge/index_manager.d.ts +15 -0
- package/dist/knowledge/index_manager.d.ts.map +1 -1
- package/dist/knowledge/index_manager.js +106 -6
- package/dist/knowledge/index_manager.js.map +1 -1
- package/dist/knowledge/loader.d.ts +8 -4
- package/dist/knowledge/loader.d.ts.map +1 -1
- package/dist/knowledge/loader.js +189 -34
- package/dist/knowledge/loader.js.map +1 -1
- package/dist/knowledge/writer.js +2 -2
- package/dist/knowledge/writer.js.map +1 -1
- package/dist/server/tools/index.d.ts.map +1 -1
- package/dist/server/tools/index.js +11 -9
- package/dist/server/tools/index.js.map +1 -1
- package/dist/server/tools/lazy_loaders.d.ts +1 -1
- package/dist/server/tools/lazy_loaders.d.ts.map +1 -1
- package/dist/server/tools/lazy_loaders.js +2 -1
- package/dist/server/tools/lazy_loaders.js.map +1 -1
- package/dist/server/tools/middleware.d.ts +2 -0
- package/dist/server/tools/middleware.d.ts.map +1 -1
- package/dist/server/tools/middleware.js +22 -6
- package/dist/server/tools/middleware.js.map +1 -1
- package/dist/server/tools/schemas.d.ts +4 -4
- package/dist/server/tools/tool_groups/admin.d.ts.map +1 -1
- package/dist/server/tools/tool_groups/admin.js +13 -16
- package/dist/server/tools/tool_groups/admin.js.map +1 -1
- package/dist/server/tools/tool_groups/knowledge.js +2 -2
- package/dist/server/tools/tool_groups/knowledge.js.map +1 -1
- package/dist/server/tools/tool_groups/product_operations.d.ts +9 -0
- package/dist/server/tools/tool_groups/product_operations.d.ts.map +1 -0
- package/dist/server/tools/tool_groups/product_operations.js +143 -0
- package/dist/server/tools/tool_groups/product_operations.js.map +1 -0
- package/dist/server/tools/tool_groups/state_machine.d.ts.map +1 -1
- package/dist/server/tools/tool_groups/state_machine.js +544 -6
- package/dist/server/tools/tool_groups/state_machine.js.map +1 -1
- package/dist/server/tools/tool_names.d.ts +4 -0
- package/dist/server/tools/tool_names.d.ts.map +1 -1
- package/dist/server/tools/tool_names.js +6 -0
- package/dist/server/tools/tool_names.js.map +1 -1
- package/dist/types/knowledge.d.ts +2 -4
- package/dist/types/knowledge.d.ts.map +1 -1
- package/dist/types/knowledge.js.map +1 -1
- package/dist/types/pipeline.d.ts +4 -3
- package/dist/types/pipeline.d.ts.map +1 -1
- package/dist/types/state_machine.d.ts +19 -4
- package/dist/types/state_machine.d.ts.map +1 -1
- package/dist/types/state_machine.js.map +1 -1
- package/package.json +14 -14
- 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 +23 -2
- 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 +11 -5
- 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 +23 -21
- 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 +25 -14
- 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 +21 -14
- 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 +18 -6
- 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 +15 -6
- 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 +9 -6
- 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 +48 -13
- 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 +13 -7
- package/templates/artifacts/shared/ADR/346/250/241/347/211/210.md +17 -5
- package/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 +31 -70
- package/templates/artifacts/shared/Bug/345/210/206/346/236/220/346/250/241/347/211/210.md +2 -10
- package/templates/artifacts/shared/OOD/350/256/276/350/256/241/346/221/230/350/246/201/346/250/241/347/211/210.md +2 -8
- package/templates/artifacts/shared/POC/347/273/223/350/256/272/346/250/241/347/211/210.md +2 -10
- 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 +47 -10
- package/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/347/211/210.md +2 -8
- package/templates/artifacts/shared//345/210/207/347/211/207/350/256/241/345/210/222/346/250/241/347/211/210.md +122 -17
- package/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 +2 -14
- package/templates/artifacts/shared//345/216/237/345/236/213/350/257/264/346/230/216/346/250/241/347/211/210.md +115 -225
- package/templates/artifacts/shared//345/220/216/347/253/257API/351/252/214/346/224/266/346/270/205/345/215/225.md +2 -13
- package/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 +11 -10
- package/templates/artifacts/shared//345/256/211/345/205/250/345/256/241/350/256/241/346/250/241/347/211/210.md +8 -33
- package/templates/artifacts/shared//345/256/241/346/237/245/346/221/230/350/246/201.md +10 -15
- package/templates/artifacts/shared//346/200/247/350/203/275/345/210/206/346/236/220/346/250/241/347/211/210.md +2 -10
- package/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 +2 -13
- package/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 +54 -20
- package/templates/artifacts/shared//346/225/205/351/232/234/345/244/215/347/233/230/346/250/241/347/211/210.md +2 -11
- package/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 +43 -31
- package/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 +2 -15
- package/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 +121 -42
- package/templates/artifacts/shared//346/236/266/346/236/204/350/256/276/350/256/241/346/250/241/347/211/210.md +110 -76
- package/templates/artifacts/shared//346/265/213/350/257/225/350/256/241/345/210/222/346/250/241/347/211/210.md +27 -18
- package/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 +2 -24
- package/templates/artifacts/shared//350/257/246/347/273/206/350/256/276/350/256/241/346/250/241/347/211/210.md +83 -30
- package/templates/artifacts/shared//350/277/201/347/247/273/350/257/204/344/274/260/346/250/241/347/211/210.md +15 -12
- package/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 +157 -36
- package/templates/artifacts/shared//351/207/215/346/236/204/346/226/271/346/241/210/346/250/241/347/211/210.md +2 -10
- package/templates/artifacts/shared//351/234/200/346/261/202/345/210/206/346/236/220/346/250/241/347/211/210.md +74 -15
- package/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 +38 -46
- package/templates/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 +1 -7
- package/templates/checklists//344/274/232/350/257/235/346/201/242/345/244/215.md +1 -11
- package/templates/checklists//345/267/245/344/275/234/346/265/201/351/252/214/346/224/266/346/270/205/345/215/225.md +1 -7
- package/templates/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 +1 -7
- package/templates/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 +1 -7
- package/templates/checklists//351/232/220/347/247/201/345/256/241/346/237/245/346/270/205/345/215/225.md +1 -7
- package/templates/checklists//351/252/214/350/257/201/351/252/214/346/224/266/346/270/205/345/215/225.md +1 -7
- package/templates/domain//345/244/232/347/247/237/346/210/267.md +1 -13
- package/templates/domain//345/256/241/350/256/241/346/227/245/345/277/227.md +1 -12
- package/templates/domain//345/257/274/345/205/245/345/257/274/345/207/272/350/247/204/345/210/231.md +1 -14
- package/templates/domain//345/267/245/344/275/234/346/265/201/345/274/225/346/223/216.md +1 -17
- package/templates/domain//346/212/245/350/241/250/347/273/237/350/256/241.md +1 -15
- package/templates/domain//346/224/257/344/273/230/350/247/204/345/210/231.md +1 -16
- package/templates/domain//346/225/260/346/215/256/346/235/203/351/231/220.md +1 -13
- package/templates/domain//351/200/232/347/224/250/346/234/272/346/242/260/346/235/241/346/254/276.md +1 -15
- package/templates/domain//351/200/232/347/237/245/350/247/204/345/210/231.md +1 -15
- package/templates/gates/existing-system/gate-/346/236/266/346/236/204/350/256/276/350/256/241.yaml +13 -14
- 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 +48 -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 +41 -8
- package/templates/gates/existing-system/gate-/350/257/225/350/277/220/350/241/214.yaml +30 -12
- package/templates/gates/existing-system/gate-/350/257/246/347/273/206/350/256/276/350/256/241.yaml +25 -15
- package/templates/gates/shared/gate-/344/272/244/344/273/230.yaml +26 -8
- package/templates/gates/shared/gate-/344/273/243/347/240/201/345/256/241/346/237/245.yaml +47 -8
- package/templates/gates/shared/gate-/344/273/273/345/212/241/350/247/204/345/210/222.yaml +131 -5
- package/templates/gates/shared/gate-/345/210/207/347/211/207/345/256/241/346/237/245.yaml +50 -0
- package/templates/gates/shared/gate-/345/210/207/347/211/207/346/211/247/350/241/214.yaml +51 -0
- package/templates/gates/shared/gate-/345/217/221/345/270/203/345/220/216/350/247/202/345/257/237.yaml +40 -8
- package/templates/gates/shared/gate-/345/256/211/345/205/250/345/256/241/350/256/241.yaml +77 -0
- package/templates/gates/shared/gate-/346/236/266/346/236/204/350/256/276/350/256/241.yaml +136 -9
- 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 +30 -4
- package/templates/gates/shared/gate-/347/274/226/347/240/201/345/207/206/345/244/207.yaml +40 -4
- package/templates/gates/shared/gate-/347/274/226/347/240/201/345/256/236/347/216/260.yaml +42 -4
- package/templates/gates/shared/gate-/347/274/226/347/240/201/351/252/214/350/257/201.yaml +33 -4
- package/templates/gates/shared/gate-/350/201/224/350/260/203/351/252/214/350/257/201.yaml +47 -8
- package/templates/gates/shared/gate-/350/257/246/347/273/206/350/256/276/350/256/241.yaml +118 -9
- package/templates/gates/shared/gate-/351/234/200/346/261/202/345/210/206/346/236/220.yaml +154 -8
- package/templates/internal/patterns/Diff/345/275/222/345/261/236/350/277/275/350/270/252.md +1 -10
- package/templates/internal/patterns/Hook/345/261/202/344/272/247/347/211/251/347/273/223/346/236/204/346/240/241/351/252/214.md +1 -5
- package/templates/internal/patterns/Java/350/264/250/351/207/217/351/227/250/347/246/201.md +1 -11
- package/templates/internal/patterns/LLM/351/242/204/347/256/227/347/275/221/345/205/263.md +1 -10
- package/templates/internal/patterns//344/272/247/347/211/251Schema/346/263/250/345/206/214/344/270/255/345/277/203.md +1 -5
- package/templates/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 +1 -10
- package/templates/internal/patterns//344/273/273/345/212/241/347/256/241/347/220/206/345/231/250.md +1 -11
- package/templates/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 +1 -10
- package/templates/internal/patterns//344/275/234/347/224/250/345/237/237/347/247/237/347/272/246.md +1 -11
- package/templates/internal/patterns//345/206/262/347/252/201/351/227/250/347/246/201.md +1 -10
- package/templates/internal/patterns//345/206/263/347/255/226/347/275/221/345/205/263.md +1 -12
- package/templates/internal/patterns//345/210/206/345/234/272/346/231/257/350/277/207/347/250/213/350/247/204/345/210/231.md +1 -5
- package/templates/internal/patterns//345/217/230/345/274/202/345/256/241/350/256/241.md +1 -11
- package/templates/internal/patterns//345/233/236/345/275/222/347/237/251/351/230/265.md +1 -10
- package/templates/internal/patterns//345/267/245/344/275/234/345/214/272/344/272/222/346/226/245/351/224/201.md +1 -10
- package/templates/internal/patterns//345/267/245/344/275/234/345/214/272/345/224/244/351/206/222.md +1 -10
- package/templates/internal/patterns//345/271/266/345/217/221/351/224/201.md +1 -12
- package/templates/internal/patterns//345/274/200/345/217/221/350/200/205/345/256/252/346/263/225.md +1 -12
- package/templates/internal/patterns//346/225/217/346/204/237/344/277/241/346/201/257/346/211/253/346/217/217.md +1 -10
- package/templates/internal/patterns//346/250/241/347/211/210Frontmatter/350/247/243/346/236/220.md +1 -5
- package/templates/internal/patterns//346/262/273/347/220/206/350/277/220/350/241/214/346/227/266/345/276/252/347/216/257.md +1 -11
- package/templates/internal/patterns//346/265/201/345/274/217/345/277/203/350/267/263.md +2 -12
- package/templates/internal/patterns//347/237/245/350/257/206/344/270/273/346/235/203.md +1 -11
- package/templates/internal/patterns//350/257/255/344/271/211/350/257/201/346/215/256.md +1 -10
- package/templates/internal/patterns//350/277/220/350/241/214/345/256/211/345/205/250/345/214/205.md +1 -11
- package/templates/internal/patterns//351/252/214/350/257/201/345/221/275/344/273/244/347/224/237/346/210/220.md +4 -12
- package/templates/internal/rules/OOD/344/270/216SOLID/350/256/276/350/256/241/350/247/204/345/210/231.md +0 -12
- package/templates/internal/rules//344/272/247/347/211/251/345/245/221/347/272/246/350/247/204/345/210/231.md +1 -7
- package/templates/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 +3 -28
- package/templates/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 -9
- package/templates/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 -12
- package/templates/internal/rules//345/221/275/344/273/244/346/211/247/350/241/214/350/247/204/345/210/231.md +1 -7
- package/templates/internal/rules//345/221/275/344/273/244/350/267/257/347/224/261/350/247/204/345/210/231.md +0 -6
- package/templates/internal/rules//345/267/245/344/275/234/346/265/201/345/245/221/347/272/246/350/247/204/345/210/231.md +1 -7
- package/templates/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 +9 -19
- package/templates/internal/rules//345/267/245/344/275/234/346/265/201/346/250/241/347/211/210/345/214/205/350/247/204/345/210/231.md +0 -7
- package/templates/internal/rules//345/267/245/345/205/267/350/260/203/347/224/250/350/247/204/345/210/231.md +1 -7
- package/templates/internal/rules//346/204/217/345/233/276/350/267/257/347/224/261/350/247/204/345/210/231.md +2 -8
- package/templates/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 +1 -7
- package/templates/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 -7
- package/templates/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 -10
- package/templates/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 +4 -18
- package/templates/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 -8
- package/templates/internal/rules//346/227/245/345/277/227/346/262/273/347/220/206/350/247/204/345/210/231.md +0 -11
- package/templates/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 -11
- package/templates/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 +4 -6
- package/templates/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 -10
- package/templates/internal/rules//346/240/270/345/277/203/344/275/223/351/252/214/345/216/237/345/210/231.md +1 -8
- package/templates/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 +2 -8
- package/templates/internal/rules//346/250/241/347/211/210Frontmatter/350/247/204/350/214/203.md +85 -64
- package/templates/internal/rules//346/250/241/347/211/210/350/265/204/344/272/247/345/217/257/350/247/201/346/200/247/350/247/204/345/210/231.md +0 -11
- package/templates/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 +1 -7
- package/templates/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 +0 -13
- package/templates/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 +1 -17
- package/templates/internal/rules//347/237/245/350/257/206/346/262/273/347/220/206/350/247/204/345/210/231.md +0 -11
- package/templates/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 +1 -7
- package/templates/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 +1 -9
- package/templates/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 -10
- package/templates/internal/rules//347/273/206/350/212/202/347/272/252/345/276/213/350/247/204/345/210/231.md +0 -10
- package/templates/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 -10
- package/templates/internal/rules//350/256/241/345/210/222/345/211/215/347/275/256/351/227/250/350/247/204/345/210/231.md +1 -11
- package/templates/internal/rules//350/256/276/350/256/241/344/272/247/347/211/251/345/214/205/350/247/204/345/210/231.md +6 -7
- package/templates/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 -11
- package/templates/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 -7
- package/templates/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 +1 -7
- package/templates/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 -15
- package/templates/internal/rules//351/205/215/347/275/256/344/274/230/345/205/210/347/272/247/350/247/204/345/210/231.md +38 -34
- package/templates/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 +5 -14
- package/templates/internal/rules//351/230/262/345/255/244/345/262/233/345/256/236/347/216/260/350/247/204/345/210/231.md +1 -7
- package/templates/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 +31 -34
- package/templates/internal/rules//351/252/214/346/224/266/346/250/241/347/211/210/350/276/223/345/207/272/345/245/221/347/272/246/350/247/204/345/210/231.md +0 -13
- package/templates/internal/rules//351/252/214/350/257/201/345/245/221/347/272/246/350/247/204/345/210/231.md +1 -7
- package/templates/patterns/API/350/256/276/350/256/241/350/247/204/350/214/203.md +1 -15
- package/templates/patterns/Docker/351/203/250/347/275/262/350/247/204/350/214/203.md +1 -13
- package/templates/patterns/Git/346/223/215/344/275/234/350/247/204/350/214/203.md +1 -17
- package/templates/patterns/N/345/212/2401/346/237/245/350/257/242/350/247/204/350/214/203.md +1 -16
- package/templates/patterns/React/345/210/227/350/241/250/350/241/250/346/240/274/350/247/204/350/214/203.md +1 -15
- package/templates/patterns/React/346/216/245/345/217/243/351/233/206/346/210/220/350/247/204/350/214/203.md +1 -16
- package/templates/patterns/React/347/212/266/346/200/201/347/256/241/347/220/206/350/247/204/350/214/203.md +1 -16
- package/templates/patterns/React/347/273/204/344/273/266/350/247/204/350/214/203.md +1 -15
- package/templates/patterns/React/350/241/250/345/215/225/350/247/204/350/214/203.md +1 -15
- package/templates/patterns/React/350/267/257/347/224/261/350/247/204/350/214/203.md +1 -16
- package/templates/patterns/SOLID/350/256/276/350/256/241/350/247/204/350/214/203.md +1 -8
- package/templates/patterns/Schema/345/205/274/345/256/271/350/247/204/350/214/203.md +1 -15
- package/templates/patterns/Vue/347/212/266/346/200/201/347/256/241/347/220/206/350/247/204/350/214/203.md +1 -14
- package/templates/patterns/Vue/347/273/204/344/273/266/350/247/204/350/214/203.md +1 -18
- package/templates/patterns/Vue/350/267/257/347/224/261/350/247/204/350/214/203.md +1 -13
- package/templates/patterns//344/272/213/344/273/266/351/251/261/345/212/250/350/247/204/350/214/203.md +1 -17
- package/templates/patterns//344/272/213/345/212/241/346/250/241/345/274/217/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//344/274/230/351/233/205/345/201/234/346/234/272/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//345/205/250/346/240/210/346/265/201/347/250/213/344/277/256/345/244/215.md +1 -14
- package/templates/patterns//345/210/206/351/241/265/346/237/245/350/257/242/350/247/204/350/214/203.md +1 -19
- package/templates/patterns//345/211/215/347/253/257/346/200/247/350/203/275/350/247/204/350/214/203.md +1 -17
- package/templates/patterns//345/220/216/347/253/257/345/256/236/347/216/260/345/267/245/347/250/213/350/247/204/350/214/203.md +1 -8
- package/templates/patterns//345/221/275/345/220/215/350/247/204/350/214/203.md +1 -14
- package/templates/patterns//345/233/275/351/231/205/345/214/226/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//345/242/236/345/210/240/346/224/271/346/237/245/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//345/244/226/351/203/250/344/276/235/350/265/226/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//345/245/221/347/272/246/345/205/274/345/256/271/350/247/204/350/214/203.md +1 -13
- package/templates/patterns//345/256/232/346/227/266/344/273/273/345/212/241/350/247/204/350/214/203.md +1 -17
- package/templates/patterns//345/256/236/346/227/266/346/216/250/351/200/201/350/247/204/350/214/203.md +1 -15
- package/templates/patterns//345/267/245/347/250/213/347/272/252/345/276/213.md +1 -14
- package/templates/patterns//345/271/266/345/217/221/346/216/247/345/210/266/350/247/204/350/214/203.md +1 -19
- package/templates/patterns//345/274/202/346/255/245/345/257/274/345/207/272/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//346/216/245/345/217/243/345/245/221/347/272/246/350/247/204/350/214/203.md +1 -14
- package/templates/patterns//346/220/234/347/264/242/346/250/241/345/274/217/350/247/204/350/214/203.md +1 -17
- package/templates/patterns//346/225/260/346/215/256/351/232/220/347/247/201/350/247/204/350/214/203.md +2 -19
- package/templates/patterns//346/226/207/344/273/266/344/270/212/344/274/240/350/247/204/350/214/203.md +1 -15
- package/templates/patterns//346/227/240/351/232/234/347/242/215/350/247/204/350/214/203.md +1 -15
- package/templates/patterns//346/227/245/345/277/227/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//346/235/203/351/231/220/350/256/244/350/257/201/350/247/204/350/214/203.md +1 -19
- package/templates/patterns//346/236/266/346/236/204/347/272/242/347/272/277.md +1 -13
- package/templates/patterns//346/265/213/350/257/225/350/264/250/351/207/217/350/247/204/350/214/203.md +1 -14
- package/templates/patterns//347/206/224/346/226/255/351/231/215/347/272/247/350/247/204/350/214/203.md +1 -17
- package/templates/patterns//347/212/266/346/200/201/346/265/201/350/275/254/350/247/204/350/214/203.md +1 -14
- package/templates/patterns//347/272/246/346/235/237/345/256/236/347/216/260/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//347/274/223/345/255/230/347/255/226/347/225/245/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//347/274/226/347/240/201/350/264/250/351/207/217/350/247/204/350/214/203.md +1 -14
- package/templates/patterns//347/274/272/351/231/267/347/256/241/347/220/206/350/247/204/350/214/203.md +1 -13
- package/templates/patterns//350/260/203/350/257/225/346/226/271/346/263/225/350/256/272.md +1 -14
- package/templates/patterns//350/276/223/345/205/245/346/240/241/351/252/214/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//351/224/231/350/257/257/345/244/204/347/220/206/350/247/204/350/214/203.md +1 -16
- package/templates/patterns//351/224/231/350/257/257/350/276/271/347/225/214/350/247/204/350/214/203.md +1 -18
- package/templates/patterns//351/242/206/345/237/237/351/251/261/345/212/250/350/256/276/350/256/241/350/247/204/350/214/203.md +1 -15
- package/templates/procedures/OOD/350/256/276/350/256/241/345/267/245/344/275/234/346/265/201.md +41 -20
- package/templates/procedures/Schema/345/217/230/346/233/264/346/265/201/346/260/264/347/272/277.md +5 -11
- package/templates/procedures//344/270/215/347/241/256/345/256/232/346/227/266/345/244/264/350/204/221/351/243/216/346/232/264/346/265/201/347/250/213.md +92 -0
- package/templates/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 +8 -9
- package/templates/procedures//344/273/243/347/240/201/351/227/250/347/246/201/346/265/201/347/250/213.md +1 -7
- package/templates/procedures//344/273/273/345/212/241/346/213/206/350/247/243/346/265/201/347/250/213.md +10 -9
- package/templates/procedures//344/273/273/345/212/241/350/247/204/345/210/222/345/267/245/344/275/234/346/265/201.md +83 -0
- package/templates/procedures//344/274/232/350/257/235/346/201/242/345/244/215/346/265/201/347/250/213.md +2 -10
- package/templates/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 +8 -16
- package/templates/procedures//345/212/237/350/203/275/345/274/200/345/217/221/346/265/201/347/250/213.md +11 -16
- package/templates/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 +1 -8
- package/templates/procedures//345/221/275/344/273/244/346/211/247/350/241/214/346/265/201/347/250/213.md +2 -7
- package/templates/procedures//345/221/275/344/273/244/350/267/257/347/224/261/346/265/201/347/250/213.md +0 -6
- package/templates/procedures//345/256/211/345/205/250/345/212/240/345/233/272/346/265/201/346/260/264/347/272/277.md +6 -12
- package/templates/procedures//345/267/245/345/205/267/350/260/203/347/224/250/346/265/201/347/250/213.md +2 -7
- package/templates/procedures//346/200/247/350/203/275/346/265/201/346/260/264/347/272/277.md +5 -11
- package/templates/procedures//346/204/217/345/233/276/350/267/257/347/224/261/346/265/201/347/250/213.md +3 -8
- package/templates/procedures//346/216/245/345/217/243/351/233/206/346/210/220/346/265/201/346/260/264/347/272/277.md +14 -14
- package/templates/procedures//346/225/260/346/215/256/345/272/223/350/277/201/347/247/273/346/265/201/347/250/213.md +1 -7
- package/templates/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 +1 -7
- package/templates/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 +8 -7
- package/templates/procedures//346/236/266/346/236/204/350/256/276/350/256/241/345/267/245/344/275/234/346/265/201.md +22 -9
- package/templates/procedures//346/246/202/345/277/265/351/252/214/350/257/201/346/265/201/346/260/264/347/272/277.md +6 -10
- package/templates/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 +18 -10
- package/templates/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 +7 -13
- package/templates/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 +29 -9
- package/templates/procedures//347/237/245/350/257/206/347/273/264/346/212/244/346/265/201/346/260/264/347/272/277.md +6 -12
- package/templates/procedures//347/264/247/346/200/245/344/277/256/345/244/215/346/265/201/346/260/264/347/272/277.md +6 -12
- package/templates/procedures//347/274/226/347/240/201/345/211/215/346/276/204/346/270/205/346/265/201/347/250/213.md +7 -7
- package/templates/procedures//347/274/226/347/240/201/351/230/266/346/256/265/346/211/247/350/241/214/345/267/245/344/275/234/346/265/201.md +101 -0
- package/templates/procedures//350/207/252/344/270/273/351/200/211/345/236/213/346/265/201/347/250/213.md +1 -7
- package/templates/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 +32 -13
- package/templates/procedures//350/256/276/350/256/241/345/256/241/350/256/241/346/265/201/347/250/213.md +17 -21
- package/templates/procedures//350/257/246/347/273/206/350/256/276/350/256/241/346/265/201/347/250/213.md +91 -24
- package/templates/procedures//350/260/203/350/257/225/346/216/222/346/237/245/346/265/201/347/250/213.md +31 -9
- package/templates/procedures//350/277/201/347/247/273/346/265/201/346/260/264/347/272/277.md +5 -11
- package/templates/procedures//351/203/250/347/275/262/345/217/221/345/270/203/346/265/201/347/250/213.md +35 -9
- package/templates/procedures//351/207/215/346/236/204/346/265/201/346/260/264/347/272/277.md +5 -11
- package/templates/procedures//351/233/206/346/210/220/351/252/214/350/257/201/346/265/201/347/250/213.md +9 -9
- package/templates/procedures//351/234/200/346/261/202/346/276/204/346/270/205/346/265/201/347/250/213.md +23 -16
- package/templates/procedures//351/252/214/346/224/266/346/265/213/350/257/225/350/247/204/345/210/222.md +8 -9
- 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 +66 -23
- package/templates/rules/existing-system//350/200/201/347/263/273/347/273/237/345/210/207/347/211/207/350/247/204/345/210/222/350/247/204/345/210/231.md +35 -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 +57 -20
- 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 +49 -25
- 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 +69 -25
- 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 +109 -23
- 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 +39 -19
- package/templates/rules/shared/SOLID/344/273/243/347/240/201/345/256/241/346/237/245/350/247/204/345/210/231.md +47 -20
- 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 +84 -11
- package/templates/rules/shared//344/270/212/346/270/270/344/272/244/345/217/211/351/252/214/350/257/201/350/247/204/345/210/231.md +56 -0
- package/templates/rules/shared//344/270/212/346/270/270/350/256/276/350/256/241/344/272/244/345/217/211/351/252/214/350/257/201/345/256/241/346/237/245/350/247/204/345/210/231.md +67 -0
- package/templates/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 +39 -16
- package/templates/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 +45 -57
- package/templates/rules/shared//345/206/263/347/255/226/345/256/214/346/225/264/346/200/247/345/256/241/346/237/245/350/247/204/345/210/231.md +18 -11
- package/templates/rules/shared//345/210/207/347/211/207/346/211/247/350/241/214/347/272/252/345/276/213/350/247/204/345/210/231.md +96 -0
- package/templates/rules/shared//345/210/207/347/211/207/350/247/204/345/210/222/350/247/204/345/210/231.md +64 -0
- package/templates/rules/shared//345/216/237/345/236/213/346/272/220/347/240/201/346/217/220/345/217/226/350/247/204/345/210/231.md +67 -0
- package/templates/rules/shared//345/216/237/345/236/213/350/257/264/346/230/216/345/256/241/346/237/245/350/247/204/345/210/231.md +73 -0
- package/templates/rules/shared//345/217/221/345/270/203/345/220/216/345/256/241/346/237/245/350/247/204/345/210/231.md +22 -13
- package/templates/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 +43 -18
- package/templates/rules/shared//345/256/211/345/205/250/345/256/241/346/237/245/350/247/204/345/210/231.md +53 -17
- package/templates/rules/shared//345/271/266/345/217/221/345/256/241/346/237/245/350/247/204/345/210/231.md +39 -10
- package/templates/rules/shared//346/200/247/350/203/275/345/256/241/346/237/245/350/247/204/345/210/231.md +32 -10
- package/templates/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 +40 -11
- package/templates/rules/shared//346/236/266/346/236/204/345/256/241/346/237/245/350/247/204/345/210/231.md +31 -11
- package/templates/rules/shared//346/236/266/346/236/204/350/256/276/350/256/241/345/256/241/346/237/245/350/247/204/345/210/231.md +102 -0
- package/templates/rules/shared//346/236/266/346/236/204/350/256/276/350/256/241/350/247/204/345/210/231.md +64 -0
- package/templates/rules/shared//347/213/254/347/253/213/345/256/241/346/237/245/350/247/204/345/210/231.md +33 -0
- package/templates/rules/shared//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 +171 -0
- package/templates/rules/shared//347/274/226/347/240/201/345/260/261/347/273/252/345/256/241/346/237/245/350/247/204/345/210/231.md +9 -13
- package/templates/rules/shared//350/201/224/350/260/203/351/252/214/350/257/201/346/270/205/345/215/225.md +62 -16
- package/templates/rules/shared//350/246/206/347/233/226/347/216/207/346/240/207/345/207/206.md +2 -3
- package/templates/rules/shared//350/257/246/347/273/206/350/256/276/350/256/241/345/256/241/346/237/245/350/247/204/345/210/231.md +82 -0
- package/templates/rules/shared//350/264/250/351/207/217/345/256/241/346/237/245/350/247/204/345/210/231.md +17 -12
- package/templates/rules/shared//350/277/275/350/270/252/347/237/251/351/230/265ID/350/247/204/345/210/231.md +48 -0
- package/templates/rules/shared//350/277/275/350/270/252/347/237/251/351/230/265/345/256/241/346/237/245/350/247/204/345/210/231.md +51 -0
- package/templates/rules/shared//351/234/200/346/261/202/350/264/250/351/207/217/345/256/241/346/237/245/350/247/204/345/210/231.md +30 -13
- package/templates/rules/shared//351/252/214/346/224/266/346/240/207/345/207/206/345/256/241/346/237/245/350/247/204/345/210/231.md +15 -15
- package/templates//346/250/241/347/211/210/350/264/241/347/214/256/346/214/207/345/215/227.md +11 -8
- package/dist/engine/config/config_auto_repair.d.ts +0 -30
- package/dist/engine/config/config_auto_repair.d.ts.map +0 -1
- package/dist/engine/config/config_auto_repair.js +0 -261
- package/dist/engine/config/config_auto_repair.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/constants.d.ts +0 -16
- package/dist/engine/config/config_precedence_contract/constants.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/constants.js +0 -166
- package/dist/engine/config/config_precedence_contract/constants.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/evidence.d.ts +0 -38
- package/dist/engine/config/config_precedence_contract/evidence.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/evidence.js +0 -59
- package/dist/engine/config/config_precedence_contract/evidence.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/field_class.d.ts +0 -11
- package/dist/engine/config/config_precedence_contract/field_class.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/field_class.js +0 -10
- package/dist/engine/config/config_precedence_contract/field_class.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/governance.d.ts +0 -31
- package/dist/engine/config/config_precedence_contract/governance.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/governance.js +0 -232
- package/dist/engine/config/config_precedence_contract/governance.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/index.d.ts +0 -21
- package/dist/engine/config/config_precedence_contract/index.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/index.js +0 -28
- package/dist/engine/config/config_precedence_contract/index.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/project_config.d.ts +0 -20
- package/dist/engine/config/config_precedence_contract/project_config.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/project_config.js +0 -210
- package/dist/engine/config/config_precedence_contract/project_config.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/resolution.d.ts +0 -93
- package/dist/engine/config/config_precedence_contract/resolution.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/resolution.js +0 -317
- package/dist/engine/config/config_precedence_contract/resolution.js.map +0 -1
- package/dist/engine/config/config_precedence_contract/types.d.ts +0 -92
- package/dist/engine/config/config_precedence_contract/types.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract/types.js +0 -20
- package/dist/engine/config/config_precedence_contract/types.js.map +0 -1
- package/dist/engine/config/config_precedence_contract.d.ts +0 -22
- package/dist/engine/config/config_precedence_contract.d.ts.map +0 -1
- package/dist/engine/config/config_precedence_contract.js +0 -34
- package/dist/engine/config/config_precedence_contract.js.map +0 -1
- package/dist/engine/config/zero_config_init.d.ts +0 -177
- package/dist/engine/config/zero_config_init.d.ts.map +0 -1
- package/dist/engine/config/zero_config_init.js +0 -857
- package/dist/engine/config/zero_config_init.js.map +0 -1
- package/templates/internal/patterns//351/233/266/351/205/215/347/275/256/345/210/235/345/247/213/345/214/226.md +0 -62
|
@@ -1,28 +1,20 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: post-release-review
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '发布后, 上线观察, post-release review'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
- frontend
|
|
8
7
|
products:
|
|
9
8
|
- '*'
|
|
10
9
|
id: ka-review-rule-发布后审查规则
|
|
11
|
-
asset_kind: review_rule
|
|
12
10
|
lifecycle_status: active
|
|
13
11
|
owner_mechanism_id: mc-delivery-gate
|
|
14
12
|
authority: supporting
|
|
15
|
-
primary_triggers:
|
|
16
|
-
- 发布后审查规则
|
|
17
|
-
secondary_triggers:
|
|
18
|
-
- 发布后审查
|
|
19
|
-
- 上线观察
|
|
20
|
-
negative_triggers: []
|
|
21
13
|
priority: P1
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
last_reviewed: '2026-06-01'
|
|
14
|
+
version: 1.2.0
|
|
15
|
+
last_reviewed: '2026-06-04'
|
|
25
16
|
stages: ["代码审查"]
|
|
17
|
+
triggers: ["发布后","上线观察","post-release review"]
|
|
26
18
|
---
|
|
27
19
|
|
|
28
20
|
# 发布后审查规则
|
|
@@ -30,27 +22,44 @@ stages: ["代码审查"]
|
|
|
30
22
|
## REL-01: 监控指标在阈值内
|
|
31
23
|
|
|
32
24
|
pattern: 发布后关键监控指标必须在正常范围内
|
|
33
|
-
severity:
|
|
25
|
+
severity: error
|
|
26
|
+
check_type: deterministic
|
|
34
27
|
scope: [backend, frontend]
|
|
35
|
-
description: 错误率、响应时间、吞吐量等关键指标在发布后 30 分钟内必须在历史基线 ±20%
|
|
28
|
+
description: 错误率、响应时间、吞吐量等关键指标在发布后 30 分钟内必须在历史基线 ±20% 范围内。监控指标必须通过,不得为建议项。
|
|
29
|
+
evidence_required:
|
|
30
|
+
- "监控指标报告路径"
|
|
31
|
+
- "错误率/响应时间/吞吐量数值"
|
|
32
|
+
- "与基线对比结果(须在 ±20% 范围内)"
|
|
36
33
|
|
|
37
34
|
## REL-02: 无新增告警
|
|
38
35
|
|
|
39
36
|
pattern: 发布后不得产生新的异常告警
|
|
40
37
|
severity: warning
|
|
38
|
+
check_type: deterministic
|
|
41
39
|
scope: [backend, frontend]
|
|
42
40
|
description: 发布后检查告警系统,不得有因本次发布新增的错误日志或异常告警
|
|
41
|
+
evidence_required:
|
|
42
|
+
- "告警系统检查结果"
|
|
43
|
+
- "新增告警列表(须为空)"
|
|
43
44
|
|
|
44
45
|
## REL-03: 回滚预案已验证
|
|
45
46
|
|
|
46
47
|
pattern: 回滚操作必须在发布前验证过
|
|
47
48
|
severity: warning
|
|
49
|
+
check_type: deterministic
|
|
48
50
|
scope: [backend, frontend]
|
|
49
51
|
description: 回滚预案必须经过实际演练或自动化验证,确认回滚操作可在 5 分钟内完成
|
|
52
|
+
evidence_required:
|
|
53
|
+
- "回滚预案文档路径"
|
|
54
|
+
- "演练/验证记录"
|
|
50
55
|
|
|
51
56
|
## REL-04: 数据一致性确认
|
|
52
57
|
|
|
53
58
|
pattern: 发布后必须验证数据一致性
|
|
54
59
|
severity: warning
|
|
60
|
+
check_type: deterministic
|
|
55
61
|
scope: backend
|
|
56
62
|
description: 涉及数据库变更的发布,发布后必须验证新老数据的一致性(数据校验脚本通过)
|
|
63
|
+
evidence_required:
|
|
64
|
+
- "数据一致性校验脚本路径"
|
|
65
|
+
- "校验结果(须通过)"
|
|
@@ -1,38 +1,63 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: backend-implementation-review
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '后端审查, Controller, DTO, 事务, 幂等, 权限'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
products:
|
|
8
7
|
- '*'
|
|
9
8
|
id: ka-review-rule-后端实现工程审查规则
|
|
10
|
-
asset_kind: review_rule
|
|
11
9
|
lifecycle_status: active
|
|
12
10
|
authority: canonical
|
|
13
11
|
owner_mechanism_id: mc-backend-implementation-contract
|
|
14
|
-
primary_triggers:
|
|
15
|
-
- 后端实现工程审查规则
|
|
16
|
-
secondary_triggers:
|
|
17
|
-
- 接口审查
|
|
18
|
-
negative_triggers: []
|
|
19
12
|
priority: P1
|
|
20
|
-
specificity: 5
|
|
21
13
|
consumes:
|
|
22
14
|
- mc-ood-solid-contract
|
|
23
15
|
required_evidence:
|
|
24
16
|
- code_review_findings
|
|
25
|
-
version: 1.
|
|
26
|
-
last_reviewed: '2026-06-
|
|
17
|
+
version: 1.2.0
|
|
18
|
+
last_reviewed: '2026-06-04'
|
|
27
19
|
stages: ["编码与单元测试", "联调验证"]
|
|
20
|
+
triggers: ["后端审查","Controller","DTO","事务","幂等","权限"]
|
|
28
21
|
---
|
|
29
22
|
|
|
30
|
-
|
|
23
|
+
# 后端实现工程审查规则
|
|
31
24
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
25
|
+
## BIE-01: Controller 边界
|
|
26
|
+
- id: BIE-01
|
|
27
|
+
- name: Controller 边界
|
|
28
|
+
- severity: error
|
|
29
|
+
- check_type: deterministic
|
|
30
|
+
- pattern: Controller 入参/出参使用数据库实体 → 改为 DTO/VO 并显式映射
|
|
31
|
+
- description: Controller 层不得直接暴露数据库实体。入参使用 RequestDTO,出参使用 ResponseVO/ResponseDTO,通过 Mapper 显式转换。
|
|
32
|
+
|
|
33
|
+
## BIE-02: 参数校验
|
|
34
|
+
- id: BIE-02
|
|
35
|
+
- name: 参数校验
|
|
36
|
+
- severity: error
|
|
37
|
+
- check_type: deterministic
|
|
38
|
+
- pattern: POST/PUT/PATCH 端点必须有参数校验注解或验证器,且校验失败有测试覆盖
|
|
39
|
+
- description: 所有 POST/PUT/PATCH 端点必须使用 @Valid/@Validated 或自定义 Validator。校验失败的路径必须有测试用例覆盖。
|
|
40
|
+
|
|
41
|
+
## BIE-03: 事务
|
|
42
|
+
- id: BIE-03
|
|
43
|
+
- name: 事务
|
|
44
|
+
- severity: error
|
|
45
|
+
- check_type: deterministic
|
|
46
|
+
- pattern: 事务中不得调用 HTTP/MQ/外部 SDK;违反须拆分边界或采用 outbox/补偿模式
|
|
47
|
+
- description: 事务范围内禁止包含 HTTP 调用、消息队列发送、外部 SDK 调用。需要跨系统一致性时使用 outbox 模式或补偿事务。
|
|
48
|
+
|
|
49
|
+
## BIE-04: 幂等
|
|
50
|
+
- id: BIE-04
|
|
51
|
+
- name: 幂等
|
|
52
|
+
- severity: error
|
|
53
|
+
- check_type: deterministic
|
|
54
|
+
- pattern: 支付、回调或写入操作必须有幂等证据(请求键/唯一约束/重复提交测试)
|
|
55
|
+
- description: 涉及支付、回调、写入的接口必须有幂等保护。通过请求键(idempotency key)、数据库唯一约束或分布式锁实现,并提供重复提交测试用例。
|
|
56
|
+
|
|
57
|
+
## BIE-05: 安全审计
|
|
58
|
+
- id: BIE-05
|
|
59
|
+
- name: 安全审计
|
|
60
|
+
- severity: error
|
|
61
|
+
- check_type: deterministic
|
|
62
|
+
- pattern: 敏感接口必须有权限校验、租户隔离和审计日志
|
|
63
|
+
- description: 涉及敏感数据的接口必须实现权限校验(RBAC/ABAC)、多租户数据隔离、操作审计日志。缺少任一项视为 hard_fail。
|
|
@@ -1,96 +1,132 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: security-rules
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '代码审查, review, 安全部署, 安全检查, 安全审计'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
- frontend
|
|
8
7
|
products:
|
|
9
8
|
- '*'
|
|
10
9
|
id: ka-review-rule-安全审查规则
|
|
11
|
-
asset_kind: review_rule
|
|
12
10
|
lifecycle_status: active
|
|
13
11
|
owner_mechanism_id: mc-generic-review
|
|
14
12
|
authority: supporting
|
|
15
|
-
primary_triggers:
|
|
16
|
-
- 安全审查规则
|
|
17
|
-
secondary_triggers: []
|
|
18
|
-
negative_triggers: []
|
|
19
13
|
priority: P1
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
last_reviewed: '2026-06-01'
|
|
14
|
+
version: 1.2.0
|
|
15
|
+
last_reviewed: '2026-06-04'
|
|
23
16
|
stages: ["代码审查"]
|
|
17
|
+
triggers: ["代码审查","review","安全部署","安全检查","安全审计"]
|
|
24
18
|
---
|
|
25
19
|
|
|
26
20
|
## SEC-01: SQL 字符串拼接导致注入风险
|
|
27
21
|
pattern: /(SELECT|INSERT|UPDATE|DELETE)\b.*[\+${]/
|
|
28
|
-
severity:
|
|
22
|
+
severity: error
|
|
23
|
+
check_type: deterministic
|
|
29
24
|
scope: backend
|
|
30
25
|
description: 禁止使用字符串拼接构造 SQL,必须使用参数化查询(PreparedStatement / MyBatis #{})
|
|
26
|
+
evidence_required:
|
|
27
|
+
- "扫描结果:含 SQL 拼接的文件路径+行号"
|
|
28
|
+
- "修复确认:参数化查询替换证据"
|
|
31
29
|
|
|
32
30
|
## SEC-02: innerHTML 赋值存在 XSS 风险
|
|
33
31
|
pattern: /\.innerHTML\s*=/
|
|
34
|
-
severity:
|
|
32
|
+
severity: error
|
|
33
|
+
check_type: deterministic
|
|
35
34
|
scope: frontend
|
|
36
35
|
description: 禁止使用 innerHTML 直接插入用户内容,必须使用 textContent 或 DOMPurify 净化
|
|
36
|
+
evidence_required:
|
|
37
|
+
- "扫描结果:含 innerHTML 赋值的文件路径+行号"
|
|
38
|
+
- "修复确认:使用安全替代方案证据"
|
|
37
39
|
|
|
38
40
|
## SEC-03: eval 或 Function 构造器执行动态代码
|
|
39
41
|
pattern: /\beval\s*\(|new\s+Function\s*\(/
|
|
40
|
-
severity:
|
|
42
|
+
severity: error
|
|
43
|
+
check_type: deterministic
|
|
41
44
|
scope: [backend, frontend]
|
|
42
45
|
description: 禁止使用 eval() 和 new Function(),存在任意代码执行风险
|
|
46
|
+
evidence_required:
|
|
47
|
+
- "扫描结果:含 eval/Function 的文件路径+行号"
|
|
43
48
|
|
|
44
49
|
## SEC-04: 硬编码的密码/密钥/token
|
|
45
50
|
pattern: /password\s*=\s*["'][^"']+["']|secret[_-]?key\s*=\s*["'][^"']+["']|api[_-]?key\s*=\s*["'][^"']+["']/i
|
|
46
|
-
severity:
|
|
51
|
+
severity: error
|
|
52
|
+
check_type: deterministic
|
|
47
53
|
scope: [backend, frontend]
|
|
48
54
|
description: 敏感凭证禁止硬编码在源码中,必须使用环境变量或密钥管理服务
|
|
55
|
+
evidence_required:
|
|
56
|
+
- "扫描结果:含硬编码凭证的文件路径+行号"
|
|
57
|
+
- "修复确认:迁移到环境变量/密钥管理服务证据"
|
|
49
58
|
|
|
50
59
|
## SEC-05: 日志中打印敏感信息
|
|
51
60
|
pattern: /log\.\w+\(.*(?:password|token|secret|身份证|idcard)/i
|
|
52
|
-
severity:
|
|
61
|
+
severity: error
|
|
62
|
+
check_type: deterministic
|
|
53
63
|
scope: backend
|
|
54
64
|
description: 禁止在日志中输出密码、token、身份证号等敏感字段,必须脱敏处理
|
|
65
|
+
evidence_required:
|
|
66
|
+
- "扫描结果:含敏感信息日志的文件路径+行号"
|
|
67
|
+
- "修复确认:脱敏处理证据"
|
|
55
68
|
|
|
56
69
|
## SEC-06: 未验证的外部重定向
|
|
57
70
|
pattern: /redirect\s*\(\s*(?:req|request|ctx)\.\w+/
|
|
58
71
|
severity: warning
|
|
72
|
+
check_type: deterministic
|
|
59
73
|
scope: backend
|
|
60
74
|
description: 重定向目标必须校验白名单域名,防止开放重定向攻击
|
|
75
|
+
evidence_required:
|
|
76
|
+
- "扫描结果:含未验证重定向的文件路径+行号"
|
|
61
77
|
|
|
62
78
|
## SEC-07: 路径遍历风险
|
|
63
79
|
pattern: /\.\.\/|\.\.\\/
|
|
64
80
|
severity: warning
|
|
81
|
+
check_type: deterministic
|
|
65
82
|
scope: [backend, frontend]
|
|
66
83
|
description: 文件路径操作必须校验和规范化,防止通过 ../ 遍历到非授权目录
|
|
84
|
+
evidence_required:
|
|
85
|
+
- "扫描结果:含路径遍历风险的文件路径+行号"
|
|
67
86
|
|
|
68
87
|
## SEC-08: 不安全的反序列化
|
|
69
88
|
pattern: /ObjectInputStream|unserialize|pickle\.load/
|
|
70
|
-
severity:
|
|
89
|
+
severity: error
|
|
90
|
+
check_type: deterministic
|
|
71
91
|
scope: backend
|
|
72
92
|
description: 禁止直接反序列化不可信数据,必须使用白名单校验或 JSON 替代方案
|
|
93
|
+
evidence_required:
|
|
94
|
+
- "扫描结果:含不安全反序列化的文件路径+行号"
|
|
73
95
|
|
|
74
96
|
## SEC-09: SSRF 服务端请求伪造
|
|
75
97
|
pattern: /(?:HttpClient|RestTemplate|WebClient|OkHttp|URLConnection)\s*\(\s*(?:req|request|ctx|param)\./
|
|
76
|
-
severity:
|
|
98
|
+
severity: error
|
|
99
|
+
check_type: deterministic
|
|
77
100
|
scope: backend
|
|
78
101
|
description: 外部 URL 请求禁止直接使用用户输入,必须校验 IP/域名白名单,防止 SSRF 攻击
|
|
102
|
+
evidence_required:
|
|
103
|
+
- "扫描结果:含 SSRF 风险的文件路径+行号"
|
|
104
|
+
- "修复确认:白名单校验证据"
|
|
79
105
|
|
|
80
106
|
## SEC-10: CORS 配置过于宽松
|
|
81
107
|
pattern: /allowedOrigins\s*\(\s*"\*"\s*\)|Access-Control-Allow-Origin.*\*/
|
|
82
108
|
severity: warning
|
|
109
|
+
check_type: deterministic
|
|
83
110
|
scope: backend
|
|
84
111
|
description: CORS 配置禁止使用通配符 *,必须指定具体域名白名单
|
|
112
|
+
evidence_required:
|
|
113
|
+
- "扫描结果:含宽松 CORS 配置的文件路径+行号"
|
|
85
114
|
|
|
86
115
|
## SEC-11: 未启用 HTTPS 的 Cookie
|
|
87
116
|
pattern: /cookie.*(?:secure\s*:\s*false|httpOnly\s*:\s*false)/i
|
|
88
117
|
severity: warning
|
|
118
|
+
check_type: deterministic
|
|
89
119
|
scope: [backend, frontend]
|
|
90
120
|
description: 敏感 Cookie 必须设置 Secure 和 HttpOnly 标志
|
|
121
|
+
evidence_required:
|
|
122
|
+
- "扫描结果:含不安全 Cookie 配置的文件路径+行号"
|
|
91
123
|
|
|
92
124
|
## SEC-12: JWT 未校验签名算法
|
|
93
125
|
pattern: /JWT|jwt.*verify|jwt.*decode/
|
|
94
|
-
severity:
|
|
126
|
+
severity: error
|
|
127
|
+
check_type: deterministic
|
|
95
128
|
scope: backend
|
|
96
129
|
description: JWT 必须显式指定签名算法(如 HS256/RS256),禁止接受 none 算法
|
|
130
|
+
evidence_required:
|
|
131
|
+
- "扫描结果:含 JWT 操作的文件路径+行号"
|
|
132
|
+
- "修复确认:显式指定签名算法证据"
|
|
@@ -1,83 +1,112 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: concurrency-rules
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '代码审查, review, 并发检查, 线程安全检查, 锁检查'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
products:
|
|
8
7
|
- '*'
|
|
9
8
|
id: ka-review-rule-并发审查规则
|
|
10
|
-
asset_kind: review_rule
|
|
11
9
|
lifecycle_status: active
|
|
12
10
|
owner_mechanism_id: mc-generic-review
|
|
13
11
|
authority: supporting
|
|
14
|
-
primary_triggers:
|
|
15
|
-
- 并发审查规则
|
|
16
|
-
secondary_triggers: []
|
|
17
|
-
negative_triggers: []
|
|
18
12
|
priority: P1
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
last_reviewed: '2026-06-01'
|
|
13
|
+
version: 1.2.0
|
|
14
|
+
last_reviewed: '2026-06-04'
|
|
22
15
|
stages: ["代码审查"]
|
|
16
|
+
triggers: ["代码审查","review","并发检查","线程安全检查","锁检查"]
|
|
23
17
|
---
|
|
24
18
|
|
|
25
19
|
## CON-01: 共享可变状态无并发保护
|
|
26
20
|
pattern: "synchronized|ReentrantLock|AtomicInteger|volatile"
|
|
27
|
-
severity:
|
|
21
|
+
severity: error
|
|
22
|
+
check_type: deterministic
|
|
28
23
|
scope: backend
|
|
29
24
|
description: 涉及金额、库存、计数器的操作必须显式声明并发控制策略。若未使用任何并发控制原语,标记为需人工确认
|
|
25
|
+
evidence_required:
|
|
26
|
+
- "扫描结果:含共享可变状态的文件路径+行号"
|
|
27
|
+
- "并发控制策略声明"
|
|
30
28
|
|
|
31
29
|
## CON-02: 分布式环境使用 JVM 级锁
|
|
32
30
|
pattern: "synchronized\\s*\\(|ReentrantLock"
|
|
33
31
|
severity: warning
|
|
32
|
+
check_type: deterministic
|
|
34
33
|
scope: backend
|
|
35
34
|
description: 多实例部署场景下 synchronized/ReentrantLock 无法跨 JVM,必须使用分布式锁(Redis/Redisson)
|
|
35
|
+
evidence_required:
|
|
36
|
+
- "扫描结果:含 JVM 级锁的文件路径+行号"
|
|
37
|
+
- "部署架构确认(单实例/多实例)"
|
|
36
38
|
|
|
37
39
|
## CON-03: 先查后改未用原子操作
|
|
38
40
|
pattern: "SELECT.*stock|SELECT.*count|SELECT.*amount.*WHERE"
|
|
39
41
|
severity: warning
|
|
42
|
+
check_type: deterministic
|
|
40
43
|
scope: backend
|
|
41
44
|
description: 库存/余额/计数器等场景禁止先 SELECT 再 UPDATE,必须使用原子操作(UPDATE SET x = x - 1 WHERE x >= 1)
|
|
45
|
+
evidence_required:
|
|
46
|
+
- "扫描结果:含先查后改模式的文件路径+行号"
|
|
42
47
|
|
|
43
48
|
## CON-04: @Transactional 同类内部调用
|
|
44
49
|
pattern: "this\\.|@Transactional"
|
|
45
50
|
severity: warning
|
|
51
|
+
check_type: deterministic
|
|
46
52
|
scope: backend
|
|
47
53
|
description: @Transactional 方法被同类内部 this.xxx() 调用时 AOP 代理失效,事务不生效
|
|
54
|
+
evidence_required:
|
|
55
|
+
- "扫描结果:含 this 调用事务方法的文件路径+行号"
|
|
48
56
|
|
|
49
57
|
## CON-05: 事务内执行外部调用
|
|
50
58
|
pattern: "RestTemplate|FeignClient|HttpClient|WebClient"
|
|
51
59
|
severity: info
|
|
60
|
+
check_type: deterministic
|
|
52
61
|
scope: backend
|
|
53
62
|
description: 事务方法中执行外部 HTTP 调用会延长事务持有时间,建议移到事务外或使用 REQUIRES_NEW 隔离
|
|
63
|
+
evidence_required:
|
|
64
|
+
- "扫描结果:事务内外部调用的文件路径+行号"
|
|
54
65
|
|
|
55
66
|
## CON-06: SimpleDateFormat 非线程安全
|
|
56
67
|
pattern: "SimpleDateFormat"
|
|
57
68
|
severity: warning
|
|
69
|
+
check_type: deterministic
|
|
58
70
|
scope: backend
|
|
59
71
|
description: SimpleDateFormat 非线程安全,多线程共享会导致日期解析错误,使用 DateTimeFormatter 或 ThreadLocal
|
|
72
|
+
evidence_required:
|
|
73
|
+
- "扫描结果:含 SimpleDateFormat 的文件路径+行号"
|
|
60
74
|
|
|
61
75
|
## CON-07: ThreadLocal 未清理导致内存泄漏
|
|
62
76
|
pattern: /ThreadLocal\s*<|new\s+ThreadLocal/
|
|
63
77
|
severity: warning
|
|
78
|
+
check_type: deterministic
|
|
64
79
|
scope: backend
|
|
65
80
|
description: ThreadLocal 必须在请求结束时 remove(),否则线程池复用会导致内存泄漏和数据串线
|
|
81
|
+
evidence_required:
|
|
82
|
+
- "扫描结果:含 ThreadLocal 的文件路径+行号"
|
|
83
|
+
- "remove() 调用确认"
|
|
66
84
|
|
|
67
85
|
## CON-08: 非线程安全的集合用作类成员变量
|
|
68
86
|
pattern: /private\s+(?:static\s+)?(?:final\s+)?(?:HashMap|ArrayList|LinkedList|HashSet)\s*</
|
|
69
87
|
severity: warning
|
|
88
|
+
check_type: deterministic
|
|
70
89
|
scope: backend
|
|
71
90
|
description: 类级别的共享集合必须使用 ConcurrentHashMap/CopyOnWriteArrayList 等线程安全实现
|
|
91
|
+
evidence_required:
|
|
92
|
+
- "扫描结果:含非线程安全集合的文件路径+行号"
|
|
72
93
|
|
|
73
94
|
## CON-09: CompletableFuture 未处理异常
|
|
74
95
|
pattern: /CompletableFuture.*(?:thenApply|thenAccept|thenCompose)\s*\(/
|
|
75
96
|
severity: warning
|
|
97
|
+
check_type: deterministic
|
|
76
98
|
scope: backend
|
|
77
99
|
description: CompletableFuture 链必须以 exceptionally() 或 handle() 结尾,防止异常被静默吞掉
|
|
100
|
+
evidence_required:
|
|
101
|
+
- "扫描结果:含 CompletableFuture 的文件路径+行号"
|
|
102
|
+
- "异常处理链确认"
|
|
78
103
|
|
|
79
104
|
## CON-10: 线程池未正确配置拒绝策略
|
|
80
105
|
pattern: /new\s+ThreadPoolExecutor\s*\(/
|
|
81
106
|
severity: warning
|
|
107
|
+
check_type: deterministic
|
|
82
108
|
scope: backend
|
|
83
109
|
description: 线程池必须显式配置拒绝策略(CallerRunsPolicy/自定义),禁止使用默认 AbortPolicy
|
|
110
|
+
evidence_required:
|
|
111
|
+
- "扫描结果:含线程池创建的文件路径+行号"
|
|
112
|
+
- "拒绝策略配置确认"
|
|
@@ -1,78 +1,100 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: performance-rules
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '代码审查, review, 性能检查, 性能优化'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
- frontend
|
|
8
7
|
products:
|
|
9
8
|
- '*'
|
|
10
9
|
id: ka-review-rule-性能审查规则
|
|
11
|
-
asset_kind: review_rule
|
|
12
10
|
lifecycle_status: active
|
|
13
11
|
owner_mechanism_id: mc-generic-review
|
|
14
12
|
authority: supporting
|
|
15
|
-
primary_triggers:
|
|
16
|
-
- 性能审查规则
|
|
17
|
-
secondary_triggers: []
|
|
18
|
-
negative_triggers: []
|
|
19
13
|
priority: P1
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
last_reviewed: '2026-06-01'
|
|
14
|
+
version: 1.2.0
|
|
15
|
+
last_reviewed: '2026-06-04'
|
|
23
16
|
stages: ["代码审查"]
|
|
17
|
+
triggers: ["代码审查","review","性能检查","性能优化"]
|
|
24
18
|
---
|
|
25
19
|
|
|
26
20
|
## PER-01: 循环内逐条数据库调用(N+1 问题)
|
|
27
21
|
pattern: /(?:for|while)\s*\(.*\)[\s\S]*?\.(?:save|insert|update|delete|query|select|findBy)\s*\(/
|
|
28
|
-
severity:
|
|
22
|
+
severity: error
|
|
23
|
+
check_type: deterministic
|
|
29
24
|
scope: backend
|
|
30
25
|
description: 循环内禁止逐条数据库操作,必须使用批量 SQL 或 IN 查询
|
|
26
|
+
evidence_required:
|
|
27
|
+
- "扫描结果:含循环内数据库调用的文件路径+行号"
|
|
28
|
+
- "修复确认:批量操作替换证据"
|
|
31
29
|
|
|
32
30
|
## PER-02: SELECT * 查询未指定字段
|
|
33
31
|
pattern: /SELECT\s+\*\s+FROM/i
|
|
34
32
|
severity: info
|
|
33
|
+
check_type: deterministic
|
|
35
34
|
scope: backend
|
|
36
35
|
description: 查询应明确指定所需字段,避免传输不必要的数据
|
|
36
|
+
evidence_required:
|
|
37
|
+
- "扫描结果:含 SELECT * 的文件路径+行号"
|
|
37
38
|
|
|
38
39
|
## PER-03: 未使用分页的大列表查询
|
|
39
40
|
pattern: /findAll\s*\(\s*\)|\.toList\(\)\s*;|find\s*\(\s*\{\s*\}\s*\)/
|
|
40
41
|
severity: warning
|
|
42
|
+
check_type: deterministic
|
|
41
43
|
scope: backend
|
|
42
44
|
description: 列表查询必须分页,禁止一次加载全量数据
|
|
45
|
+
evidence_required:
|
|
46
|
+
- "扫描结果:含未分页查询的文件路径+行号"
|
|
43
47
|
|
|
44
48
|
## PER-04: 大循环内创建对象或字符串拼接
|
|
45
49
|
pattern: /(?:for|while)\s*\(.*\)[\s\S]*?new\s+(?:ArrayList|HashMap|StringBuilder)/
|
|
46
50
|
severity: info
|
|
51
|
+
check_type: deterministic
|
|
47
52
|
scope: backend
|
|
48
53
|
description: 大循环内避免重复创建对象,应提前初始化或使用对象池
|
|
54
|
+
evidence_required:
|
|
55
|
+
- "扫描结果:含循环内创建对象的文件路径+行号"
|
|
49
56
|
|
|
50
57
|
## PER-05: 前端组件不必要的重渲染
|
|
51
58
|
pattern: /onClick=\{\(\).*=>|style=\{\{/
|
|
52
59
|
severity: info
|
|
60
|
+
check_type: deterministic
|
|
53
61
|
scope: frontend
|
|
54
62
|
description: 内联函数和对象作为 props 会导致子组件不必要的重渲染,应使用 useCallback/useMemo
|
|
63
|
+
evidence_required:
|
|
64
|
+
- "扫描结果:含内联函数/对象的文件路径+行号"
|
|
55
65
|
|
|
56
66
|
## PER-06: 未使用 useMemo/useCallback 的高开销计算
|
|
57
67
|
pattern: /(?:\.sort|\.filter|\.map|\.reduce)\s*\(.*=>.*(?:\.sort|\.filter|\.map)/
|
|
58
68
|
severity: info
|
|
69
|
+
check_type: deterministic
|
|
59
70
|
scope: frontend
|
|
60
71
|
description: 链式数组操作或高开销计算应使用 useMemo 缓存结果,避免每次渲染重复计算
|
|
72
|
+
evidence_required:
|
|
73
|
+
- "扫描结果:含未缓存计算的文件路径+行号"
|
|
61
74
|
|
|
62
75
|
## PER-07: 未使用连接池的数据库连接
|
|
63
76
|
pattern: /DriverManager\.getConnection/
|
|
64
77
|
severity: warning
|
|
78
|
+
check_type: deterministic
|
|
65
79
|
scope: backend
|
|
66
80
|
description: 禁止使用 DriverManager 直接创建连接,必须使用连接池(HikariCP/Druid)
|
|
81
|
+
evidence_required:
|
|
82
|
+
- "扫描结果:含 DriverManager 调用的文件路径+行号"
|
|
67
83
|
|
|
68
84
|
## PER-08: 大事务包含非必要操作
|
|
69
85
|
pattern: /@Transactional[\s\S]*?(?:log\.|email|send|notify|http)/
|
|
70
86
|
severity: warning
|
|
87
|
+
check_type: deterministic
|
|
71
88
|
scope: backend
|
|
72
89
|
description: @Transactional 方法内禁止包含发送邮件、HTTP 调用、MQ 发送等非必要操作,避免长事务
|
|
90
|
+
evidence_required:
|
|
91
|
+
- "扫描结果:含大事务非必要操作的文件路径+行号"
|
|
73
92
|
|
|
74
93
|
## PER-09: 前端图片未压缩或懒加载
|
|
75
94
|
pattern: /<img\s+src=/
|
|
76
95
|
severity: info
|
|
96
|
+
check_type: deterministic
|
|
77
97
|
scope: frontend
|
|
78
98
|
description: 图片资源必须使用压缩/懒加载/响应式加载,禁止原始大图直接展示
|
|
99
|
+
evidence_required:
|
|
100
|
+
- "扫描结果:含未优化图片的文件路径+行号"
|
|
@@ -1,83 +1,112 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: api-contract-rules
|
|
3
3
|
type: review_rule
|
|
4
|
-
when: '代码审查, review, 接口契约检查, API规范检查'
|
|
5
4
|
scope:
|
|
6
5
|
- backend
|
|
7
6
|
products:
|
|
8
7
|
- '*'
|
|
9
8
|
id: ka-review-rule-接口契约审查规则
|
|
10
|
-
asset_kind: review_rule
|
|
11
9
|
lifecycle_status: active
|
|
12
10
|
owner_mechanism_id: mc-generic-review
|
|
13
11
|
authority: supporting
|
|
14
|
-
primary_triggers:
|
|
15
|
-
- 接口契约审查规则
|
|
16
|
-
secondary_triggers: []
|
|
17
|
-
negative_triggers: []
|
|
18
12
|
priority: P1
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
last_reviewed: '2026-06-01'
|
|
13
|
+
version: 1.2.0
|
|
14
|
+
last_reviewed: '2026-06-04'
|
|
22
15
|
stages: ["代码审查"]
|
|
16
|
+
triggers: ["代码审查","review","接口契约检查","API规范检查"]
|
|
23
17
|
---
|
|
24
18
|
|
|
25
19
|
## API-01: Controller 返回 Entity 而非 DTO
|
|
26
20
|
pattern: "ResponseEntity<Entity>|ResponseEntity<\\s*$"
|
|
27
21
|
severity: warning
|
|
22
|
+
check_type: deterministic
|
|
28
23
|
scope: backend
|
|
29
24
|
description: 禁止直接返回数据库 Entity,必须通过 DTO/VO 转换,防止敏感字段泄漏和结构耦合
|
|
25
|
+
evidence_required:
|
|
26
|
+
- "扫描结果:含直接返回 Entity 的 Controller 文件路径+行号"
|
|
27
|
+
- "修复确认:DTO/VO 转换替换证据"
|
|
30
28
|
|
|
31
29
|
## API-02: 缺少 @Transactional 的写操作
|
|
32
30
|
pattern: "@(PostMapping|PutMapping|DeleteMapping|PatchMapping)"
|
|
33
31
|
severity: warning
|
|
32
|
+
check_type: deterministic
|
|
34
33
|
scope: backend
|
|
35
34
|
description: 写操作 Service 方法必须标注 @Transactional(rollbackFor = Exception.class)
|
|
35
|
+
evidence_required:
|
|
36
|
+
- "扫描结果:含写操作但缺少 @Transactional 的方法文件路径+行号"
|
|
37
|
+
- "修复确认:事务注解添加证据"
|
|
36
38
|
|
|
37
39
|
## API-03: 接口缺少权限注解
|
|
38
40
|
pattern: "@(PostMapping|PutMapping|DeleteMapping)"
|
|
39
|
-
severity:
|
|
41
|
+
severity: error
|
|
42
|
+
check_type: deterministic
|
|
40
43
|
scope: backend
|
|
41
44
|
description: 写接口必须有 @PreAuthorize 或 @Secured 注解,禁止裸露写操作
|
|
45
|
+
evidence_required:
|
|
46
|
+
- "扫描结果:含裸露写操作(无权限注解)的接口文件路径+行号"
|
|
47
|
+
- "修复确认:权限注解添加证据"
|
|
42
48
|
|
|
43
49
|
## API-04: 硬编码分页参数
|
|
44
50
|
pattern: "LIMIT\\s+\\d+|pageSize\\s*=\\s*\\d{4,}"
|
|
45
51
|
severity: warning
|
|
52
|
+
check_type: deterministic
|
|
46
53
|
scope: backend
|
|
47
54
|
description: 分页参数禁止硬编码大数字,pageSize 上限不超过 100
|
|
55
|
+
evidence_required:
|
|
56
|
+
- "扫描结果:含硬编码分页参数的文件路径+行号"
|
|
57
|
+
- "修复确认:参数化替换证据"
|
|
48
58
|
|
|
49
59
|
## API-05: 缺少参数校验注解
|
|
50
60
|
pattern: "@RequestBody\\s+\\w+\\s+\\w+"
|
|
51
61
|
severity: info
|
|
62
|
+
check_type: deterministic
|
|
52
63
|
scope: backend
|
|
53
|
-
description: @RequestBody 参数应搭配 @Valid 或 @Validated 注解触发校验
|
|
64
|
+
description: "@RequestBody 参数应搭配 @Valid 或 @Validated 注解触发校验"
|
|
65
|
+
evidence_required:
|
|
66
|
+
- "扫描结果:含未校验 @RequestBody 参数的接口文件路径+行号"
|
|
54
67
|
|
|
55
68
|
## API-06: 接口路径不符合 RESTful 规范
|
|
56
69
|
pattern: "@(Get|Post|Put|Delete)Mapping.*(/get|/query|/add|/update|/delete|/list)"
|
|
57
70
|
severity: info
|
|
71
|
+
check_type: deterministic
|
|
58
72
|
scope: backend
|
|
59
73
|
description: 接口路径应使用资源名词 + HTTP 方法语义,避免 /getUser、/deleteOrder 等动词路径
|
|
74
|
+
evidence_required:
|
|
75
|
+
- "扫描结果:含非 RESTful 路径的接口文件路径+行号"
|
|
60
76
|
|
|
61
77
|
## API-07: 接口缺少统一响应包装
|
|
62
78
|
pattern: /ResponseEntity<\s*(?!ApiResult|Result|R<)/
|
|
63
79
|
severity: warning
|
|
80
|
+
check_type: deterministic
|
|
64
81
|
scope: backend
|
|
65
82
|
description: 接口返回值必须使用统一响应包装(如 Result<T>),禁止直接返回裸数据或 ResponseEntity
|
|
83
|
+
evidence_required:
|
|
84
|
+
- "扫描结果:含未包装响应的接口文件路径+行号"
|
|
85
|
+
- "修复确认:统一响应包装替换证据"
|
|
66
86
|
|
|
67
87
|
## API-08: 分页接口返回非标准结构
|
|
68
88
|
pattern: /Page(?:Info|able)|PageRequest/
|
|
69
89
|
severity: info
|
|
90
|
+
check_type: deterministic
|
|
70
91
|
scope: backend
|
|
71
92
|
description: 分页接口必须返回标准结构(total、list、pageNum、pageSize),禁止自定义分页格式
|
|
93
|
+
evidence_required:
|
|
94
|
+
- "扫描结果:含非标准分页结构的接口文件路径+行号"
|
|
72
95
|
|
|
73
96
|
## API-09: 缺少接口版本号
|
|
74
97
|
pattern: /@(?:Get|Post|Put|Delete)Mapping\s*\(\s*"\/(?!v\d)/
|
|
75
98
|
severity: info
|
|
99
|
+
check_type: deterministic
|
|
76
100
|
scope: backend
|
|
77
101
|
description: API 路径应包含版本号前缀(如 /api/v1/),便于后续接口演进和兼容
|
|
102
|
+
evidence_required:
|
|
103
|
+
- "扫描结果:含无版本号路径的接口文件路径+行号"
|
|
78
104
|
|
|
79
105
|
## API-10: 接口缺少 Swagger/OpenAPI 文档注解
|
|
80
106
|
pattern: /@(?:Get|Post|Put|Delete)Mapping\s*\(/
|
|
81
107
|
severity: info
|
|
108
|
+
check_type: deterministic
|
|
82
109
|
scope: backend
|
|
83
110
|
description: 接口必须添加 @Operation/@Api 注解,保证 API 文档自动生成
|
|
111
|
+
evidence_required:
|
|
112
|
+
- "扫描结果:含缺少文档注解的接口文件路径+行号"
|