From 7be9ecc4c69dd0fde14dfc02c9aeafca8975e413 Mon Sep 17 00:00:00 2001 From: RaidMax Date: Thu, 16 Jun 2022 18:44:49 -0500 Subject: [PATCH] optimize client searching --- SharedLibraryCore/Services/ClientService.cs | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/SharedLibraryCore/Services/ClientService.cs b/SharedLibraryCore/Services/ClientService.cs index 4e1c21c36..681aa6cf3 100644 --- a/SharedLibraryCore/Services/ClientService.cs +++ b/SharedLibraryCore/Services/ClientService.cs @@ -853,15 +853,16 @@ public async Task> FindClientsByIdentifier(string identifier) else { - iqClients = iqClients.Where(_client => networkId == _client.NetworkId || - linkIds.Contains(_client.AliasLinkId) - || !_appConfig.EnableImplicitAccountLinking && - _client.CurrentAlias.IPAddress != null && - _client.CurrentAlias.IPAddress == ipAddress); + iqClients = iqClients.Where(client => networkId == client.NetworkId || linkIds.Contains(client.AliasLinkId)); + } + + if (ipAddress is not null && !_appConfig.EnableImplicitAccountLinking) + { + iqClients = iqClients.Union(context.Clients.Where(client => client.CurrentAlias.IPAddress == ipAddress)); } // we want to project our results - var iqClientProjection = iqClients.OrderByDescending(_client => _client.LastConnection) + var iqClientProjection = iqClients.OrderByDescending(client => client.LastConnection) .Select(client => new PlayerInfo { Name = client.CurrentAlias.Name, @@ -878,7 +879,9 @@ public async Task> FindClientsByIdentifier(string identifier) // this is so we don't try to evaluate this in the linq to entities query foreach (var client in clients) + { client.Level = ((Permission)client.LevelInt).ToLocalizedLevelName(); + } return clients; }