🎉 Removed unnecessary files & logs, updated documentation & UI components. 🖥️🔍📚💻

This commit is contained in:
Till Tomczak 2025-06-01 01:20:36 +02:00
parent 9e15c4d5c8
commit 40ca104860
22 changed files with 1476 additions and 2166 deletions

View File

@ -3557,10 +3557,13 @@ def check_session_activity():
auth_logger.info(f"🕒 Automatische Abmeldung: Benutzer {current_user.email} war {inactive_duration.total_seconds()/60:.1f} Minuten inaktiv (Limit: {max_inactive_minutes}min)")
# Session-Daten vor Logout speichern für Benachrichtigung
session['auto_logout_reason'] = f"Automatische Abmeldung nach {max_inactive_minutes} Minuten Inaktivität"
session['auto_logout_time'] = now.isoformat()
logout_reason = f"Automatische Abmeldung nach {max_inactive_minutes} Minuten Inaktivität"
logout_time = now.isoformat()
# Benutzer abmelden
logout_user()
# Session komplett leeren
session.clear()
# JSON-Response für AJAX-Requests
@ -3586,7 +3589,7 @@ def check_session_activity():
if 'session_ip' in session and session['session_ip'] != request.remote_addr:
auth_logger.warning(f"⚠️ IP-Adresse geändert für Benutzer {current_user.email}: {session['session_ip']}{request.remote_addr}")
# Optional: Benutzer abmelden bei IP-Wechsel (kann bei VPN/Proxy problematisch sein)
# session['security_warning'] = "IP-Adresse hat sich geändert"
session['security_warning'] = "IP-Adresse hat sich geändert"
@app.before_request
def setup_session_security():

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1 @@

View File

