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
|
|
|
}
|