-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathworker.go
85 lines (70 loc) · 1.82 KB
/
worker.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package lightcable
import (
"context"
)
type worker struct {
room string
server *Server
// Registered clients.
clients map[*Client]bool
// Register requests from the clients.
register chan *Client
// Inbound messages from the clients.
broadcast chan Message
// Unregister requests from clients.
unregister chan *Client
}
func newWorker(room string, server *Server) *worker {
return &worker{
room: room,
server: server,
clients: make(map[*Client]bool),
register: make(chan *Client, server.config.SignBufferCount),
broadcast: make(chan Message, server.config.CastBufferCount),
unregister: make(chan *Client, server.config.SignBufferCount),
}
}
func (w *worker) run(ctx context.Context) {
defer w.server.onRoomClose(w.room)
for {
select {
case client := <-w.register:
if len(w.clients) == 0 {
// This in order to noblock server threads, use worker threads callback
w.server.onRoomReady(w.room)
}
w.clients[client] = true
go client.readPump()
go client.writePump(ctx)
// client has two threads
// So execute the callback here
w.server.onConnReady(client)
case client := <-w.unregister:
if _, ok := w.clients[client]; ok {
delete(w.clients, client)
close(client.send)
}
// client has two threads
// So execute the callback here
w.server.onConnClose(client)
// Last client, need close this room
if len(w.clients) == 0 {
w.server.unregister <- client
// This in order to noblock server threads, use worker threads callback
w.server.onRoomClose(w.room)
return
}
case message := <-w.broadcast:
for client := range w.clients {
if w.server.config.Local || message.conn != client.conn {
select {
case client.send <- message:
default:
close(client.send)
delete(w.clients, client)
}
}
}
}
}
}