morz-infoboard/TODO.md
Jesko Anschütz 7e7a692521 Tenant-Feature Phase 1+2: Auth-Fundament + Login-Flow + UX-Textverbesserung
- DB-Migration 002_auth.sql (users + sessions Tabellen)
- AuthStore mit Session-Management, bcrypt, EnsureAdminUser
- Login/Logout Handler mit Cookie-Session (HttpOnly, SameSite=Lax)
- Login-Template (Bulma-Card, deutsche Labels)
- Config: AdminPassword, DefaultTenantSlug, DevMode
- Fallback-Texte: "Netzwerk offline" → "Server nicht erreichbar"
- TENANT-FEATURE-PLAN.md mit 46 Checkboxen als Steuerungsdatei

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-23 15:46:14 +01:00

9.6 KiB
Raw Blame History

Info-Board Neu - Umsetzungs-Todo

Phase 0 - Projektbasis

  • Projektverzeichnisstruktur unter /srv/docker/info-board-neu festlegen
  • Namenskonventionen fuer Server, Player, Rollen und Pakete definieren
  • Dokumentationsstruktur fuer Architektur, Betrieb und Deployment anlegen
  • Entscheidung fuer Server-Tech-Stack dokumentieren
  • Entscheidung fuer Player-Implementierung dokumentieren
  • Sprachentscheidung dokumentieren: Go als bevorzugte Sprache fuer Agent und moeglichst viele Backend-Komponenten

Phase 1 - Fachliches Fundament

  • Rollenmodell fuer admin und monitorgebundene Nutzer final festschreiben
  • Datenmodell fuer tenant, screen, user, media_asset, playlist, playlist_item, screen_status, screen_snapshot definieren
  • Playlist-Semantik mit duration, valid_from, valid_until, load_timeout, cache_policy, on_error spezifizieren
  • Fallback-Regel fuer ungeplante oder leere Inhalte verbindlich definieren
  • Statusmodell fuer Online/Offline/Degraded/Error definieren
  • Kommandokatalog fuer Admin-Aktionen finalisieren
  • Template- und Kampagnenmodell fuer globale monitoruebergreifende Uebersteuerung finalisieren
  • Prioritaetsregel campaign > tenant_playlist > fallback verbindlich festschreiben
  • Entscheidung dokumentieren, dass playlist_items.screen_id entfernt wird
  • Entscheidung dokumentieren, dass Gruppen bei Kampagnen serverseitig in Einzel-Assignments expandiert werden

Phase 2 - Technische Zielarchitektur

  • Server-Komponentenliste finalisieren
  • API-Schnittstellen grob definieren
  • MQTT-Topic-Struktur finalisieren
  • HTTPS- und MQTT-Aufgabentrennung dokumentieren
  • Screenshot-/Vorschaustrategie spezifizieren
  • Offline- und Cache-Strategie bis auf Dateiebene festlegen
  • Sicherheitsmodell fuer Uploads, Login und Rechte pruefen
  • API fuer Templates, Kampagnen, Aktivierung und Deaktivierung ausarbeiten
  • Provisionierungs-Workflow fuer neue Screens technisch durchplanen
  • Secret-Handling fuer initiale Root-Passwoerter oder Bootstrap-Zugaenge definieren
  • API-Fehlermodell und gemeinsame Fehlerantworten festlegen
  • ACK-Timeout-Strategie fuer device_command festlegen
  • message_wall-Rendering serverseitig verbindlich entscheiden
  • Netzwerktopologie fuer SSH-basierte Erstprovisionierung als Worker-/Jumphost-faehiges Modell festlegen

Phase 3 - Player-Design

  • Minimalen Paketbedarf fuer den Player auf Raspberry Pi OS Debian 13 ermitteln
  • X11-Minimalkonzept fuer Chromium-Kiosk dokumentieren
  • Startmechanismus fuer Chromium ohne Desktop-Umgebung definieren
  • Verzeichnislayout auf dem Player festlegen
  • player-agent fachlich zuschneiden
  • player-ui fachlich zuschneiden (lokale Kiosk-Seite mit Splash + Sysinfo-Overlay)
  • Watchdog-Konzept fuer Browser und Agent definieren
  • Offline-Overlay-Verhalten spezifizieren
  • Fehlerbehandlung fuer Web-Inhalte und Timeouts ausarbeiten
  • Display-Steuerung fuer An/Aus, Rotation und Neustart planen
  • Sysinfo-Overlay erweitern: load, freier RAM, IP-Adresse(n) anzeigen