@ -78791,3 +78791,457 @@ WHERE users.id = ?
2025-06-01 01:03:04 - myp.database_cleanup - INFO - 🧹 Starte umfassendes Datenbank-Cleanup...
2025-06-01 01:03:04 - myp.database_cleanup - INFO - 📝 Schritt 1: Schließe alle Datenbankverbindungen...
2025-06-01 01:03:04 - myp.database_cleanup - INFO - 🔄 Schließe alle aktiven Datenbankverbindungen...
2025-06-01 01:13:16 - myp.windows_fixes - INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-06-01 01:13:16 - myp.windows_fixes - INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-06-01 01:13:16 - myp.windows_fixes - INFO - ✅ Globaler subprocess-Patch angewendet
2025-06-01 01:13:16 - myp.windows_fixes - INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-06-01 01:13:16 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-06-01 01:13:16 - myp.printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-06-01 01:13:16 - myp.printer_monitor - INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-06-01 01:13:16 - myp.database - INFO - Datenbank-Wartungs-Scheduler gestartet
2025-06-01 01:13:16 - myp.backup - INFO - BackupManager initialisiert (minimal implementation)
2025-06-01 01:13:16 - myp.analytics - INFO - 📈 Analytics Engine initialisiert
2025-06-01 01:13:17 - myp.dashboard - INFO - Dashboard-Background-Worker gestartet
2025-06-01 01:13:17 - myp.app - INFO - SQLite für Produktionsumgebung konfiguriert (WAL-Modus, Cache, Optimierungen)
2025-06-01 01:13:17 - myp.email_notification - INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)
2025-06-01 01:13:17 - myp.maintenance - INFO - Wartungs-Scheduler gestartet
2025-06-01 01:13:17 - myp.multi_location - INFO - Standard-Standort erstellt
2025-06-01 01:13:17 - myp.dashboard - INFO - Dashboard-Background-Worker gestartet
2025-06-01 01:13:17 - myp.maintenance - INFO - Wartungs-Scheduler gestartet
2025-06-01 01:13:17 - myp.multi_location - INFO - Standard-Standort erstellt
2025-06-01 01:13:17 - myp.dashboard - INFO - Dashboard WebSocket-Server wird mit threading initialisiert (eventlet-Fallback)
2025-06-01 01:13:17 - myp.dashboard - INFO - Dashboard WebSocket-Server initialisiert (async_mode: threading)
2025-06-01 01:13:17 - myp.security - INFO - 🔒 Security System initialisiert
2025-06-01 01:13:17 - myp.permissions - INFO - 🔐 Permission Template Helpers registriert
2025-06-01 01:13:17 - myp.app - INFO - ==================================================
2025-06-01 01:13:17 - myp.app - INFO - [START] MYP (Manage Your Printers) wird gestartet...
2025-06-01 01:13:17 - myp.app - INFO - [FOLDER] Log-Verzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\logs
2025-06-01 01:13:17 - myp.app - INFO - [CHART] Log-Level: INFO
2025-06-01 01:13:17 - myp.app - INFO - [PC] Betriebssystem: Windows 11
2025-06-01 01:13:17 - myp.app - INFO - [WEB] Hostname: C040L0079726760
2025-06-01 01:13:17 - myp.app - INFO - [TIME] Startzeit: 01.06.2025 01:13:17
2025-06-01 01:13:17 - myp.app - INFO - ==================================================
2025-06-01 01:13:17 - myp.app - INFO - 🔄 Starte Datenbank-Setup und Migrationen...
2025-06-01 01:13:17 - myp.app - INFO - Datenbank mit Optimierungen initialisiert
2025-06-01 01:13:17 - myp.app - INFO - ✅ JobOrder-Tabelle bereits vorhanden
2025-06-01 01:13:17 - myp.app - INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-06-01 01:13:17 - myp.app - INFO - ✅ Datenbank-Setup und Migrationen erfolgreich abgeschlossen
2025-06-01 01:13:17 - myp.app - INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-06-01 01:13:17 - myp.printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-06-01 01:13:17 - myp.printer_monitor - WARNING - ⚠️ Keine aktiven Drucker zur Initialisierung gefunden
2025-06-01 01:13:17 - myp.app - INFO - Keine Drucker zur Initialisierung gefunden
2025-06-01 01:13:17 - myp.app - INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-06-01 01:13:17 - myp.app - INFO - Job-Scheduler gestartet
2025-06-01 01:13:17 - myp.app - INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-06-01 01:13:17 - myp.app - INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-06-01 01:13:17 - werkzeug - INFO - WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
* Running on all addresses (0.0.0.0)
* Running on http://127.0.0.1:5000
* Running on http://192.168.178.111:5000
2025-06-01 01:13:17 - werkzeug - INFO - Press CTRL+C to quit
2025-06-01 01:13:18 - myp.printer_monitor - INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-06-01 01:13:18 - myp.printer_monitor - INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-06-01 01:13:18 - myp.printer_monitor - INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-06-01 01:13:19 - myp.app - INFO - Admin-Check für Funktion api_admin_database_status: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:19 - myp.app - INFO - Admin-Check für Funktion api_admin_system_status: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:19 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:19 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:19 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:19 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:19 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:19] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:13:19 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:19 - myp.app - INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:19 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:19] "GET /api/admin/system-health HTTP/1.1" 200 -
2025-06-01 01:13:19 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:19] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:13:19 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:19] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:13:19 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:19] "GET /api/admin/database/status HTTP/1.1" 200 -
2025-06-01 01:13:20 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:13:20 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:20] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:13:21 - myp.app - WARNING - Disk-Informationen nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:13:21 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /dashboard HTTP/1.1" 200 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /api/admin/system/status HTTP/1.1" 200 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/css/tailwind.min.css HTTP/1.1" 200 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/ui-components.js HTTP/1.1" 200 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - myp.app - INFO - Admin-Check für Funktion api_admin_system_status: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:21 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:21] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:13:22 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:13:22 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:22 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:22 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:13:22 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:13:22 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:22] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:13:22 - myp.app - WARNING - Disk-Informationen nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:13:23 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:23] "GET /api/admin/system/status HTTP/1.1" 200 -
2025-06-01 01:13:23 - myp.app - INFO - Admin-Check für Funktion api_admin_system_status: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:23 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:23] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:13:24 - myp.app - WARNING - Disk-Informationen nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:13:24 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:24] "GET /api/admin/system/status HTTP/1.1" 200 -
2025-06-01 01:13:24 - myp.printer_monitor - INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-06-01 01:13:30 - myp.printer_monitor - INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-06-01 01:13:36 - myp.printer_monitor - INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /dashboard HTTP/1.1" 200 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:13:42 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:42 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:42 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:13:42 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:13:42 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:42] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:13:42 - myp.printer_monitor - INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-06-01 01:13:43 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:43] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:13:48 - myp.printer_monitor - INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-06-01 01:13:54 - myp.printer_monitor - INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /admin-dashboard HTTP/1.1" 200 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/admin.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/admin-system.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/admin-live.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /static/js/admin-dashboard.js HTTP/1.1" 304 -
2025-06-01 01:13:55 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:13:55 - myp.app - INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:13:55 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:55 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:13:55 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:55] "GET /api/admin/system-health HTTP/1.1" 200 -
2025-06-01 01:13:55 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:13:56 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:56] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:13:56 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:56] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:13:56 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:56] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:13:56 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:56] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:13:56 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:56] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:13:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:57] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:13:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:13:59] "GET /.well-known/appspecific/com.chrome.devtools.json HTTP/1.1" 404 -
2025-06-01 01:14:05 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:14:06 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:14:06 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:06] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:14:15 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:14:16 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:14:16 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:16] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:14:25 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:14:25 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:14:25 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:25] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:14:25 - myp.app - INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:14:25 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:14:25 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:14:25 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:25] "GET /api/admin/system-health HTTP/1.1" 200 -
2025-06-01 01:14:25 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:14:25 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:25] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:14:26 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:26] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:14:27 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:14:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:27] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /jobs HTTP/1.1" 200 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:14:29 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:29] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:14:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:30] "GET /api/jobs HTTP/1.1" 200 -
2025-06-01 01:14:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:30] "GET /api/printers HTTP/1.1" 200 -
2025-06-01 01:14:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:30] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:14:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:30] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:14:31 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:31] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:14:41 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:41] "GET /.well-known/appspecific/com.chrome.devtools.json HTTP/1.1" 404 -
2025-06-01 01:14:45 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:14:45] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:15:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:00] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:15:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:00] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:15:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:00] "GET /api/jobs HTTP/1.1" 200 -
2025-06-01 01:15:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:00] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:15:14 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:14] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:15:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:30] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:15:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:30] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:15:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:30] "GET /api/jobs HTTP/1.1" 200 -
2025-06-01 01:15:30 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:30] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:15:44 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:44] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /admin-dashboard HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/admin.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/admin-system.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/admin-live.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/js/admin-dashboard.js HTTP/1.1" 304 -
2025-06-01 01:15:47 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:15:47 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:15:47 - myp.app - INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:15:47 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:15:47 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/admin/system-health HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:15:47 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:47] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:15:48 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:48] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:15:57 - myp.app - INFO - Admin-Check für Funktion api_admin_stats_live: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /requests/overview HTTP/1.1" 200 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:15:57 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:57] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:15:58 - myp.app - WARNING - System-Performance-Metriken nicht verfügbar: argument 1 (impossible<bad format char>)
2025-06-01 01:15:58 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:58] "GET /api/admin/stats/live HTTP/1.1" 200 -
2025-06-01 01:15:58 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:58] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:15:58 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:58] "GET /request HTTP/1.1" 200 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:15:59 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:15:59] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /calendar HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/main.min.css HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/timegrid.min.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/interaction.min.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/list.min.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/core.min.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/fullcalendar/daygrid.min.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:16:00 - myp.calendar - INFO - 📅 Kalender-Events abgerufen: 0 Einträge für Zeitraum 2025-06-01 00:00:00 bis 2025-06-08 00:00:00
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /api/calendar/events?start=2025-06-01T00:00:00%2B02:00&end=2025-06-08T00:00:00%2B02:00 HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:16:00 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:00] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /stats HTTP/1.1" 200 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:16:01 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:01] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /jobs HTTP/1.1" 200 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:02 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:02] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /api/jobs HTTP/1.1" 200 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /api/printers HTTP/1.1" 200 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:16:03 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:03] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:16:04 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:04] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:16:18 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:18] "GET /api/jobs?page=1 HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /admin-dashboard HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/css/components.css HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/css/optimization-animations.css HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/admin.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/admin-system.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/admin-live.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/js/admin-dashboard.js HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/session/status HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/user/settings HTTP/1.1" 200 -
2025-06-01 01:16:27 - myp.app - INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:16:27 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/notifications HTTP/1.1" 200 -
2025-06-01 01:16:27 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/admin/system-health HTTP/1.1" 200 -
2025-06-01 01:16:27 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /api/stats HTTP/1.1" 200 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/manifest.json HTTP/1.1" 304 -
2025-06-01 01:16:27 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:27] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-06-01 01:16:28 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:28] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-06-01 01:16:28 - myp.app - INFO - Admin-Check für Funktion admin_add_user_page: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 01:16:28 - myp.app - INFO - Admin-Benutzer-Hinzufügen-Seite aufgerufen von User 1
2025-06-01 01:16:28 - werkzeug - INFO - 127.0.0.1 - - [01/Jun/2025 01:16:28] "GET /admin/users/add HTTP/1.1" 200 -

View File

@ -9,3 +9,13 @@
2025-05-30 21:51:45 - myp.jobs - INFO - ✅ Job 4 erstellt für Drucker 5, Start: 2025-05-30 21:52:00, Dauer: 60 Minuten, Status: scheduled
2025-05-30 21:51:45 - myp.jobs - INFO - ⏰ Erstelle geplanten Job für Drucker Tapo P110 (192.168.0.104) (Start in 0.2 Min)
2025-05-30 21:51:45 - myp.jobs - INFO - ✅ Job 5 erstellt für Drucker 5, Start: 2025-05-30 21:52:00, Dauer: 60 Minuten, Status: scheduled
2025-06-01 01:14:30 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:14:45 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:00 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:00 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:14 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:30 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:30 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:15:44 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:16:03 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)
2025-06-01 01:16:18 - myp.jobs - INFO - Jobs abgerufen: 0 von 0 (Seite 1)

View File

@ -2643,3 +2643,19 @@
2025-06-01 01:02:11 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:02:41 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:02:41 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:13:19 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:13:19 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:13:22 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:13:22 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:13:42 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:13:42 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:13:55 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:13:55 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:14:25 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:14:25 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:14:30 - myp.printers - INFO - Schnelles Laden abgeschlossen: 6 Drucker geladen (ohne Status-Check)
2025-06-01 01:15:47 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:15:47 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-06-01 01:16:03 - myp.printers - INFO - Schnelles Laden abgeschlossen: 6 Drucker geladen (ohne Status-Check)
2025-06-01 01:16:27 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-06-01 01:16:27 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker

