🎉 Refactor Backend Database Files & Cleanup 🗑️

This commit is contained in:
Till Tomczak 2025-05-31 23:12:03 +02:00
parent d53ce33bab
commit 5f1b0c63e1
13 changed files with 1952 additions and 819 deletions

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

View File

@ -71133,3 +71133,888 @@ WHERE users.id = ?
2025-05-31 21:43:45 - myp.app - INFO - 🔄 Beende Queue Manager...
2025-05-31 21:43:45 - myp.app - WARNING - 🛑 Signal 2 empfangen - fahre System herunter...
2025-05-31 21:43:45 - myp.app - INFO - 🔄 Beende Queue Manager...
2025-05-31 22:50:38 - myp.windows_fixes - INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-05-31 22:50:38 - myp.windows_fixes - INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-05-31 22:50:38 - myp.windows_fixes - INFO - ✅ Globaler subprocess-Patch angewendet
2025-05-31 22:50:38 - myp.windows_fixes - INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-05-31 22:50:38 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-05-31 22:50:39 - myp.printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-05-31 22:50:39 - myp.printer_monitor - INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-05-31 22:50:39 - myp.database - INFO - Datenbank-Wartungs-Scheduler gestartet
2025-05-31 22:50:39 - myp.analytics - INFO - 📈 Analytics Engine initialisiert
2025-05-31 22:50:39 - myp.security - INFO - 🔒 Security System initialisiert
2025-05-31 22:50:39 - myp.permissions - INFO - 🔐 Permission Template Helpers registriert
2025-05-31 22:50:39 - myp.app - INFO - ==================================================
2025-05-31 22:50:39 - myp.app - INFO - [START] MYP (Manage Your Printers) wird gestartet...
2025-05-31 22:50:39 - myp.app - INFO - [FOLDER] Log-Verzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\logs
2025-05-31 22:50:39 - myp.app - INFO - [CHART] Log-Level: INFO
2025-05-31 22:50:39 - myp.app - INFO - [PC] Betriebssystem: Windows 11
2025-05-31 22:50:39 - myp.app - INFO - [WEB] Hostname: C040L0079726760
2025-05-31 22:50:39 - myp.app - INFO - [TIME] Startzeit: 31.05.2025 22:50:39
2025-05-31 22:50:39 - myp.app - INFO - ==================================================
2025-05-31 22:50:39 - myp.app - INFO - SQLite für Produktionsumgebung konfiguriert (WAL-Modus, Cache, Optimierungen)
2025-05-31 22:50:39 - myp.app - INFO - Datenbank mit Optimierungen initialisiert
2025-05-31 22:50:40 - myp.app - INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-05-31 22:50:40 - myp.app - INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-05-31 22:50:40 - myp.printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-05-31 22:50:40 - myp.printer_monitor - WARNING - ⚠️ Keine aktiven Drucker zur Initialisierung gefunden
2025-05-31 22:50:40 - myp.app - INFO - Keine Drucker zur Initialisierung gefunden
2025-05-31 22:50:40 - myp.app - INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-05-31 22:50:40 - myp.app - INFO - Job-Scheduler gestartet
2025-05-31 22:50:40 - myp.app - INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-05-31 22:50:40 - myp.app - INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-05-31 22:50:40 - 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-05-31 22:50:40 - werkzeug - INFO - Press CTRL+C to quit
2025-05-31 22:50:41 - myp.printer_monitor - INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-05-31 22:50:41 - myp.printer_monitor - INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-05-31 22:50:41 - myp.printer_monitor - INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-05-31 22:50:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:41] "GET / HTTP/1.1" 302 -
2025-05-31 22:50:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:41] "GET /auth/login HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/css/components.css HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/css/professional-theme.css HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/optimization-features.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/job-manager.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/ui-components.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/css/tailwind.min.css HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/offline-app.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/debug-fix.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/csp-violation-handler.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/dark-mode-fix.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/global-refresh-functions.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/event-handlers.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/js/printer_monitor.js HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/manifest.json HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/favicon.svg HTTP/1.1" 200 -
2025-05-31 22:50:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:50:42] "GET /static/icons/icon-144x144.png HTTP/1.1" 200 -
2025-05-31 22:50:47 - myp.printer_monitor - INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-05-31 22:50:53 - myp.printer_monitor - INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-05-31 22:50:59 - myp.printer_monitor - INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-05-31 22:51:05 - myp.printer_monitor - INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-05-31 22:51:06 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:06] "POST /auth/login HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET / HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/notifications.js HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/session-manager.js HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/js/auto-logout.js HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:08 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:08] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:51:09 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:09] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 22:51:11 - myp.printer_monitor - INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-05-31 22:51:17 - myp.printer_monitor - INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s
2025-05-31 22:51:30 - myp.app - INFO - Benutzer admin@mercedes-benz.com hat sich abgemeldet
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "POST /auth/logout HTTP/1.1" 302 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /auth/login HTTP/1.1" 200 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/css/components.css HTTP/1.1" 200 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:30 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:30] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET / HTTP/1.1" 302 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /auth/login HTTP/1.1" 200 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:42] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:51:44 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:44] "POST /auth/login HTTP/1.1" 200 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET / HTTP/1.1" 200 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:51:45 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:45] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:46] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:51:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:47] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /admin-dashboard HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/admin.js HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/admin-system.js HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/admin-live.js HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/js/admin-dashboard.js HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 22:51:49 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 22:51:49 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 22:51:49 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 22:51:49 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/stats HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /api/stats HTTP/1.1" 200 -
2025-05-31 22:51:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:49] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:51:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:50] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 22:51:50 - myp.app - ERROR - Fehler beim System-Gesundheitscheck: argument 1 (impossible<bad format char>)
2025-05-31 22:51:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:50] "GET /api/admin/system-health HTTP/1.1" 500 -
2025-05-31 22:51:57 - myp.app - INFO - Benutzer admin@mercedes-benz.com hat sich abgemeldet
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "POST /auth/logout HTTP/1.1" 302 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /auth/login HTTP/1.1" 200 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:51:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:51:57] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /request HTTP/1.1" 200 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:52:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:52:01] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:53:05 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:05] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:06 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:06] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 22:53:07 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:07] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:53:48 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:48] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:49] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /request HTTP/1.1" 200 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 22:53:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:53:50] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /request HTTP/1.1" 200 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 22:54:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:21] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /requests/overview HTTP/1.1" 200 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:54:39 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:39] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /stats HTTP/1.1" 302 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /auth/login?next=/stats HTTP/1.1" 200 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:54:53 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:53] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:54:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:55] "POST /auth/login HTTP/1.1" 200 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET / HTTP/1.1" 200 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - myp.app - WARNING - Schema-Problem beim User-Load für ID 1: (sqlite3.InterfaceError) bad parameter or other API misuse
[SQL: SELECT users.id AS users_id, users.email AS users_email, users.username AS users_username, users.password_hash AS users_password_hash, users.name AS users_name, users.role AS users_role, users.active AS users_active, users.created_at AS users_created_at, users.last_login AS users_last_login, users.updated_at AS users_updated_at, users.settings AS users_settings, users.last_activity AS users_last_activity, users.department AS users_department, users.position AS users_position, users.phone AS users_phone, users.bio AS users_bio
FROM users
WHERE users.id = ?
LIMIT ? OFFSET ?]
[parameters: (1, 1, 0)]
(Background on this error at: https://sqlalche.me/e/20/rvf5)
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /api/notifications HTTP/1.1" 302 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /auth/login?next=/api/notifications HTTP/1.1" 302 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET / HTTP/1.1" 200 -
2025-05-31 22:54:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:57] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:54:58 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:54:58] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 22:55:27 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:27] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:55:27 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:27] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:55:27 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:27] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:55:32 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:32] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:55:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:37] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET / HTTP/1.1" 200 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 22:55:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:41] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 22:55:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:55:42] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 22:56:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:56:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:56:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:56:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:16] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:56:21 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:21] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:56:26 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:26] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:56:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:56:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:56:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:56:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:57:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:57:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:57:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:57:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:57:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:57:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:57:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:58:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:58:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:58:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:58:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:58:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:58:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:58:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:59:11 - myp.app - WARNING - Schema-Problem beim User-Load für ID 1: tuple index out of range
2025-05-31 22:59:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:59:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:59:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 22:59:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 22:59:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 22:59:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 22:59:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:00:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:00:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:00:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:00:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:00:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:00:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:00:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:00:41] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET / HTTP/1.1" 200 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 23:01:00 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:00] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:01:01 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:01] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET / HTTP/1.1" 200 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:01:12 - myp.app - WARNING - Schema-Problem beim User-Load für ID 1: tuple index out of range
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 23:01:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:12] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:01:13 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:13] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:01:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:42] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:42] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:01:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:42] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:01:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:47] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:52 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:52] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:01:57 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:01:57] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:02:12 - myp.app - WARNING - 🛑 Signal 2 empfangen - fahre System herunter...
2025-05-31 23:02:12 - myp.app - INFO - 🔄 Beende Queue Manager...
2025-05-31 23:02:12 - myp.app - INFO - Job-Scheduler gestoppt
2025-05-31 23:02:12 - myp.app - INFO - 💾 Führe Datenbank-Cleanup durch...
2025-05-31 23:02:12 - myp.app - INFO - 📝 Führe WAL-Checkpoint durch...
2025-05-31 23:02:12 - myp.app - INFO - WAL-Checkpoint abgeschlossen: 0 Seiten übertragen, 0 Seiten zurückgesetzt
2025-05-31 23:02:12 - myp.app - INFO - 📁 Schalte Journal-Mode um...
2025-05-31 23:02:12 - myp.app - INFO - ✅ Datenbank-Cleanup abgeschlossen - WAL-Dateien sollten verschwunden sein
2025-05-31 23:02:12 - myp.app - INFO - ✅ Shutdown abgeschlossen
2025-05-31 23:02:14 - myp.windows_fixes - INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-05-31 23:02:14 - myp.windows_fixes - INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-05-31 23:02:14 - myp.windows_fixes - INFO - ✅ Globaler subprocess-Patch angewendet
2025-05-31 23:02:14 - myp.windows_fixes - INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-05-31 23:02:14 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-05-31 23:02:14 - myp.printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-05-31 23:02:14 - myp.printer_monitor - INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-05-31 23:02:14 - myp.database - INFO - Datenbank-Wartungs-Scheduler gestartet
2025-05-31 23:02:14 - myp.analytics - INFO - 📈 Analytics Engine initialisiert
2025-05-31 23:02:14 - myp.security - INFO - 🔒 Security System initialisiert
2025-05-31 23:02:14 - myp.permissions - INFO - 🔐 Permission Template Helpers registriert
2025-05-31 23:02:14 - myp.app - INFO - ==================================================
2025-05-31 23:02:14 - myp.app - INFO - [START] MYP (Manage Your Printers) wird gestartet...
2025-05-31 23:02:14 - myp.app - INFO - [FOLDER] Log-Verzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\logs
2025-05-31 23:02:14 - myp.app - INFO - [CHART] Log-Level: INFO
2025-05-31 23:02:14 - myp.app - INFO - [PC] Betriebssystem: Windows 11
2025-05-31 23:02:14 - myp.app - INFO - [WEB] Hostname: C040L0079726760
2025-05-31 23:02:14 - myp.app - INFO - [TIME] Startzeit: 31.05.2025 23:02:14
2025-05-31 23:02:14 - myp.app - INFO - ==================================================
2025-05-31 23:02:14 - myp.app - INFO - SQLite für Produktionsumgebung konfiguriert (WAL-Modus, Cache, Optimierungen)
2025-05-31 23:02:14 - myp.app - INFO - Datenbank mit Optimierungen initialisiert
2025-05-31 23:02:14 - myp.app - INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-05-31 23:02:14 - myp.app - INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-05-31 23:02:14 - myp.printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-05-31 23:02:14 - myp.printer_monitor - WARNING - ⚠️ Keine aktiven Drucker zur Initialisierung gefunden
2025-05-31 23:02:14 - myp.app - INFO - Keine Drucker zur Initialisierung gefunden
2025-05-31 23:02:14 - myp.app - INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-05-31 23:02:14 - myp.app - INFO - Job-Scheduler gestartet
2025-05-31 23:02:14 - myp.app - INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-05-31 23:02:14 - myp.app - INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-05-31 23:02:14 - 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-05-31 23:02:14 - werkzeug - INFO - Press CTRL+C to quit
2025-05-31 23:02:15 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:15] "GET / HTTP/1.1" 200 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 23:02:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:16] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:02:16 - myp.printer_monitor - INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-05-31 23:02:16 - myp.printer_monitor - INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-05-31 23:02:16 - myp.printer_monitor - INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-05-31 23:02:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:17] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:02:21 - myp.app - WARNING - 🛑 Signal 2 empfangen - fahre System herunter...
2025-05-31 23:02:21 - myp.app - INFO - 🔄 Beende Queue Manager...
2025-05-31 23:02:21 - myp.app - INFO - Job-Scheduler gestoppt
2025-05-31 23:02:21 - myp.app - INFO - 💾 Führe Datenbank-Cleanup durch...
2025-05-31 23:02:21 - myp.app - INFO - 📝 Führe WAL-Checkpoint durch...
2025-05-31 23:02:21 - myp.app - INFO - WAL-Checkpoint abgeschlossen: 0 Seiten übertragen, 0 Seiten zurückgesetzt
2025-05-31 23:02:21 - myp.app - INFO - 📁 Schalte Journal-Mode um...
2025-05-31 23:02:21 - myp.app - INFO - ✅ Datenbank-Cleanup abgeschlossen - WAL-Dateien sollten verschwunden sein
2025-05-31 23:02:21 - myp.app - INFO - ✅ Shutdown abgeschlossen
2025-05-31 23:02:33 - myp.windows_fixes - INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-05-31 23:02:33 - myp.windows_fixes - INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-05-31 23:02:33 - myp.windows_fixes - INFO - ✅ Globaler subprocess-Patch angewendet
2025-05-31 23:02:33 - myp.windows_fixes - INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-05-31 23:02:33 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-05-31 23:02:33 - myp.printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-05-31 23:02:33 - myp.printer_monitor - INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-05-31 23:02:33 - myp.database - INFO - Datenbank-Wartungs-Scheduler gestartet
2025-05-31 23:02:33 - myp.analytics - INFO - 📈 Analytics Engine initialisiert
2025-05-31 23:02:33 - myp.security - INFO - 🔒 Security System initialisiert
2025-05-31 23:02:33 - myp.permissions - INFO - 🔐 Permission Template Helpers registriert
2025-05-31 23:02:33 - myp.app - INFO - ==================================================
2025-05-31 23:02:33 - myp.app - INFO - [START] MYP (Manage Your Printers) wird gestartet...
2025-05-31 23:02:33 - myp.app - INFO - [FOLDER] Log-Verzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\logs
2025-05-31 23:02:33 - myp.app - INFO - [CHART] Log-Level: INFO
2025-05-31 23:02:33 - myp.app - INFO - [PC] Betriebssystem: Windows 11
2025-05-31 23:02:33 - myp.app - INFO - [WEB] Hostname: C040L0079726760
2025-05-31 23:02:33 - myp.app - INFO - [TIME] Startzeit: 31.05.2025 23:02:33
2025-05-31 23:02:33 - myp.app - INFO - ==================================================
2025-05-31 23:02:33 - myp.app - INFO - SQLite für Produktionsumgebung konfiguriert (WAL-Modus, Cache, Optimierungen)
2025-05-31 23:02:33 - myp.app - INFO - Datenbank mit Optimierungen initialisiert
2025-05-31 23:02:34 - myp.app - INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-05-31 23:02:34 - myp.app - INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-05-31 23:02:34 - myp.printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-05-31 23:02:34 - myp.printer_monitor - WARNING - ⚠️ Keine aktiven Drucker zur Initialisierung gefunden
2025-05-31 23:02:34 - myp.app - INFO - Keine Drucker zur Initialisierung gefunden
2025-05-31 23:02:34 - myp.app - INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-05-31 23:02:34 - myp.app - INFO - Job-Scheduler gestartet
2025-05-31 23:02:34 - myp.app - INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-05-31 23:02:34 - myp.app - INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-05-31 23:02:34 - 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-05-31 23:02:34 - werkzeug - INFO - Press CTRL+C to quit
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET / HTTP/1.1" 200 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/css/tailwind.min.css HTTP/1.1" 200 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/favicon.svg HTTP/1.1" 304 -
2025-05-31 23:02:35 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:35] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:02:35 - myp.printer_monitor - INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-05-31 23:02:35 - myp.printer_monitor - INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-05-31 23:02:35 - myp.printer_monitor - INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-05-31 23:02:36 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:02:36] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:02:41 - myp.printer_monitor - INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-05-31 23:02:47 - myp.printer_monitor - INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-05-31 23:02:53 - myp.printer_monitor - INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-05-31 23:02:59 - myp.printer_monitor - INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-05-31 23:03:05 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:05] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:03:05 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:05] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:03:05 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:05] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:03:05 - myp.printer_monitor - INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-05-31 23:03:10 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:10] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:03:11 - myp.printer_monitor - INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s
2025-05-31 23:03:15 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:15] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /dashboard HTTP/1.1" 200 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:03:16 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:16] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:03:17 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:03:17 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:17 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:17 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:03:17 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:17] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:03:18 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:18] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:03:34 - myp.app - WARNING - 🛑 Signal 2 empfangen - fahre System herunter...
2025-05-31 23:03:34 - myp.app - INFO - 🔄 Beende Queue Manager...
2025-05-31 23:03:35 - myp.app - INFO - Job-Scheduler gestoppt
2025-05-31 23:03:35 - myp.app - INFO - 💾 Führe Datenbank-Cleanup durch...
2025-05-31 23:03:35 - myp.app - INFO - 📝 Führe WAL-Checkpoint durch...
2025-05-31 23:03:35 - myp.app - INFO - WAL-Checkpoint abgeschlossen: 0 Seiten übertragen, 0 Seiten zurückgesetzt
2025-05-31 23:03:35 - myp.app - INFO - 📁 Schalte Journal-Mode um...
2025-05-31 23:03:35 - myp.app - INFO - ✅ Datenbank-Cleanup abgeschlossen - WAL-Dateien sollten verschwunden sein
2025-05-31 23:03:35 - myp.app - INFO - ✅ Shutdown abgeschlossen
2025-05-31 23:03:45 - myp.windows_fixes - INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-05-31 23:03:45 - myp.windows_fixes - INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-05-31 23:03:45 - myp.windows_fixes - INFO - ✅ Globaler subprocess-Patch angewendet
2025-05-31 23:03:45 - myp.windows_fixes - INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-05-31 23:03:45 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-05-31 23:03:45 - myp.printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-05-31 23:03:45 - myp.printer_monitor - INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-05-31 23:03:45 - myp.database - INFO - Datenbank-Wartungs-Scheduler gestartet
2025-05-31 23:03:45 - myp.analytics - INFO - 📈 Analytics Engine initialisiert
2025-05-31 23:03:45 - myp.security - INFO - 🔒 Security System initialisiert
2025-05-31 23:03:45 - myp.permissions - INFO - 🔐 Permission Template Helpers registriert
2025-05-31 23:03:45 - myp.app - INFO - ==================================================
2025-05-31 23:03:45 - myp.app - INFO - [START] MYP (Manage Your Printers) wird gestartet...
2025-05-31 23:03:45 - myp.app - INFO - [FOLDER] Log-Verzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\logs
2025-05-31 23:03:45 - myp.app - INFO - [CHART] Log-Level: INFO
2025-05-31 23:03:45 - myp.app - INFO - [PC] Betriebssystem: Windows 11
2025-05-31 23:03:45 - myp.app - INFO - [WEB] Hostname: C040L0079726760
2025-05-31 23:03:45 - myp.app - INFO - [TIME] Startzeit: 31.05.2025 23:03:45
2025-05-31 23:03:45 - myp.app - INFO - ==================================================
2025-05-31 23:03:45 - myp.app - INFO - SQLite für Produktionsumgebung konfiguriert (WAL-Modus, Cache, Optimierungen)
2025-05-31 23:03:45 - myp.app - INFO - Datenbank mit Optimierungen initialisiert
2025-05-31 23:03:46 - myp.app - INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-05-31 23:03:46 - myp.app - INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-05-31 23:03:46 - myp.printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-05-31 23:03:46 - myp.printer_monitor - WARNING - ⚠️ Keine aktiven Drucker zur Initialisierung gefunden
2025-05-31 23:03:46 - myp.app - INFO - Keine Drucker zur Initialisierung gefunden
2025-05-31 23:03:46 - myp.app - INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-05-31 23:03:46 - myp.app - INFO - Job-Scheduler gestartet
2025-05-31 23:03:46 - myp.app - INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-05-31 23:03:46 - myp.app - INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-05-31 23:03:46 - 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-05-31 23:03:46 - werkzeug - INFO - Press CTRL+C to quit
2025-05-31 23:03:47 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:47 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:47] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:03:47 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:47 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:47] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-05-31 23:03:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:47] "POST /api/dashboard/refresh HTTP/1.1" 404 -
2025-05-31 23:03:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:47] "POST /api/dashboard/refresh HTTP/1.1" 404 -
2025-05-31 23:03:47 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:47] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:03:47 - myp.printer_monitor - INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-05-31 23:03:47 - myp.printer_monitor - INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-05-31 23:03:47 - myp.printer_monitor - INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-05-31 23:03:48 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:48] "POST /api/dashboard/refresh HTTP/1.1" 404 -
2025-05-31 23:03:48 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:48] "POST /api/dashboard/refresh HTTP/1.1" 404 -
2025-05-31 23:03:48 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:48] "POST /api/dashboard/refresh HTTP/1.1" 404 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /dashboard HTTP/1.1" 200 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/css/components.css HTTP/1.1" 200 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/css/tailwind.min.css HTTP/1.1" 200 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:03:49 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:03:49 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:49 - myp.printer_monitor - INFO - 🔄 Aktualisiere Live-Druckerstatus...
2025-05-31 23:03:49 - myp.printer_monitor - INFO - Keine aktiven Drucker gefunden
2025-05-31 23:03:49 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:49] "GET /api/printers/monitor/live-status?use_cache=true HTTP/1.1" 200 -
2025-05-31 23:03:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:50] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:03:50 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:50] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:03:51 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:51] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:03:53 - myp.printer_monitor - INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-05-31 23:03:54 - myp.app - INFO - Benutzer admin@mercedes-benz.com hat sich abgemeldet
2025-05-31 23:03:54 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:54] "POST /auth/logout HTTP/1.1" 302 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /auth/login HTTP/1.1" 200 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:03:55 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:03:55] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:03:59 - myp.printer_monitor - INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-05-31 23:04:05 - myp.printer_monitor - INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-05-31 23:04:09 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:09] "POST /auth/login HTTP/1.1" 200 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET / HTTP/1.1" 200 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/css/tailwind.min.css HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/css/components.css HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/css/professional-theme.css HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/ui-components.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/offline-app.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/optimization-features.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/debug-fix.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/job-manager.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/dark-mode-fix.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/global-refresh-functions.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/event-handlers.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/csp-violation-handler.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/printer_monitor.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/notifications.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/session-manager.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/js/auto-logout.js HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/iso-27001.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/mercedes-star.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/gdpr.svg HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /api/user/settings HTTP/1.1" 200 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/manifest.json HTTP/1.1" 304 -
2025-05-31 23:04:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:11] "GET /static/icons/icon-144x144.png HTTP/1.1" 304 -
2025-05-31 23:04:11 - myp.printer_monitor - INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-05-31 23:04:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:12] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:04:17 - myp.printer_monitor - INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-05-31 23:04:23 - myp.printer_monitor - INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s
2025-05-31 23:04:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:04:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:04:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:04:46 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:46] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:04:51 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:51] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:04:56 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:04:56] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:05:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:05:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:05:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:05:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:05:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:05:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:05:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:06:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:06:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:06:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:06:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:41] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:06:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:41] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:06:41 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:06:41] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:07:11 - myp.app - WARNING - Schema-Problem beim User-Load für ID 1: tuple index out of range
2025-05-31 23:07:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:11] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:07:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:11] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:07:11 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:11] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:07:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:42] "GET /api/session/status HTTP/1.1" 302 -
2025-05-31 23:07:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:42] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:07:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:42] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:07:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:42] "GET /auth/login?next=/api/session/status HTTP/1.1" 302 -
2025-05-31 23:07:42 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:07:42] "GET / HTTP/1.1" 200 -
2025-05-31 23:08:12 - myp.app - WARNING - Schema-Problem beim User-Load für ID 1: tuple index out of range
2025-05-31 23:08:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:08:12] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:08:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:08:12] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:08:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:08:12] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:09:12 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:09:12] "POST /api/session/heartbeat HTTP/1.1" 200 -
2025-05-31 23:09:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:09:37] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:09:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:09:37] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:09:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:09:37] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:10:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:10:37] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:10:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:10:37] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:10:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:10:37] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:11:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:11:37] "GET /api/notifications HTTP/1.1" 200 -
2025-05-31 23:11:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:11:37] "GET /api/session/status HTTP/1.1" 200 -
2025-05-31 23:11:37 - werkzeug - INFO - 127.0.0.1 - - [31/May/2025 23:11:37] "GET /api/statistics/public HTTP/1.1" 404 -
2025-05-31 23:11:57 - myp.app - INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db

