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>
|
||
|---|---|---|
| .. | ||
| cmd/agent | ||
| internal | ||
| Dockerfile | ||
| go.mod | ||
| go.sum | ||
| README.md | ||
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/– Startpunktinternal/app/– Initialisierung und Laufzeitinternal/config/– Konfiguration (Env + JSON-Datei)internal/mqttheartbeat/– MQTT-Publisherinternal/playerserver/– lokaler HTTP-Server fuer Kiosk-UI