"feat: Update error handling documentation and live printer system guide"

This commit is contained in:
Till Tomczak 2025-05-29 20:38:19 +02:00
parent 1d3bb5ea8f
commit bc2fd5a68c
2 changed files with 467 additions and 2 deletions

View File

@ -92,4 +92,93 @@ window.jobManager // JobManager-Instanz
## Status: ✅ BEHOBEN
Alle JavaScript-Fehler wurden erfolgreich behoben. Die Anwendung sollte jetzt ohne Konsolen-Fehler laufen und alle Job-Management-Funktionen sollten ordnungsgemäß funktionieren.
Alle JavaScript-Fehler wurden erfolgreich behoben. Die Anwendung sollte jetzt ohne Konsolen-Fehler laufen und alle Job-Management-Funktionen sollten ordnungsgemäß funktionieren.
# MYP Platform - Behobene Fehler und Implementierungen
## [2025-01-05] Live-Druckererkennungs-System implementiert ✅
### Problem
Die Druckererkennung funktionierte nicht richtig und benötigte:
- Live Drucker-Erkennung (IP-Adressen aus Datenbank prüfen)
- Session-Speicherung für schnelle Änderungen (aber auch Datenbank)
- Beim Programmstart alle Steckdosen in den gleichen Zustand versetzen (ausschalten)
### Lösung
Komplettes Live-Druckererkennungs-System mit Session-Caching und automatischer Steckdosen-Initialisierung implementiert.
#### Backend-Komponenten
1. **PrinterMonitor Klasse** (`utils/printer_monitor.py`)
- Live-Status-Überwachung mit mehrstufigem Caching
- Session-Cache (30s TTL) für schnelle Zugriffe
- DB-Cache (5min TTL) für persistente Daten
- Threadsichere Implementierung mit Locks
- Parallele Drucker-Abfragen mit ThreadPoolExecutor
2. **Steckdosen-Initialisierung**
- Automatische Ausschaltung aller Steckdosen beim Programmstart
- Einheitlicher Startzustand für alle Drucker
- Fehlertolerante Implementierung mit detailliertem Logging
- Admin-gesteuerte manuelle Initialisierung
3. **Smart-Plug-Integration**
- Unterstützung für TP-Link Tapo und generische APIs
- Ping-Tests für Grundkonnektivität
- HTTP-Status-Abfragen für Steckdosen-Zustand
- Verschiedene API-Endpunkte automatisch testen
#### API-Endpunkte
- `GET /api/printers/monitor/live-status` - Live-Status mit Caching
- `GET /api/printers/monitor/summary` - Schnelle Status-Zusammenfassung
- `POST /api/printers/monitor/clear-cache` - Cache-Management
- `POST /api/printers/monitor/initialize-outlets` - Admin-Initialisierung
#### Frontend-Integration
1. **JavaScript PrinterMonitor Klasse** (`static/js/printer_monitor.js`)
- Automatischer Start auf relevanten Seiten
- Event-basierte Status-Updates
- Adaptive Aktualisierungsintervalle (30s normal, 60s wenn Seite verborgen)
- Schnelle Updates (5s) für kritische Operationen
2. **Status-Kategorien**
- **Online**: Drucker eingeschaltet und erreichbar
- **Standby**: Drucker ausgeschaltet aber Steckdose erreichbar
- **Offline**: Drucker/Steckdose nicht erreichbar
- **Unreachable**: Grundkonnektivität fehlgeschlagen
- **Unconfigured**: Unvollständige Konfiguration
#### Performance-Optimierungen
- Parallele Drucker-Abfragen (max 8 Workers)
- Mehrstufiges Caching-System
- Adaptive Timeouts und Error-Handling
- Exponential Backoff bei Fehlern
- Sichtbarkeitsbasierte Update-Intervalle
#### Fehlerbehandlung
- Automatische Wiederherstellung mit Fehler-Zählern
- Graceful Degradation bei Teilausfällen
- Detailliertes Logging mit verschiedenen Log-Levels
- Rate-Limiting für API-Endpunkte
### Integration in Hauptanwendung
- Import in `app.py` und automatische Initialisierung beim Start
- Rate-Limited API-Routen mit Admin-Berechtigung für kritische Funktionen
- Logging-Integration mit bestehenden Systemen
### Technische Details
- Threadsichere Implementierung mit Locks
- Session-Integration für Browser-basiertes Caching
- Unterstützung für verschiedene Smart-Plug-Protokolle
- Windows-kompatible Ping-Implementierung
- Umfassende Dokumentation in `docs/live_drucker_system.md`
### Ergebnis
✅ **Live-Druckererkennung funktioniert vollständig**
**Session-Caching für schnelle Updates implementiert**
✅ **Automatische Steckdosen-Initialisierung beim Programmstart**
✅ **Umfassende API und Frontend-Integration**
✅ **Production-ready mit Error-Handling und Logging**
---
## [2024-12-29] Template-Ladeproblem behoben ✅

