From 63d2381c5b25ccc97179d38467f4f615fb007b7b Mon Sep 17 00:00:00 2001 From: Zrips Date: Tue, 16 Apr 2024 14:51:33 +0300 Subject: [PATCH] Async data load on login when in multiserver mode --- .../com/gamingmesh/jobs/PlayerManager.java | 62 +++++++++++++------ .../gamingmesh/jobs/commands/list/boost.java | 32 +++++----- .../jobs/commands/list/resetlimit.java | 4 +- .../com/gamingmesh/jobs/i18n/Language.java | 6 +- 4 files changed, 64 insertions(+), 40 deletions(-) diff --git a/src/main/java/com/gamingmesh/jobs/PlayerManager.java b/src/main/java/com/gamingmesh/jobs/PlayerManager.java index 9f285a1a..0c1b9481 100644 --- a/src/main/java/com/gamingmesh/jobs/PlayerManager.java +++ b/src/main/java/com/gamingmesh/jobs/PlayerManager.java @@ -24,6 +24,7 @@ import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.UUID; +import java.util.concurrent.CompletableFuture; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; import java.util.concurrent.ThreadLocalRandom; @@ -69,7 +70,6 @@ import net.Zrips.CMILib.Items.CMIItemStack; import net.Zrips.CMILib.Items.CMIMaterial; import net.Zrips.CMILib.Logs.CMIDebug; import net.Zrips.CMILib.Messages.CMIMessages; -import net.Zrips.CMILib.NBT.CMINBT; import net.Zrips.CMILib.Version.Version; import net.Zrips.CMILib.Version.Schedulers.CMIScheduler; @@ -232,29 +232,51 @@ public class PlayerManager { JobsPlayer jPlayer = playersUUIDCache.get(player.getUniqueId()); if (jPlayer == null || Jobs.getGCManager().MultiServerCompatability()) { - if (jPlayer != null) - jPlayer = Jobs.getJobsDAO().loadFromDao(jPlayer); - else - jPlayer = Jobs.getJobsDAO().loadFromDao(player); if (Jobs.getGCManager().MultiServerCompatability()) { - jPlayer.setArchivedJobs(Jobs.getJobsDAO().getArchivedJobs(jPlayer)); - jPlayer.setPaymentLimit(Jobs.getJobsDAO().getPlayersLimits(jPlayer)); - jPlayer.setPoints(Jobs.getJobsDAO().getPlayerPoints(jPlayer)); + CompletableFuture future = CompletableFuture.supplyAsync(() -> { + JobsPlayer jobsPlayer = playersUUIDCache.get(player.getUniqueId()); + jobsPlayer = jobsPlayer == null ? new JobsPlayer(player) : jobsPlayer; + loadPlayer(jobsPlayer); + return jobsPlayer; + }); + future.thenAccept(this::finalizeJoinPlayer); + return; } - // Lets load quest progression - PlayerInfo info = Jobs.getJobsDAO().loadPlayerData(player.getUniqueId()); - if (info != null) { - jPlayer.setDoneQuests(info.getQuestsDone()); - jPlayer.setQuestProgressionFromString(info.getQuestProgression()); - } + jPlayer = jPlayer == null ? new JobsPlayer(player) : jPlayer; + jPlayer = Jobs.getJobsDAO().loadFromDao(jPlayer); - Jobs.getJobsDAO().loadLog(jPlayer); + loadPlayer(jPlayer); } + finalizeJoinPlayer(jPlayer); + } + + private static void loadPlayer(JobsPlayer jPlayer) { + + Jobs.getJobsDAO().loadFromDao(jPlayer); + + if (Jobs.getGCManager().MultiServerCompatability()) { + jPlayer.setArchivedJobs(Jobs.getJobsDAO().getArchivedJobs(jPlayer)); + jPlayer.setPaymentLimit(Jobs.getJobsDAO().getPlayersLimits(jPlayer)); + jPlayer.setPoints(Jobs.getJobsDAO().getPlayerPoints(jPlayer)); + } + + // Lets load quest progression + PlayerInfo info = Jobs.getJobsDAO().loadPlayerData(jPlayer.getUniqueId()); + if (info != null) { + jPlayer.setDoneQuests(info.getQuestsDone()); + jPlayer.setQuestProgressionFromString(info.getQuestProgression()); + } + + Jobs.getJobsDAO().loadLog(jPlayer); + } + + private void finalizeJoinPlayer(JobsPlayer jPlayer) { + addPlayer(jPlayer); - autoJoinJobs(player); + autoJoinJobs(jPlayer.getPlayer()); jPlayer.onConnect(); jPlayer.reloadHonorific(); Jobs.getPermissionHandler().recalculatePermissions(jPlayer); @@ -488,9 +510,9 @@ public class PlayerManager { Jobs.takeSlot(job); Jobs.getSignUtil().updateAllSign(job); - + job.modifyTotalPlayerWorking(1); - + jPlayer.maxJobsEquation = CMINumber.clamp(getMaxJobs(jPlayer), 0, 9999); // Removing from cached item boost for recalculation @@ -535,7 +557,7 @@ public class PlayerManager { jPlayer.getLeftTimes().remove(jPlayer.getUniqueId()); Jobs.getSignUtil().updateAllSign(job); - + job.modifyTotalPlayerWorking(-1); // Removing from cached item boost for recalculation @@ -832,7 +854,7 @@ public class PlayerManager { message = message.replace("%playerdisplayname%", jPlayer.getDisplayName()); message = message.replace("%titlename%", levelUpEvent.getNewTitle() .getChatColor().toString() + levelUpEvent.getNewTitle().getName()); - + message = Language.updateJob(message, job); if (Jobs.getGCManager().isBroadcastingSkillups() || Jobs.getGCManager().TitleChangeActionBar || Jobs.getGCManager().TitleChangeChat) { diff --git a/src/main/java/com/gamingmesh/jobs/commands/list/boost.java b/src/main/java/com/gamingmesh/jobs/commands/list/boost.java index c683abb9..7a82198d 100644 --- a/src/main/java/com/gamingmesh/jobs/commands/list/boost.java +++ b/src/main/java/com/gamingmesh/jobs/commands/list/boost.java @@ -9,7 +9,6 @@ import com.gamingmesh.jobs.container.Job; import com.gamingmesh.jobs.i18n.Language; import net.Zrips.CMILib.Locale.LC; -import net.Zrips.CMILib.Logs.CMIDebug; import net.Zrips.CMILib.RawMessages.RawMessage; import net.Zrips.CMILib.Time.CMITimeManager; import net.Zrips.CMILib.Time.timeModifier; @@ -97,23 +96,26 @@ public class boost implements Cmd { } } Language.sendMessage(sender, "command.boost.output.allreset"); - } else { - for (Job one : Jobs.getJobs()) { - one.addBoost(type, 0); - } - Language.sendMessage(sender, "command.boost.output.alltypereset", "%type%", type.getDisplayName()); + return true; } - } else { - if (type == null) { - for (CurrencyType curr : CurrencyType.values()) { - job.addBoost(curr, 0); - } - Language.sendMessage(sender, "command.boost.output.jobsboostreset", job); - } else { - job.addBoost(type, 0); - Language.sendMessage(sender, "command.boost.output.jobstypeboostreset", job, "%type%", type.getDisplayName()); + + for (Job one : Jobs.getJobs()) { + one.addBoost(type, 0); } + Language.sendMessage(sender, "command.boost.output.alltypereset", "%type%", type.getDisplayName()); + return true; } + + if (type == null) { + for (CurrencyType curr : CurrencyType.values()) { + job.addBoost(curr, 0); + } + Language.sendMessage(sender, "command.boost.output.jobsboostreset", job); + return true; + } + + job.addBoost(type, 0); + Language.sendMessage(sender, "command.boost.output.jobstypeboostreset", job, "%type%", type.getDisplayName()); return true; } diff --git a/src/main/java/com/gamingmesh/jobs/commands/list/resetlimit.java b/src/main/java/com/gamingmesh/jobs/commands/list/resetlimit.java index 5ed223fa..fad4fc1b 100644 --- a/src/main/java/com/gamingmesh/jobs/commands/list/resetlimit.java +++ b/src/main/java/com/gamingmesh/jobs/commands/list/resetlimit.java @@ -11,9 +11,9 @@ public class resetlimit implements Cmd { @Override public Boolean perform(Jobs plugin, final CommandSender sender, final String[] args) { - if (args.length != 1) { + + if (args.length != 1) return false; - } if (args[0].equalsIgnoreCase("all")) { for (JobsPlayer jPlayer : Jobs.getPlayerManager().getPlayersCache().values()) { diff --git a/src/main/java/com/gamingmesh/jobs/i18n/Language.java b/src/main/java/com/gamingmesh/jobs/i18n/Language.java index 4496d770..1cd66829 100644 --- a/src/main/java/com/gamingmesh/jobs/i18n/Language.java +++ b/src/main/java/com/gamingmesh/jobs/i18n/Language.java @@ -53,9 +53,9 @@ public class Language { public static String updateJob(String text, Job job) { return text - .replaceAll("\\[jobname\\]|%jobname%", job.getName()) - .replaceAll("\\[jobdisplayname\\]|%jobdisplayname%", job.getDisplayName()) - .replaceAll("\\[jobfullname\\]|%jobfullname%", job.getJobFullName()); + .replaceAll("(\\[|%)jobname(\\]|%)", job.getName()) + .replaceAll("(\\[|%)jobdisplayname(\\]|%)", job.getDisplayName()) + .replaceAll("(\\[|%)jobfullname(\\]|%)", job.getJobFullName()); } public static void sendMessage(CommandSender sender, String key, Object... variables) {