hub.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package server
  2. import (
  3. "sync"
  4. "sikey.com/websocket/stackexchange"
  5. )
  6. type HubConfig struct {
  7. ConnectSize int
  8. DisconnectSize int
  9. MessageSize int
  10. StackExchange *stackexchange.StackExchange
  11. }
  12. type Hub struct {
  13. clients map[string]*Client
  14. mutex sync.RWMutex
  15. Connect chan *Client
  16. Disconnect chan *Client
  17. Message chan *Message
  18. }
  19. func NewHub(cfg HubConfig) *Hub {
  20. hub := &Hub{
  21. clients: make(map[string]*Client),
  22. mutex: sync.RWMutex{},
  23. Connect: make(chan *Client, cfg.ConnectSize),
  24. Disconnect: make(chan *Client, cfg.DisconnectSize),
  25. Message: make(chan *Message, cfg.MessageSize),
  26. }
  27. go hub.run()
  28. go hub.remote() // 远程消息
  29. return hub
  30. }
  31. func (h *Hub) run() {
  32. for {
  33. select {
  34. case client := <-h.Connect:
  35. h.clients[client.UserId] = client
  36. case client := <-h.Disconnect:
  37. close(client.Send)
  38. delete(h.clients, client.UserId)
  39. case message := <-h.Message:
  40. if client, ok := h.clients[message.receiver]; ok {
  41. client.Send <- message
  42. } else {
  43. // 不在同一台服务器, 这里将消息发送至拓展应用
  44. }
  45. }
  46. }
  47. }
  48. func (h *Hub) remote() {
  49. }