{
"event": "PreToolUse",
"tool_name": "Edit",
"tool_input": {
"file_path": "\/var\/www\/tools\/ki-protokoll\/claude-hook\/quality\/pre_rules.py",
"old_string": "from . import pre_rules_guard\nfrom . import pre_rules_security\nfrom . import pre_rules_validation\n\n\n# =============================================================================\n# HELPER FUNCTIONS\n# =============================================================================\n\ndef allow() -> dict:\n \"\"\"Erzeugt Allow-Response.\"\"\"\n return {\"allowed\": True}",
"new_string": "from . import pre_rules_guard\nfrom . import pre_rules_security\nfrom . import pre_rules_validation\nfrom .rule_base import allow"
}
}
{
"tool_response": {
"filePath": "\/var\/www\/tools\/ki-protokoll\/claude-hook\/quality\/pre_rules.py",
"oldString": "from . import pre_rules_guard\nfrom . import pre_rules_security\nfrom . import pre_rules_validation\n\n\n# =============================================================================\n# HELPER FUNCTIONS\n# =============================================================================\n\ndef allow() -> dict:\n \"\"\"Erzeugt Allow-Response.\"\"\"\n return {\"allowed\": True}",
"newString": "from . import pre_rules_guard\nfrom . import pre_rules_security\nfrom . import pre_rules_validation\nfrom .rule_base import allow",
"originalFile": "#!\/usr\/bin\/env python3\n\"\"\"\nPre-Hook Regeln (BLOCK) - Modular und erweiterbar ohne Claude-Neustart.\n\nAlle P-Regeln aus dem Quality Gate Plan.\nImportiert Regeln aus spezialisierten Modulen.\n\"\"\"\n\nfrom . import pre_rules_guard\nfrom . import pre_rules_security\nfrom . import pre_rules_validation\n\n\n# =============================================================================\n# HELPER FUNCTIONS\n# =============================================================================\n\ndef allow() -> dict:\n \"\"\"Erzeugt Allow-Response.\"\"\"\n return {\"allowed\": True}\n\n\n# =============================================================================\n# MAIN CHECK FUNCTION\n# =============================================================================\n\n# Alle aktiven Regeln in Prüfungsreihenfolge\nRULES = [\n # Prüfung 1: SRP + KISS + Prüfung 4: OOP\n *pre_rules_guard.RULES,\n\n # Prüfung 2: MVC + CRUD + Prüfung 6: SOLID + DIP + H-Regeln\n *pre_rules_security.RULES,\n\n # Prüfung 3: PSR + Types\n *pre_rules_validation.RULES,\n]\n\n\ndef check(file_path: str, content: str) -> dict:\n \"\"\"\n Führt alle Pre-Hook-Regeln aus.\n Stoppt beim ersten Verstoß.\n \"\"\"\n for rule in RULES:\n result = rule(file_path, content)\n if result is not None:\n return result\n\n return allow()\n",
"structuredPatch": [
{
"oldStart": 9,
"oldLines": 18,
"newStart": 9,
"newLines": 10,
"lines": [
" from . import pre_rules_guard",
" from . import pre_rules_security",
" from . import pre_rules_validation",
"+from .rule_base import allow",
" ",
" ",
" # =============================================================================",
"-# HELPER FUNCTIONS",
"-# =============================================================================",
"-",
"-def allow() -> dict:",
"- \"\"\"Erzeugt Allow-Response.\"\"\"",
"- return {\"allowed\": True}",
"-",
"-",
"-# =============================================================================",
" # MAIN CHECK FUNCTION",
" # =============================================================================",
" "
]
}
],
"userModified": false,
"replaceAll": false
}
}