From 4de654b6e46536a4cce9018e54763e3d75a7ce96 Mon Sep 17 00:00:00 2001 From: "Robin C. Ladiges" Date: Sat, 27 Apr 2024 17:50:28 +0200 Subject: [PATCH] ignore & crash instead of disconnect clients after reaching the MaxPlayers limit Otherwise they'll enter an endless disconnect-reconnnect loop spamming the server with new TCP connections. --- Server/Server.cs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/Server/Server.cs b/Server/Server.cs index 51d9ad0..555e204 100644 --- a/Server/Server.cs +++ b/Server/Server.cs @@ -197,6 +197,11 @@ async Task Read(Memory readMem, int readSize, int readOffset) { client.Ignored = true; client.Banned = true; } + // is the server full? + else if (Clients.Count(x => x.Connected) >= Settings.Instance.Server.MaxPlayers) { + client.Logger.Error($"Ignoring player {client.Name} ({client.Id}/{remote}) as server reached max players of {Settings.Instance.Server.MaxPlayers}"); + client.Ignored = true; + } // send server init (required to crash ignored players later) await client.Send(new InitPacket { @@ -213,11 +218,12 @@ await client.Send(new InitPacket { // add client to the set of connected players lock (Clients) { - // is the server full? - if (Clients.Count(x => x.Connected) == Settings.Instance.Server.MaxPlayers) { - client.Logger.Error($"Turned away as server is at max clients"); + // is the server full? (check again, to prevent race conditions) + if (Clients.Count(x => x.Connected) >= Settings.Instance.Server.MaxPlayers) { + client.Logger.Error($"Ignoring player {client.Name} ({client.Id}/{remote}) as server reached max players of {Settings.Instance.Server.MaxPlayers}"); + client.Ignored = true; memory.Dispose(); - goto disconnect; + continue; } // detect and handle reconnections @@ -354,7 +360,6 @@ await Parallel.ForEachAsync(otherConnectedPlayers, async (other, _) => { } // client disconnected - disconnect: if (client.Name != "Unknown User" && client.Id != Guid.Parse("00000000-0000-0000-0000-000000000000")) { Logger.Info($"Client {remote} ({client.Name}/{client.Id}) disconnected from the server"); }