hub.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package server
  2. import (
  3. "context"
  4. "sync"
  5. "sikey.com/websocket/config"
  6. "x.sikey.com.cn/serverx/zlog"
  7. )
  8. type Hub struct {
  9. serverId string // serverId 服务器ID
  10. clients map[string]*Client
  11. mutex sync.RWMutex
  12. Connect chan *Client
  13. Disconnect chan *Client
  14. Message chan *Message
  15. FirebaseMessage chan *FirebaseMessage
  16. FCM *FirebaseMessageServer
  17. Nats *Nats
  18. }
  19. func NewHub(serverId string) *Hub {
  20. hub := &Hub{
  21. serverId: serverId,
  22. clients: make(map[string]*Client),
  23. mutex: sync.RWMutex{},
  24. Connect: make(chan *Client, config.Websocket.ConnectSize),
  25. Disconnect: make(chan *Client, config.Websocket.ConnectSize),
  26. Message: make(chan *Message, config.Websocket.MessageSize),
  27. Nats: NewNats(config.Websocket.NatsUrl),
  28. FCM: NewFirebaseMessageServer(),
  29. }
  30. go hub.run()
  31. return hub
  32. }
  33. func (h *Hub) run() {
  34. for {
  35. select {
  36. case client := <-h.Connect:
  37. h.mutex.Lock()
  38. // if c, ok := h.clients[client.UserId]; ok {
  39. // h.Disconnect <- c
  40. // }
  41. h.clients[client.UserId] = client
  42. h.mutex.Unlock()
  43. if h.Nats != nil {
  44. h.Nats.Subscribe <- &subscriber{client: client}
  45. }
  46. case client := <-h.Disconnect:
  47. h.mutex.Lock()
  48. close(client.Send)
  49. delete(h.clients, client.UserId)
  50. h.mutex.Unlock()
  51. if h.Nats != nil {
  52. h.Nats.Unsubscribe <- &subscriber{client: client}
  53. }
  54. case message := <-h.Message:
  55. h.mutex.RLock()
  56. zlog.Info("message: ", message)
  57. if client, ok := h.clients[message.Receiver]; ok {
  58. client.Send <- message
  59. } else {
  60. h.Nats.Send <- &natsMessage{userId: message.Receiver, message: message}
  61. }
  62. h.mutex.RUnlock()
  63. case firebaseMessage := <-h.FirebaseMessage:
  64. if err := h.FCM.Send(context.Background(), firebaseMessage.token, firebaseMessage.message); err != nil {
  65. zlog.Error("unable to send fcm message: ", err)
  66. }
  67. }
  68. }
  69. }
  70. func (h *Hub) GetClients() []string {
  71. h.mutex.RLock()
  72. defer h.mutex.RUnlock()
  73. var clients = make([]string, 0)
  74. for _, c := range h.clients {
  75. clients = append(clients, c.UserId)
  76. }
  77. return clients
  78. }
  79. func (h *Hub) getClientByUserId(userId string) *Client {
  80. h.mutex.RLock()
  81. defer h.mutex.RUnlock()
  82. if client, ok := h.clients[userId]; ok {
  83. return client
  84. }
  85. return nil
  86. }