// Copyright 2018 Team 254. All Rights Reserved. // Author: pat@patfairbank.com (Patrick Fairbank) // // Web routes for a placeholder display to be later configured by the server. package web import ( "github.com/Team254/cheesy-arena/model" "github.com/Team254/cheesy-arena/websocket" "net/http" ) // Shows a random ID to visually identify the display so that it can be configured on the server. func (web *Web) placeholderDisplayHandler(w http.ResponseWriter, r *http.Request) { if !web.userIsReader(w, r) { return } if !web.enforceDisplayConfiguration(w, r, nil) { return } template, err := web.parseFiles("templates/placeholder_display.html") if err != nil { handleWebErr(w, err) return } data := struct { *model.EventSettings }{web.arena.EventSettings} err = template.ExecuteTemplate(w, "placeholder_display.html", data) if err != nil { handleWebErr(w, err) return } } // The websocket endpoint for sending configuration commands to the display. func (web *Web) placeholderDisplayWebsocketHandler(w http.ResponseWriter, r *http.Request) { if !web.userIsReader(w, r) { return } display, err := web.registerDisplay(r) if err != nil { handleWebErr(w, err) return } defer web.arena.MarkDisplayDisconnected(display) ws, err := websocket.NewWebsocket(w, r) if err != nil { handleWebErr(w, err) return } defer ws.Close() // Subscribe the websocket to the notifiers whose messages will be passed on to the client. ws.HandleNotifiers(web.arena.DisplayConfigurationNotifier, web.arena.ReloadDisplaysNotifier) }