sharded-gotify/api
Jannis Mattheis 79e1dc9c9a Prevent deadlock on stream.Close()
GR = goroutine
[GR#1] http server gets closed
[GR#2] client.NotifyClose() will be executed
[GR#2] client.once.Do will be executed (lock's client.once.m)
[GR#1] stream.Close will be executed (lock's stream.lock)
[GR#1] client.Close will be executed (waits for client.once.m)
[GR#2] stream.remove will be executed (waits for stream.lock)

GR#1 holds lock stream.lock and waits for client.once.m
GR#2 holds lock client.once.m and waits for stream.lock

We prevent the deadlock with releasing the client.once.m lock earlier.
2018-11-22 20:59:29 +01:00
..
stream Prevent deadlock on stream.Close() 2018-11-22 20:59:29 +01:00
internalutil.go Use gofmt -s 2018-03-25 19:33:29 +02:00
message.go [#71] Make title in message not necessary field 2018-11-14 20:05:24 +01:00
message_test.go [#71] Make title in message not necessary field 2018-11-14 20:05:24 +01:00
token.go Close web socket connection on delete client 2018-04-02 12:35:16 +02:00
token_test.go Remove monkey dependency 2018-11-06 21:38:15 +01:00
user.go Close web socket connection on delete user 2018-04-02 12:35:16 +02:00
user_test.go Close web socket connection on delete user 2018-04-02 12:35:16 +02:00