View File

@ -2751,3 +2751,6 @@
2025-06-01 00:56:23 - myp.scheduler - INFO - Scheduler gestartet
2025-06-01 01:03:04 - myp.scheduler - INFO - Scheduler-Thread beendet
2025-06-01 01:03:04 - myp.scheduler - INFO - Scheduler gestoppt
2025-06-01 01:13:16 - myp.scheduler - INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-06-01 01:13:17 - myp.scheduler - INFO - Scheduler-Thread gestartet
2025-06-01 01:13:17 - myp.scheduler - INFO - Scheduler gestartet

File diff suppressed because one or more lines are too long

View File

@ -356,20 +356,60 @@ async function loadRecentActivity() {
async function loadSystemStatus() {
try {
const response = await fetch('/api/stats');
if (!response.ok) {
throw new Error(`HTTP ${response.status}: ${response.statusText}`);
}
const data = await response.json();
// Update system stats
document.getElementById('total-print-time').textContent =
formatPrintTime(data.total_print_time_hours);
document.getElementById('completed-jobs-count').textContent =
data.total_jobs_completed || 0;
document.getElementById('total-material-used').textContent =
formatMaterialUsed(data.total_material_used);
document.getElementById('last-updated-time').textContent =
data.last_updated ? formatDateTime(data.last_updated) : '-';
// Prüfen ob data gültig ist
if (!data || typeof data !== 'object') {
throw new Error('Ungültige Antwort vom Server erhalten');
}
// Update system stats mit Fallback-Werten
const totalPrintTimeEl = document.getElementById('total-print-time');
if (totalPrintTimeEl) {
totalPrintTimeEl.textContent = formatPrintTime(data.total_print_time_hours);
}
const completedJobsEl = document.getElementById('completed-jobs-count');
if (completedJobsEl) {
completedJobsEl.textContent = data.total_jobs_completed || 0;
}
const totalMaterialEl = document.getElementById('total-material-used');
if (totalMaterialEl) {
totalMaterialEl.textContent = formatMaterialUsed(data.total_material_used);
}
const lastUpdatedEl = document.getElementById('last-updated-time');
if (lastUpdatedEl) {
lastUpdatedEl.textContent = data.last_updated ? formatDateTime(data.last_updated) : '-';
}
console.log('✅ Systemstatus erfolgreich geladen:', data);
} catch (error) {
console.error('Error loading system status:', error);
showToast('Fehler beim Laden des Systemstatus', 'error');
const errorMessage = error.message || 'Unbekannter Systemfehler';
showToast(`Fehler beim Laden des Systemstatus: ${errorMessage}`, 'error');
// Fallback-Werte anzeigen
const elements = [
'total-print-time',
'completed-jobs-count',
'total-material-used',
'last-updated-time'
];
elements.forEach(id => {
const el = document.getElementById(id);
if (el) {
el.textContent = 'Fehler beim Laden';
el.classList.add('text-red-500');
}
});
}
}

View File

@ -114,7 +114,7 @@
type: e.error ? e.error.constructor.name : 'Unbekannter Typ'
};
console.error('🐛 JavaScript Error abgefangen:', errorInfo);
console.error('🐛 JavaScript Error abgefangen:', JSON.stringify(errorInfo, null, 2));
// Spezifische Fehlerbehebungen
if (e.message.includes('MVP.UI.DarkModeManager is not a constructor')) {
@ -153,6 +153,12 @@
e.preventDefault();
return false;
}
if (e.message.includes('showToast is not defined')) {
console.log('🔧 showToast Fehler erkannt - verwende Fallback');
e.preventDefault();
return false;
}
});
// Promise rejection handler

View File

