grain/server/relay.go

73 lines
1.4 KiB
Go

package relay
import (
"encoding/json"
"fmt"
"grain/server/handlers"
"grain/config"
relay "grain/server/types"
"golang.org/x/net/websocket"
)
func WebSocketHandler(ws *websocket.Conn) {
defer ws.Close()
var msg string
rateLimiter := config.GetRateLimiter()
subscriptions := make(map[string][]relay.Filter) // Subscription map scoped to the connection
for {
err := websocket.Message.Receive(ws, &msg)
if err != nil {
fmt.Println("Error receiving message:", err)
ws.Close()
return
}
fmt.Println("Received message:", msg)
if allowed, msg := rateLimiter.AllowWs(); !allowed {
websocket.Message.Send(ws, fmt.Sprintf(`{"error": "%s"}`, msg))
ws.Close()
return
}
var message []interface{}
err = json.Unmarshal([]byte(msg), &message)
if err != nil {
fmt.Println("Error parsing message:", err)
continue
}
if len(message) < 2 {
fmt.Println("Invalid message format")
continue
}
messageType, ok := message[0].(string)
if !ok {
fmt.Println("Invalid message type")
continue
}
switch messageType {
case "EVENT":
handlers.HandleEvent(ws, message)
case "REQ":
if allowed, msg := rateLimiter.AllowReq(); !allowed {
websocket.Message.Send(ws, fmt.Sprintf(`{"error": "%s"}`, msg))
ws.Close()
return
}
handlers.HandleReq(ws, message, subscriptions)
case "CLOSE":
handlers.HandleClose(ws, message)
default:
fmt.Println("Unknown message type:", messageType)
}
}
}