WebSocketServer/socketserver/hub.go

88 lines
2.5 KiB
Go

package socketserver
import (
"clickandjoin.app/websocketserver/modules/cache"
"clickandjoin.app/websocketserver/modules/rabbitmq"
"clickandjoin.app/websocketserver/modules/structs"
"clickandjoin.app/websocketserver/modules/utils"
"clickandjoin.app/websocketserver/socketclients"
"github.com/gofiber/websocket/v2"
"github.com/google/uuid"
"github.com/sirupsen/logrus"
)
var register = make(chan *structs.SocketClient)
var broadcast = make(chan structs.SocketMessage)
var unregister = make(chan *websocket.Conn)
func RunHub() {
for {
select {
case newSocketClient := <-register:
uuid := uuid.New().String()
queueName, err := rabbitmq.CreateClientBinding(newSocketClient, uuid)
if err != nil {
logrus.Errorln("Failed to create client binding, err:", err)
break
}
newSocketClient.RabbitMqQueueName = queueName
cache.SocketClients[uuid] = newSocketClient
logrus.Debugln("REGISTER CLIENT:", uuid)
// for testing
marshaled, err := utils.MarshalMessage(structs.SocketMessageTest{Cmd: 99999, Body: uuid})
if err != nil {
logrus.Errorln("Failed to marshal uuid, err:", err)
break
}
newSocketClient.Conn.WriteMessage(websocket.TextMessage, []byte(marshaled))
case data := <-broadcast:
var receivedMessage structs.ReceivedMessage
err := utils.UnmarshalReceivedMessage(data.Msg, &receivedMessage)
if err != nil {
logrus.Errorln("Failed to unmarshal received msg, err:", err)
}
logrus.Debugln("RECEIVED WEBSOCKET MESSAGE:", receivedMessage)
if receivedMessage.Rec != "" {
isConnected, recSocketClient := socketclients.IsReceiverConnectedToThisServer(receivedMessage.Rec)
// send message to target receiver when connected to this server
if isConnected {
logrus.Debugln("FORWARDING MESSAGE: receiver is on connected to this server")
recSocketClient.SendMessage(structs.SendSocketMessage{Cmd: receivedMessage.Cmd, Body: receivedMessage.Body})
} else {
logrus.Debugln("FORWARDING MESSAGE: receiver connected to other server")
err = rabbitmq.PublishClientMessage(structs.RabbitMqMessage{Cmd: receivedMessage.Cmd, Rec: receivedMessage.Rec, Body: receivedMessage.Body})
if err != nil {
logrus.Errorln("Failed to publish client message, err:", err)
}
}
}
case connection := <-unregister:
for id, client := range cache.SocketClients {
if connection == client.Conn {
logrus.Debugln("UNREGISTER CLIENT:", id)
delete(cache.SocketClients, id)
rabbitmq.DeleteClient(client.RabbitMqConsumerId, client.RabbitMqQueueName)
}
}
}
}
}