morz-infoboard/player/agent
Jesko Anschütz e03948f25d Kopplung Agent↔Backend: Selbstregistrierung + Playlist-Rotation
Backend:
- ScreenStore.Upsert(): idempotentes INSERT ON CONFLICT für Self-Registration
- POST /api/v1/screens/register: Agent registriert sich beim Start (upsert)
- manage/register.go: neuer Handler, immer unter Tenant "morz"

Agent:
- config: screen_name + screen_orientation (mit Fallback auf screen_id / landscape)
- app.go: registerScreen() — POST /api/v1/screens/register beim Start (Retry 30s)
- app.go: pollPlaylist() — GET /api/v1/screens/{slug}/playlist alle 60s
- app.go: nowFn liefert Playlist statt statischer URL; PlayerContentURL als Fallback
- playerserver: PlaylistItem-Struct in NowPlaying; JS rotiert Items per duration_seconds
- JS: Playlist-Fingerprint verhindert Reset laufender Rotation bei unverändertem Stand

Ansible:
- config.json.j2: screen_name + screen_orientation ergänzt
- host_vars/info10: screen_name + screen_orientation
- host_vars/info01-dev: screen_name + screen_orientation

Kopplung per Konvention: screen_id (config.json) = slug (DB)
Beim ersten Neustart der Agents erscheinen die Bildschirme automatisch im Admin-UI.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-23 05:57:58 +01:00
..
cmd/agent Fuehre Health-Modell und strukturierte Agent-Logs ein 2026-03-22 16:55:20 +01:00
internal Kopplung Agent↔Backend: Selbstregistrierung + Playlist-Rotation 2026-03-23 05:57:58 +01:00
Dockerfile Baue Layout-Resolver und lokale Entwicklungsgerueste aus 2026-03-22 16:03:21 +01:00
go.mod Fuege MQTT-Heartbeat zum Agent hinzu (kein Broker konfiguriert = skip) 2026-03-22 20:54:12 +01:00
go.sum Fuege MQTT-Heartbeat zum Agent hinzu (kein Broker konfiguriert = skip) 2026-03-22 20:54:12 +01:00
README.md Baue Ebene 1: Player-UI, Kiosk-Display und vollstaendiges Ansible-Deployment 2026-03-22 22:34:16 +01:00

Agent

Lokaler Dienst auf dem Signage-Geraet.

Aufgaben

  • periodischer HTTP-Statusreport an den Server
  • optionaler MQTT-Heartbeat (wird uebersprungen wenn kein Broker konfiguriert)
  • lokale Player-UI unter http://127.0.0.1:8090/player
  • JSON-Statusendpunkt unter http://127.0.0.1:8090/api/now-playing

Unterstruktur

  • cmd/agent/ Startpunkt
  • internal/app/ Initialisierung und Laufzeit
  • internal/config/ Konfiguration (Env + JSON-Datei)
  • internal/mqttheartbeat/ MQTT-Publisher
  • internal/playerserver/ lokaler HTTP-Server fuer Kiosk-UI