yanic/database/socket/internal.go

36 lines
683 B
Go
Raw Normal View History

2017-04-27 21:09:46 +02:00
package socket
import (
"encoding/json"
2017-04-27 22:28:31 +02:00
"log"
2017-04-27 21:09:46 +02:00
"net"
)
2017-04-27 22:44:06 +02:00
func (conn *Connection) handleSocketConnection(ln net.Listener) {
2017-04-27 21:09:46 +02:00
for {
c, err := ln.Accept()
if err != nil {
2017-04-27 22:28:31 +02:00
log.Println("[socket-database] error during connection of a client", err)
2017-04-27 21:09:46 +02:00
continue
}
2017-04-27 22:44:06 +02:00
conn.clientMux.Lock()
conn.clients[c.RemoteAddr()] = c
conn.clientMux.Unlock()
2017-04-27 21:09:46 +02:00
}
}
2017-05-29 21:33:51 +02:00
func (conn *Connection) sendJSON(msg Message) {
2017-04-27 22:44:06 +02:00
conn.clientMux.Lock()
2017-04-27 22:28:31 +02:00
for addr, c := range conn.clients {
2017-04-27 21:09:46 +02:00
d := json.NewEncoder(c)
err := d.Encode(&msg)
if err != nil {
2017-04-27 22:28:31 +02:00
log.Println("[socket-database] client has not recieve event:", err)
2017-04-27 21:45:44 +02:00
c.Close()
2017-04-27 22:28:31 +02:00
delete(conn.clients, addr)
2017-04-27 21:09:46 +02:00
}
}
2017-04-27 22:44:06 +02:00
conn.clientMux.Unlock()
2017-04-27 21:09:46 +02:00
}