@ -128,18 +128,48 @@ window.refreshJobs = async function() {
}
try {
// Jobs-Daten neu laden
if (typeof jobManager !== 'undefined' && jobManager.loadJobs) {
// Jobs-Daten neu laden mit verbesserter Fehlerbehandlung
if (typeof window.jobManager !== 'undefined' && window.jobManager && window.jobManager.loadJobs) {
await window.jobManager.loadJobs();
} else if (typeof jobManager !== 'undefined' && jobManager && jobManager.loadJobs) {
await jobManager.loadJobs();
} else {
// Fallback: Seite neu laden
window.location.reload();
// Fallback: API-Aufruf direkt
console.log('📝 JobManager nicht verfügbar - verwende direkten API-Aufruf');
const response = await fetch('/api/jobs', {
headers: {
'Content-Type': 'application/json',
'X-CSRFToken': getCSRFToken()
}
});
if (!response.ok) {
throw new Error(`API-Fehler: ${response.status} ${response.statusText}`);
}
const data = await response.json();
console.log('📝 Jobs erfolgreich über API geladen:', data);
// Wenn JobsContainer vorhanden ist, versuche die Jobs zu rendern
const jobsContainer = document.querySelector('.jobs-container, #jobs-container, .job-grid');
if (jobsContainer && data.jobs) {
// Einfache Jobs-Darstellung als Fallback
jobsContainer.innerHTML = data.jobs.map(job => `
<div class="job-card p-4 border rounded-lg">
<h3 class="font-semibold">${job.filename || 'Unbekannter Job'}</h3>
<p class="text-sm text-gray-600">Status: ${job.status || 'Unbekannt'}</p>
</div>
`).join('');
}
}
showToast('✅ Druckaufträge erfolgreich aktualisiert', 'success');
} catch (error) {
console.error('Jobs-Refresh Fehler:', error);
showToast('❌ Fehler beim Aktualisieren der Jobs', 'error');
const errorMessage = error.message === 'undefined' ?
'Jobs-Manager nicht verfügbar' :
error.message || 'Unbekannter Fehler';
showToast(`❌ Fehler beim Laden der Jobs: ${errorMessage}`, 'error');
} finally {
if (refreshButton) {
refreshButton.disabled = false;

View File

@ -709,46 +709,40 @@ class OptimizationManager {
}
showSuccessMessage(message) {
this.showToast(message, 'success');
// Verwende das globale Glassmorphism-System anstelle eines einfachen Toasts
if (typeof showFlashMessage === 'function') {
showFlashMessage(message, 'success');
} else {
console.log('Success:', message);
}
}
showErrorMessage(message) {
this.showToast(message, 'error');
// Verwende das globale Glassmorphism-System anstelle eines einfachen Toasts
if (typeof showFlashMessage === 'function') {
showFlashMessage(message, 'error');
} else {
console.error('Error:', message);
}
}
showWarningMessage(message) {
this.showToast(message, 'warning');
// Verwende das globale Glassmorphism-System anstelle eines einfachen Toasts
if (typeof showFlashMessage === 'function') {
showFlashMessage(message, 'warning');
} else {
console.warn('Warning:', message);
}
}
showToast(message, type = 'info') {
// Einfache Toast-Benachrichtigung
const toast = document.createElement('div');
toast.className = `fixed top-4 right-4 z-50 p-4 rounded-lg shadow-lg transition-all duration-300 transform translate-x-full`;
const colors = {
success: 'bg-green-500 text-white',
error: 'bg-red-500 text-white',
warning: 'bg-yellow-500 text-black',
info: 'bg-blue-500 text-white'
};
toast.className += ` ${colors[type]}`;
toast.textContent = message;
document.body.appendChild(toast);
// Animation einblenden
setTimeout(() => {
toast.classList.remove('translate-x-full');
}, 100);
// Nach 5 Sekunden automatisch entfernen
setTimeout(() => {
toast.classList.add('translate-x-full');
setTimeout(() => {
toast.remove();
}, 300);
}, 5000);
// Verwende das globale Glassmorphism-System für alle Toast-Nachrichten
if (typeof showFlashMessage === 'function') {
showFlashMessage(message, type);
} else {
// Fallback falls Glassmorphism-System nicht verfügbar
console.log(`${type.toUpperCase()}: ${message}`);
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,249 @@
/**
* MYP Platform - JavaScript Fehler Validierung und Überwachung
* Überprüft die behobenen Fehler und aktiviert weitere Fallbacks bei Bedarf
*/
(function() {
'use strict';
console.log('🔍 JavaScript Fehlervalidierung wird gestartet...');
/**
* Validierung der showToast-Verfügbarkeit
*/
function validateShowToast() {
const testsPassed = [];
// Test 1: Grundfunktion verfügbar
if (typeof window.showToast === 'function') {
testsPassed.push('✅ window.showToast ist verfügbar');
} else {
console.warn('⚠️ window.showToast nicht verfügbar - aktiviere Fallback');
// Fallback aktivieren
window.showToast = function(message, type = 'info', duration = 5000) {
console.log(`🔧 Validation-Fallback showToast: [${type.toUpperCase()}] ${message}`);
// Versuche MYP.UI.toast zu verwenden
if (window.MYP && window.MYP.UI && window.MYP.UI.toast && window.MYP.UI.toast.show) {
window.MYP.UI.toast.show(message, type, duration);
}
};
testsPassed.push('🔧 Fallback showToast aktiviert');
}
// Test 2: MYP.UI.toast verfügbar
if (window.MYP && window.MYP.UI && window.MYP.UI.toast) {
testsPassed.push('✅ MYP.UI.toast ist verfügbar');
} else {
testsPassed.push('⚠️ MYP.UI.toast noch nicht verfügbar (wird später geladen)');
}
return testsPassed;
}
/**
* Validierung der Manager-Verfügbarkeit
*/
function validateManagers() {
const testsPassed = [];
// JobManager-Test
if (typeof window.jobManager !== 'undefined' && window.jobManager) {
testsPassed.push('✅ window.jobManager ist verfügbar');
} else if (typeof jobManager !== 'undefined' && jobManager) {
testsPassed.push('✅ jobManager (global) ist verfügbar');
} else {
testsPassed.push('⚠️ JobManager nicht verfügbar - API-Fallback wird verwendet');
}
// Refresh-Funktionen Test
if (typeof window.refreshJobs === 'function') {
testsPassed.push('✅ refreshJobs-Funktion ist verfügbar');
} else {
testsPassed.push('❌ refreshJobs-Funktion fehlt');
}
if (typeof window.refreshStats === 'function') {
testsPassed.push('✅ refreshStats-Funktion ist verfügbar');
} else {
testsPassed.push('❌ refreshStats-Funktion fehlt');
}
return testsPassed;
}
/**
* API-Endpunkt Validierung
*/
async function validateAPIEndpoints() {
const testsPassed = [];
const endpoints = [
{ url: '/api/stats', name: 'Statistiken' },
{ url: '/api/jobs', name: 'Jobs' }
];
for (const endpoint of endpoints) {
try {
const response = await fetch(endpoint.url, {
method: 'HEAD', // Nur Header abrufen, kein Body
headers: {
'Content-Type': 'application/json'
}
});
if (response.ok || response.status === 405) { // 405 = Method Not Allowed ist OK
testsPassed.push(`${endpoint.name} API (${endpoint.url}) ist erreichbar`);
} else {
testsPassed.push(`⚠️ ${endpoint.name} API (${endpoint.url}) antwortet mit Status ${response.status}`);
}
} catch (error) {
testsPassed.push(`${endpoint.name} API (${endpoint.url}) nicht erreichbar: ${error.message}`);
}
}
return testsPassed;
}
/**
* DOM-Element Validierung
*/
function validateDOMElements() {
const testsPassed = [];
const criticalElements = [
'total-print-time',
'completed-jobs-count',
'total-material-used',
'last-updated-time'
];
criticalElements.forEach(elementId => {
const element = document.getElementById(elementId);
if (element) {
testsPassed.push(`✅ Element #${elementId} gefunden`);
} else {
testsPassed.push(`⚠️ Element #${elementId} nicht gefunden`);
}
});
// Container-Elemente
const containers = [
'.jobs-container',
'#jobs-container',
'.job-grid',
'#refresh-button'
];
containers.forEach(selector => {
const element = document.querySelector(selector);
if (element) {
testsPassed.push(`✅ Container ${selector} gefunden`);
} else {
testsPassed.push(`⚠️ Container ${selector} nicht gefunden`);
}
});
return testsPassed;
}
/**
* Error Handler Validierung
*/
function validateErrorHandling() {
const testsPassed = [];
// Test ob unser error handler aktiv ist
const testError = new Error('Validation Test Error');
window.dispatchEvent(new ErrorEvent('error', {
message: 'Test error for validation',
filename: 'validation-fix.js',
lineno: 1,
error: testError
}));
testsPassed.push('✅ Error Handler Funktionalität getestet');
return testsPassed;
}
/**
* Vollständige Validierung durchführen
*/
async function runCompleteValidation() {
console.log('🔍 Starte vollständige JavaScript-Validierung...');
const results = {
showToast: validateShowToast(),
managers: validateManagers(),
domElements: validateDOMElements(),
errorHandling: validateErrorHandling(),
apiEndpoints: await validateAPIEndpoints()
};
// Ergebnisse ausgeben
console.group('🔍 Validierungsergebnisse:');
Object.keys(results).forEach(category => {
console.group(`📋 ${category}:`);
results[category].forEach(result => console.log(result));
console.groupEnd();
});
console.groupEnd();
// Zusammenfassung
const allResults = Object.values(results).flat();
const successCount = allResults.filter(r => r.startsWith('✅')).length;
const warningCount = allResults.filter(r => r.startsWith('⚠️')).length;
const errorCount = allResults.filter(r => r.startsWith('❌')).length;
console.log(`📊 Validierung abgeschlossen: ${successCount} OK, ${warningCount} Warnungen, ${errorCount} Fehler`);
// Status-Toast anzeigen
if (typeof window.showToast === 'function') {
if (errorCount === 0) {
window.showToast(`✅ JavaScript-Validierung erfolgreich: ${successCount} Checks bestanden`, 'success');
} else {
window.showToast(`⚠️ JavaScript-Validierung: ${errorCount} Probleme gefunden`, 'warning');
}
}
return results;
}
/**
* Kontinuierliche Überwachung
*/
function startContinuousMonitoring() {
setInterval(() => {
// Prüfe kritische Funktionen
if (typeof window.showToast !== 'function') {
console.warn('⚠️ showToast-Funktion verloren - reaktiviere Fallback');
validateShowToast();
}
// Prüfe auf neue Fehler
const errorElements = document.querySelectorAll('.text-red-500');
if (errorElements.length > 0) {
console.warn(`⚠️ ${errorElements.length} Fehler-Elemente gefunden`);
}
}, 30000); // Alle 30 Sekunden
}
// Globale Funktionen exportieren
window.validateJavaScript = runCompleteValidation;
window.validateShowToast = validateShowToast;
// DOMContentLoaded abwarten und dann validieren
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', () => {
setTimeout(runCompleteValidation, 2000); // 2 Sekunden warten
startContinuousMonitoring();
});
} else {
setTimeout(runCompleteValidation, 2000);
startContinuousMonitoring();
}
console.log('✅ JavaScript Fehlervalidierung initialisiert');
})();

View File

@ -1,190 +1,544 @@
<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Benutzer hinzufügen - MYP Admin</title>
<link href="https://cdn.jsdelivr.net/npm/tailwindcss@2.2.19/dist/tailwind.min.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
</head>
<body class="bg-gray-100">
<div class="min-h-screen py-8">
<div class="max-w-2xl mx-auto">
<!-- Header -->
<div class="bg-white rounded-lg shadow-md p-6 mb-6">
<div class="flex items-center justify-between">
<div class="flex items-center space-x-3">
<i class="fas fa-user-plus text-blue-600 text-2xl"></i>
<h1 class="text-2xl font-bold text-gray-800">Neuen Benutzer hinzufügen</h1>
{% extends "base.html" %}
{% block title %}Benutzer hinzufügen - Ausbilder-Bereich - Mercedes-Benz{% endblock %}
{% block extra_css %}
<style>
/* Spezielle Styles für Admin-Benutzer-Formular */
.admin-form-container {
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
border: 1px solid rgba(0, 0, 0, 0.05);
box-shadow:
0 20px 25px -5px rgba(0, 0, 0, 0.1),
0 10px 10px -5px rgba(0, 0, 0, 0.04),
0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}
.dark .admin-form-container {
background: rgba(15, 23, 42, 0.95);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow:
0 20px 25px -5px rgba(0, 0, 0, 0.25),
0 10px 10px -5px rgba(0, 0, 0, 0.1),
0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}
.form-field-premium {
position: relative;
overflow: hidden;
}
.form-field-premium::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 1px;
background: linear-gradient(90deg, transparent, rgba(59, 130, 246, 0.5), transparent);
opacity: 0;
transition: opacity 0.3s ease;
}
.form-field-premium:focus-within::before {
opacity: 1;
}
.input-premium {
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
background: rgba(255, 255, 255, 0.8);
backdrop-filter: blur(8px);
border: 1px solid rgba(0, 0, 0, 0.1);
}
.dark .input-premium {
background: rgba(15, 23, 42, 0.8);
border: 1px solid rgba(255, 255, 255, 0.1);
color: #ffffff;
}
.input-premium:focus {
background: rgba(255, 255, 255, 0.95);
border-color: rgba(59, 130, 246, 0.5);
box-shadow:
0 0 0 3px rgba(59, 130, 246, 0.1),
0 10px 25px -5px rgba(59, 130, 246, 0.1);
transform: translateY(-1px);
}
.dark .input-premium:focus {
background: rgba(15, 23, 42, 0.95);
border-color: rgba(59, 130, 246, 0.5);
box-shadow:
0 0 0 3px rgba(59, 130, 246, 0.1),
0 10px 25px -5px rgba(59, 130, 246, 0.1);
}
.btn-mercedes-primary {
background: linear-gradient(135deg, #1e40af 0%, #3b82f6 100%);
box-shadow:
0 4px 15px rgba(59, 130, 246, 0.3),
0 0 0 1px rgba(255, 255, 255, 0.1) inset;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-mercedes-primary:hover {
background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 100%);
box-shadow:
0 8px 25px rgba(59, 130, 246, 0.4),
0 0 0 1px rgba(255, 255, 255, 0.2) inset;
transform: translateY(-2px);
}
.btn-mercedes-secondary {
background: linear-gradient(135deg, #6b7280 0%, #9ca3af 100%);
box-shadow:
0 4px 15px rgba(107, 114, 128, 0.3),
0 0 0 1px rgba(255, 255, 255, 0.1) inset;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-mercedes-secondary:hover {
background: linear-gradient(135deg, #4b5563 0%, #6b7280 100%);
box-shadow:
0 8px 25px rgba(107, 114, 128, 0.4),
0 0 0 1px rgba(255, 255, 255, 0.2) inset;
transform: translateY(-2px);
}
.info-box-premium {
background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(139, 92, 246, 0.1) 100%);
border: 1px solid rgba(59, 130, 246, 0.2);
backdrop-filter: blur(10px);
}
.dark .info-box-premium {
background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(139, 92, 246, 0.1) 100%);
border: 1px solid rgba(59, 130, 246, 0.3);
}
.validation-error {
border-color: #ef4444 !important;
box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}
.validation-success {
border-color: #10b981 !important;
box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1) !important;
}
</style>
{% endblock %}
{% block content %}
<div class="max-w-4xl mx-auto space-y-8">
<!-- Header Section mit Mercedes-Benz Design -->
<div class="admin-form-container rounded-2xl p-8 transition-all duration-300">
<div class="flex items-center justify-between mb-6">
<div class="flex items-center space-x-4">
<!-- Mercedes Icon -->
<div class="w-12 h-12 rounded-full bg-gradient-to-br from-blue-500 to-blue-600 flex items-center justify-center shadow-lg">
<svg class="w-7 h-7 text-white" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4.354a4 4 0 110 5.292M15 21H3v-1a6 6 0 0112 0v1zm0 0h6v-1a6 6 0 00-9-5.197m3 4.197a4 4 0 11-8 0 4 4 0 018 0z"/>
</svg>
</div>
<div>
<h1 class="text-3xl font-bold text-slate-900 dark:text-white transition-colors duration-300">
Neuen Benutzer hinzufügen
</h1>
<p class="text-slate-600 dark:text-slate-400 mt-1 transition-colors duration-300">
Erstellen Sie einen neuen Benutzer für das Mercedes-Benz MYP System
</p>
</div>
</div>
<!-- Zurück Button -->
<a href="{{ url_for('admin_page', tab='users') }}"
class="bg-gray-500 hover:bg-gray-600 text-white px-4 py-2 rounded-lg transition-colors">
<i class="fas fa-arrow-left mr-2"></i>Zurück
class="btn-mercedes-secondary text-white px-6 py-3 rounded-xl font-medium transition-all duration-300 flex items-center space-x-2 hover:scale-105">
<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 19l-7-7m0 0l7-7m-7 7h18"/>
</svg>
<span>Zurück zur Übersicht</span>
</a>
</div>
</div>
<!-- Formular -->
<div class="bg-white rounded-lg shadow-md p-6">
<form action="{{ url_for('admin_create_user_form') }}" method="POST" class="space-y-6">
<!-- Hauptformular -->
<div class="admin-form-container rounded-2xl p-8 transition-all duration-300">
<form id="userForm" action="{{ url_for('admin_create_user_form') }}" method="POST" class="space-y-8">
<!-- CSRF Token -->
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}"/>
<!-- Formular-Header -->
<div class="border-b border-slate-200 dark:border-slate-700 pb-6">
<h2 class="text-xl font-semibold text-slate-900 dark:text-white mb-2 transition-colors duration-300">
Benutzerdaten eingeben
</h2>
<p class="text-slate-600 dark:text-slate-400 transition-colors duration-300">
Bitte füllen Sie alle erforderlichen Felder aus, um einen neuen Benutzer zu erstellen.
</p>
</div>
<div class="grid grid-cols-1 lg:grid-cols-2 gap-8">
<!-- Linke Spalte: Grunddaten -->
<div class="space-y-6">
<!-- E-Mail -->
<div>
<label for="email" class="block text-sm font-medium text-gray-700 mb-2">
<i class="fas fa-envelope mr-2"></i>E-Mail-Adresse *
<div class="form-field-premium">
<label for="email" class="block text-sm font-semibold text-slate-900 dark:text-white mb-3 transition-colors duration-300">
<svg class="w-4 h-4 inline mr-2 text-blue-500" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 12a4 4 0 10-8 0 4 4 0 008 0zm0 0v1.5a2.5 2.5 0 005 0V12a9 9 0 10-9 9m4.5-1.206a8.959 8.959 0 01-4.5 1.207"/>
</svg>
E-Mail-Adresse *
</label>
<input type="email"
id="email"
name="email"
required
class="w-full px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent"
placeholder="benutzer@beispiel.de">
class="input-premium w-full px-4 py-3 rounded-xl focus:outline-none transition-all duration-300 text-slate-900 dark:text-white placeholder-slate-500 dark:placeholder-slate-400"
placeholder="beispiel@mercedes-benz.com"
data-validation="email">
<div class="validation-message hidden mt-2 text-sm text-red-500"></div>
</div>
<!-- Name -->
<div>
<label for="name" class="block text-sm font-medium text-gray-700 mb-2">
<i class="fas fa-user mr-2"></i>Vollständiger Name
<!-- Vollständiger Name -->
<div class="form-field-premium">
<label for="name" class="block text-sm font-semibold text-slate-900 dark:text-white mb-3 transition-colors duration-300">
<svg class="w-4 h-4 inline mr-2 text-blue-500" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/>
</svg>
Vollständiger Name
</label>
<input type="text"
id="name"
name="name"
class="w-full px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent"
placeholder="Max Mustermann">
class="input-premium w-full px-4 py-3 rounded-xl focus:outline-none transition-all duration-300 text-slate-900 dark:text-white placeholder-slate-500 dark:placeholder-slate-400"
placeholder="Max Mustermann"
data-validation="name">
<div class="validation-message hidden mt-2 text-sm text-gray-500">
Optional: Wird für die Anzeige im System verwendet
</div>
</div>
</div>
<!-- Rechte Spalte: Sicherheit & Rolle -->
<div class="space-y-6">
<!-- Passwort -->
<div>
<label for="password" class="block text-sm font-medium text-gray-700 mb-2">
<i class="fas fa-lock mr-2"></i>Passwort *
<div class="form-field-premium">
<label for="password" class="block text-sm font-semibold text-slate-900 dark:text-white mb-3 transition-colors duration-300">
<svg class="w-4 h-4 inline mr-2 text-blue-500" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 15v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2zm10-10V7a4 4 0 00-8 0v4h8z"/>
</svg>
Passwort *
</label>
<div class="relative">
<input type="password"
id="password"
name="password"
required
minlength="6"
class="w-full px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent"
placeholder="Mindestens 6 Zeichen">
class="input-premium w-full px-4 py-3 pr-12 rounded-xl focus:outline-none transition-all duration-300 text-slate-900 dark:text-white placeholder-slate-500 dark:placeholder-slate-400"
placeholder="Mindestens 6 Zeichen"
data-validation="password">
<button type="button"
id="togglePassword"
class="absolute right-3 top-1/2 transform -translate-y-1/2 text-slate-500 hover:text-slate-700 dark:text-slate-400 dark:hover:text-slate-200 transition-colors duration-300">
<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"/>
</svg>
</button>
</div>
<div class="validation-message hidden mt-2 text-sm text-red-500"></div>
<!-- Passwort-Stärke-Anzeige -->
<div id="passwordStrength" class="hidden mt-3">
<div class="flex space-x-1 mb-2">
<div class="strength-bar h-1 flex-1 bg-gray-200 dark:bg-gray-700 rounded"></div>
<div class="strength-bar h-1 flex-1 bg-gray-200 dark:bg-gray-700 rounded"></div>
<div class="strength-bar h-1 flex-1 bg-gray-200 dark:bg-gray-700 rounded"></div>
<div class="strength-bar h-1 flex-1 bg-gray-200 dark:bg-gray-700 rounded"></div>
</div>
<div class="text-xs text-slate-600 dark:text-slate-400">
<span id="strengthText">Passwort-Stärke</span>
</div>
</div>
</div>
<!-- Rolle -->
<div>
<label for="role" class="block text-sm font-medium text-gray-700 mb-2">
<i class="fas fa-user-tag mr-2"></i>Benutzerrolle
<!-- Benutzerrolle -->
<div class="form-field-premium">
<label for="role" class="block text-sm font-semibold text-slate-900 dark:text-white mb-3 transition-colors duration-300">
<svg class="w-4 h-4 inline mr-2 text-blue-500" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12l2 2 4-4m5.618-4.016A11.955 11.955 0 0112 2.944a11.955 11.955 0 01-8.618 3.04A12.02 12.02 0 003 9c0 5.591 3.824 10.29 9 11.622 5.176-1.332 9-6.03 9-11.622 0-1.042-.133-2.052-.382-3.016z"/>
</svg>
Benutzerrolle
</label>
<select id="role"
name="role"
class="w-full px-3 py-2 border border-gray-300 rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent">
<option value="user">Benutzer</option>
<option value="admin">Administrator</option>
class="input-premium w-full px-4 py-3 rounded-xl focus:outline-none transition-all duration-300 text-slate-900 dark:text-white">
<option value="user">👤 Standard-Benutzer</option>
<option value="admin">⚙️ Administrator (Ausbilder)</option>
</select>
<div class="mt-2 text-sm text-slate-600 dark:text-slate-400">
<span id="roleDescription">Standard-Zugriff auf das MYP System</span>
</div>
</div>
</div>
</div>
<!-- Hinweise -->
<div class="bg-blue-50 border border-blue-200 rounded-lg p-4">
<div class="flex">
<i class="fas fa-info-circle text-blue-500 mt-0.5 mr-3"></i>
<div class="text-sm text-blue-700">
<p class="font-semibold mb-1">Hinweise:</p>
<ul class="list-disc list-inside space-y-1">
<li>Felder mit * sind Pflichtfelder</li>
<li>Das Passwort muss mindestens 6 Zeichen lang sein</li>
<li>Der Benutzername wird automatisch aus der E-Mail-Adresse generiert</li>
<li>Administratoren haben Vollzugriff auf das System</li>
<!-- Informations-Box -->
<div class="info-box-premium rounded-xl p-6 transition-all duration-300">
<div class="flex items-start space-x-3">
<div class="flex-shrink-0">
<svg class="w-6 h-6 text-blue-500" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"/>
</svg>
</div>
<div class="flex-1">
<h3 class="text-sm font-semibold text-slate-900 dark:text-white mb-2 transition-colors duration-300">
Wichtige Hinweise zum Erstellen von Benutzern
</h3>
<ul class="text-sm text-slate-700 dark:text-slate-300 space-y-1 transition-colors duration-300">
<li class="flex items-center space-x-2">
<svg class="w-4 h-4 text-green-500 flex-shrink-0" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z" clip-rule="evenodd"/>
</svg>
<span>Felder mit * sind Pflichtfelder und müssen ausgefüllt werden</span>
</li>
<li class="flex items-center space-x-2">
<svg class="w-4 h-4 text-green-500 flex-shrink-0" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z" clip-rule="evenodd"/>
</svg>
<span>Das Passwort muss mindestens 6 Zeichen lang sein</span>
</li>
<li class="flex items-center space-x-2">
<svg class="w-4 h-4 text-green-500 flex-shrink-0" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z" clip-rule="evenodd"/>
</svg>
<span>Der Benutzername wird automatisch aus der E-Mail-Adresse generiert</span>
</li>
<li class="flex items-center space-x-2">
<svg class="w-4 h-4 text-amber-500 flex-shrink-0" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"/>
</svg>
<span>Administratoren haben Vollzugriff auf das Mercedes-Benz MYP System</span>
</li>
</ul>
</div>
</div>
</div>
<!-- Aktionen -->
<div class="flex space-x-3 pt-4">
<!-- Aktions-Buttons -->
<div class="flex flex-col sm:flex-row space-y-3 sm:space-y-0 sm:space-x-4 pt-6 border-t border-slate-200 dark:border-slate-700">
<button type="submit"
class="flex-1 bg-blue-600 hover:bg-blue-700 text-white px-4 py-2 rounded-lg transition-colors">
<i class="fas fa-save mr-2"></i>Benutzer erstellen
id="submitBtn"
class="btn-mercedes-primary text-white px-8 py-4 rounded-xl font-semibold transition-all duration-300 flex items-center justify-center space-x-3 hover:scale-105 disabled:opacity-50 disabled:cursor-not-allowed">
<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/>
</svg>
<span>Benutzer erstellen</span>
<div class="loading-spinner hidden ml-2">
<svg class="animate-spin w-4 h-4 text-white" fill="none" viewBox="0 0 24 24">
<circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
<path class="opacity-75" fill="currentColor" d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path>
</svg>
</div>
</button>
<a href="{{ url_for('admin_page', tab='users') }}"
class="flex-1 bg-gray-500 hover:bg-gray-600 text-white px-4 py-2 rounded-lg text-center transition-colors">
<i class="fas fa-times mr-2"></i>Abbrechen
class="btn-mercedes-secondary text-white px-8 py-4 rounded-xl font-semibold text-center transition-all duration-300 flex items-center justify-center space-x-3 hover:scale-105">
<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
</svg>
<span>Abbrechen</span>
</a>
</div>
</form>
</div>
</div>
</div>
</div>
{% endblock %}
<!-- Flash Messages -->
{% with messages = get_flashed_messages(with_categories=true) %}
{% if messages %}
<div class="fixed top-4 right-4 z-50 space-y-2">
{% for category, message in messages %}
<div class="alert alert-{{ 'danger' if category == 'error' else category }} bg-{{ 'red' if category == 'error' else 'green' }}-100 border border-{{ 'red' if category == 'error' else 'green' }}-400 text-{{ 'red' if category == 'error' else 'green' }}-700 px-4 py-3 rounded-lg shadow-md">
<div class="flex items-center">
<i class="fas fa-{{ 'exclamation-triangle' if category == 'error' else 'check-circle' }} mr-2"></i>
{{ message }}
</div>
</div>
{% endfor %}
</div>
{% endif %}
{% endwith %}
<!-- JavaScript für Form-Validierung -->
<script>
document.addEventListener('DOMContentLoaded', function() {
const form = document.querySelector('form');
{% block scripts %}
<script>
document.addEventListener('DOMContentLoaded', function() {
const form = document.getElementById('userForm');
const emailInput = document.getElementById('email');
const passwordInput = document.getElementById('password');
const nameInput = document.getElementById('name');
const roleSelect = document.getElementById('role');
const submitBtn = document.getElementById('submitBtn');
const togglePasswordBtn = document.getElementById('togglePassword');
// E-Mail-Validierung
emailInput.addEventListener('blur', function() {
const email = this.value;
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
// Passwort-Sichtbarkeit umschalten
togglePasswordBtn.addEventListener('click', function() {
const type = passwordInput.getAttribute('type') === 'password' ? 'text' : 'password';
passwordInput.setAttribute('type', type);
if (email && !emailRegex.test(email)) {
this.classList.add('border-red-500');
this.classList.remove('border-gray-300');
// Icon ändern
const icon = this.querySelector('svg path:last-child');
if (type === 'text') {
// Auge durchgestrichen
icon.setAttribute('d', 'M3 3l18 18M10.584 10.587a2 2 0 002.828 2.829M9.363 5.365A9.466 9.466 0 0112 5c4.478 0 8.268 2.943 9.542 7a9.564 9.564 0 01-1.226 1.686m-2.854 2.852A9.465 9.465 0 0112 19c-4.478 0-8.268-2.943-9.542-7a9.564 9.564 0 011.226-1.686');
} else {
this.classList.remove('border-red-500');
this.classList.add('border-gray-300');
// Normales Auge
icon.setAttribute('d', 'M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z');
}
});
// Passwort-Validierung
passwordInput.addEventListener('input', function() {
const password = this.value;
// Rolle-Beschreibung aktualisieren
const roleDescriptions = {
'user': 'Standard-Zugriff auf das MYP System - kann Reservierungen erstellen und verwalten',
'admin': 'Vollzugriff auf das System - kann Benutzer verwalten, Systemeinstellungen ändern und alle Bereiche einsehen'
};
if (password.length > 0 && password.length < 6) {
this.classList.add('border-red-500');
this.classList.remove('border-gray-300');
} else {
this.classList.remove('border-red-500');
this.classList.add('border-gray-300');
roleSelect.addEventListener('change', function() {
const roleDescription = document.getElementById('roleDescription');
roleDescription.textContent = roleDescriptions[this.value] || roleDescriptions['user'];
});
// E-Mail-Validierung
function validateEmail(email) {
const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
return emailRegex.test(email);
}
// Passwort-Stärke bewerten
function getPasswordStrength(password) {
let score = 0;
if (password.length >= 6) score++;
if (password.length >= 8) score++;
if (/[A-Z]/.test(password)) score++;
if (/[a-z]/.test(password)) score++;
if (/[0-9]/.test(password)) score++;
if (/[^A-Za-z0-9]/.test(password)) score++;
return Math.min(score, 4);
}
// Validierung anzeigen
function showValidation(input, isValid, message = '') {
const validationMessage = input.parentNode.querySelector('.validation-message');
input.classList.remove('validation-error', 'validation-success');
if (validationMessage) {
validationMessage.classList.add('hidden');
}
if (input.value) {
if (isValid) {
input.classList.add('validation-success');
} else {
input.classList.add('validation-error');
if (validationMessage && message) {
validationMessage.textContent = message;
validationMessage.classList.remove('hidden');
}
}
}
}
// Passwort-Stärke anzeigen
function updatePasswordStrength(password) {
const strengthContainer = document.getElementById('passwordStrength');
const strengthBars = strengthContainer.querySelectorAll('.strength-bar');
const strengthText = document.getElementById('strengthText');
if (password.length === 0) {
strengthContainer.classList.add('hidden');
return;
}
strengthContainer.classList.remove('hidden');
const strength = getPasswordStrength(password);
const colors = ['bg-red-500', 'bg-yellow-500', 'bg-blue-500', 'bg-green-500'];
const texts = ['Sehr schwach', 'Schwach', 'Mittel', 'Stark'];
strengthBars.forEach((bar, index) => {
bar.className = 'strength-bar h-1 flex-1 rounded transition-colors duration-300';
if (index < strength) {
bar.classList.add(colors[strength - 1]);
} else {
bar.classList.add('bg-gray-200', 'dark:bg-gray-700');
}
});
strengthText.textContent = strength > 0 ? `Passwort-Stärke: ${texts[strength - 1]}` : 'Passwort-Stärke';
}
// Event Listeners für Validierung
emailInput.addEventListener('blur', function() {
const isValid = validateEmail(this.value);
showValidation(this, isValid, 'Bitte geben Sie eine gültige E-Mail-Adresse ein');
});
emailInput.addEventListener('input', function() {
if (this.value) {
const isValid = validateEmail(this.value);
showValidation(this, isValid);
}
});
passwordInput.addEventListener('input', function() {
const isValid = this.value.length >= 6;
showValidation(this, isValid, 'Das Passwort muss mindestens 6 Zeichen lang sein');
updatePasswordStrength(this.value);
});
// Form-Submit-Validierung
form.addEventListener('submit', function(e) {
const email = emailInput.value;
const password = passwordInput.value;
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
if (!email || !emailRegex.test(email)) {
e.preventDefault();
alert('Bitte geben Sie eine gültige E-Mail-Adresse ein.');
emailInput.focus();
const email = emailInput.value.trim();
const password = passwordInput.value.trim();
let isValid = true;
let firstErrorField = null;
// E-Mail validieren
if (!email) {
showValidation(emailInput, false, 'E-Mail-Adresse ist erforderlich');
isValid = false;
if (!firstErrorField) firstErrorField = emailInput;
} else if (!validateEmail(email)) {
showValidation(emailInput, false, 'Bitte geben Sie eine gültige E-Mail-Adresse ein');
isValid = false;
if (!firstErrorField) firstErrorField = emailInput;
}
// Passwort validieren
if (!password) {
showValidation(passwordInput, false, 'Passwort ist erforderlich');
isValid = false;
if (!firstErrorField) firstErrorField = passwordInput;
} else if (password.length < 6) {
showValidation(passwordInput, false, 'Das Passwort muss mindestens 6 Zeichen lang sein');
isValid = false;
if (!firstErrorField) firstErrorField = passwordInput;
}
if (!isValid) {
if (firstErrorField) {
firstErrorField.focus();
firstErrorField.scrollIntoView({ behavior: 'smooth', block: 'center' });
}
return;
}
if (!password || password.length < 6) {
e.preventDefault();
alert('Das Passwort muss mindestens 6 Zeichen lang sein.');
passwordInput.focus();
return;
}
// Loading-State anzeigen
submitBtn.disabled = true;
submitBtn.querySelector('.loading-spinner').classList.remove('hidden');
submitBtn.querySelector('span').textContent = 'Wird erstellt...';
// Formular absenden
setTimeout(() => {
form.submit();
}, 500);
});
});
</script>
</body>
</html>
// Initiale Rolle-Beschreibung setzen
const roleDescription = document.getElementById('roleDescription');
roleDescription.textContent = roleDescriptions[roleSelect.value];
console.log('✅ Admin Benutzer-Formular erfolgreich initialisiert');
});
</script>
{% endblock %}

View File

@ -91,6 +91,41 @@
if (moonIcon) moonIcon.classList.add('hidden');
}
}
// MYP App für Offline-Funktionalität initialisieren
if (typeof MYPApp !== 'undefined') {
window.mypApp = new MYPApp();
}
// Flask Flash Messages über das Glassmorphism-System anzeigen
const flashContainer = document.getElementById('flask-flash-messages');
if (flashContainer) {
const flashCount = parseInt(flashContainer.getAttribute('data-flash-count')) || 0;
for (let i = 1; i <= flashCount; i++) {
const flashData = flashContainer.getAttribute('data-flash-' + i);
if (flashData) {
const [category, message] = flashData.split('|', 2);
let messageType = category;
// Flask-Kategorien zu JavaScript-Kategorien mappen
if (messageType === 'danger') messageType = 'error';
// Nachricht über das moderne Glassmorphism-System anzeigen
if (typeof showFlashMessage === 'function') {
// Kleine Verzögerung für bessere UX
setTimeout(() => {
showFlashMessage(message, messageType, 6000);
}, i * 200); // Nachrichten gestaffelt anzeigen
}
}
}
// Container nach Verarbeitung entfernen
flashContainer.remove();
}
console.log('🚀 MYP Platform UI erfolgreich initialisiert');
});
</script>
@ -565,15 +600,15 @@
<!-- Main Content -->
<main id="main-content" class="flex-grow max-w-7xl w-full mx-auto px-3 sm:px-6 lg:px-8 py-4 sm:py-8">
<div class="container mx-auto px-4 py-8">
<!-- Flash Messages -->
<!-- Flash Messages - Modernisiert für Glassmorphism-Kompatibilität -->
{% with messages = get_flashed_messages(with_categories=true) %}
{% if messages %}
<div class="flash-messages mb-4">
<!-- Flask Flash Messages als Datenattribute für JavaScript -->
<div id="flask-flash-messages" style="display: none;"
{% for category, message in messages %}
<div class="alert alert-{{ category }} mb-2">
{{ message }}
</div>
data-flash-{{ loop.index }}="{{ category }}|{{ message | e }}"
{% endfor %}
data-flash-count="{{ messages|length }}">
</div>
{% endif %}
{% endwith %}
@ -745,6 +780,34 @@
window.mypApp = new MYPApp();
}
// Flask Flash Messages über das Glassmorphism-System anzeigen
const flashContainer = document.getElementById('flask-flash-messages');
if (flashContainer) {
const flashCount = parseInt(flashContainer.getAttribute('data-flash-count')) || 0;
for (let i = 1; i <= flashCount; i++) {
const flashData = flashContainer.getAttribute('data-flash-' + i);
if (flashData) {
const [category, message] = flashData.split('|', 2);
let messageType = category;
// Flask-Kategorien zu JavaScript-Kategorien mappen
if (messageType === 'danger') messageType = 'error';
// Nachricht über das moderne Glassmorphism-System anzeigen
if (typeof showFlashMessage === 'function') {
// Kleine Verzögerung für bessere UX
setTimeout(() => {
showFlashMessage(message, messageType, 6000);
}, i * 200); // Nachrichten gestaffelt anzeigen
}
}
}
// Container nach Verarbeitung entfernen
flashContainer.remove();
}
console.log('🚀 MYP Platform UI erfolgreich initialisiert');
});
</script>

View File

@ -0,0 +1,25 @@
"""
Backup Manager - Datensicherungsverwaltung
Minimal implementation to resolve import dependencies.
"""
from utils.logging_config import get_logger
backup_logger = get_logger("backup")
class BackupManager:
"""Minimale BackupManager-Implementierung"""
def __init__(self):
self.enabled = False
backup_logger.info("BackupManager initialisiert (minimal implementation)")
def create_backup(self, backup_type="manual"):
"""Erstellt ein Backup (Placeholder)"""
backup_logger.info(f"Backup-Erstellung angefordert: {backup_type}")
return {"success": False, "message": "Backup-Funktionalität nicht implementiert"}
def restore_backup(self, backup_path):
"""Stellt ein Backup wieder her (Placeholder)"""
backup_logger.info(f"Backup-Wiederherstellung angefordert: {backup_path}")
return {"success": False, "message": "Restore-Funktionalität nicht implementiert"}