View File

@ -27,3 +27,12 @@
2025-05-31 18:07:50 - myp.auth - WARNING - JSON-Parsing fehlgeschlagen: 400 Bad Request: The browser (or proxy) sent a request that this server could not understand.
2025-05-31 18:07:50 - myp.auth - INFO - Benutzer admin@mercedes-benz.com hat sich erfolgreich angemeldet
2025-05-31 18:07:51 - myp.auth - INFO - 🔐 Neue Session erstellt für Benutzer admin@mercedes-benz.com von IP 127.0.0.1
2025-05-31 22:51:06 - myp.auth - WARNING - JSON-Parsing fehlgeschlagen: 400 Bad Request: Failed to decode JSON object: Expecting value: line 1 column 1 (char 0)
2025-05-31 22:51:06 - myp.auth - INFO - Benutzer admin@mercedes-benz.com hat sich erfolgreich angemeldet
2025-05-31 22:51:08 - myp.auth - INFO - 🔐 Neue Session erstellt für Benutzer admin@mercedes-benz.com von IP 127.0.0.1
2025-05-31 22:51:44 - myp.auth - WARNING - JSON-Parsing fehlgeschlagen: 400 Bad Request: Failed to decode JSON object: Expecting value: line 1 column 1 (char 0)
2025-05-31 22:51:44 - myp.auth - INFO - Benutzer admin@mercedes-benz.com hat sich erfolgreich angemeldet
2025-05-31 22:54:55 - myp.auth - WARNING - JSON-Parsing fehlgeschlagen: 400 Bad Request: Failed to decode JSON object: Expecting value: line 1 column 1 (char 0)
2025-05-31 22:54:55 - myp.auth - INFO - Benutzer admin@mercedes-benz.com hat sich erfolgreich angemeldet
2025-05-31 23:04:09 - myp.auth - WARNING - JSON-Parsing fehlgeschlagen: 400 Bad Request: Failed to decode JSON object: Expecting value: line 1 column 1 (char 0)
2025-05-31 23:04:09 - myp.auth - INFO - Benutzer admin@mercedes-benz.com hat sich erfolgreich angemeldet