View File

@ -1 +1,377 @@
# Live-Druckererkennungs-System - MYP Platform
## Übersicht
Das Live-Druckererkennungs-System überwacht kontinuierlich den Status aller konfigurierten Drucker und bietet Echtzeit-Updates mit Session-Caching und automatischer Steckdosen-Initialisierung.
## Features
### 🔄 Live-Monitoring
- **Echtzeit-Status-Updates** alle 30 Sekunden
- **Parallele Abfragen** für bessere Performance
- **Automatische Fehlerbehandlung** mit exponential backoff
- **Adaptive Aktualisierungsintervalle** basierend auf Seitensichtbarkeit
### 💾 Session-Caching
- **Session-basierter Cache** für schnelle Zugriffe (30 Sekunden TTL)
- **Datenbank-Cache** für persistente Daten (5 Minuten TTL)
- **Threadsicheres Caching** mit Locks
- **Automatische Cache-Invalidierung**
### 🔌 Steckdosen-Initialisierung
- **Automatischer Start** beim Programmstart
- **Einheitlicher Startzustand** (alle Steckdosen ausgeschaltet)
- **Fehlertolerante Initialisierung** mit detailliertem Logging
- **Admin-gesteuerte manuelle Initialisierung**
### 📊 Status-Kategorien
- **Online**: Drucker eingeschaltet und erreichbar
- **Standby**: Drucker ausgeschaltet aber Steckdose erreichbar
- **Offline**: Drucker/Steckdose nicht erreichbar
- **Unreachable**: Grundkonnektivität fehlgeschlagen
- **Unconfigured**: Unvollständige Konfiguration
## Backend-Architektur
### PrinterMonitor Klasse (`utils/printer_monitor.py`)
```python
class PrinterMonitor:
def __init__(self):
self.session_cache = {} # Session-Cache für schnelle Zugriffe
self.db_cache = {} # DB-Cache für persistente Daten
self.cache_lock = threading.Lock()
self.session_cache_ttl = 30 # 30 Sekunden
self.db_cache_ttl = 300 # 5 Minuten
```
#### Hauptmethoden
##### `initialize_all_outlets_on_startup()`
- Schaltet beim Programmstart alle Steckdosen aus
- Setzt alle Drucker in den gleichen Startzustand
- Protokolliert detaillierte Ergebnisse
##### `get_live_printer_status(use_session_cache=True)`
- Holt Live-Status mit mehrstufigem Caching
- Prüft Session-Cache → DB-Cache → Live-Abfrage
- Aktualisiert beide Cache-Ebenen
##### `_check_single_printer_status(printer, timeout=7)`
- Überprüft einzelnen Drucker mit umfassenden Tests
- Ping-Test für Grundkonnektivität
- Smart-Plug-Status-Abfrage über HTTP-APIs
- Unterstützt verschiedene Smart-Plug-Typen
## API-Endpunkte
### GET `/api/printers/monitor/live-status`
Holt Live-Druckerstatus mit Session-Caching.
**Parameter:**
- `use_cache` (optional): Verwende Session-Cache (default: true)
**Response:**
```json
{
"success": true,
"printers": {
"1": {
"id": 1,
"name": "Printer 1",
"status": "online",
"active": true,
"ip_address": "192.168.0.100",
"plug_ip": "192.168.0.110",
"location": "Werk 040 - Berlin - TBA",
"last_checked": "2025-01-05T10:30:00",
"ping_successful": true,
"outlet_reachable": true,
"outlet_state": "on"
}
},
"summary": {
"total": 6,
"online": 2,
"offline": 1,
"standby": 2,
"unreachable": 1,
"unconfigured": 0
},
"cache_used": true,
"timestamp": "2025-01-05T10:30:00",
"total_printers": 6
}
```
### GET `/api/printers/monitor/summary`
Schnelle Status-Zusammenfassung ohne vollständige Details.
**Response:**
```json
{
"success": true,
"summary": {
"total": 6,
"online": 2,
"offline": 1,
"standby": 2,
"unreachable": 1,
"unconfigured": 0
},
"timestamp": "2025-01-05T10:30:00"
}
```
### POST `/api/printers/monitor/clear-cache`
Löscht alle Monitor-Caches (Session und DB).
**Response:**
```json
{
"success": true,
"message": "Drucker-Monitor-Cache erfolgreich geleert"
}
```
### POST `/api/printers/monitor/initialize-outlets` (Admin)
Initialisiert alle Drucker-Steckdosen (schaltet sie aus).
**Response:**
```json
{
"success": true,
"message": "Steckdosen-Initialisierung abgeschlossen: 5/6 erfolgreich",
"results": {
"Printer 1": true,
"Printer 2": true,
"Printer 3": false,
"Printer 4": true,
"Printer 5": true,
"Printer 6": true
},
"statistics": {
"total": 6,
"successful": 5,
"failed": 1
}
}
```
## Frontend-Integration
### PrinterMonitor JavaScript-Klasse (`static/js/printer_monitor.js`)
#### Automatischer Start
```javascript
// Auto-Start auf relevanten Seiten
const relevantPages = ['/printers', '/dashboard', '/admin'];
if (relevantPages.some(page => currentPath.includes(page))) {
window.printerMonitor.start();
}
```
#### Event-Handler registrieren
```javascript
// Status-Updates abonnieren
window.printerMonitor.onUpdate((data) => {
if (data.type === 'update') {
updatePrinterDisplay(data.printers);
updateSummary(data.summary);
// Änderungen anzeigen
data.changes.forEach(change => {
if (change.type === 'status_change') {
showStatusChangeNotification(change);
}
});
}
});
```
#### Schnelle Updates aktivieren
```javascript
// Für kritische Operationen
window.printerMonitor.enableFastUpdates(); // 5 Sekunden Intervall
// Später wieder deaktivieren
window.printerMonitor.disableFastUpdates(); // 30 Sekunden Intervall
```
#### Cache-Management
```javascript
// Cache leeren und neu laden
await window.printerMonitor.clearCache();
// Sofortige Aktualisierung ohne Cache
await window.printerMonitor.forceUpdate();
```
#### Admin-Funktionen
```javascript
// Steckdosen initialisieren (nur für Admins)
try {
const result = await window.printerMonitor.initializeAllOutlets();
console.log('Initialisierung erfolgreich:', result.statistics);
} catch (error) {
console.error('Initialisierung fehlgeschlagen:', error);
}
```
## Smart-Plug-Unterstützung
Das System unterstützt verschiedene Smart-Plug-APIs:
### TP-Link Tapo
```http
GET http://192.168.0.110/status
Authorization: Basic dXNlcjpwYXNzd29yZA==
Response:
{
"system": {
"get_sysinfo": {
"relay_state": 1 // 1 = on, 0 = off
}
}
}
```
### Generische APIs
```http
# Status-Abfrage
GET http://192.168.0.110/api/status
GET http://192.168.0.110/relay/status
GET http://192.168.0.110/state
# Steckdose ausschalten
POST http://192.168.0.110/relay/off
POST http://192.168.0.110/api/relay/off
POST http://192.168.0.110/set?relay=off
```
## Konfiguration
### Drucker-Modell erweitern
```python
# models.py
class Printer(Base):
# ... bestehende Felder ...
plug_ip = Column(String(50), nullable=False)
plug_username = Column(String(100), nullable=False)
plug_password = Column(String(100), nullable=False)
last_checked = Column(DateTime, nullable=True)
```
### Rate-Limiting
```python
# Rate-Limits für API-Endpunkte
@limit_requests("printer_monitor_live", 60, 5) # 5/min für Live-Status
@limit_requests("printer_monitor_summary", 30, 10) # 10/30s für Summary
@limit_requests("printer_monitor_cache", 120, 3) # 3/2min für Cache-Clear
@limit_requests("printer_monitor_init", 300, 2) # 2/5min für Initialisierung
```
## Logging
### Log-Kategorien
- **INFO**: Normale Operationen, Status-Updates
- **WARNING**: Fehlerhafte Konfigurationen, Initialisierungsprobleme
- **ERROR**: Kritische Fehler, Netzwerkprobleme
- **DEBUG**: Detaillierte Ping/HTTP-Informationen
### Beispiel-Logs
```
2025-01-05 10:30:00 - printer_monitor - INFO - 🖨️ Drucker-Monitor initialisiert
2025-01-05 10:30:01 - printer_monitor - INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-01-05 10:30:02 - printer_monitor - INFO - ✅ Printer 1: Steckdose ausgeschaltet
2025-01-05 10:30:03 - printer_monitor - WARNING - ❌ Printer 3: Steckdose konnte nicht ausgeschaltet werden
2025-01-05 10:30:05 - printer_monitor - INFO - 🎯 Steckdosen-Initialisierung abgeschlossen: 5/6 erfolgreich
```
## Performance-Optimierungen
### Threading
- **Parallele Drucker-Abfragen** mit ThreadPoolExecutor
- **Maximale Worker**: min(anzahl_drucker, 8)
- **Timeout-Handling** für hängende Anfragen
### Caching-Strategie
1. **Session-Cache** (30s): Sofortige Antworten für wiederholte Anfragen
2. **DB-Cache** (5min): Reduziert Datenbankzugriffe
3. **Adaptive TTL**: Längere Cache-Zeiten bei Fehlern
### Netzwerk-Optimierungen
- **Kurze Ping-Timeouts** (3s) für schnelle Konnektivitätsprüfung
- **HTTP-Timeouts** (5-7s) für Smart-Plug-APIs
- **Exponential Backoff** bei wiederholten Fehlern
## Fehlerbehandlung
### Automatische Wiederherstellung
- **Fehler-Zähler** mit maximal 3 Versuchen
- **Intervall-Erhöhung** bei wiederholten Fehlern
- **Cache-Fallback** bei Netzwerkproblemen
### Graceful Degradation
- **Teilweise Ergebnisse** bei einzelnen Drucker-Fehlern
- **Letzte bekannte Werte** aus Cache bei Totalausfall
- **Benutzerbenachrichtigung** über Systemprobleme
## Wartung und Monitoring
### System-Health-Checks
```bash
# Cache-Status prüfen
curl -X GET /api/printers/monitor/summary
# Cache leeren
curl -X POST /api/printers/monitor/clear-cache
# Vollständige Aktualisierung
curl -X GET "/api/printers/monitor/live-status?use_cache=false"
```
### Database-Wartung
```sql
-- Alte last_checked Werte bereinigen
UPDATE printers SET last_checked = NULL WHERE last_checked < datetime('now', '-1 day');
-- Drucker-Status-Statistiken
SELECT status, COUNT(*) FROM printers GROUP BY status;
```
## Troubleshooting
### Häufige Probleme
#### Problem: Drucker werden als "unreachable" angezeigt
**Lösung:**
1. Netzwerkverbindung prüfen
2. IP-Adressen in Datenbank validieren
3. Firewall-Regeln überprüfen
#### Problem: Steckdosen-Initialisierung schlägt fehl
**Lösung:**
1. Smart-Plug-Konfiguration prüfen (IP, Username, Password)
2. API-Endpunkte testen
3. Timeout-Werte erhöhen
#### Problem: Cache funktioniert nicht
**Lösung:**
1. Session-Konfiguration prüfen
2. Cache manuell leeren
3. Speicher-Limits überprüfen
### Debug-Befehle
```python
# Einzelnen Drucker testen
from utils.printer_monitor import printer_monitor
status = printer_monitor._check_single_printer_status(printer)
# Cache-Inhalt prüfen
print(printer_monitor.db_cache)
# Steckdose manuell testen
success = printer_monitor._turn_outlet_off("192.168.0.110", "user", "pass")
```