浏览代码

more refactoring/rewrites for player data loading stuff

nossr50 4 年之前
父节点
当前提交
64e1d1a9d7

+ 5 - 0
pom.xml

@@ -200,6 +200,11 @@
             <artifactId>mcMMO-API</artifactId>
             <version>0.01.00-SNAPSHOT</version>
         </dependency>
+        <dependency>
+            <groupId>com.neetgames</groupId>
+            <artifactId>jmal-core</artifactId>
+            <version>0.01.00-SNAPSHOT</version>
+        </dependency>
         <dependency>
             <groupId>com.neetgames</groupId>
             <artifactId>jmal</artifactId>

+ 1 - 1
src/main/java/com/gmail/nossr50/chat/SamePartyPredicate.java

@@ -25,7 +25,7 @@ public class SamePartyPredicate<T extends CommandSender> implements Predicate<T>
         } else {
             if(t instanceof Player) {
                 Player player = (Player) t;
-                McMMOPlayer mcMMOPlayer = UserManager.getPlayer(player);
+                McMMOPlayer mcMMOPlayer = mcMMO.getUserManager().queryPlayer(player);
                 if(mcMMOPlayer != null) {
                     return mcMMOPlayer.getParty() == party;
                 }

+ 5 - 4
src/main/java/com/gmail/nossr50/commands/AbilityToggleCommand.java

@@ -4,26 +4,27 @@ import com.gmail.nossr50.datatypes.player.McMMOPlayer;
 import com.gmail.nossr50.locale.LocaleLoader;
 import com.gmail.nossr50.util.Permissions;
 import org.bukkit.command.CommandSender;
+import org.jetbrains.annotations.NotNull;
 
 public class AbilityToggleCommand extends ToggleCommand {
     @Override
-    protected boolean hasOtherPermission(CommandSender sender) {
+    protected boolean hasOtherPermission(@NotNull CommandSender sender) {
         return Permissions.mcabilityOthers(sender);
     }
 
     @Override
-    protected boolean hasSelfPermission(CommandSender sender) {
+    protected boolean hasSelfPermission(@NotNull CommandSender sender) {
         return Permissions.mcability(sender);
     }
 
     @Override
-    protected void applyCommandAction(McMMOPlayer mmoPlayer) {
+    protected void applyCommandAction(@NotNull McMMOPlayer mmoPlayer) {
         mmoPlayer.getPlayer().sendMessage(LocaleLoader.getString("Commands.Ability." + (mmoPlayer.getSuperAbilityManager().getAbilityActivationPermission() ? "Off" : "On")));
         mmoPlayer.getSuperAbilityManager().toggleAbilityActivationPermission();
     }
 
     @Override
-    protected void sendSuccessMessage(CommandSender sender, String playerName) {
+    protected void sendSuccessMessage(@NotNull CommandSender sender, @NotNull String playerName) {
         sender.sendMessage(LocaleLoader.getString("Commands.Ability.Toggle", playerName));
     }
 }

+ 2 - 2
src/main/java/com/gmail/nossr50/commands/CommandManager.java

@@ -97,13 +97,13 @@ public class CommandManager {
     }
 
     public void validateLoadedData(@NotNull Player player) {
-        if(UserManager.getPlayer(player) == null) {
+        if(mcMMO.getUserManager().queryPlayer(player) == null) {
             throw new ConditionFailedException("Your mcMMO player data has not yet loaded!");
         }
     }
 
     public void validatePlayerParty(@NotNull Player player) {
-        McMMOPlayer mmoPlayer = UserManager.getPlayer(player);
+        McMMOPlayer mmoPlayer = mcMMO.getUserManager().queryPlayer(player);
 
         if(mmoPlayer.getParty() == null) {
             throw new ConditionFailedException(LocaleLoader.getString("Commands.Party.None"));

+ 5 - 4
src/main/java/com/gmail/nossr50/commands/MHDCommand.java

@@ -3,6 +3,7 @@ package com.gmail.nossr50.commands;
 import com.gmail.nossr50.config.Config;
 import com.gmail.nossr50.database.FlatFileDatabaseManager;
 import com.gmail.nossr50.database.SQLDatabaseManager;
+import com.gmail.nossr50.datatypes.player.McMMOPlayer;
 import com.gmail.nossr50.mcMMO;
 import com.google.common.collect.ImmutableList;
 import org.bukkit.command.Command;
@@ -19,8 +20,8 @@ public class MHDCommand implements TabExecutor {
         if (mcMMO.getDatabaseManager() instanceof SQLDatabaseManager) {
             SQLDatabaseManager m = (SQLDatabaseManager) mcMMO.getDatabaseManager();
             m.resetMobHealthSettings();
-            for (mmoPlayer player : mcMMO.getUserManager().getPlayers()) {
-                player.getProfile().setMobHealthbarType(Config.getInstance().getMobHealthbarDefault());
+            for (McMMOPlayer mmoPlayer : mcMMO.getUserManager().getPlayers()) {
+                mmoPlayer.setMobHealthBarType(Config.getInstance().getMobHealthbarDefault());
             }
             sender.sendMessage("Mob health reset");
             return true;
@@ -28,8 +29,8 @@ public class MHDCommand implements TabExecutor {
         if (mcMMO.getDatabaseManager() instanceof FlatFileDatabaseManager) {
             FlatFileDatabaseManager m = (FlatFileDatabaseManager) mcMMO.getDatabaseManager();
             m.resetMobHealthSettings();
-            for (mmoPlayer player : mcMMO.getUserManager().getPlayers()) {
-                player.getProfile().setMobHealthbarType(Config.getInstance().getMobHealthbarDefault());
+            for (McMMOPlayer mmoPlayer : mcMMO.getUserManager().getPlayers()) {
+                mmoPlayer.setMobHealthBarType(Config.getInstance().getMobHealthbarDefault());
             }
             sender.sendMessage("Mob health reset");
             return true;

+ 5 - 4
src/main/java/com/gmail/nossr50/commands/McgodCommand.java

@@ -4,26 +4,27 @@ import com.gmail.nossr50.datatypes.player.McMMOPlayer;
 import com.gmail.nossr50.locale.LocaleLoader;
 import com.gmail.nossr50.util.Permissions;
 import org.bukkit.command.CommandSender;
+import org.jetbrains.annotations.NotNull;
 
 public class McgodCommand extends ToggleCommand {
     @Override
-    protected boolean hasOtherPermission(CommandSender sender) {
+    protected boolean hasOtherPermission(@NotNull CommandSender sender) {
         return Permissions.mcgodOthers(sender);
     }
 
     @Override
-    protected boolean hasSelfPermission(CommandSender sender) {
+    protected boolean hasSelfPermission(@NotNull CommandSender sender) {
         return Permissions.mcgod(sender);
     }
 
     @Override
-    protected void applyCommandAction(McMMOPlayer mmoPlayer) {
+    protected void applyCommandAction(@NotNull McMMOPlayer mmoPlayer) {
         mmoPlayer.getPlayer().sendMessage(LocaleLoader.getString("Commands.GodMode." + (mmoPlayer.getGodMode() ? "Disabled" : "Enabled")));
         mmoPlayer.toggleGodMode();
     }
 
     @Override
-    protected void sendSuccessMessage(CommandSender sender, String playerName) {
+    protected void sendSuccessMessage(@NotNull CommandSender sender, @NotNull String playerName) {
         sender.sendMessage(LocaleLoader.getString("Commands.GodMode.Toggle", playerName));
     }
 }

+ 7 - 6
src/main/java/com/gmail/nossr50/commands/McrefreshCommand.java

@@ -4,30 +4,31 @@ import com.gmail.nossr50.datatypes.player.McMMOPlayer;
 import com.gmail.nossr50.locale.LocaleLoader;
 import com.gmail.nossr50.util.Permissions;
 import org.bukkit.command.CommandSender;
+import org.jetbrains.annotations.NotNull;
 
 public class McrefreshCommand extends ToggleCommand {
     @Override
-    protected boolean hasOtherPermission(CommandSender sender) {
+    protected boolean hasOtherPermission(@NotNull CommandSender sender) {
         return Permissions.mcrefreshOthers(sender);
     }
 
     @Override
-    protected boolean hasSelfPermission(CommandSender sender) {
+    protected boolean hasSelfPermission(@NotNull CommandSender sender) {
         return Permissions.mcrefresh(sender);
     }
 
     @Override
-    protected void applyCommandAction(McMMOPlayer mmoPlayer) {
+    protected void applyCommandAction(@NotNull McMMOPlayer mmoPlayer) {
         mmoPlayer.setRecentlyHurtTimestamp(0);
-        mmoPlayer.resetCooldowns();
+        mmoPlayer.getSuperAbilityManager().resetCooldowns();
         mmoPlayer.getSuperAbilityManager().unprimeAllAbilityTools();
-        mmoPlayer.getSuperAbilityManager().resetSuperAbilities();
+        mmoPlayer.getSuperAbilityManager().disableSuperAbilities();
 
         mmoPlayer.getPlayer().sendMessage(LocaleLoader.getString("Ability.Generic.Refresh"));
     }
 
     @Override
-    protected void sendSuccessMessage(CommandSender sender, String playerName) {
+    protected void sendSuccessMessage(@NotNull CommandSender sender, @NotNull String playerName) {
         sender.sendMessage(LocaleLoader.getString("Commands.mcrefresh.Success", playerName));
     }
 }

+ 23 - 10
src/main/java/com/gmail/nossr50/commands/ToggleCommand.java

@@ -1,11 +1,16 @@
 package com.gmail.nossr50.commands;
 
 import com.gmail.nossr50.datatypes.player.McMMOPlayer;
+import com.gmail.nossr50.locale.LocaleLoader;
+import com.gmail.nossr50.mcMMO;
 import com.gmail.nossr50.util.commands.CommandUtils;
 import com.google.common.collect.ImmutableList;
+import org.bukkit.Bukkit;
+import org.bukkit.OfflinePlayer;
 import org.bukkit.command.Command;
 import org.bukkit.command.CommandSender;
 import org.bukkit.command.TabExecutor;
+import org.bukkit.entity.Player;
 import org.bukkit.util.StringUtil;
 import org.jetbrains.annotations.NotNull;
 
@@ -30,7 +35,14 @@ public abstract class ToggleCommand implements TabExecutor {
                     return true;
                 }
 
-                applyCommandAction(mcMMO.getUserManager().getPlayer(sender.getName()));
+                McMMOPlayer mmoPlayer = mcMMO.getUserManager().queryPlayer((Player) sender);
+
+                if(mmoPlayer != null) {
+                    applyCommandAction(mmoPlayer);
+                } else {
+                    mmoPlayer.getPlayer().sendMessage(LocaleLoader.getString("Commands.NotLoaded"));
+                }
+
                 return true;
 
             case 1:
@@ -40,17 +52,18 @@ public abstract class ToggleCommand implements TabExecutor {
                 }
 
                 String playerName = CommandUtils.getMatchedPlayerName(args[0]);
-                McMMOPlayer mmoPlayer = mcMMO.getUserManager().getPlayer(playerName);
+                Player otherPlayer = Bukkit.getPlayer(playerName);
+                McMMOPlayer mmoOther = mcMMO.getUserManager().queryPlayer(otherPlayer);
 
-                if (!CommandUtils.checkPlayerExistence(sender, playerName, mmoPlayer)) {
+                if (!CommandUtils.checkPlayerExistence(sender, playerName, mmoOther)) {
                     return true;
                 }
 
-                if (CommandUtils.isOffline(sender, mmoPlayer.getPlayer())) {
-                    return true;
+                if(mmoOther.getPlayer().isOnline()) {
+                    return false;
                 }
 
-                applyCommandAction(mmoPlayer);
+                applyCommandAction(mmoOther);
                 sendSuccessMessage(sender, playerName);
                 return true;
 
@@ -68,8 +81,8 @@ public abstract class ToggleCommand implements TabExecutor {
         return ImmutableList.of();
     }
 
-    protected abstract boolean hasOtherPermission(CommandSender sender);
-    protected abstract boolean hasSelfPermission(CommandSender sender);
-    protected abstract void applyCommandAction(McMMOPlayer mmoPlayer);
-    protected abstract void sendSuccessMessage(CommandSender sender, String playerName);
+    protected abstract boolean hasOtherPermission(@NotNull CommandSender sender);
+    protected abstract boolean hasSelfPermission(@NotNull CommandSender sender);
+    protected abstract void applyCommandAction(@NotNull McMMOPlayer mmoPlayer);
+    protected abstract void sendSuccessMessage(@NotNull CommandSender sender, @NotNull String playerName);
 }

+ 9 - 1
src/main/java/com/gmail/nossr50/commands/admin/PlayerDebugCommand.java

@@ -1,6 +1,8 @@
 package com.gmail.nossr50.commands.admin;
 
 import com.gmail.nossr50.datatypes.player.McMMOPlayer;
+import com.gmail.nossr50.locale.LocaleLoader;
+import com.gmail.nossr50.mcMMO;
 import com.gmail.nossr50.util.player.NotificationManager;
 import org.bukkit.command.Command;
 import org.bukkit.command.CommandExecutor;
@@ -13,7 +15,13 @@ public class PlayerDebugCommand implements CommandExecutor {
     @Override
     public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String[] args) {
         if(sender instanceof Player) {
-            McMMOPlayer mmoPlayer = mcMMO.getUserManager().getPlayer((Player) sender);
+            McMMOPlayer mmoPlayer = mcMMO.getUserManager().queryPlayer((Player) sender);
+
+            if(mmoPlayer == null) {
+                sender.sendMessage(LocaleLoader.getString("Commands.NotLoaded"));
+                return true;
+            }
+
             mmoPlayer.toggleDebugMode(); //Toggle debug mode
             NotificationManager.sendPlayerInformationChatOnlyPrefixed(mmoPlayer.getPlayer(), "Commands.Mmodebug.Toggle", String.valueOf(mmoPlayer.isDebugMode()));
             return true;

+ 5 - 4
src/main/java/com/gmail/nossr50/commands/chat/McChatSpy.java

@@ -5,26 +5,27 @@ import com.gmail.nossr50.datatypes.player.McMMOPlayer;
 import com.gmail.nossr50.locale.LocaleLoader;
 import com.gmail.nossr50.util.Permissions;
 import org.bukkit.command.CommandSender;
+import org.jetbrains.annotations.NotNull;
 
 public class McChatSpy extends ToggleCommand {
     @Override
-    protected boolean hasOtherPermission(CommandSender sender) {
+    protected boolean hasOtherPermission(@NotNull CommandSender sender) {
         return Permissions.adminChatSpyOthers(sender);
     }
 
     @Override
-    protected boolean hasSelfPermission(CommandSender sender) {
+    protected boolean hasSelfPermission(@NotNull CommandSender sender) {
         return Permissions.adminChatSpy(sender);
     }
 
     @Override
-    protected void applyCommandAction(McMMOPlayer mmoPlayer) {
+    protected void applyCommandAction(@NotNull McMMOPlayer mmoPlayer) {
         mmoPlayer.getPlayer().sendMessage(LocaleLoader.getString("Commands.AdminChatSpy." + (mmoPlayer.isPartyChatSpying() ? "Disabled" : "Enabled")));
         mmoPlayer.togglePartyChatSpying();
     }
 
     @Override
-    protected void sendSuccessMessage(CommandSender sender, String playerName) {
+    protected void sendSuccessMessage(@NotNull CommandSender sender, @NotNull String playerName) {
         sender.sendMessage(LocaleLoader.getString("Commands.AdminChatSpy.Toggle", playerName));
     }
 }

+ 25 - 19
src/main/java/com/gmail/nossr50/commands/player/InspectCommand.java

@@ -10,6 +10,7 @@ import com.gmail.nossr50.util.Permissions;
 import com.gmail.nossr50.util.commands.CommandUtils;
 import com.gmail.nossr50.util.scoreboards.ScoreboardManager;
 import com.google.common.collect.ImmutableList;
+import org.bukkit.Bukkit;
 import org.bukkit.command.Command;
 import org.bukkit.command.CommandSender;
 import org.bukkit.command.TabExecutor;
@@ -25,17 +26,23 @@ public class InspectCommand implements TabExecutor {
     public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String[] args) {
         if (args.length == 1) {
             String playerName = CommandUtils.getMatchedPlayerName(args[0]);
-            McMMOPlayer mmoPlayer = mcMMO.getUserManager().queryPlayerName(playerName);
 
-            // If the mmoPlayer doesn't exist, create a temporary profile and check if it's present in the database. If it's not, abort the process.
-            if (mmoPlayer == null) {
-                PlayerProfile profile = mcMMO.getDatabaseManager().queryPlayerDataByUUID(playerName, false); // Temporary Profile
+            PlayerProfile playerProfile = mcMMO.getUserManager().queryPlayer(playerName);
+            Player targetPlayer = Bukkit.getPlayer(playerName);
 
-                if (!CommandUtils.isLoaded(sender, profile)) {
-                    return true;
-                }
+            if(playerProfile == null) {
+                //TODO: Localize
+                sender.sendMessage("Data was not found in the database for the given player name!");
+                return true;
+            }
 
-                if (Config.getInstance().getScoreboardsEnabled() && sender instanceof Player && Config.getInstance().getInspectUseBoard()) {
+
+            if(targetPlayer == null) {
+                //Target is offline
+
+                if (Config.getInstance().getScoreboardsEnabled()
+                        && sender instanceof Player
+                        && Config.getInstance().getInspectUseBoard()) {
                     ScoreboardManager.enablePlayerInspectScoreboard((Player) sender, profile);
 
                     if (!Config.getInstance().getInspectUseChat()) {
@@ -59,30 +66,29 @@ public class InspectCommand implements TabExecutor {
                 for (PrimarySkillType skill : PrimarySkillType.MISC_SKILLS) {
                     sender.sendMessage(CommandUtils.displaySkill(profile, skill));
                 }
-
             } else {
-                Player target = mmoPlayer.getPlayer();
 
-                if (CommandUtils.hidden(sender, target, Permissions.inspectHidden(sender))) {
+                if (CommandUtils.hidden(sender, targetPlayer, Permissions.inspectHidden(sender))) {
                     sender.sendMessage(LocaleLoader.getString("Inspect.Offline"));
                     return true;
-                } else if (CommandUtils.tooFar(sender, target, Permissions.inspectFar(sender))) {
+                } else if (CommandUtils.tooFar(sender, targetPlayer, Permissions.inspectFar(sender))) {
                     return true;
                 }
 
-                if (Config.getInstance().getScoreboardsEnabled() && sender instanceof Player && Config.getInstance().getInspectUseBoard()) {
-                    ScoreboardManager.enablePlayerInspectScoreboard((Player) sender, mmoPlayer);
+                if (Config.getInstance().getScoreboardsEnabled()
+                        && sender instanceof Player && Config.getInstance().getInspectUseBoard()) {
+                    ScoreboardManager.enablePlayerInspectScoreboard((Player) sender, playerProfile);
 
                     if (!Config.getInstance().getInspectUseChat()) {
                         return true;
                     }
                 }
 
-                sender.sendMessage(LocaleLoader.getString("Inspect.Stats", target.getName()));
-                CommandUtils.printGatheringSkills(target, sender);
-                CommandUtils.printCombatSkills(target, sender);
-                CommandUtils.printMiscSkills(target, sender);
-                sender.sendMessage(LocaleLoader.getString("Commands.PowerLevel", mmoPlayer.getPowerLevel()));
+                sender.sendMessage(LocaleLoader.getString("Inspect.Stats", targetPlayer.getName()));
+                CommandUtils.printGatheringSkills(targetPlayer, sender);
+                CommandUtils.printCombatSkills(targetPlayer, sender);
+                CommandUtils.printMiscSkills(targetPlayer, sender);
+                sender.sendMessage(LocaleLoader.getString("Commands.PowerLevel", playerProfile.getExperienceManager().getPowerLevel()));
             }
 
             return true;

+ 1 - 1
src/main/java/com/gmail/nossr50/database/AbstractDatabaseManager.java

@@ -1,9 +1,9 @@
 package com.gmail.nossr50.database;
 
-import com.gmail.nossr50.api.exceptions.ProfileRetrievalException;
 import com.gmail.nossr50.datatypes.player.PersistentPlayerDataBuilder;
 import com.gmail.nossr50.datatypes.player.PlayerProfile;
 import com.gmail.nossr50.mcMMO;
+import com.neetgames.mcmmo.exceptions.ProfileRetrievalException;
 import org.apache.commons.lang.NullArgumentException;
 import org.bukkit.entity.Player;
 import org.jetbrains.annotations.NotNull;

+ 11 - 2
src/main/java/com/gmail/nossr50/database/DatabaseManager.java

@@ -1,13 +1,13 @@
 package com.gmail.nossr50.database;
 
-import com.gmail.nossr50.api.exceptions.InvalidSkillException;
-import com.gmail.nossr50.api.exceptions.ProfileRetrievalException;
 import com.gmail.nossr50.config.Config;
 import com.gmail.nossr50.datatypes.database.DatabaseType;
 import com.gmail.nossr50.datatypes.database.PlayerStat;
 import com.gmail.nossr50.datatypes.player.MMODataSnapshot;
 import com.gmail.nossr50.datatypes.player.PlayerProfile;
 import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
+import com.neetgames.mcmmo.exceptions.InvalidSkillException;
+import com.neetgames.mcmmo.exceptions.ProfileRetrievalException;
 import org.apache.commons.lang.NullArgumentException;
 import org.bukkit.entity.Player;
 import org.jetbrains.annotations.NotNull;
@@ -97,6 +97,15 @@ public interface DatabaseManager {
      */
     @Nullable PlayerProfile queryPlayerDataByUUID(@NotNull UUID uuid, @NotNull String playerName) throws ProfileRetrievalException, NullArgumentException;
 
+    /**
+     * Load player data (in the form of {@link PlayerProfile}) if player data exists
+     * Returns null if it doesn't
+     *
+     * @param playerName the current player name for this player
+     * @return The player's data, or null if not found
+     */
+    @Nullable PlayerProfile queryPlayerByName(@NotNull String playerName) throws ProfileRetrievalException;
+
     /**
      * This method queries the DB for player data for target player
      * If it fails to find data for this player, or if it does find data but the data is corrupted,

+ 1 - 6
src/main/java/com/gmail/nossr50/datatypes/player/McMMOPlayer.java

@@ -38,17 +38,12 @@ import net.kyori.adventure.identity.Identity;
 import org.bukkit.Location;
 import org.bukkit.entity.Player;
 import org.bukkit.metadata.FixedMetadataValue;
-import org.bukkit.permissions.Permissible;
-import org.bukkit.permissions.Permission;
-import org.bukkit.permissions.PermissionAttachment;
-import org.bukkit.permissions.PermissionAttachmentInfo;
 import org.bukkit.plugin.Plugin;
 import org.jetbrains.annotations.NotNull;
 import org.jetbrains.annotations.Nullable;
 
 import java.util.HashMap;
 import java.util.Map;
-import java.util.Set;
 import java.util.UUID;
 
 public class McMMOPlayer extends PlayerProfile implements Identified {
@@ -549,7 +544,7 @@ public class McMMOPlayer extends PlayerProfile implements Identified {
      * Etc...
      */
     public void cleanup() {
-        superAbilityManager.resetSuperAbilities();
+        superAbilityManager.disableSuperAbilities();
         getTamingManager().cleanupAllSummons();
     }
 

+ 1 - 1
src/main/java/com/gmail/nossr50/listeners/CommandListener.java

@@ -26,7 +26,7 @@
 //
 //        SkillUtils.removeAbilityBoostsFromInventory(player);
 //
-//        McMMOPlayer mmoPlayer = UserManager.getPlayer(player);
+//        McMMOPlayer mmoPlayer = mcMMO.getUserManager().queryPlayer(player);
 //
 //        if(mmoPlayer == null)
 //            return;

+ 3 - 2
src/main/java/com/gmail/nossr50/mcMMO.java

@@ -57,6 +57,7 @@ import org.bukkit.event.HandlerList;
 import org.bukkit.metadata.FixedMetadataValue;
 import org.bukkit.plugin.PluginManager;
 import org.bukkit.plugin.java.JavaPlugin;
+import org.jetbrains.annotations.NotNull;
 
 import java.io.File;
 import java.io.IOException;
@@ -428,7 +429,7 @@ public class mcMMO extends JavaPlugin {
         return salvageableManager;
     }
 
-    public static DatabaseManager getDatabaseManager() {
+    public static @NotNull DatabaseManager getDatabaseManager() {
         return databaseManager;
     }
 
@@ -666,7 +667,7 @@ public class mcMMO extends JavaPlugin {
         return spawnedProjectileTracker;
     }
 
-    public static UserManager getUserManager() {
+    public static @NotNull UserManager getUserManager() {
         return userManager;
     }
 

+ 3 - 11
src/main/java/com/gmail/nossr50/util/commands/CommandUtils.java

@@ -13,6 +13,7 @@ import com.google.common.collect.ImmutableList;
 import org.bukkit.OfflinePlayer;
 import org.bukkit.command.CommandSender;
 import org.bukkit.entity.Player;
+import org.jetbrains.annotations.NotNull;
 
 import java.util.ArrayList;
 import java.util.List;
@@ -118,15 +119,6 @@ public final class CommandUtils {
         return hasPlayerDataKey;
     }
 
-    public static boolean isLoaded(CommandSender sender, PlayerProfile profile) {
-        if (profile.isLoaded()) {
-            return true;
-        }
-
-        sender.sendMessage(LocaleLoader.getString("Commands.NotLoaded"));
-        return false;
-    }
-
     public static boolean isInvalidInteger(CommandSender sender, String value) {
         if (StringUtils.isInt(value)) {
             return false;
@@ -204,11 +196,11 @@ public final class CommandUtils {
         printMiscSkills(player, player);
     }
 
-    public static String displaySkill(PlayerProfile profile, PrimarySkillType skill) {
+    public static String displaySkill(@NotNull PlayerProfile profile, @NotNull PrimarySkillType skill) {
         if (skill.isChildSkill()) {
             return LocaleLoader.getString("Skills.ChildStats", LocaleLoader.getString(StringUtils.getCapitalized(skill.toString()) + ".Listener") + " ", profile.getSkillLevel(skill));
         }
-        if (profile.getSkillLevel(skill) == Config.getInstance().getLevelCap(skill)){
+        if (profile.getExperienceManager().getSkillLevel(skill) == Config.getInstance().getLevelCap(skill)){
             return LocaleLoader.getString("Skills.Stats", LocaleLoader.getString(StringUtils.getCapitalized(skill.toString()) + ".Listener") + " ", profile.getSkillLevel(skill), profile.getSkillXpLevel(skill), LocaleLoader.getString("Skills.MaxXP"));
         }
         return LocaleLoader.getString("Skills.Stats", LocaleLoader.getString(StringUtils.getCapitalized(skill.toString()) + ".Listener") + " ", profile.getSkillLevel(skill), profile.getSkillXpLevel(skill), profile.getXpToLevel(skill));

+ 10 - 2
src/main/java/com/gmail/nossr50/util/input/SuperAbilityManager.java

@@ -4,6 +4,7 @@ import com.gmail.nossr50.config.AdvancedConfig;
 import com.gmail.nossr50.config.Config;
 import com.gmail.nossr50.datatypes.interactions.NotificationType;
 import com.gmail.nossr50.datatypes.player.McMMOPlayer;
+import com.gmail.nossr50.datatypes.player.PersistentPlayerData;
 import com.gmail.nossr50.datatypes.skills.AbilityToolType;
 import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
 import com.gmail.nossr50.datatypes.skills.SuperAbilityType;
@@ -20,6 +21,7 @@ import com.gmail.nossr50.util.sounds.SoundManager;
 import com.gmail.nossr50.util.sounds.SoundType;
 import org.bukkit.entity.Player;
 import org.bukkit.inventory.ItemStack;
+import org.jetbrains.annotations.NotNull;
 
 import java.util.HashMap;
 import java.util.Map;
@@ -35,9 +37,11 @@ public class SuperAbilityManager {
     private boolean abilityActivationPermission = true;
 
     private final Map<AbilityToolType, Boolean> toolMode = new HashMap<>();
+    private final PersistentPlayerData persistentPlayerData;
 
-    public SuperAbilityManager(McMMOPlayer mmoPlayer) {
+    public SuperAbilityManager(@NotNull McMMOPlayer mmoPlayer, @NotNull PersistentPlayerData persistentPlayerData) {
         this.mmoPlayer = mmoPlayer;
+        this.persistentPlayerData = persistentPlayerData;
         this.player = mmoPlayer.getPlayer();
 
         for (SuperAbilityType superAbilityType : SuperAbilityType.values()) {
@@ -231,13 +235,17 @@ public class SuperAbilityManager {
     /**
      * Reset the mode of all abilities.
      */
-    public void resetSuperAbilities() {
+    public void disableSuperAbilities() {
         for (SuperAbilityType ability : SuperAbilityType.values()) {
             // Correctly disable and handle any special deactivate code
             new AbilityDisableTask(mmoPlayer, ability).run();
         }
     }
 
+    public void resetCooldowns() {
+        this.persistentPlayerData.resetCooldowns();
+    }
+
     /**
      * Get the mode of an ability.
      *

+ 4 - 0
src/main/java/com/gmail/nossr50/util/player/UserManager.java

@@ -67,6 +67,10 @@ public final class UserManager {
             return null;
     }
 
+    public @Nullable PlayerProfile queryPlayer(@NotNull String playerName) {
+        return mcMMO.getDatabaseManager().queryPlayerByName(playerName);
+    }
+
     /**
      * Remove a user.
      *