View File

@ -1707,3 +1707,4 @@ information about how to avoid this problem.
2025-05-31 21:43:39 - myp.scheduler - ERROR - ❌ Konnte Steckdose für Sofort-Job 2 nicht einschalten
2025-05-31 21:43:42 - myp.scheduler - ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x7fd976d9a810>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-05-31 21:43:42 - myp.scheduler - ERROR - ❌ Konnte Steckdose für Sofort-Job 3 nicht einschalten
2025-05-31 22:51:50 - myp.app - ERROR - Fehler beim System-Gesundheitscheck: argument 1 (impossible<bad format char>)

View File

@ -2461,3 +2461,11 @@
2025-05-31 18:08:37 - myp.printers - WARNING - [SCHED] Langsame Ausführung: API-Live-Drucker-Status-Abfrage - 9036.76 ms
2025-05-31 18:08:45 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 1 Drucker
2025-05-31 18:08:45 - myp.printers - WARNING - [SCHED] Langsame Ausführung: API-Live-Drucker-Status-Abfrage - 9035.70 ms
2025-05-31 22:51:49 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-05-31 22:51:49 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-05-31 23:03:17 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-05-31 23:03:17 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-05-31 23:03:47 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-05-31 23:03:47 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker
2025-05-31 23:03:49 - myp.printers - INFO - 🔄 Live-Status-Abfrage von Benutzer Administrator (ID: 1)
2025-05-31 23:03:49 - myp.printers - INFO - ✅ Live-Status-Abfrage erfolgreich: 0 Drucker

View File

@ -2647,3 +2647,21 @@
2025-05-31 21:43:39 - myp.scheduler - INFO - ⚡ Starte Sofort-Job 3: teste
2025-05-31 21:43:42 - myp.scheduler - ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x7fd976d9a810>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-05-31 21:43:42 - myp.scheduler - ERROR - ❌ Konnte Steckdose für Sofort-Job 3 nicht einschalten
2025-05-31 22:50:39 - myp.scheduler - INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-05-31 22:50:40 - myp.scheduler - INFO - Scheduler-Thread gestartet
2025-05-31 22:50:40 - myp.scheduler - INFO - Scheduler gestartet
2025-05-31 23:02:12 - myp.scheduler - INFO - Scheduler-Thread beendet
2025-05-31 23:02:12 - myp.scheduler - INFO - Scheduler gestoppt
2025-05-31 23:02:14 - myp.scheduler - INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-05-31 23:02:14 - myp.scheduler - INFO - Scheduler-Thread gestartet
2025-05-31 23:02:14 - myp.scheduler - INFO - Scheduler gestartet
2025-05-31 23:02:21 - myp.scheduler - INFO - Scheduler-Thread beendet
2025-05-31 23:02:21 - myp.scheduler - INFO - Scheduler gestoppt
2025-05-31 23:02:33 - myp.scheduler - INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-05-31 23:02:34 - myp.scheduler - INFO - Scheduler-Thread gestartet
2025-05-31 23:02:34 - myp.scheduler - INFO - Scheduler gestartet
2025-05-31 23:03:35 - myp.scheduler - INFO - Scheduler-Thread beendet
2025-05-31 23:03:35 - myp.scheduler - INFO - Scheduler gestoppt
2025-05-31 23:03:45 - myp.scheduler - INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-05-31 23:03:46 - myp.scheduler - INFO - Scheduler-Thread gestartet
2025-05-31 23:03:46 - myp.scheduler - INFO - Scheduler gestartet

View File