Phase 4 - Server-Design

  • API-Backend fachlich schneiden
  • Admin-Oberflaeche in Hauptbereiche aufteilen
  • Firmen-/Monitor-Oberflaeche in Hauptbereiche aufteilen
  • Firmen-/Tenant-Oberfläche → siehe docs/TENANT-FEATURE-PLAN.md
  • Storage-Konzept fuer Uploads, Cache-Dateien und Screenshots festlegen
  • Authentifizierungskonzept festlegen
  • Mandantentrennung im Datenmodell und in den APIs absichern
  • Logging- und Monitoring-Konzept definieren
  • Template-Editor fuer globale Kampagnen fachlich schneiden
  • Aktivierungsoberflaeche fuer saisonale oder temporäre Kampagnen planen
  • Gruppierung oder Slot-Modell fuer monitoruebergreifende Layouts planen
  • Provisionierungs-UI fuer neue Screens fachlich und technisch schneiden
  • Jobrunner-Konzept fuer Ansible-gestuetzte Erstinstallation planen

Phase 5 - Prototyping

  • Minimalen Server-Prototyp bauen
  • Minimalen Player-Agent-Prototyp bauen
  • Minimale Player-UI bauen
  • Lokale Test-Playlist mit Bild, Video, PDF und Webseite anlegen
  • BUG: Datei 120papag.mpg ist als type: image gespeichert, muss type: video sein Player-UI versucht <img>-Laden, was fehlschlägt
  • Fallback-Verzeichnisbetrieb demonstrieren
  • valid_from/valid_until im Prototyp pruefen
  • Offline-Sync mit lokalem Cache pruefen
  • MQTT-Topic signage/screen/{screenSlug}/playlist-changed spezifiziert und dokumentiert
  • MQTT-Kommandos reload, restart_player, reboot, display_on, display_off testweise durchspielen
  • globale Kampagne testen, die tenantbezogenen Content temporär ueberschreibt
  • Rueckfall auf Normalbetrieb nach manueller Deaktivierung pruefen

Phase 6 - Betriebsfaehigkeit

  • Docker-Compose-Setup fuer den Server anlegen
  • systemd-Units fuer den Player erstellen
  • Chromium-Kiosk-Startskript erstellen
  • Screenshot-Erzeugung auf dem Player integrieren
  • Heartbeat- und Statusmeldungen integrieren
  • MQTT-Playlist-Change-Synchronisation mit Backend-Debounce (2s) und Agent-Debounce (3s) implementiert
  • Fehler- und Wiederanlaufverhalten verifizieren

Phase 7 - Ansible-Automatisierung

  • Rolle signage_base erstellen
  • Rolle signage_player erstellen
  • Rolle signage_display erstellen
  • Rolle signage_server erstellen
  • Rolle signage_provision erstellen
  • Inventar-/Variablenmodell fuer mehrere Monitore entwerfen
  • Screen-spezifische Variablen wie screen_id, Rotation und Aufloesung abbilden
  • Erstinstallation eines neuen Players automatisieren
  • Update-Rollout eines bestehenden Players automatisieren
  • Bootstrap ueber Root-Passwort auf SSH-Key und dauerhafte Verwaltung umstellen

Phase 8 - Pilotbetrieb

  • Einen Referenzmonitor fuer den Pilotbetrieb auswaehlen
  • Pilotmonitor neu aufsetzen
  • Verbindung zum Zentralserver herstellen
  • Upload- und Playlist-Pflege mit einem Testmandanten pruefen
  • Admin-Funktionen am Pilotmonitor pruefen
  • globale Template-Aktivierung fuer einen oder mehrere Monitore im Pilot testen
  • Offline-Betrieb real testen
  • Browser-/Renderer-Stabilitaet ueber laengeren Zeitraum beobachten
  • komplette Neu-Provisionierung eines frischen Test-Screens aus dem Admin-Backend pruefen

