1
Fork 0
mirror of https://github.com/jech/galene.git synced 2024-11-22 16:45:58 +01:00

Fix error handling at websocket close.

This commit is contained in:
Juliusz Chroboczek 2020-12-05 01:18:27 +01:00
parent 26e6ecc3bc
commit e8c732c54c

View file

@ -657,13 +657,13 @@ func readMessage(conn *websocket.Conn, m *clientMessage) error {
return conn.ReadJSON(&m) return conn.ReadJSON(&m)
} }
func StartClient(conn *websocket.Conn) error { func StartClient(conn *websocket.Conn) (err error) {
var m clientMessage var m clientMessage
err := readMessage(conn, &m) err = readMessage(conn, &m)
if err != nil { if err != nil {
conn.Close() conn.Close()
return err return
} }
if m.Type != "handshake" { if m.Type != "handshake" {
@ -674,7 +674,8 @@ func StartClient(conn *websocket.Conn) error {
), ),
) )
conn.Close() conn.Close()
return group.ProtocolError("client didn't handshake") err = group.ProtocolError("client didn't handshake")
return
} }
c := &webClient{ c := &webClient{
@ -689,14 +690,15 @@ func StartClient(conn *websocket.Conn) error {
c.writerDone = make(chan struct{}) c.writerDone = make(chan struct{})
go clientWriter(conn, c.writeCh, c.writerDone) go clientWriter(conn, c.writeCh, c.writerDone)
defer func() { defer func() {
var e []byte m, e := errorToWSCloseMessage(c.id, err)
if !isWSNormalError(err) { if isWSNormalError(err) {
var m *clientMessage err = nil
m, e = errorToWSCloseMessage(c.id, err) } else if _, ok := err.(group.KickError); ok {
err = nil
}
if m != nil { if m != nil {
c.write(*m) c.write(*m)
} }
}
c.close(e) c.close(e)
}() }()