mirror of
https://github.com/twofas/2fas-server.git
synced 2024-12-12 20:20:19 +01:00
41 lines
751 B
Go
41 lines
751 B
Go
|
package common
|
||
|
|
||
|
type Hub struct {
|
||
|
clients map[*Client]bool
|
||
|
broadcast chan []byte
|
||
|
register chan *Client
|
||
|
unregister chan *Client
|
||
|
}
|
||
|
|
||
|
func NewHub() *Hub {
|
||
|
return &Hub{
|
||
|
broadcast: make(chan []byte),
|
||
|
register: make(chan *Client),
|
||
|
unregister: make(chan *Client),
|
||
|
clients: make(map[*Client]bool),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (h *Hub) Run() {
|
||
|
for {
|
||
|
select {
|
||
|
case client := <-h.register:
|
||
|
h.clients[client] = true
|
||
|
case client := <-h.unregister:
|
||
|
if _, ok := h.clients[client]; ok {
|
||
|
delete(h.clients, client)
|
||
|
close(client.send)
|
||
|
}
|
||
|
case message := <-h.broadcast:
|
||
|
for client := range h.clients {
|
||
|
select {
|
||
|
case client.send <- message:
|
||
|
default:
|
||
|
close(client.send)
|
||
|
delete(h.clients, client)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|