@ -1,103 +1,33 @@
/**
* MYP Platform Komponenten-Bibliothek
* Erweiterte UI-Komponenten basierend auf Tailwind CSS
* RESPONSIVE DESIGN OPTIMIERT FÜR ALLE BILDSCHIRMGROSSEN
*/
@layer components {
/* ===== RESPONSIVE FOUNDATION STYLES ===== */
/* Base responsive container */
.responsive-container {
@apply w-full max-w-none mx-auto px-3 sm:px-4 md:px-6 lg:px-8 xl:px-12;
}
/* Responsive grid system */
.responsive-grid {
@apply grid gap-3 sm:gap-4 md:gap-6 lg:gap-8;
grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}
.responsive-grid-2 {
@apply grid gap-3 sm:gap-4 md:gap-6 grid-cols-1 sm:grid-cols-2;
}
.responsive-grid-3 {
@apply grid gap-3 sm:gap-4 md:gap-6 grid-cols-1 sm:grid-cols-2 lg:grid-cols-3;
}
.responsive-grid-4 {
@apply grid gap-3 sm:gap-4 md:gap-6 grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4;
}
/* ===== PROFESSIONELLE MERCEDES-BENZ KARTEN - RESPONSIVE ===== */
/* Professionelle Mercedes-Benz Karten und Container */
.card {
@apply bg-white dark:bg-slate-900 rounded-lg sm:rounded-xl shadow-mobile sm:shadow-tablet lg:shadow-desktop border border-slate-200 dark:border-slate-700 p-3 sm:p-4 md:p-6 m-2 sm:m-3 md:m-4 transition-all duration-300;
@apply bg-white dark:bg-slate-900 rounded-xl shadow-lg border border-slate-200 dark:border-slate-700 p-6 m-4 transition-all duration-300;
}
.card-hover {
@apply hover:shadow-xl hover:shadow-slate-300/50 dark:hover:shadow-slate-900/50 hover:bg-slate-50 dark:hover:bg-slate-800 transform hover:-translate-y-1 transition-all duration-300;
}
/* Responsive dashboard card */
.dashboard-card {
@apply bg-white dark:bg-slate-900 rounded-lg sm:rounded-xl md:rounded-2xl shadow-mobile sm:shadow-tablet lg:shadow-desktop border border-slate-200 dark:border-slate-700 p-3 sm:p-4 md:p-6 lg:p-8 transition-all duration-300;
}
.container-panel {
@apply bg-slate-50 dark:bg-slate-800 rounded-lg sm:rounded-xl p-3 sm:p-4 md:p-6 m-2 sm:m-3 md:m-4 border border-slate-200 dark:border-slate-700 shadow-sm;
@apply bg-slate-50 dark:bg-slate-800 rounded-xl p-6 m-4 border border-slate-200 dark:border-slate-700 shadow-sm;
}
/* ===== RESPONSIVE NAVIGATION ===== */
/* Professional Navigation Bar */
.navbar {
@apply bg-white/90 dark:bg-slate-900/90 backdrop-blur-md border-b border-slate-200 dark:border-slate-700 sticky top-0 z-50 transition-all duration-300;
}
/* Desktop navigation menu */
.navbar-menu-new {
@apply flex items-center space-x-1 lg:space-x-2 xl:space-x-3;
}
/* Navigation items responsive */
.nav-item {
@apply flex items-center gap-2 lg:gap-3 px-3 lg:px-4 py-2 lg:py-3 rounded-lg text-sm lg:text-base font-medium text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-800 hover:text-slate-900 dark:hover:text-white transition-all duration-300 relative;
}
.nav-item.active {
@apply bg-blue-100 dark:bg-blue-900/30 text-blue-700 dark:text-blue-300 font-semibold shadow-sm;
}
/* Mobile menu */
.mobile-menu-new {
@apply bg-white dark:bg-slate-900 border-b border-slate-200 dark:border-slate-700 backdrop-blur-md;
}
.mobile-nav-item {
@apply flex items-center gap-3 px-4 py-3 text-base font-medium text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-800 hover:text-slate-900 dark:hover:text-white transition-all duration-300 rounded-lg mx-2;
}
.mobile-nav-item.active {
@apply bg-blue-100 dark:bg-blue-900/30 text-blue-700 dark:text-blue-300 font-semibold;
}
/* Brand section responsive */
.navbar-brand {
@apply flex items-center no-underline transition-all duration-300 hover:opacity-80;
}
/* ===== RESPONSIVE FORMS ===== */
/* Professionelle Formulare */
.form-input {
@apply w-full rounded-lg sm:rounded-xl border-2 border-slate-300 dark:border-slate-600 bg-white dark:bg-slate-800 px-3 sm:px-4 py-2 sm:py-3 text-sm sm:text-base text-slate-900 dark:text-white placeholder-slate-500 dark:placeholder-slate-400 focus:border-blue-500 dark:focus:border-blue-400 focus:ring-4 focus:ring-blue-500/20 dark:focus:ring-blue-400/20 transition-all duration-300 touch-target;
@apply w-full rounded-xl border-2 border-slate-300 dark:border-slate-600 bg-white dark:bg-slate-800 px-4 py-3 text-slate-900 dark:text-white placeholder-slate-500 dark:placeholder-slate-400 focus:border-blue-500 dark:focus:border-blue-400 focus:ring-4 focus:ring-blue-500/20 dark:focus:ring-blue-400/20 transition-all duration-300;
}
.form-label {
@apply block text-xs sm:text-sm font-semibold text-slate-700 dark:text-slate-300 mb-1 sm:mb-2 transition-colors duration-300;
@apply block text-sm font-semibold text-slate-700 dark:text-slate-300 mb-2 transition-colors duration-300;
}
.form-group {
@apply mb-4 sm:mb-6;
@apply mb-6;
}
.form-help {
@ -108,13 +38,13 @@
@apply mt-1 text-xs text-red-600 dark:text-red-400 font-medium transition-colors duration-300;
}
/* ===== RESPONSIVE BUTTONS ===== */
/* Professionelle Buttons */
.btn-icon {
@apply inline-flex items-center justify-center rounded-lg sm:rounded-xl p-2 sm:p-3 transition-all duration-300 shadow-mobile sm:shadow-tablet hover:shadow-lg touch-target;
@apply inline-flex items-center justify-center rounded-xl p-3 transition-all duration-300 shadow-md hover:shadow-lg;
}
.btn-text {
@apply inline-flex items-center justify-center gap-2 rounded-lg sm:rounded-xl px-4 sm:px-6 py-2 sm:py-3 text-xs sm:text-sm font-semibold transition-all duration-300 shadow-mobile sm:shadow-tablet hover:shadow-lg touch-target;
@apply inline-flex items-center justify-center gap-2 rounded-xl px-6 py-3 text-sm font-semibold transition-all duration-300 shadow-md hover:shadow-lg;
}
.btn-rounded {
@ -122,16 +52,16 @@
}
.btn-sm {
@apply px-3 sm:px-4 py-1.5 sm:py-2 text-xs;
@apply px-4 py-2 text-xs;
}
.btn-lg {
@apply px-6 sm:px-8 py-3 sm:py-4 text-sm sm:text-base;
@apply px-8 py-4 text-base;
}
/* ===== RESPONSIVE BADGES ===== */
/* Professionelle Badges und Tags */
.badge {
@apply inline-flex items-center rounded-full px-2 sm:px-3 py-1 sm:py-1.5 text-xs font-semibold transition-all duration-300 shadow-sm;
@apply inline-flex items-center rounded-full px-3 py-1.5 text-xs font-semibold transition-all duration-300 shadow-sm;
}
.badge-blue {
@ -154,9 +84,9 @@
@apply bg-purple-100 text-purple-800 border border-purple-200 dark:bg-purple-900/30 dark:text-purple-300 dark:border-purple-700;
}
/* ===== RESPONSIVE STATUS INDICATORS ===== */
/* Erweiterte Status Anzeigen */
.status-dot {
@apply relative flex h-2 w-2 sm:h-3 sm:w-3 rounded-full shadow-sm;
@apply relative flex h-3 w-3 rounded-full shadow-sm;
}
.status-dot::after {
@ -183,13 +113,13 @@
@apply bg-yellow-500 dark:bg-yellow-400;
}
/* ===== RESPONSIVE TABLES ===== */
/* Professionelle Tabellen */
.table-container {
@apply w-full overflow-x-auto rounded-lg sm:rounded-xl border border-slate-200 dark:border-slate-700 shadow-mobile sm:shadow-tablet lg:shadow-desktop bg-white dark:bg-slate-900;
@apply w-full overflow-x-auto rounded-xl border border-slate-200 dark:border-slate-700 shadow-lg bg-white dark:bg-slate-900;
}
.table-styled {
@apply w-full whitespace-nowrap text-left text-xs sm:text-sm text-slate-700 dark:text-slate-300;
@apply w-full whitespace-nowrap text-left text-sm text-slate-700 dark:text-slate-300;
}
.table-styled thead {
@ -197,7 +127,7 @@
}
.table-styled th {
@apply px-3 sm:px-6 py-2 sm:py-4 font-semibold text-slate-900 dark:text-white transition-colors duration-300 text-xs sm:text-sm;
@apply px-6 py-4 font-semibold text-slate-900 dark:text-white transition-colors duration-300;
}
.table-styled tbody tr {
@ -209,12 +139,12 @@
}
.table-styled td {
@apply px-3 sm:px-6 py-2 sm:py-4 transition-colors duration-300 text-xs sm:text-sm;
@apply px-6 py-4 transition-colors duration-300;
}
/* ===== RESPONSIVE ALERTS ===== */
/* Professionelle Alert und Toast */
.alert {
@apply rounded-lg sm:rounded-xl border-2 p-3 sm:p-4 md:p-6 mb-3 sm:mb-4 transition-all duration-300 shadow-mobile sm:shadow-tablet;
@apply rounded-xl border-2 p-6 mb-4 transition-all duration-300 shadow-lg;
}
.alert-info {
@ -233,9 +163,9 @@
@apply bg-red-50 dark:bg-red-900/20 border-red-300 dark:border-red-600 text-red-900 dark:text-red-200;
}
/* ===== RESPONSIVE NAVIGATION TABS ===== */
/* Professionelle Navigation */
.nav-tab {
@apply inline-flex items-center gap-1 sm:gap-2 px-3 sm:px-6 py-2 sm:py-3 border-b-2 text-xs sm:text-sm font-semibold transition-all duration-300;
@apply inline-flex items-center gap-2 px-6 py-3 border-b-2 text-sm font-semibold transition-all duration-300;
}
.nav-tab-active {
@ -246,9 +176,18 @@
@apply border-transparent text-slate-600 dark:text-slate-400 hover:text-slate-900 dark:hover:text-slate-200 hover:border-slate-300 dark:hover:border-slate-600 hover:bg-slate-50 dark:hover:bg-slate-800 rounded-t-lg;
}
/* ===== RESPONSIVE PRINTER STATUS ===== */
/* Professionelle Navigation Links */
.nav-link {
@apply flex items-center gap-3 px-4 py-3 rounded-xl text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-800 hover:text-slate-900 dark:hover:text-white transition-all duration-300 font-medium;
}
.nav-link.active {
@apply bg-blue-100 dark:bg-blue-900/30 text-blue-700 dark:text-blue-300 font-semibold shadow-sm;
}
/* Erweiterte Printer Status */
.printer-status {
@apply inline-flex items-center gap-1 sm:gap-2 px-2 sm:px-4 py-1 sm:py-2 rounded-full text-xs font-semibold shadow-sm border;
@apply inline-flex items-center gap-2 px-4 py-2 rounded-full text-xs font-semibold shadow-sm border;
}
.printer-ready {
@ -271,9 +210,9 @@
@apply bg-purple-100 dark:bg-purple-900/30 text-purple-800 dark:text-purple-300 border-purple-200 dark:border-purple-700;
}
/* ===== RESPONSIVE JOB STATUS ===== */
/* Erweiterte Job Status */
.job-status {
@apply inline-flex items-center gap-1 sm:gap-2 px-2 sm:px-4 py-1 sm:py-2 rounded-full text-xs font-semibold shadow-sm border;
@apply inline-flex items-center gap-2 px-4 py-2 rounded-full text-xs font-semibold shadow-sm border;
}
.job-queued {
@ -300,9 +239,9 @@
@apply bg-purple-100 dark:bg-purple-900/30 text-purple-800 dark:text-purple-300 border-purple-200 dark:border-purple-700;
}
/* ===== RESPONSIVE BUTTONS - ENHANCED ===== */
/* Professionelle Buttons für beide Modi */
.btn {
@apply px-4 sm:px-6 py-2 sm:py-3 rounded-lg sm:rounded-xl transition-all duration-300 focus:outline-none focus:ring-4 shadow-mobile sm:shadow-tablet hover:shadow-lg font-semibold text-sm sm:text-base touch-target;
@apply px-6 py-3 rounded-xl transition-all duration-300 focus:outline-none focus:ring-4 shadow-lg hover:shadow-xl font-semibold;
}
.btn-primary {
@ -321,192 +260,312 @@
@apply btn bg-green-600 hover:bg-green-700 text-white focus:ring-green-500/50 shadow-green-500/25;
}
/* ===== RESPONSIVE DARK MODE TOGGLE ===== */
.dark-mode-toggle-premium {
@apply relative inline-flex items-center justify-center w-10 h-10 sm:w-11 sm:h-11 rounded-full transition-all duration-300 focus:outline-none focus:ring-4 focus:ring-blue-500/50 touch-target;
}
/* Professionelle Mercedes-Benz Design-Komponenten */
/* ===== RESPONSIVE MERCEDES-BENZ DESIGN COMPONENTS ===== */
/* Glassmorphism - Responsive */
/* Glassmorphism - Verbessert für beide Modi */
.mercedes-glass {
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(15px) saturate(180%);
backdrop-filter: blur(20px);
border: 1px solid rgba(255, 255, 255, 0.2);
transition: all 0.3s ease;
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
@apply rounded-lg sm:rounded-xl;
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}
.dark .mercedes-glass {
background: rgba(15, 23, 42, 0.9);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
/* Responsive Gradients */
/* Professionelle Gradients - Strikt getrennt */
.professional-gradient {
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 25%, #cbd5e1 50%, #94a3b8 75%, #64748b 100%);
@apply rounded-lg sm:rounded-xl;
}
.dark .professional-gradient {
background: linear-gradient(135deg, #0f172a 0%, #1e293b 25%, #334155 50%, #475569 75%, #64748b 100%);
}
/* Responsive Mercedes Pattern */
/* Mercedes-Pattern - Verbessert */
.mercedes-pattern {
background-image:
radial-gradient(circle at 25% 25%, rgba(255,255,255,0.1) 1px, transparent 1px),
radial-gradient(circle at 75% 75%, rgba(255,255,255,0.1) 1px, transparent 1px);
background-size: 40px 40px;
}
@media (min-width: 640px) {
.mercedes-pattern {
background-size: 60px 60px;
background-image:
radial-gradient(circle at 25% 25%, rgba(255,255,255,0.1) 2px, transparent 2px),
radial-gradient(circle at 75% 75%, rgba(255,255,255,0.1) 2px, transparent 2px);
}
background-size: 60px 60px;
}
.dark .mercedes-pattern {
background-image:
radial-gradient(circle at 25% 25%, rgba(255,255,255,0.05) 1px, transparent 1px),
radial-gradient(circle at 75% 75%, rgba(255,255,255,0.05) 1px, transparent 1px);
radial-gradient(circle at 25% 25%, rgba(255,255,255,0.05) 2px, transparent 2px),
radial-gradient(circle at 75% 75%, rgba(255,255,255,0.05) 2px, transparent 2px);
background-size: 60px 60px;
}
/* Responsive Professional Shadows */
.professional-shadow {
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.1),
0 4px 8px rgba(0, 0, 0, 0.05),
0 0 0 1px rgba(255, 255, 255, 0.05);
}
@media (min-width: 768px) {
/* Professionelle Schatten - Kontextabhängig */
.professional-shadow {
box-shadow:
0 25px 50px -12px rgba(0, 0, 0, 0.15),
0 8px 16px rgba(0, 0, 0, 0.1),
0 0 0 1px rgba(255, 255, 255, 0.05);
}
}
.dark .professional-shadow {
box-shadow:
0 10px 25px -5px rgba(0, 0, 0, 0.3),
0 4px 8px rgba(0, 0, 0, 0.2),
0 0 0 1px rgba(255, 255, 255, 0.1);
}
@media (min-width: 768px) {
.dark .professional-shadow {
box-shadow:
0 25px 50px -12px rgba(0, 0, 0, 0.5),
0 8px 16px rgba(0, 0, 0, 0.3),
0 0 0 1px rgba(255, 255, 255, 0.1);
}
/* Professionelle Button Styles - Erweitert */
.professional-button {
background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
transition: all 0.3s ease;
position: relative;
overflow: hidden;
box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
}
/* ===== RESPONSIVE LOADING AND SHIMMER ===== */
.dark .professional-button {
background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
box-shadow: 0 4px 15px rgba(59, 130, 246, 0.2);
}
.professional-button::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: left 0.5s;
}
.professional-button:hover::before {
left: 100%;
}
.professional-button:hover {
background: linear-gradient(135deg, #1d4ed8 0%, #1e40af 100%);
transform: translateY(-2px);
box-shadow: 0 15px 35px rgba(59, 130, 246, 0.4);
}
.dark .professional-button:hover {
background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
box-shadow: 0 15px 35px rgba(59, 130, 246, 0.3);
}
/* Professionelle Input Fields - Erweitert */
.input-field {
transition: all 0.3s ease;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
border: 2px solid rgba(203, 213, 225, 0.8);
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}
.dark .input-field {
background: rgba(51, 65, 85, 0.95);
border: 2px solid rgba(71, 85, 105, 0.8);
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.input-field:focus {
transform: translateY(-2px);
box-shadow: 0 10px 25px rgba(59, 130, 246, 0.15);
border-color: #3b82f6;
background: rgba(255, 255, 255, 1);
}
.dark .input-field:focus {
background: rgba(51, 65, 85, 1);
box-shadow: 0 10px 25px rgba(59, 130, 246, 0.2);
}
/* Professionelle Cards - Erweitert */
.professional-card {
border-radius: 1.5rem;
overflow: hidden;
background: rgba(255, 255, 255, 0.98);
backdrop-filter: blur(20px);
border: 1px solid rgba(203, 213, 225, 0.5);
transition: all 0.3s ease;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.dark .professional-card {
background: rgba(15, 23, 42, 0.98);
border: 1px solid rgba(71, 85, 105, 0.5);
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}
.professional-card:hover {
transform: translateY(-4px);
box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
}
.dark .professional-card:hover {
box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
}
/* Professionelle Navigation Verbesserungen */
.nav-item {
position: relative;
transition: all 0.3s ease;
border-radius: 0.75rem;
}
.nav-item::after {
content: '';
position: absolute;
bottom: -2px;
left: 50%;
width: 0;
height: 2px;
background: linear-gradient(90deg, #3b82f6, #1d4ed8);
transition: all 0.3s ease;
transform: translateX(-50%);
}
.nav-item:hover::after,
.nav-item.active::after {
width: 100%;
}
/* Verbesserte Header-Stile */
.hero-header {
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
border: 1px solid rgba(203, 213, 225, 0.5);
}
.dark .hero-header {
background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
border: 1px solid rgba(71, 85, 105, 0.5);
}
/* Verbesserte Container */
.main-container {
background: rgba(248, 250, 252, 0.8);
backdrop-filter: blur(10px);
}
.dark .main-container {
background: rgba(15, 23, 42, 0.8);
}
/* Professionelle Status Badges - Erweitert */
.status-badge {
display: inline-flex;
align-items: center;
padding: 0.5rem 0.75rem;
font-size: 0.75rem;
font-weight: 700;
border-radius: 9999px;
transition: all 0.2s ease;
border: 1px solid transparent;
text-transform: uppercase;
letter-spacing: 0.025em;
}
.status-badge:hover {
transform: scale(1.05);
}
/* Smooth Transitions für alle Elemente */
* {
transition:
background-color 0.3s ease,
border-color 0.3s ease,
color 0.3s ease,
box-shadow 0.3s ease,
transform 0.3s ease;
}
/* Interactive Hover Effects */
.interactive-hover {
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.interactive-hover:hover {
transform: translateY(-2px);
}
/* Light Mode spezifische Hover-Effekte */
.interactive-hover:hover {
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}
.dark .interactive-hover:hover {
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}
/* Professional Loading States */
.loading-shimmer {
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%);
background-size: 200% 100%;
animation: shimmer 1.5s infinite;
@apply rounded-lg sm:rounded-xl;
animation: shimmer 2s infinite;
}
.dark .loading-shimmer {
background: linear-gradient(90deg, #374151 25%, #4b5563 50%, #374151 75%);
background: linear-gradient(90deg, #334155 25%, #475569 50%, #334155 75%);
background-size: 200% 100%;
}
@keyframes shimmer {
0% { background-position: -200% 0; }
100% { background-position: 200% 0; }
0% { background-position: 200% 0; }
100% { background-position: -200% 0; }
}
/* ===== RESPONSIVE FOCUS RINGS ===== */
/* Focus Indicators für Accessibility */
.focus-ring:focus {
@apply outline-none ring-4 ring-blue-500/50 dark:ring-blue-400/50;
outline: 3px solid #3b82f6;
outline-offset: 2px;
}
.dark .focus-ring:focus {
@apply ring-blue-400/50;
outline: 3px solid #60a5fa;
}
/* ===== RESPONSIVE TITLES ===== */
/* Professionelle Typography */
.professional-title {
@apply text-lg sm:text-xl md:text-2xl lg:text-3xl xl:text-4xl font-bold text-slate-900 dark:text-white tracking-tight;
background: linear-gradient(135deg, #1e293b 0%, #475569 100%);
-webkit-background-clip: text;
background-clip: text;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
font-weight: 700;
letter-spacing: -0.025em;
}
.dark .professional-title {
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
-webkit-background-clip: text;
background-clip: text;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
/* ===== RESPONSIVE UTILITIES ===== */
/* Touch-friendly interactive elements */
.touch-friendly {
@apply min-h-[44px] min-w-[44px] touch-target;
}
/* Responsive text sizes */
.text-responsive {
font-size: clamp(0.875rem, 2.5vw, 1.125rem);
line-height: 1.5;
}
.text-responsive-lg {
font-size: clamp(1.125rem, 3vw, 1.5rem);
line-height: 1.4;
}
.text-responsive-xl {
font-size: clamp(1.5rem, 4vw, 2.25rem);
line-height: 1.3;
}
/* ===== MOBILE-SPECIFIC OPTIMIZATIONS ===== */
/* Responsives Design für kleine Bildschirme */
@media (max-width: 768px) {
.professional-shadow {
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}
.professional-card {
@apply rounded-lg;
border-radius: 1rem;
}
.mercedes-glass {
backdrop-filter: blur(10px);
}
/* Optimize spacing for mobile */
.card {
@apply m-1 p-3;
}
.dashboard-card {
@apply p-4;
backdrop-filter: blur(15px);
}
}
/* ===== ANIMATION CLASSES - RESPONSIVE ===== */
/* Animationen für bessere UX */
.fade-in {
animation: fadeIn 0.5s ease-in-out;
}
.slide-up {
animation: slideUp 0.5s ease-out;
animation: slideUp 0.5s ease-in-out;
}
@keyframes fadeIn {
@ -520,86 +579,26 @@
@keyframes slideUp {
from {
transform: translateY(30px);
opacity: 0;
transform: translateY(30px);
}
to {
transform: translateY(0);
opacity: 1;
transform: translateY(0);
}
}
/* ===== CSS CUSTOM PROPERTIES - RESPONSIVE ===== */
/* Root Variablen für konsistente Farben */
:root {
--border-radius-mobile: 0.5rem;
--border-radius-tablet: 0.75rem;
--border-radius-desktop: 1rem;
--shadow-mobile: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
--shadow-tablet: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
--shadow-desktop: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
--mercedes-primary: #3b82f6;
--mercedes-secondary: #64748b;
--mercedes-accent: #1d4ed8;
--shadow-light: rgba(0, 0, 0, 0.1);
--shadow-dark: rgba(0, 0, 0, 0.3);
}
.dark {
--shadow-mobile: 0 1px 3px 0 rgba(0, 0, 0, 0.3);
--shadow-tablet: 0 4px 6px -1px rgba(0, 0, 0, 0.3);
--shadow-desktop: 0 10px 15px -3px rgba(0, 0, 0, 0.3);
}
/* ===== RESPONSIVE SCROLLBAR IMPROVEMENTS ===== */
/* Webkit-Browser - Responsive scrollbars */
::-webkit-scrollbar {
width: 4px;
height: 4px;
}
@media (min-width: 768px) {
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
}
::-webkit-scrollbar-track {
background: transparent;
}
::-webkit-scrollbar-thumb {
background: transparent;
border-radius: 3px;
transition: all 0.3s ease;
}
/* Nur bei Hover über scrollbaren Container sichtbar */
*:hover::-webkit-scrollbar-thumb {
background: rgba(0, 0, 0, 0.05);
}
*:hover::-webkit-scrollbar-thumb:hover {
background: rgba(0, 0, 0, 0.1);
}
/* Dark Mode - noch dezenter */
.dark *:hover::-webkit-scrollbar-thumb {
background: rgba(255, 255, 255, 0.03);
}
.dark *:hover::-webkit-scrollbar-thumb:hover {
background: rgba(255, 255, 255, 0.08);
}
/* ===== PRINT STYLES ===== */
@media print {
.card, .dashboard-card {
@apply shadow-none border border-gray-300;
}
.btn, .nav-item {
@apply shadow-none;
}
.dark-mode-toggle-premium {
@apply hidden;
}
--shadow-light: rgba(0, 0, 0, 0.2);
--shadow-dark: rgba(0, 0, 0, 0.5);
}
}

View File

@ -2,16 +2,13 @@
<html lang="de" class="scroll-smooth">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0, minimum-scale=1.0, user-scalable=yes">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0, minimum-scale=1.0">
<meta name="description" content="MYP Platform - Mercedes-Benz 3D Druck Management System">
<meta name="robots" content="noindex, nofollow">
<!-- Enhanced mobile browser UI -->
<!-- Dynamic theme-color meta tags for browser UI -->
<meta name="theme-color" media="(prefers-color-scheme: light)" content="#ffffff">
<meta name="theme-color" media="(prefers-color-scheme: dark)" content="#000000">
<meta name="theme-color" id="metaThemeColor" content="#000000">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="default">
<meta name="format-detection" content="telephone=no">
<!-- CSRF-Token für Formulare -->
<meta name="csrf-token" content="{{ csrf_token() }}">
@ -96,27 +93,20 @@
});
</script>
<!-- Enhanced Responsive Styles -->
<!-- Disable Transitions Styling -->
<style>
.disable-transitions,
.disable-transitions * {
transition: none !important;
}
/* ===== RESPONSIVE SCROLLBARS ===== */
/* ===== ULTRA-DEZENTE SCROLLBALKEN ===== */
/* Webkit-Browser - Responsive */
::-webkit-scrollbar {
width: 4px;
height: 4px;
}
@media (min-width: 768px) {
/* Webkit-Browser (Chrome, Safari, Edge) */
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
}
::-webkit-scrollbar-track {
background: transparent;
@ -161,66 +151,37 @@
scrollbar-color: rgba(255, 255, 255, 0.03) transparent;
}
/* ===== RESPONSIVE SAFE AREAS ===== */
/* iOS Safe Area Support */
.safe-area-top {
padding-top: env(safe-area-inset-top);
/* Spezielle Container die scrollbar brauchen */
.modal-content::-webkit-scrollbar,
.dropdown-menu::-webkit-scrollbar {
width: 4px;
}
.safe-area-bottom {
padding-bottom: env(safe-area-inset-bottom);
.modal-content::-webkit-scrollbar-thumb,
.dropdown-menu::-webkit-scrollbar-thumb {
background: rgba(0, 0, 0, 0.1);
}
.safe-area-left {
padding-left: env(safe-area-inset-left);
}
.safe-area-right {
padding-right: env(safe-area-inset-right);
}
/* ===== TOUCH OPTIMIZATIONS ===== */
/* Touch-friendly targets */
.touch-target {
min-height: 44px;
min-width: 44px;
}
@media (pointer: coarse) {
.touch-target {
min-height: 48px;
min-width: 48px;
}
}
/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
}
.dark .modal-content::-webkit-scrollbar-thumb,
.dark .dropdown-menu::-webkit-scrollbar-thumb {
background: rgba(255, 255, 255, 0.1);
}
</style>
{% block head %}{% endblock %}
</head>
<body class="min-h-screen flex flex-col bg-white text-slate-900 dark:bg-black dark:text-white transition-colors duration-300 text-responsive mercedes-background safe-area-top safe-area-bottom">
<body class="min-h-screen flex flex-col bg-white text-slate-900 dark:bg-black dark:text-white transition-colors duration-300 text-base mercedes-background">
<!-- Navigation - Responsive Enhanced -->
<!-- Navigation -->
<nav class="navbar">
<div class="responsive-container">
<div class="flex items-center justify-between h-14 sm:h-16 md:h-18 lg:h-20">
<!-- Brand Section - Responsive -->
<div class="max-w-7xl mx-auto px-3 sm:px-4 lg:px-6">
<div class="flex items-center justify-between h-16 sm:h-18 lg:h-20">
<!-- Brand Section -->
<div class="flex-shrink-0">
<a href="{{ url_for('dashboard') }}" class="navbar-brand group" aria-label="Zur Startseite">
<!-- Mercedes-Benz Logo - Responsive sizes -->
<div class="w-4 h-4 sm:w-5 sm:h-5 md:w-6 md:h-6 lg:w-7 lg:h-7 transition-all duration-300 group-hover:rotate-180">
<!-- Mercedes-Benz Logo -->
<div class="w-5 h-5 sm:w-6 sm:h-6 lg:w-7 lg:h-7 transition-all duration-300 group-hover:rotate-180">
<svg class="w-full h-full text-slate-900 dark:text-white transition-colors duration-300" fill="currentColor" viewBox="0 0 80 80" aria-hidden="true">
<path d="M58.6,4.5C53,1.6,46.7,0,40,0c-6.7,0-13,1.6-18.6,4.5v0C8.7,11.2,0,24.6,0,40c0,15.4,8.7,28.8,21.5,35.5
C27,78.3,33.3,80,40,80c6.7,0,12.9-1.7,18.5-4.6C71.3,68.8,80,55.4,80,40C80,24.6,71.3,11.2,58.6,4.5z M4,40
@ -230,101 +191,101 @@
c0,6.2-1.5,12-4.3,17.1L58.6,46.8z"/>
</svg>
</div>
<!-- Brand Text - Responsive -->
<div class="flex flex-col ml-2 sm:ml-3">
<span class="text-xs sm:text-sm lg:text-base font-bold text-slate-900 dark:text-white transition-colors duration-300 tracking-tight">Mercedes-Benz</span>
<span class="text-xs font-medium text-slate-600 dark:text-slate-400 transition-colors duration-300 hidden sm:inline">MYP 3D-Druck Platform</span>
<!-- Brand Text -->
<div class="flex flex-col ml-3">
<span class="text-sm lg:text-base font-bold text-slate-900 dark:text-white transition-colors duration-300 tracking-tight">Mercedes-Benz</span>
<span class="text-xs font-medium text-slate-600 dark:text-slate-400 transition-colors duration-300">MYP 3D-Druck Reservierungsplatform -</span>
</div>
</a>
</div>
<!-- Desktop Navigation Menu - Responsive -->
<!-- Desktop Navigation Menu - überarbeitetes Design -->
<div class="hidden lg:flex flex-1 justify-center">
<nav class="navbar-menu-new" role="navigation" aria-label="Hauptnavigation">
<a href="{{ url_for('dashboard') }}"
class="nav-item {{ 'active' if request.endpoint == 'dashboard' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M3 7v10a2 2 0 002 2h14a2 2 0 002-2V9a2 2 0 00-2-2H5a2 2 0 00-2-2z"/>
</svg>
<span class="hidden xl:inline">Dashboard</span>
<span>Dashboard</span>
</a>
<a href="{{ url_for('printers_page') }}"
class="nav-item {{ 'active' if request.endpoint == 'printers_page' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg: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="M17 17h2a2 2 0 002-2v-4a2 2 0 00-2-2H5a2 2 0 00-2 2v4a2 2 0 002 2h2m2 4h6a2 2 0 002-2v-4a2 2 0 00-2-2H9a2 2 0 00-2 2v4a2 2 0 002 2zm8-12V5a2 2 0 00-2-2H9a2 2 0 00-2 2v4h10z"/>
<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="M13 10V3L4 14h7v7l9-11h-7z"/>
</svg>
<span class="hidden xl:inline">3D-Drucker</span>
<span>Drucker-Steckdosen</span>
</a>
<a href="{{ url_for('jobs_page') }}"
class="nav-item {{ 'active' if request.endpoint == 'jobs_page' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M9 5H7a2 2 0 00-2 2v10a2 2 0 002 2h8a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"/>
</svg>
<span class="hidden xl:inline">Druckaufträge</span>
<span>Reservierungen</span>
</a>
<a href="{{ url_for('stats_page') }}"
class="nav-item {{ 'active' if request.endpoint == 'stats_page' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M9 19v-6a2 2 0 00-2-2H5a2 2 0 00-2 2v6a2 2 0 002 2h2a2 2 0 002-2zm0 0V9a2 2 0 012-2h2a2 2 0 012 2v10m-6 0a2 2 0 002 2h2a2 2 0 002-2m0 0V5a2 2 0 012-2h2a2 2 0 012 2v14a2 2 0 01-2 2h-2a2 2 0 01-2-2z"/>
</svg>
<span class="hidden xl:inline">Statistiken</span>
<span>Statistiken</span>
</a>
<a href="{{ url_for('calendar.calendar_view') }}"
class="nav-item {{ 'active' if request.endpoint == 'calendar.calendar_view' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z"/>
</svg>
<span class="hidden xl:inline">Schichtplan</span>
<span>Schichtplan</span>
</a>
<a href="{{ url_for('guest.guest_request_form') }}"
class="nav-item {{ 'active' if request.endpoint == 'guest.guest_request_form' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/>
</svg>
<span class="hidden xl:inline">Gastanfrage</span>
<span>Antrag stellen</span>
</a>
<a href="{{ url_for('guest.guest_requests_overview') }}"
class="nav-item {{ 'active' if request.endpoint == 'guest.guest_requests_overview' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z"/>
</svg>
<span class="hidden xl:inline">Anträge Übersicht</span>
<span>Meine Anträge</span>
</a>
{% if current_user.is_authenticated and current_user.is_admin %}
<a href="{{ url_for('admin_page') }}"
class="nav-item {{ 'active' if request.endpoint == 'admin_page' else '' }}">
<svg class="w-4 h-4 lg:w-5 lg:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
</svg>
<span class="hidden xl:inline">Administration</span>
<span>Ausbilder-Bereich</span>
</a>
{% endif %}
</nav>
</div>
<!-- Rechte Seite der Navbar - Responsive -->
<div class="flex items-center space-x-1 sm:space-x-2 md:space-x-3">
<!-- Mobile Menu Toggle -->
<!-- Rechte Seite der Navbar -->
<div class="flex items-center space-x-2 sm:space-x-3">
<!-- Mobile Menu Toggle (neu) -->
<button
id="mobileMenuToggle"
class="lg:hidden touch-target rounded-full text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50 transition-all duration-300"
class="lg:hidden p-2 rounded-full text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50"
aria-label="Menü öffnen"
aria-expanded="false"
>
<svg class="w-5 h-5 sm:w-6 sm:h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6h16M4 12h16M4 18h16"/>
</svg>
</button>
<!-- Dark Mode Toggle - Enhanced Responsive -->
<!-- Dark Mode Toggle - Moderner, schöner Design -->
<div class="relative">
<button
id="darkModeToggle"
@ -336,19 +297,19 @@
<!-- Hintergrund-Ring für besseren visuellen Effekt -->
<div class="absolute inset-0 rounded-full bg-gradient-to-r from-amber-300 to-orange-400 dark:from-blue-400 dark:to-purple-500 opacity-0 group-hover:opacity-100 blur-sm transition-all duration-500"></div>
<!-- Haupt-Container - Responsive -->
<div class="relative flex items-center justify-center w-9 h-9 sm:w-10 sm:h-10 md:w-11 md:h-11 rounded-full bg-white/80 dark:bg-slate-800/80 backdrop-blur-md border border-slate-200/50 dark:border-slate-600/50 shadow-lg dark:shadow-slate-900/20 transition-all duration-300 group-hover:scale-105 group-active:scale-95">
<!-- Haupt-Container -->
<div class="relative flex items-center justify-center w-11 h-11 rounded-full bg-white/80 dark:bg-slate-800/80 backdrop-blur-md border border-slate-200/50 dark:border-slate-600/50 shadow-lg dark:shadow-slate-900/20 transition-all duration-300 group-hover:scale-105 group-active:scale-95">
<!-- Sonnen-Icon (Light Mode) -->
<div class="sun-icon absolute inset-0 flex items-center justify-center transition-all duration-500 ease-in-out opacity-100 dark:opacity-0 scale-100 dark:scale-75 rotate-0 dark:rotate-90">
<svg class="w-4 h-4 sm:w-5 sm:h-5 text-amber-500 drop-shadow-sm" fill="currentColor" viewBox="0 0 24 24" style="margin: auto;">
<svg class="w-5 h-5 text-amber-500 drop-shadow-sm" fill="currentColor" viewBox="0 0 24 24" style="margin: auto;">
<path d="M12 2.25a.75.75 0 01.75.75v2.25a.75.75 0 01-1.5 0V3a.75.75 0 01.75-.75zM7.5 12a4.5 4.5 0 119 0 4.5 4.5 0 01-9 0zM18.894 6.166a.75.75 0 00-1.06-1.06l-1.591 1.59a.75.75 0 101.06 1.061l1.591-1.59zM21.75 12a.75.75 0 01-.75.75h-2.25a.75.75 0 010-1.5H21a.75.75 0 01.75.75zM17.834 18.894a.75.75 0 001.06-1.06l-1.59-1.591a.75.75 0 10-1.061 1.06l1.59 1.591zM12 18a.75.75 0 01.75.75V21a.75.75 0 01-1.5 0v-2.25A.75.75 0 0112 18zM7.758 17.303a.75.75 0 00-1.061-1.06l-1.591 1.59a.75.75 0 001.06 1.061l1.591-1.59zM6 12a.75.75 0 01-.75.75H3a.75.75 0 010-1.5h2.25A.75.75 0 016 12zM6.697 7.757a.75.75 0 001.06-1.06l-1.59-1.591a.75.75 0 00-1.061 1.06l1.59 1.591z"/>
</svg>
</div>
<!-- Mond-Icon (Dark Mode) -->
<div class="moon-icon absolute inset-0 flex items-center justify-center transition-all duration-500 ease-in-out opacity-0 dark:opacity-100 scale-75 dark:scale-100 rotate-90 dark:rotate-0">
<svg class="w-4 h-4 sm:w-5 sm:h-5 text-blue-400 drop-shadow-sm" fill="currentColor" viewBox="0 0 24 24" style="margin: auto;">
<svg class="w-5 h-5 text-blue-400 drop-shadow-sm" fill="currentColor" viewBox="0 0 24 24" style="margin: auto;">
<path fill-rule="evenodd" d="M9.528 1.718a.75.75 0 01.162.819A8.97 8.97 0 009 6a9 9 0 009 9 8.97 8.97 0 003.463-.69.75.75 0 01.981.98 10.503 10.503 0 01-9.694 6.46c-5.799 0-10.5-4.701-10.5-10.5 0-4.368 2.667-8.112 6.46-9.694a.75.75 0 01.818.162z" clip-rule="evenodd"/>
</svg>
</div>
@ -363,37 +324,37 @@
</div>
</button>
<!-- Tooltip - Responsive -->
<div class="absolute bottom-full left-1/2 transform -translate-x-1/2 mb-2 px-2 py-1 bg-slate-900 dark:bg-slate-700 text-white text-xs rounded whitespace-nowrap opacity-0 group-hover:opacity-100 transition-opacity duration-200 pointer-events-none z-50 hidden sm:block">
<!-- Tooltip -->
<div class="absolute bottom-full left-1/2 transform -translate-x-1/2 mb-2 px-2 py-1 bg-slate-900 dark:bg-slate-700 text-white text-xs rounded whitespace-nowrap opacity-0 group-hover:opacity-100 transition-opacity duration-200 pointer-events-none z-50">
<span class="dark:hidden">Dark Mode aktivieren</span>
<span class="hidden dark:inline">Light Mode aktivieren</span>
<div class="absolute top-full left-1/2 transform -translate-x-1/2 w-0 h-0 border-l-4 border-r-4 border-t-4 border-transparent border-t-slate-900 dark:border-t-slate-700"></div>
</div>
</div>
{% if current_user.is_authenticated %}
<!-- Benachrichtigungen - Responsive -->
<!-- Benachrichtigungen - kompakteres Design -->
<div class="relative">
<button
id="notificationToggle"
class="touch-target rounded-full text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50 transition-all duration-200"
class="relative p-1.5 rounded-full text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50 transition-all duration-200"
aria-label="Benachrichtigungen anzeigen"
title="Benachrichtigungen"
>
<svg class="w-4 h-4 sm:w-5 sm:h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<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 17h5l-1.405-1.405A2.032 2.032 0 0118 14.158V11a6.002 6.002 0 00-4-5.659V5a2 2 0 10-4 0v.341C7.67 6.165 6 8.388 6 11v3.159c0 .538-.214 1.055-.595 1.436L4 17h5m6 0v1a3 3 0 11-6 0v-1m6 0H9"/>
</svg>
<!-- Badge für ungelesene Benachrichtigungen -->
<span id="notificationBadge" class="absolute -top-1 -right-1 bg-red-500 text-white text-xs rounded-full h-3 w-3 sm:h-4 sm:w-4 flex items-center justify-center font-medium hidden">
<span id="notificationBadge" class="absolute -top-1 -right-1 bg-red-500 text-white text-xs rounded-full h-4 w-4 flex items-center justify-center font-medium hidden">
0
</span>
</button>
<!-- Benachrichtigungs-Dropdown - Responsive -->
<div id="notificationDropdown" class="absolute right-0 mt-2 w-64 sm:w-72 md:w-80 bg-white dark:bg-slate-800 rounded-lg shadow-lg border border-slate-200 dark:border-slate-600 z-50 hidden">
<!-- Benachrichtigungs-Dropdown -->
<div id="notificationDropdown" class="absolute right-0 mt-2 w-72 sm:w-80 bg-white dark:bg-slate-800 rounded-lg shadow-lg border border-slate-200 dark:border-slate-600 z-50 hidden">
<div class="p-3 border-b border-slate-200 dark:border-slate-600">
<h3 class="text-sm sm:text-base font-semibold text-slate-900 dark:text-white">Benachrichtigungen</h3>
<h3 class="text-base font-semibold text-slate-900 dark:text-white">Benachrichtigungen</h3>
</div>
<div id="notificationList" class="max-h-64 sm:max-h-80 overflow-y-auto">
<div id="notificationList" class="max-h-80 overflow-y-auto">
<div class="p-3 text-center text-slate-500 dark:text-slate-400 text-sm">
Keine neuen Benachrichtigungen
</div>
@ -406,17 +367,17 @@
</div>
</div>
<!-- User Profile Dropdown - Responsive -->
<!-- User Profile Dropdown - kompakteres Design -->
<div class="relative" id="user-menu-container">
<button
id="user-menu-button"
class="flex items-center space-x-1 rounded-full p-1 text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50 transition-all duration-200 touch-target"
class="flex items-center space-x-1 rounded-full p-1 text-slate-700 dark:text-slate-300 hover:bg-slate-100/80 dark:hover:bg-slate-800/50 transition-all duration-200"
aria-expanded="false"
aria-haspopup="true"
aria-label="Benutzermenu öffnen"
>
<!-- Profile Avatar - Responsive -->
<div class="w-5 h-5 sm:w-6 sm:h-6 rounded-full bg-blue-500 flex items-center justify-center text-white text-xs font-medium">
<!-- Profile Avatar -->
<div class="w-6 h-6 rounded-full bg-blue-500 flex items-center justify-center text-white text-xs font-medium">
{{ current_user.email[0].upper() if current_user.email else 'U' }}
</div>
<!-- User Info (nur auf größeren Geräten) -->
@ -425,16 +386,16 @@
</div>
</button>
<!-- User Menu Dropdown - Responsive -->
<div id="user-dropdown" class="absolute right-0 mt-2 w-56 sm:w-64 bg-white dark:bg-slate-800 rounded-lg shadow-lg border border-slate-200 dark:border-slate-600 z-50 hidden origin-top-right">
<!-- User Menu Dropdown -->
<div id="user-dropdown" class="absolute right-0 mt-2 w-64 bg-white dark:bg-slate-800 rounded-lg shadow-lg border border-slate-200 dark:border-slate-600 z-50 hidden origin-top-right">
<!-- User Info Header -->
<div class="px-3 sm:px-4 py-3 border-b border-slate-200 dark:border-slate-600">
<div class="px-4 py-3 border-b border-slate-200 dark:border-slate-600">
<div class="flex items-center space-x-3">
<div class="w-8 h-8 sm:w-10 sm:h-10 rounded-full bg-blue-500 flex items-center justify-center text-white font-medium">
<div class="w-10 h-10 rounded-full bg-blue-500 flex items-center justify-center text-white font-medium">
{{ current_user.email[0].upper() if current_user.email else 'U' }}
</div>
<div class="flex-1 min-w-0">
<p class="text-xs sm:text-sm font-medium text-slate-900 dark:text-white truncate">
<p class="text-sm font-medium text-slate-900 dark:text-white truncate">
{{ current_user.full_name if current_user.full_name else current_user.email.split('@')[0] if current_user.email else 'Benutzer' }}
</p>
<p class="text-xs text-slate-500 dark:text-slate-400 truncate">
@ -442,26 +403,26 @@
</p>
{% if current_user.is_admin %}
<span class="inline-flex items-center px-2 py-0.5 rounded text-xs font-medium bg-purple-100 text-purple-800 dark:bg-purple-900 dark:text-purple-200 mt-1">
Administrator
Ausbilder
</span>
{% endif %}
</div>
</div>
</div>
<!-- Menu Items - Responsive -->
<!-- Menu Items -->
<div class="py-1">
<a href="{{ url_for('user_profile') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center px-4 py-2 text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" 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>
Mein Profil
</a>
<a href="{{ url_for('user_settings') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center px-4 py-2 text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
</svg>
@ -469,16 +430,16 @@
</a>
<a href="{{ url_for('jobs_page') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center px-4 py-2 text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 6v6m0 0v6m0-6h6m-6 0H6"/>
</svg>
Neuer Auftrag
Neue Reservierung
</a>
<a href="{{ url_for('stats_page') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center px-4 py-2 text-sm text-slate-700 dark:text-slate-300 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 19v-6a2 2 0 00-2-2H5a2 2 0 00-2 2v6a2 2 0 002 2h2a2 2 0 002-2zm0 0V9a2 2 0 012-2h2a2 2 0 012 2v10m-6 0a2 2 0 002 2h2a2 2 0 002-2m0 0V5a2 2 0 012-2h2a2 2 0 012 2v14a2 2 0 01-2 2h-2a2 2 0 01-2-2z"/>
</svg>
Analytik
@ -487,24 +448,24 @@
<div class="border-t border-slate-200 dark:border-slate-600">
<a href="{{ url_for('privacy') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-500 dark:text-slate-400 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" 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"/>
class="flex items-center px-4 py-2 text-sm text-slate-500 dark:text-slate-400 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" 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 2zm10-10V7a4 4 0 00-8 0v4h8z"/>
</svg>
Datenschutz
</a>
<a href="{{ url_for('terms') }}"
class="flex items-center px-3 sm:px-4 py-2 text-xs sm:text-sm text-slate-500 dark:text-slate-400 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center px-4 py-2 text-sm text-slate-500 dark:text-slate-400 hover:bg-slate-100 dark:hover:bg-slate-700 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z"/>
</svg>
Nutzungsbedingungen
</a>
<button onclick="handleLogout()"
class="flex items-center w-full px-3 sm:px-4 py-2 text-xs sm:text-sm text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20 transition-colors duration-200">
<svg class="w-3 h-3 sm:w-4 sm:h-4 mr-2 sm:mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center w-full px-4 py-2 text-sm text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20 transition-colors duration-200">
<svg class="w-4 h-4 mr-3" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 16l4-4m0 0l-4-4m4 4H7m6 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"/>
</svg>
Abmelden
@ -513,10 +474,10 @@
</div>
</div>
{% else %}
<!-- Login Button - Responsive -->
<!-- Login Button - kompakteres Design -->
<a href="{{ url_for('login') }}"
class="flex items-center space-x-1 py-1.5 sm:py-2 px-2 sm:px-3 rounded-md bg-blue-600 hover:bg-blue-700 text-white text-xs sm:text-sm transition-colors duration-200 touch-target">
<svg class="w-3 h-3 sm:w-3.5 sm:h-3.5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
class="flex items-center space-x-1 py-1 px-2 rounded-md bg-blue-600 hover:bg-blue-700 text-white text-xs transition-colors duration-200">
<svg class="w-3.5 h-3.5" fill="none" stroke="currentColor" viewBox="0 0 24 24" aria-hidden="true">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M11 16l-4-4m0 0l4-4m-4 4h14m-5 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"/>
</svg>
<span class="hidden sm:inline">Anmelden</span>
@ -527,8 +488,8 @@
</div>
</nav>
<!-- Mobile Menu - Enhanced Responsive -->
<div id="mobileMenu" class="mobile-menu-new hidden lg:hidden animate-slide-down">
<!-- Mobile Menu (neu) -->
<div id="mobileMenu" class="mobile-menu-new hidden lg:hidden">
<nav class="flex flex-col space-y-1 px-3 py-4" role="navigation" aria-label="Mobile Navigation">
<a href="{{ url_for('dashboard') }}"
class="mobile-nav-item {{ 'active' if request.endpoint == 'dashboard' else '' }}">
@ -541,9 +502,9 @@
<a href="{{ url_for('printers_page') }}"
class="mobile-nav-item {{ 'active' if request.endpoint == 'printers_page' else '' }}">
<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="M17 17h2a2 2 0 002-2v-4a2 2 0 00-2-2H5a2 2 0 00-2 2v4a2 2 0 002 2h2m2 4h6a2 2 0 002-2v-4a2 2 0 00-2-2H9a2 2 0 00-2 2v4a2 2 0 002 2zm8-12V5a2 2 0 00-2-2H9a2 2 0 00-2 2v4h10z"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 10V3L4 14h7v7l9-11h-7z"/>
</svg>
<span>3D-Drucker</span>
<span>Drucker-Steckdosen</span>
</a>
<a href="{{ url_for('jobs_page') }}"
@ -551,7 +512,7 @@
<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="M9 5H7a2 2 0 00-2 2v10a2 2 0 002 2h8a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"/>
</svg>
<span>Druckaufträge</span>
<span>Reservierungen</span>
</a>
<a href="{{ url_for('stats_page') }}"
@ -575,7 +536,7 @@
<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="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/>
</svg>
<span>Gastanfrage</span>
<span>Antrag stellen</span>
</a>
<a href="{{ url_for('guest.guest_requests_overview') }}"
@ -583,7 +544,7 @@
<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="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z"/>
</svg>
<span>Anträge Übersicht</span>
<span>Meine Anträge</span>
</a>
{% if current_user.is_authenticated and current_user.is_admin %}
@ -593,20 +554,21 @@
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/>
</svg>
<span>Administration</span>
<span>Ausbilder-Bereich</span>
</a>
{% endif %}
</nav>
</div>
<!-- Main Content - Enhanced Responsive -->
<main id="main-content" class="flex-grow responsive-container py-4 sm:py-6 md:py-8">
<!-- Flash Messages - Responsive -->
<!-- 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 -->
{% with messages = get_flashed_messages(with_categories=true) %}
{% if messages %}
<div class="flash-messages mb-4 space-y-2 sm:space-y-3">
<div class="flash-messages mb-4">
{% for category, message in messages %}
<div class="alert alert-{{ category }}">
<div class="alert alert-{{ category }} mb-2">
{{ message }}
</div>
{% endfor %}
@ -615,17 +577,18 @@
{% endwith %}
{% block content %}{% endblock %}
</div>
</main>
<!-- Mercedes-Benz Footer - Enhanced Responsive -->
<!-- Mercedes-Benz Footer -->
<footer class="bg-white dark:bg-black border-t border-gray-200 dark:border-slate-700 mt-auto transition-colors duration-300">
<div class="responsive-container">
<div class="py-4 sm:py-6 md:py-8 border-t border-gray-200 dark:border-slate-700 mt-6 sm:mt-8 md:mt-12 pt-4 sm:pt-6 md:pt-8">
<div class="responsive-grid-3">
<!-- Brand Section - Responsive -->
<div class="flex flex-col space-y-3 sm:space-y-4">
<div class="flex items-center gap-2 sm:gap-3">
<div class="w-5 h-5 sm:w-6 sm:h-6">
<div class="max-w-screen-xl w-full mx-auto px-3 sm:px-6 lg:px-8">
<div class="py-4 sm:py-8 border-t border-gray-200 dark:border-slate-700 mt-8 sm:mt-12 pt-4 sm:pt-8">
<div class="grid grid-cols-1 sm:grid-cols-3 gap-6 sm:gap-8">
<!-- Brand Section - Stack on mobile -->
<div class="flex flex-col space-y-4">
<div class="flex items-center gap-3">
<div class="w-6 h-6">
<svg class="w-full h-full text-slate-900 dark:text-white transition-colors duration-300" fill="currentColor" viewBox="0 0 80 80">
<path d="M58.6,4.5C53,1.6,46.7,0,40,0c-6.7,0-13,1.6-18.6,4.5v0C8.7,11.2,0,24.6,0,40c0,15.4,8.7,28.8,21.5,35.5
C27,78.3,33.3,80,40,80c6.7,0,12.9-1.7,18.5-4.6C71.3,68.8,80,55.4,80,40C80,24.6,71.3,11.2,58.6,4.5z M4,40
@ -636,19 +599,19 @@
</svg>
</div>
<div>
<div class="text-sm sm:text-base font-bold text-slate-900 dark:text-white transition-colors duration-300">Mercedes-Benz</div>
<div class="text-xs text-slate-600 dark:text-slate-400 transition-colors duration-300">MYP Platform</div>
<div class="text-base font-bold text-slate-900 dark:text-white transition-colors duration-300">Mercedes-Benz</div>
<div class="text-xs text-slate-600 dark:text-slate-400 transition-colors duration-300">TBA Marienfelde - Steckdosen-Steuerung</div>
</div>
</div>
<p class="text-xs leading-relaxed text-slate-600 dark:text-slate-400 transition-colors duration-300">
<p class="text-xs text-slate-600 dark:text-slate-400 leading-relaxed transition-colors duration-300">
Das Beste oder nichts - Professionelles 3D-Druck Management für Mercedes-Benz.
</p>
</div>
<!-- System Info - Responsive -->
<div class="flex flex-col space-y-3 sm:space-y-4">
<h3 class="text-base sm:text-lg font-semibold text-slate-900 dark:text-white transition-colors duration-300">System</h3>
<div class="space-y-2 text-xs leading-relaxed text-slate-600 dark:text-slate-400 transition-colors duration-300">
<!-- System Info -->
<div class="flex flex-col space-y-4">
<h3 class="text-lg font-semibold text-slate-900 dark:text-white transition-colors duration-300">System</h3>
<div class="space-y-2 text-xs text-slate-600 dark:text-slate-400 leading-relaxed transition-colors duration-300">
<div class="flex justify-between">
<span>Version:</span>
<span class="text-slate-900 dark:text-white font-medium transition-colors duration-300">3.0.0</span>
@ -663,10 +626,10 @@
</div>
</div>
<!-- Copyright - Responsive -->
<div class="flex flex-col space-y-3 sm:space-y-4">
<h3 class="text-base sm:text-lg font-semibold text-slate-900 dark:text-white transition-colors duration-300">Rechtliches</h3>
<div class="space-y-2 text-xs leading-relaxed text-slate-600 dark:text-slate-400 transition-colors duration-300">
<!-- Copyright -->
<div class="flex flex-col space-y-4">
<h3 class="text-lg font-semibold text-slate-900 dark:text-white transition-colors duration-300">Rechtliches</h3>
<div class="space-y-2 text-xs text-slate-600 dark:text-slate-400 leading-relaxed transition-colors duration-300">
<p>© 2024 Mercedes-Benz Group AG</p>
<p>Alle Rechte vorbehalten.</p>
<p class="text-xs text-slate-500 dark:text-slate-500 transition-colors duration-300">
@ -695,134 +658,8 @@
<script src="{{ url_for('static', filename='js/auto-logout.js') }}"></script>
{% endif %}
<!-- Enhanced JavaScript Functions - Responsive -->
<!-- Additional JavaScript Functions -->
<script>
/**
* Enhanced Responsive JavaScript Functions
*/
// Viewport Detection
function getViewportSize() {
return {
width: Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0),
height: Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0)
};
}
function isMobile() {
return getViewportSize().width < 768;
}
function isTablet() {
const width = getViewportSize().width;
return width >= 768 && width < 1024;
}
function isDesktop() {
return getViewportSize().width >= 1024;
}
// Touch Device Detection
function isTouchDevice() {
return 'ontouchstart' in window || navigator.maxTouchPoints > 0;
}
// Mobile Menu Enhanced Functionality
function initializeMobileMenu() {
const mobileMenuToggle = document.getElementById('mobileMenuToggle');
const mobileMenu = document.getElementById('mobileMenu');
if (mobileMenuToggle && mobileMenu) {
mobileMenuToggle.addEventListener('click', function() {
const isVisible = !mobileMenu.classList.contains('hidden');
if (isVisible) {
mobileMenu.classList.add('hidden');
mobileMenuToggle.setAttribute('aria-expanded', 'false');
mobileMenuToggle.innerHTML = `
<svg class="w-5 h-5 sm:w-6 sm:h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
</svg>
`;
} else {
mobileMenu.classList.remove('hidden');
mobileMenuToggle.setAttribute('aria-expanded', 'true');
mobileMenuToggle.innerHTML = `
<svg class="w-5 h-5 sm:w-6 sm:h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"/>
</svg>
`;
}
});
// Close mobile menu when clicking outside
document.addEventListener('click', function(event) {
if (!mobileMenu.contains(event.target) && !mobileMenuToggle.contains(event.target)) {
if (!mobileMenu.classList.contains('hidden')) {
mobileMenu.classList.add('hidden');
mobileMenuToggle.setAttribute('aria-expanded', 'false');
mobileMenuToggle.focus();
}
}
});
// Close mobile menu on escape key
document.addEventListener('keydown', function(event) {
if (event.key === 'Escape' && !mobileMenu.classList.contains('hidden')) {
mobileMenu.classList.add('hidden');
mobileMenuToggle.setAttribute('aria-expanded', 'false');
mobileMenuToggle.focus();
}
});
}
}
// Responsive Image Loading
function optimizeImages() {
const images = document.querySelectorAll('img[data-src]');
const imageObserver = new IntersectionObserver((entries, observer) => {
entries.forEach(entry => {
if (entry.isIntersecting) {
const img = entry.target;
img.src = img.dataset.src;
img.classList.remove('loading');
imageObserver.unobserve(img);
}
});
});
images.forEach(img => imageObserver.observe(img));
}
// Responsive Table Enhancement
function enhanceResponsiveTables() {
const tables = document.querySelectorAll('.table-container');
tables.forEach(table => {
if (isMobile()) {
table.style.fontSize = '0.75rem';
} else if (isTablet()) {
table.style.fontSize = '0.875rem';
} else {
table.style.fontSize = '1rem';
}
});
}
// Viewport Resize Handler
function handleViewportResize() {
enhanceResponsiveTables();
// Update mobile menu visibility on resize
const mobileMenu = document.getElementById('mobileMenu');
if (mobileMenu && isDesktop()) {
mobileMenu.classList.add('hidden');
const mobileMenuToggle = document.getElementById('mobileMenuToggle');
if (mobileMenuToggle) {
mobileMenuToggle.setAttribute('aria-expanded', 'false');
}
}
}
/**
* Logout-Handler für sicheres Abmelden
*/
@ -858,32 +695,15 @@
}
/**
* Enhanced Initialization
* Initialisierung aller UI-Komponenten nach DOM-Load
*/
document.addEventListener('DOMContentLoaded', function() {
// Initialize responsive features
initializeMobileMenu();
optimizeImages();
enhanceResponsiveTables();
// Add viewport resize listener
let resizeTimeout;
window.addEventListener('resize', function() {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(handleViewportResize, 250);
});
// Initialize MYP App für Offline-Funktionalität
// MYP App für Offline-Funktionalität initialisieren
if (typeof MYPApp !== 'undefined') {
window.mypApp = new MYPApp();
}
// Add touch device optimizations
if (isTouchDevice()) {
document.body.classList.add('touch-device');
}
console.log('🚀 MYP Platform UI erfolgreich initialisiert (Responsive Enhanced)');
console.log('🚀 MYP Platform UI erfolgreich initialisiert');
});
</script>

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
{% extends "base.html" %}
{% block title %}Mercedes-Benz MYP Platform - 3D-Druck Management{% endblock %}
{% block title %}Mercedes-Benz TBA Marienfelde - Steckdosen-Steuerung für 3D-Drucker{% endblock %}
{% block extra_css %}
<style>
@ -383,14 +383,14 @@
<h1 class="text-6xl md:text-8xl font-bold mb-6 tracking-tight">
<span class="bg-gradient-to-r from-white via-blue-200 to-white bg-clip-text text-transparent">
MYP Platform
TBA Platform
</span>
</h1>
<p class="text-xl md:text-2xl text-blue-100 max-w-4xl mx-auto leading-relaxed mb-4">
<strong>Das Beste oder nichts</strong> - Professionelles 3D-Druck Management für die Mercedes-Benz Ausbildungsstätte Werk Berlin
<strong>Das Beste oder nichts</strong> - Intelligente Steckdosen-Steuerung für 3D-Drucker in der Mercedes-Benz Technischen Berufsausbildung Werk Marienfelde
</p>
<p class="text-lg md:text-xl text-blue-200 max-w-3xl mx-auto leading-relaxed mb-12">
Präzision in jeder Schicht. Innovation in jedem Detail. Mercedes-Benz Qualität in der additiven Fertigung.
Sichere Ein-/Ausschaltung und Reservierungsmanagement. Ausbilder-geprüfte Anträge für höchste Sicherheit und Qualität.
</p>
<!-- Enhanced CTA Buttons -->
@ -417,7 +417,7 @@
<svg class="w-6 h-6 mr-3 group-hover:scale-110 transition-transform" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<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>
Gastanfrage stellen
Antrag für Nutzung stellen
</a>
</div>
@ -429,11 +429,11 @@
<div class="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
<div class="text-center mb-16">
<h2 class="text-5xl font-bold text-mercedes-black dark:text-white mb-6">
Mercedes-Benz Qualität in der 3D-Produktion
Mercedes-Benz TBA: Sichere Drucker-Steckdosen-Verwaltung
</h2>
<p class="text-xl text-mercedes-gray dark:text-slate-400 max-w-4xl mx-auto leading-relaxed">
Unsere "Manage-Your-Printer" (MYP) Platform vereint höchste Präzision mit intelligenter Steuerung für die Fertigungsprozesse in der Ausbildungsstätte.
Für kontinuierliche <strong>Mercedes-Benz Standards</strong> in der Fertigung.
Unser Steckdosen-Management-System ermöglicht die sichere Steuerung von 3D-Drucker-Steckdosen in der Technischen Berufsausbildung.
Ausbilder-überwachte Genehmigungsprozesse für <strong>höchste Sicherheitsstandards</strong> im Werk Marienfelde.
</p>
</div>
@ -442,20 +442,20 @@
<div class="mercedes-feature-card p-8 text-center group">
<div class="feature-icon w-20 h-20 bg-gradient-to-br from-blue-100 to-blue-200 dark:from-blue-900/30 dark:to-blue-800/30 rounded-xl flex items-center justify-center mx-auto mb-6">
<svg class="w-10 h-10 text-mercedes-blue" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 12h14M5 12a2 2 0 01-2-2V6a2 2 0 012-2h14a2 2 0 012 2v4a2 2 0 01-2 2M5 12a2 2 0 00-2 2v4a2 2 0 002 2h14a2 2 0 002-2v-4a2 2 0 00-2-2m-2-4h.01M17 16h.01"/>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 10V3L4 14h7v7l9-11h-7z"/>
</svg>
</div>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">Intelligente Druckersteuerung</h3>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">Sichere Steckdosen-Steuerung</h3>
<p class="text-mercedes-gray dark:text-slate-400 leading-relaxed">
Automatisch Verwaltung und Überwachung aller 3D-Drucker mit Echtzeit-Status
und optimierter Ressourcenverteilung für maximale Effizienz und Qualität.
Kontrollierte Ein- und Ausschaltung von 3D-Drucker-Steckdosen mit Echtzeit-Status
und Sicherheitsprotokollen für die Ausbildungswerkstatt.
</p>
<div class="mt-6 flex justify-center">
<span class="inline-flex items-center px-3 py-1 rounded-full text-sm font-medium bg-blue-100 text-blue-800 dark:bg-blue-900/30 dark:text-blue-300">
<svg class="w-4 h-4 mr-1" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 10V3L4 14h7v7l9-11h-7z"/>
</svg>
Automatisiert
Sicher
</span>
</div>
</div>
@ -467,17 +467,17 @@
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-3 7h3m-3 4h3m-6-4h.01M9 16h.01"/>
</svg>
</div>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">Präzise Auftragsplanung</h3>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">Ausbilder-geprüfte Reservierungen</h3>
<p class="text-mercedes-gray dark:text-slate-400 leading-relaxed">
Strukturierte Produktionsplanung mit Mercedes-Benz Standards für termingerechte und qualitätsorientierte Fertigung -
Effizientes Druckerwarteschlangen-Management.
Strukturiertes Reservierungssystem mit Ausbilder-Genehmigung für optimale Ressourcenverteilung
und sichere Nutzung in der TBA.
</p>
<div class="mt-6 flex justify-center">
<span class="inline-flex items-center px-3 py-1 rounded-full text-sm font-medium bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-300">
<svg class="w-4 h-4 mr-1" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/>
</svg>
MB Standards
Ausbilder-geprüft
</span>
</div>
</div>
@ -489,17 +489,17 @@
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 19v-6a2 2 0 00-2-2H5a2 2 0 00-2 2v6a2 2 0 002 2h2a2 2 0 002-2zm0 0V9a2 2 0 012-2h2a2 2 0 012 2v10m-6 0a2 2 0 002 2h2a2 2 0 002-2m0 0V5a2 2 0 012-2h2a2 2 0 012 2v14a2 2 0 01-2 2h-2a2 2 0 01-2-2z"/>
</svg>
</div>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">Umfassende Analytik</h3>
<h3 class="text-2xl font-bold text-mercedes-black dark:text-white mb-4">TBA-Nutzungsstatistiken</h3>
<p class="text-mercedes-gray dark:text-slate-400 leading-relaxed">
Detaillierte Produktionsstatistiken und Leistungsanalysen zur Qualitätssicherung.
Lokale Datenauswertung für fundierte Entscheidungen.
Detaillierte Auswertungen der Steckdosen-Nutzung und Reservierungsstatistiken zur
Optimierung der Ausbildungsabläufe im Werk Marienfelde.
</p>
<div class="mt-6 flex justify-center">
<span class="inline-flex items-center px-3 py-1 rounded-full text-sm font-medium bg-purple-100 text-purple-800 dark:bg-purple-900/30 dark:text-purple-300">
<svg class="w-4 h-4 mr-1" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 19v-6a2 2 0 00-2-2H5a2 2 0 00-2 2v6a2 2 0 002 2h2a2 2 0 002-2zm0 0V9a2 2 0 012-2h2a2 2 0 012 2v10m-6 0a2 2 0 002 2h2a2 2 0 002-2m0 0V5a2 2 0 012-2h2a2 2 0 012 2v14a2 2 0 01-2 2h-2a2 2 0 01-2-2z"/>
</svg>
Real-Time
TBA-optimiert
</span>
</div>
</div>
@ -730,7 +730,7 @@
<svg class="w-6 h-6 mr-3 group-hover:scale-110 transition-transform" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<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>
Gastanfrage stellen
Antrag für Nutzung stellen
</a>
{% endif %}
</div>