Phase 9 - Migration der Bestandsmonitore

  • Migrationsreihenfolge fuer info01 bis info09 festlegen
  • Rueckfallstrategie pro Monitor definieren
  • Altinhalte in das neue Medienmodell ueberfuehren
  • Playlists uebernehmen oder neu modellieren
  • Monitore nacheinander umstellen
  • Nach jeder Umstellung Stabilitaet und Fernsteuerung pruefen

Phase 10 - Nacharbeiten

  • Betriebsdokumentation schreiben
  • Admin-Handbuch schreiben
  • Kurzhandbuch fuer Firmen-Nutzer schreiben
  • Backup- und Restore-Konzept dokumentieren
  • Update- und Release-Prozess festlegen
  • Langfristige Wayland-Neubewertung fuer spaetere Version vormerken

UX-Verbesserungen (Gestaltungsplan)

Hohe Prioritaet

  • Flash-Messages nach Aktionen in Manage-UI (Upload, Loeschen, Speichern) — Feedback fuer den Nutzer
  • Screen-Online/Offline-Status in Admin-Tabelle anzeigen (aus /status-Endpoint befuellen)
  • Playlist-Tabelle in overflow-x Wrapper einwickeln (Responsive auf kleinen Screens)
  • PDF-Darstellung: Sidebar und Toolbar im Chromium PDF-Viewer ausblenden (URL-Parameter navpanes=0, toolbar=0)
  • PDF-Darstellung: PDF.js fuer automatisches Seitendurchblaettern integrieren

Mittlere Prioritaet

  • Loesch-Bestaetigung: Bulma-Modal statt browser-nativer confirm()-Dialog
  • Status-Page: Sprache von Englisch auf Deutsch vereinheitlichen
  • Status-Page: Relative Zeitstempel statt RFC3339 ("vor 2 Minuten")
  • Querlinks zwischen Admin-UI und Status-Page (Navigation)
  • Bulma und SortableJS als lokale Assets einbetten statt CDN
  • Player-UI: CSS-Transitions fuer sanfte Content-Wechsel (Fade statt abrupt)
  • Player-UI: Erweitertes Sysinfo-Overlay (aktueller Titel, Playlist-Laenge)
  • Aria-Labels fuer Loesch-Buttons und Drag-Handles (Accessibility)

Niedrige Prioritaet

  • Upload-Fortschrittsbalken in Manage-UI
  • vars.yml Download-Button in Provision-UI statt Copy-Paste
  • Toggle-Switch statt Ja/Nein-Select fuer Enabled-Feld

UX-Bug-Fixes

  • Fix: Protokoll-relative URLs (//cdn...) werden nicht mehr durch URL-Normalisierung kaputtgeschrieben
  • Fix: PDF-Fragment-Parameter werden mit bestehenden Fragments gemerged statt blind angehängt
  • Fix: /api/startup-token setzt Cache-Control: no-store Header (Server + Client)
  • Fix: TestAssetsServed Nil-Dereferenz durch tote Goroutine behoben

Querschnittsthemen

  • Datensicherung fuer Datenbank und Medien einplanen
  • TLS-/Reverse-Proxy-Konzept festlegen
  • Ressourcenverbrauch auf Raspberry Pi beobachten
  • Verhalten bei grossen Videos optimieren
  • Verhalten bei defekten externen Webseiten absichern
  • Datenschutz- und Rechtefragen fuer Screenshots/Vorschauen pruefen

Erste konkrete Abarbeitungsreihenfolge

  • 1. Projektstruktur im neuen Verzeichnis vervollstaendigen
  • 2. Datenmodell in eigener Datei ausformulieren
  • 3. API- und MQTT-Vertrag definieren
  • 4. Player-Minimalkonzept fuer Raspberry Pi OS Debian 13 festzurren
  • 5. Server-Compose-Grundgeruest erstellen
  • 6. Player-Prototyp mit lokalem Browser-Renderer bauen
  • 7. Offline-Cache und Fallback robust machen
  • 8. UIs fuer Admin und Firmen schrittweise aufbauen
  • 9. Ansible-Rollen erstellen
  • 10. Pilotmonitor migrieren