mirror of
https://github.com/Luzifer/twitch-manager.git
synced 2025-01-04 02:46:03 +00:00
Fix concurrent writes to socket
This commit is contained in:
parent
c3344534a8
commit
dce43ffd99
1 changed files with 18 additions and 2 deletions
20
api.go
20
api.go
|
@ -93,25 +93,41 @@ func handleUpdateSocket(w http.ResponseWriter, r *http.Request) {
|
|||
defer conn.Close()
|
||||
|
||||
// Register listener
|
||||
id := uuid.Must(uuid.NewV4()).String()
|
||||
subscribeSocket(id, conn.WriteJSON)
|
||||
var (
|
||||
connLock = new(sync.Mutex)
|
||||
id = uuid.Must(uuid.NewV4()).String()
|
||||
)
|
||||
subscribeSocket(id, func(msg interface{}) error {
|
||||
connLock.Lock()
|
||||
defer connLock.Unlock()
|
||||
|
||||
return conn.WriteJSON(msg)
|
||||
})
|
||||
defer unsubscribeSocket(id)
|
||||
|
||||
keepAlive := time.NewTicker(5 * time.Second)
|
||||
defer keepAlive.Stop()
|
||||
go func() {
|
||||
for range keepAlive.C {
|
||||
connLock.Lock()
|
||||
|
||||
if err := conn.WriteMessage(websocket.PingMessage, nil); err != nil {
|
||||
log.WithError(err).Error("Unable to send ping message")
|
||||
connLock.Unlock()
|
||||
conn.Close()
|
||||
return
|
||||
}
|
||||
|
||||
connLock.Unlock()
|
||||
}
|
||||
}()
|
||||
|
||||
connLock.Lock()
|
||||
if err := conn.WriteJSON(compileSocketMessage(msgTypeStore, store)); err != nil {
|
||||
log.WithError(err).Error("Unable to send initial state")
|
||||
return
|
||||
}
|
||||
connLock.Unlock()
|
||||
|
||||
// Handle socket
|
||||
for {
|
||||
|
|
Loading…
Reference in a new issue