From c9426d11afcf7186a4ced3731bc1f15872c86233 Mon Sep 17 00:00:00 2001 From: Rainnny7 Date: Wed, 10 Apr 2024 07:24:24 -0400 Subject: [PATCH] Fix servers not caching --- src/main/java/me/braydon/mc/service/MojangService.java | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/src/main/java/me/braydon/mc/service/MojangService.java b/src/main/java/me/braydon/mc/service/MojangService.java index bd7ce1e..0e51e51 100644 --- a/src/main/java/me/braydon/mc/service/MojangService.java +++ b/src/main/java/me/braydon/mc/service/MojangService.java @@ -358,20 +358,18 @@ public final class MojangService { String lookupHostname = hostname; // The hostname used to lookup the server int port = platform.getDefaultPort(); // Port to ping - String portString = null; if (hostname.contains(":")) { // Hostname contains a port String[] split = hostname.split(":"); hostname = split[0]; - portString = split[1]; try { // Try and parse the port - port = Integer.parseInt(portString); + port = Integer.parseInt(split[1]); } catch (NumberFormatException ex) { // Invalid port throw new BadRequestException("Invalid port defined"); } } // Check the cache for the server - Optional cached = minecraftServerCache.findById(platform.name() + "-" + hostname + "-" + port); + Optional cached = minecraftServerCache.findById(platform.name() + "-" + lookupHostname); if (cached.isPresent()) { // Respond with the cache if present log.info("Found server in cache: {}", hostname); return cached.get(); @@ -384,7 +382,7 @@ public final class MojangService { // Build our server model, cache it, and then return it CachedMinecraftServer minecraftServer = new CachedMinecraftServer( - platform.name() + "-" + lookupHostname + "-" + (portString == null ? port : portString), + platform.name() + "-" + lookupHostname, platform.getPinger().ping(hostname, port), System.currentTimeMillis() );