From f8c6d35abdf313fde72c7cb95a1340583d861e51 Mon Sep 17 00:00:00 2001 From: imthatgin Date: Tue, 2 Apr 2024 19:48:32 +0200 Subject: [PATCH] Fixes issue with ID being inconsistent --- router/network_client.go | 4 +++- router/router.go | 34 +++++++++++++++++----------------- 2 files changed, 20 insertions(+), 18 deletions(-) diff --git a/router/network_client.go b/router/network_client.go index f712ebc..543c37f 100644 --- a/router/network_client.go +++ b/router/network_client.go @@ -7,12 +7,14 @@ import ( ) type NetworkClient struct { + id string *websocket.Conn ctx context.Context } func NewNetworkClient(ctx context.Context, underlying *websocket.Conn) *NetworkClient { return &NetworkClient{ + id: GetId(underlying), Conn: underlying, ctx: ctx, } @@ -42,5 +44,5 @@ func (c *NetworkClient) SendMessageBytes(msgBytes []byte) error { } func (c *NetworkClient) Id() string { - return Id(c) + return c.id } diff --git a/router/router.go b/router/router.go index f8015c8..ea49de4 100644 --- a/router/router.go +++ b/router/router.go @@ -26,9 +26,10 @@ var ( callbacks = make(map[reflect.Type][]any) - idMap = make(map[*websocket.Conn]string) - clientMap = make(map[*websocket.Conn]*NetworkClient) - mapMutex sync.Mutex + idMap = make(map[*websocket.Conn]string) + idMapMutex sync.Mutex + clientMap = make(map[*websocket.Conn]*NetworkClient) + clientMapMutex sync.Mutex ) // On adds a callback to be called whenever the specified message type T is received. @@ -94,23 +95,22 @@ func ProcessMessage(sender *NetworkClient, msg []byte) error { } func Client(conn *websocket.Conn) *NetworkClient { - mapMutex.Lock() - defer mapMutex.Unlock() + clientMapMutex.Lock() + defer clientMapMutex.Unlock() client, ok := clientMap[conn] if ok { return client } - clientMap[conn] = NewNetworkClient(context.Background(), conn) return clientMap[conn] } -func Id(client *NetworkClient) string { - mapMutex.Lock() - defer mapMutex.Unlock() +func GetId(conn *websocket.Conn) string { + idMapMutex.Lock() + defer idMapMutex.Unlock() - id, ok := idMap[client.Conn] + id, ok := idMap[conn] if ok { return id } @@ -119,7 +119,7 @@ func Id(client *NetworkClient) string { _, _ = rand.Read(bytes) id = fmt.Sprintf("%x", bytes[:10]) - idMap[client.Conn] = id + idMap[conn] = id return id } @@ -128,8 +128,8 @@ func Id(client *NetworkClient) string { func Peers() []*NetworkClient { var peers []*NetworkClient - mapMutex.Lock() - defer mapMutex.Unlock() + clientMapMutex.Lock() + defer clientMapMutex.Unlock() for _, v := range clientMap { peers = append(peers, v) @@ -179,8 +179,8 @@ func CallDisconnect(sender *websocket.Conn, err error) { go callback(client, err) } - mapMutex.Lock() - defer mapMutex.Unlock() + clientMapMutex.Lock() + defer clientMapMutex.Unlock() delete(idMap, sender) delete(clientMap, sender) @@ -200,8 +200,8 @@ func ResetRouter() { errorCallbacks = []func(sender *NetworkClient, err error){} callbacks = make(map[reflect.Type][]any) - mapMutex.Lock() - defer mapMutex.Unlock() + clientMapMutex.Lock() + defer clientMapMutex.Unlock() idMap = make(map[*websocket.Conn]string) clientMap = make(map[*websocket.Conn]*NetworkClient)