feat(wiring): GlobalOverrideStore in Router, App und Scheduler-Goroutinen
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
parent
42458e68ff
commit
9aabf18aa2
2 changed files with 27 additions and 10 deletions
|
|
@ -26,8 +26,9 @@ type App struct {
|
||||||
server *http.Server
|
server *http.Server
|
||||||
notifier *mqttnotifier.Notifier
|
notifier *mqttnotifier.Notifier
|
||||||
authStore *store.AuthStore
|
authStore *store.AuthStore
|
||||||
scheduleStore *store.ScreenScheduleStore
|
scheduleStore *store.ScreenScheduleStore
|
||||||
screenStore *store.ScreenStore
|
globalOverrideStore *store.GlobalOverrideStore
|
||||||
|
screenStore *store.ScreenStore
|
||||||
dbPool *db.Pool // V7: für db.Close() im Shutdown
|
dbPool *db.Pool // V7: für db.Close() im Shutdown
|
||||||
logger *log.Logger
|
logger *log.Logger
|
||||||
}
|
}
|
||||||
|
|
@ -62,6 +63,7 @@ func New() (*App, error) {
|
||||||
playlists := store.NewPlaylistStore(pool.Pool)
|
playlists := store.NewPlaylistStore(pool.Pool)
|
||||||
authStore := store.NewAuthStore(pool.Pool)
|
authStore := store.NewAuthStore(pool.Pool)
|
||||||
schedules := store.NewScreenScheduleStore(pool.Pool)
|
schedules := store.NewScreenScheduleStore(pool.Pool)
|
||||||
|
globalOverrides := store.NewGlobalOverrideStore(pool.Pool)
|
||||||
|
|
||||||
// Ensure admin user exists — generate a random password if none is configured.
|
// Ensure admin user exists — generate a random password if none is configured.
|
||||||
adminPassword := cfg.AdminPassword
|
adminPassword := cfg.AdminPassword
|
||||||
|
|
@ -100,8 +102,9 @@ func New() (*App, error) {
|
||||||
AuthStore: authStore,
|
AuthStore: authStore,
|
||||||
Notifier: notifier,
|
Notifier: notifier,
|
||||||
ScreenshotStore: ss,
|
ScreenshotStore: ss,
|
||||||
ScheduleStore: schedules,
|
ScheduleStore: schedules,
|
||||||
Config: cfg,
|
GlobalOverrideStore: globalOverrides,
|
||||||
|
Config: cfg,
|
||||||
UploadDir: cfg.UploadDir,
|
UploadDir: cfg.UploadDir,
|
||||||
Logger: logger,
|
Logger: logger,
|
||||||
})
|
})
|
||||||
|
|
@ -111,8 +114,9 @@ func New() (*App, error) {
|
||||||
server: &http.Server{Addr: cfg.HTTPAddress, Handler: handler},
|
server: &http.Server{Addr: cfg.HTTPAddress, Handler: handler},
|
||||||
notifier: notifier,
|
notifier: notifier,
|
||||||
authStore: authStore,
|
authStore: authStore,
|
||||||
scheduleStore: schedules,
|
scheduleStore: schedules,
|
||||||
screenStore: screens,
|
globalOverrideStore: globalOverrides,
|
||||||
|
screenStore: screens,
|
||||||
dbPool: pool, // V7: Referenz für Shutdown
|
dbPool: pool, // V7: Referenz für Shutdown
|
||||||
logger: logger,
|
logger: logger,
|
||||||
}, nil
|
}, nil
|
||||||
|
|
@ -145,8 +149,8 @@ func (a *App) Run() error {
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// Display-Zeitplan-Scheduler
|
// Display-Zeitplan-Scheduler
|
||||||
go scheduler.Run(ctx, a.scheduleStore, a.screenStore, a.notifier)
|
go scheduler.Run(ctx, a.scheduleStore, a.screenStore, a.globalOverrideStore, a.notifier)
|
||||||
go scheduler.Reconcile(ctx, a.scheduleStore, a.screenStore, a.screenStore, a.notifier)
|
go scheduler.Reconcile(ctx, a.scheduleStore, a.screenStore, a.screenStore, a.globalOverrideStore, a.notifier)
|
||||||
|
|
||||||
// W2: Signal-Handler für Graceful Shutdown.
|
// W2: Signal-Handler für Graceful Shutdown.
|
||||||
sigCh := make(chan os.Signal, 1)
|
sigCh := make(chan os.Signal, 1)
|
||||||
|
|
|
||||||
|
|
@ -21,8 +21,9 @@ type RouterDeps struct {
|
||||||
AuthStore *store.AuthStore
|
AuthStore *store.AuthStore
|
||||||
Notifier *mqttnotifier.Notifier
|
Notifier *mqttnotifier.Notifier
|
||||||
ScreenshotStore *ScreenshotStore
|
ScreenshotStore *ScreenshotStore
|
||||||
ScheduleStore *store.ScreenScheduleStore
|
ScheduleStore *store.ScreenScheduleStore
|
||||||
Config config.Config
|
GlobalOverrideStore *store.GlobalOverrideStore
|
||||||
|
Config config.Config
|
||||||
UploadDir string
|
UploadDir string
|
||||||
Logger *log.Logger
|
Logger *log.Logger
|
||||||
}
|
}
|
||||||
|
|
@ -192,6 +193,18 @@ func registerManageRoutes(mux *http.ServeMux, d RouterDeps) {
|
||||||
mux.Handle("POST /api/v1/screens/{screenSlug}/schedule",
|
mux.Handle("POST /api/v1/screens/{screenSlug}/schedule",
|
||||||
authScreen(http.HandlerFunc(manage.HandleUpdateSchedule(d.ScreenStore, d.ScheduleStore))))
|
authScreen(http.HandlerFunc(manage.HandleUpdateSchedule(d.ScreenStore, d.ScheduleStore))))
|
||||||
|
|
||||||
|
// ── Globaler Override ────────────────────────────────────────────────
|
||||||
|
mux.Handle("GET /api/v1/global-override",
|
||||||
|
authOnly(http.HandlerFunc(manage.HandleGetGlobalOverride(d.GlobalOverrideStore))))
|
||||||
|
mux.Handle("POST /api/v1/global-override",
|
||||||
|
authOnly(http.HandlerFunc(manage.HandleSetGlobalOverride(d.GlobalOverrideStore, d.ScreenStore, notifier))))
|
||||||
|
mux.Handle("DELETE /api/v1/global-override",
|
||||||
|
authOnly(http.HandlerFunc(manage.HandleDeleteGlobalOverride(d.GlobalOverrideStore))))
|
||||||
|
|
||||||
|
// ── Per-Screen Override ───────────────────────────────────────────────
|
||||||
|
mux.Handle("POST /api/v1/screens/{screenSlug}/override",
|
||||||
|
authScreen(http.HandlerFunc(manage.HandleSetScreenOverride(d.ScreenStore, d.ScheduleStore))))
|
||||||
|
|
||||||
// ── JSON API — screens ────────────────────────────────────────────────
|
// ── JSON API — screens ────────────────────────────────────────────────
|
||||||
// Self-registration: no auth (player calls this on startup).
|
// Self-registration: no auth (player calls this on startup).
|
||||||
mux.HandleFunc("POST /api/v1/screens/register",
|
mux.HandleFunc("POST /api/v1/screens/register",
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue