//package com.gmail.nossr50.api; // //import com.gmail.nossr50.config.Config; //import com.gmail.nossr50.config.experience.ExperienceConfig; //import com.gmail.nossr50.datatypes.experience.FormulaType; //import com.gmail.nossr50.datatypes.player.McMMOPlayer; //import com.gmail.nossr50.datatypes.player.PlayerProfile; //import com.gmail.nossr50.datatypes.skills.PrimarySkillType; //import com.gmail.nossr50.mcMMO; //import com.gmail.nossr50.skills.child.FamilyTree; //import com.gmail.nossr50.util.player.UserManager; //import com.gmail.nossr50.util.skills.CombatUtils; //import com.neetgames.mcmmo.exceptions.InvalidPlayerException; //import com.neetgames.mcmmo.exceptions.InvalidSkillException; //import com.neetgames.mcmmo.exceptions.InvalidXPGainReasonException; //import com.neetgames.mcmmo.experience.XPGainSource; //import org.bukkit.Bukkit; //import org.bukkit.OfflinePlayer; //import org.bukkit.block.BlockState; //import org.bukkit.entity.LivingEntity; //import org.bukkit.entity.Player; // //import java.util.ArrayList; //import java.util.Set; //import java.util.UUID; // //public final class ExperienceAPI { // private ExperienceAPI() {} // // /** // * Returns whether given string is a valid type of skill suitable for the // * other API calls in this class. // * </br> // * This function is designed for API usage. // * // * @param skillType A string that may or may not be a skill // * @return true if this is a valid mcMMO skill // */ // public static boolean isValidSkillType(String skillType) { // return PrimarySkillType.getSkill(skillType) != null; // } // // /** // * Start the task that gives combat XP. // * Processes combat XP like mcMMO normally would, so mcMMO will check whether or not the entity should reward XP when giving out the XP // * // * @param mcMMOPlayer The attacking player // * @param target The defending entity // * @param primarySkillType The skill being used // * @param multiplier final XP result will be multiplied by this // * @deprecated Draft API // */ // @Deprecated // public static void addCombatXP(McMMOPlayer mcMMOPlayer, LivingEntity target, PrimarySkillType primarySkillType, double multiplier) { // CombatUtils.processCombatXP(mcMMOPlayer, target, primarySkillType, multiplier); // } // // /** // * Start the task that gives combat XP. // * Processes combat XP like mcMMO normally would, so mcMMO will check whether or not the entity should reward XP when giving out the XP // * // * @param mcMMOPlayer The attacking player // * @param target The defending entity // * @param primarySkillType The skill being used // * @deprecated Draft API // */ // @Deprecated // public static void addCombatXP(McMMOPlayer mcMMOPlayer, LivingEntity target, PrimarySkillType primarySkillType) { // CombatUtils.processCombatXP(mcMMOPlayer, target, primarySkillType); // } // // /** // * Returns whether the given skill type string is both valid and not a // * child skill. (Child skills have no XP of their own, and their level is // * derived from the parent(s).) // * </br> // * This function is designed for API usage. // * // * @param skillType the skill to check // * @return true if this is a valid, non-child mcMMO skill // */ // public static boolean isNonChildSkill(String skillType) { // PrimarySkillType skill = PrimarySkillType.getSkill(skillType); // // return skill != null && !skill.isChildSkill(); // } // // @Deprecated // public static void addRawXP(Player player, String skillType, int XP) { // addRawXP(player, skillType, (float) XP); // } // // /** // * Adds raw XP to the player. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // */ // @Deprecated // public static void addRawXP(Player player, String skillType, float XP) { // addRawXP(player, skillType, XP, "UNKNOWN"); // } // // /** // * Adds raw XP to the player. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addRawXP(Player player, String skillType, float XP, String xpGainReason) { // addRawXP(player, skillType, XP, xpGainReason, false); // } // // /** // * Adds raw XP to the player. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * @param isUnshared true if the XP cannot be shared with party members // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addRawXP(Player player, String skillType, float XP, String xpGainReason, boolean isUnshared) { // if (isUnshared) { // getPlayer(player).beginUnsharedXpGain(getSkillType(skillType), XP, getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // return; // } // // getPlayer(player).applyXpGain(getSkillType(skillType), XP, getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // } // // /** // * Adds raw XP to an offline player. // * </br> // * This function is designed for API usage. // * // * @deprecated We're using float for our XP values now // * replaced by {@link #addRawXPOffline(String playerName, String skillType, float XP)} // */ // @Deprecated // public static void addRawXPOffline(String playerName, String skillType, int XP) { // addRawXPOffline(playerName, skillType, (float) XP); // } // // /** // * Adds raw XP to an offline player. // * </br> // * This function is designed for API usage. // * // * @deprecated We're using uuids to get an offline player // * replaced by {@link #addRawXPOffline(UUID uuid, String skillType, float XP)} // * // * @param playerName The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static void addRawXPOffline(String playerName, String skillType, float XP) { // addOfflineXP(playerName, getSkillType(skillType), (int) Math.floor(XP)); // } // // /** // * Adds raw XP to an offline player. // * </br> // * This function is designed for API usage. // * // * @param uuid The UUID of player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static void addRawXPOffline(UUID uuid, String skillType, float XP) { // addOfflineXP(uuid, getSkillType(skillType), (int) Math.floor(XP)); // } // // /** // * Adds XP to the player, calculates for XP Rate only. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // */ // @Deprecated // public static void addMultipliedXP(Player player, String skillType, int XP) { // addMultipliedXP(player, skillType, XP, "UNKNOWN"); // } // // /** // * Adds XP to the player, calculates for XP Rate only. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addMultipliedXP(Player player, String skillType, int XP, String xpGainReason) { // getPlayer(player).applyXpGain(getSkillType(skillType), (int) (XP * ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier()), getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // } // // /** // * Adds XP to an offline player, calculates for XP Rate only. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static void addMultipliedXPOffline(String playerName, String skillType, int XP) { // addOfflineXP(playerName, getSkillType(skillType), (int) (XP * ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier())); // } // // /** // * Adds XP to the player, calculates for XP Rate and skill modifier. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // */ // @Deprecated // public static void addModifiedXP(Player player, String skillType, int XP) { // addModifiedXP(player, skillType, XP, "UNKNOWN"); // } // // /** // * Adds XP to the player, calculates for XP Rate and skill modifier. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addModifiedXP(Player player, String skillType, int XP, String xpGainReason) { // addModifiedXP(player, skillType, XP, xpGainReason, false); // } // // /** // * Adds XP to the player, calculates for XP Rate and skill modifier. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * @param isUnshared true if the XP cannot be shared with party members // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addModifiedXP(Player player, String skillType, int XP, String xpGainReason, boolean isUnshared) { // PrimarySkillType skill = getSkillType(skillType); // // if (isUnshared) { // getPlayer(player).beginUnsharedXpGain(skill, (int) (XP / skill.getXpModifier() * ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier()), getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // return; // } // // getPlayer(player).applyXpGain(skill, (int) (XP / skill.getXpModifier() * ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier()), getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // } // // /** // * Adds XP to an offline player, calculates for XP Rate and skill modifier. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static void addModifiedXPOffline(String playerName, String skillType, int XP) { // PrimarySkillType skill = getSkillType(skillType); // // addOfflineXP(playerName, skill, (int) (XP / skill.getXpModifier() * ExperienceConfig.getInstance().getExperienceGainsGlobalMultiplier())); // } // // /** // * Adds XP to the player, calculates for XP Rate, skill modifiers, perks, child skills, // * and party sharing. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * // * @throws InvalidSkillException if the given skill is not valid // */ // @Deprecated // public static void addXP(Player player, String skillType, int XP) { // addXP(player, skillType, XP, "UNKNOWN"); // } // // /** // * Adds XP to the player, calculates for XP Rate, skill modifiers, perks, child skills, // * and party sharing. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addXP(Player player, String skillType, int XP, String xpGainReason) { // addXP(player, skillType, XP, xpGainReason, false); // } // // /** // * Adds XP to the player, calculates for XP Rate, skill modifiers, perks, child skills, // * and party sharing. // * </br> // * This function is designed for API usage. // * // * @param player The player to add XP to // * @param skillType The skill to add XP to // * @param XP The amount of XP to add // * @param xpGainReason The reason to gain XP // * @param isUnshared true if the XP cannot be shared with party members // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidXPGainReasonException if the given xpGainReason is not valid // */ // public static void addXP(Player player, String skillType, int XP, String xpGainReason, boolean isUnshared) { // if (isUnshared) { // getPlayer(player).beginUnsharedXpGain(getSkillType(skillType), XP, getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // return; // } // // getPlayer(player).beginXpGain(getSkillType(skillType), XP, getXPGainReason(xpGainReason), XPGainSource.CUSTOM); // } // // /** // * Get the amount of XP a player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param player The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static int getXP(Player player, String skillType) { // return getPlayer(player).getSkillXpLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the amount of XP an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static int getOfflineXP(String playerName, String skillType) { // return getOfflineProfile(playerName).getSkillXpLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the amount of XP an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static int getOfflineXP(UUID uuid, String skillType) { // return getOfflineProfile(uuid).getSkillXpLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the raw amount of XP a player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param player The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static float getXPRaw(Player player, String skillType) { // return getPlayer(player).getSkillXpLevelRaw(getNonChildSkillType(skillType)); // } // // /** // * Get the raw amount of XP an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static float getOfflineXPRaw(String playerName, String skillType) { // return getOfflineProfile(playerName).getSkillXpLevelRaw(getNonChildSkillType(skillType)); // } // // /** // * Get the raw amount of XP an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP in a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static float getOfflineXPRaw(UUID uuid, String skillType) { // return getOfflineProfile(uuid).getSkillXpLevelRaw(getNonChildSkillType(skillType)); // } // // /** // * Get the total amount of XP needed to reach the next level. // * </br> // * This function is designed for API usage. // * // * @param player The player to get the XP amount for // * @param skillType The skill to get the XP amount for // * @return the total amount of XP needed to reach the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static int getXPToNextLevel(Player player, String skillType) { // return getPlayer(player).getXpToLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the total amount of XP an offline player needs to reach the next level. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get XP for // * @param skillType The skill to get XP for // * @return the total amount of XP needed to reach the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static int getOfflineXPToNextLevel(String playerName, String skillType) { // return getOfflineProfile(playerName).getXpToLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the total amount of XP an offline player needs to reach the next level. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get XP for // * @param skillType The skill to get XP for // * @return the total amount of XP needed to reach the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static int getOfflineXPToNextLevel(UUID uuid, String skillType) { // return getOfflineProfile(uuid).getXpToLevel(getNonChildSkillType(skillType)); // } // // /** // * Get the amount of XP remaining until the next level. // * </br> // * This function is designed for API usage. // * // * @param player The player to get the XP amount for // * @param skillType The skill to get the XP amount for // * @return the amount of XP remaining until the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static int getXPRemaining(Player player, String skillType) { // PrimarySkillType skill = getNonChildSkillType(skillType); // // PlayerProfile profile = getPlayer(player).getProfile(); // // return profile.getXpToLevel(skill) - profile.getSkillXpLevel(skill); // } // // /** // * Get the amount of XP an offline player has left before leveling up. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP needed to reach the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static int getOfflineXPRemaining(String playerName, String skillType) { // PrimarySkillType skill = getNonChildSkillType(skillType); // PlayerProfile profile = getOfflineProfile(playerName); // // return profile.getXpToLevel(skill) - profile.getSkillXpLevel(skill); // } // // /** // * Get the amount of XP an offline player has left before leveling up. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get XP for // * @param skillType The skill to get XP for // * @return the amount of XP needed to reach the next level // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static float getOfflineXPRemaining(UUID uuid, String skillType) { // PrimarySkillType skill = getNonChildSkillType(skillType); // PlayerProfile profile = getOfflineProfile(uuid); // // return profile.getXpToLevel(skill) - profile.getSkillXpLevelRaw(skill); // } // // /** // * Add levels to a skill. // * </br> // * This function is designed for API usage. // * // * @param player The player to add levels to // * @param skillType Type of skill to add levels to // * @param levels Number of levels to add // * // * @throws InvalidSkillException if the given skill is not valid // */ // public static void addLevel(Player player, String skillType, int levels) { // getPlayer(player).addLevels(getSkillType(skillType), levels); // } // // /** // * Add levels to a skill for an offline player. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to add levels to // * @param skillType Type of skill to add levels to // * @param levels Number of levels to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static void addLevelOffline(String playerName, String skillType, int levels) { // PlayerProfile profile = getOfflineProfile(playerName); // PrimarySkillType skill = getSkillType(skillType); // // if (skill.isChildSkill()) { // Set<PrimarySkillType> parentSkills = FamilyTree.getParents(skill); // // for (PrimarySkillType parentSkill : parentSkills) { // profile.addLevels(parentSkill, (levels / parentSkills.size())); // } // // profile.scheduleAsyncSave(); // return; // } // // profile.addLevels(skill, levels); // profile.scheduleAsyncSave(); // } // // /** // * Add levels to a skill for an offline player. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to add levels to // * @param skillType Type of skill to add levels to // * @param levels Number of levels to add // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static void addLevelOffline(UUID uuid, String skillType, int levels) { // PlayerProfile profile = getOfflineProfile(uuid); // PrimarySkillType skill = getSkillType(skillType); // // if (skill.isChildSkill()) { // Set<PrimarySkillType> parentSkills = FamilyTree.getParents(skill); // // for (PrimarySkillType parentSkill : parentSkills) { // profile.addLevels(parentSkill, (levels / parentSkills.size())); // } // // profile.scheduleAsyncSave(); // return; // } // // profile.addLevels(skill, levels); // profile.scheduleAsyncSave(); // } // // /** // * Get the level a player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param player The player to get the level for // * @param skillType The skill to get the level for // * @return the level of a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @deprecated Use getLevel(Player player, PrimarySkillType skillType) instead // */ // @Deprecated // public static int getLevel(Player player, String skillType) { // return getPlayer(player).getSkillLevel(getSkillType(skillType)); // } // // /** // * Get the level a player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param player The player to get the level for // * @param skillType The skill to get the level for // * @return the level of a given skill // * // * @throws InvalidSkillException if the given skill is not valid // */ // public static int getLevel(Player player, PrimarySkillType skillType) { // return getPlayer(player).getSkillLevel(skillType); // } // // /** // * Get the level an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get the level for // * @param skillType The skill to get the level for // * @return the level of a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static int getLevelOffline(String playerName, String skillType) { // return getOfflineProfile(playerName).getSkillLevel(getSkillType(skillType)); // } // // /** // * Get the level an offline player has in a specific skill. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get the level for // * @param skillType The skill to get the level for // * @return the level of a given skill // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static int getLevelOffline(UUID uuid, String skillType) { // return getOfflineProfile(uuid).getSkillLevel(getSkillType(skillType)); // } // // /** // * Gets the power level of a player. // * </br> // * This function is designed for API usage. // * // * @param player The player to get the power level for // * @return the power level of the player // */ // public static int getPowerLevel(Player player) { // return getPlayer(player).getPowerLevel(); // } // // /** // * Gets the power level of an offline player. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to get the power level for // * @return the power level of the player // * // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static int getPowerLevelOffline(String playerName) { // int powerLevel = 0; // PlayerProfile profile = getOfflineProfile(playerName); // // for (PrimarySkillType type : PrimarySkillType.NON_CHILD_SKILLS) { // powerLevel += profile.getSkillLevel(type); // } // // return powerLevel; // } // // /** // * Gets the power level of an offline player. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to get the power level for // * @return the power level of the player // * // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static int getPowerLevelOffline(UUID uuid) { // int powerLevel = 0; // PlayerProfile profile = getOfflineProfile(uuid); // // for (PrimarySkillType type : PrimarySkillType.NON_CHILD_SKILLS) { // powerLevel += profile.getSkillLevel(type); // } // // return powerLevel; // } // // /** // * Get the level cap of a specific skill. // * </br> // * This function is designed for API usage. // * // * @param skillType The skill to get the level cap for // * @return the level cap of a given skill // * // * @throws InvalidSkillException if the given skill is not valid // */ // public static int getLevelCap(String skillType) { // return Config.getInstance().getLevelCap(getSkillType(skillType)); // } // // /** // * Get the power level cap. // * </br> // * This function is designed for API usage. // * // * @return the overall power level cap // */ // public static int getPowerLevelCap() { // return Config.getInstance().getPowerLevelCap(); // } // // /** // * Get the position on the leaderboard of a player. // * </br> // * This function is designed for API usage. // * // * @param playerName The name of the player to check // * @param skillType The skill to check // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // * // * @return the position on the leaderboard // */ // @Deprecated // public static int getPlayerRankSkill(String playerName, String skillType) { // return mcMMO.getDatabaseManager().readRank(mcMMO.p.getServer().getOfflinePlayer(playerName).getName()).get(getNonChildSkillType(skillType)); // } // // /** // * Get the position on the leaderboard of a player. // * </br> // * This function is designed for API usage. // * // * @param uuid The name of the player to check // * @param skillType The skill to check // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // * // * @return the position on the leaderboard // */ // public static int getPlayerRankSkill(UUID uuid, String skillType) { // return mcMMO.getDatabaseManager().readRank(mcMMO.p.getServer().getOfflinePlayer(uuid).getName()).get(getNonChildSkillType(skillType)); // } // // /** // * Get the position on the power level leaderboard of a player. // * </br> // * This function is designed for API usage. // * // * @param playerName The name of the player to check // * // * @throws InvalidPlayerException if the given player does not exist in the database // * // * @return the position on the power level leaderboard // */ // @Deprecated // public static int getPlayerRankOverall(String playerName) { // return mcMMO.getDatabaseManager().readRank(mcMMO.p.getServer().getOfflinePlayer(playerName).getName()).get(null); // } // // /** // * Get the position on the power level leaderboard of a player. // * </br> // * This function is designed for API usage. // * // * @param uuid The name of the player to check // * // * @throws InvalidPlayerException if the given player does not exist in the database // * // * @return the position on the power level leaderboard // */ // public static int getPlayerRankOverall(UUID uuid) { // return mcMMO.getDatabaseManager().readRank(mcMMO.p.getServer().getOfflinePlayer(uuid).getName()).get(null); // } // // /** // * Sets the level of a player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param player The player to set the level of // * @param skillType The skill to set the level for // * @param skillLevel The value to set the level to // * // * @throws InvalidSkillException if the given skill is not valid // */ // public static void setLevel(Player player, String skillType, int skillLevel) { // getPlayer(player).modifySkill(getSkillType(skillType), skillLevel); // } // // /** // * Sets the level of an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to set the level of // * @param skillType The skill to set the level for // * @param skillLevel The value to set the level to // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // @Deprecated // public static void setLevelOffline(String playerName, String skillType, int skillLevel) { // getOfflineProfile(playerName).modifySkill(getSkillType(skillType), skillLevel); // } // // /** // * Sets the level of an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to set the level of // * @param skillType The skill to set the level for // * @param skillLevel The value to set the level to // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // */ // public static void setLevelOffline(UUID uuid, String skillType, int skillLevel) { // getOfflineProfile(uuid).modifySkill(getSkillType(skillType), skillLevel); // } // // /** // * Sets the XP of a player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param player The player to set the XP of // * @param skillType The skill to set the XP for // * @param newValue The value to set the XP to // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static void setXP(Player player, String skillType, int newValue) { // getPlayer(player).setSkillXpLevel(getNonChildSkillType(skillType), newValue); // } // // /** // * Sets the XP of an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to set the XP of // * @param skillType The skill to set the XP for // * @param newValue The value to set the XP to // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static void setXPOffline(String playerName, String skillType, int newValue) { // getOfflineProfile(playerName).setSkillXpLevel(getNonChildSkillType(skillType), newValue); // } // // /** // * Sets the XP of an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to set the XP of // * @param skillType The skill to set the XP for // * @param newValue The value to set the XP to // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static void setXPOffline(UUID uuid, String skillType, int newValue) { // getOfflineProfile(uuid).setSkillXpLevel(getNonChildSkillType(skillType), newValue); // } // // /** // * Removes XP from a player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param player The player to change the XP of // * @param skillType The skill to change the XP for // * @param xp The amount of XP to remove // * // * @throws InvalidSkillException if the given skill is not valid // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static void removeXP(Player player, String skillType, int xp) { // getPlayer(player).removeXp(getNonChildSkillType(skillType), xp); // } // // /** // * Removes XP from an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param playerName The player to change the XP of // * @param skillType The skill to change the XP for // * @param xp The amount of XP to remove // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // @Deprecated // public static void removeXPOffline(String playerName, String skillType, int xp) { // getOfflineProfile(playerName).removeXp(getNonChildSkillType(skillType), xp); // } // // /** // * Removes XP from an offline player in a specific skill type. // * </br> // * This function is designed for API usage. // * // * @param uuid The player to change the XP of // * @param skillType The skill to change the XP for // * @param xp The amount of XP to remove // * // * @throws InvalidSkillException if the given skill is not valid // * @throws InvalidPlayerException if the given player does not exist in the database // * @throws UnsupportedOperationException if the given skill is a child skill // */ // public static void removeXPOffline(UUID uuid, String skillType, int xp) { // getOfflineProfile(uuid).removeXp(getNonChildSkillType(skillType), xp); // } // // /** // * Check how much XP is needed for a specific level with the selected level curve. // * </br> // * This function is designed for API usage. // * // * @param level The level to get the amount of XP for // * // * @throws InvalidFormulaTypeException if the given formulaType is not valid // */ // public static int getXpNeededToLevel(int level) { // return mcMMO.getFormulaManager().getXPtoNextLevel(level, ExperienceConfig.getInstance().getFormulaType()); // } // // /** // * Check how much XP is needed for a specific level with the provided level curve. // * </br> // * This function is designed for API usage. // * // * @param level The level to get the amount of XP for // * @param formulaType The formula type to get the amount of XP for // * // * @throws InvalidFormulaTypeException if the given formulaType is not valid // */ // public static int getXpNeededToLevel(int level, String formulaType) { // return mcMMO.getFormulaManager().getXPtoNextLevel(level, getFormulaType(formulaType)); // } // // /** // * Will add the appropriate type of XP from the block to the player based on the material of the blocks given // * @param blockStates the blocks to reward XP for // * @param mcMMOPlayer the target player // */ // public static void addXpFromBlocks(ArrayList<BlockState> blockStates, McMMOPlayer mcMMOPlayer) // { // for(BlockState bs : blockStates) // { // for(PrimarySkillType skillType : PrimarySkillType.values()) // { // if(ExperienceConfig.getInstance().getXp(skillType, bs.getType()) > 0) // { // mcMMOPlayer.applyXpGain(skillType, ExperienceConfig.getInstance().getXp(skillType, bs.getType()), XPGainReason.PVE, XPGainSource.SELF); // } // } // } // } // // /** // * Will add the appropriate type of XP from the block to the player based on the material of the blocks given if it matches the given skillType // * @param blockStates the blocks to reward XP for // * @param mcMMOPlayer the target player // * @param skillType target primary skill // */ // public static void addXpFromBlocksBySkill(ArrayList<BlockState> blockStates, McMMOPlayer mcMMOPlayer, PrimarySkillType skillType) // { // for(BlockState bs : blockStates) // { // if(ExperienceConfig.getInstance().getXp(skillType, bs.getType()) > 0) // { // mcMMOPlayer.applyXpGain(skillType, ExperienceConfig.getInstance().getXp(skillType, bs.getType()), XPGainReason.PVE, XPGainSource.SELF); // } // } // } // // /** // * Will add the appropriate type of XP from the block to the player based on the material of the blocks given // * @param blockState The target blockstate // * @param mcMMOPlayer The target player // */ // public static void addXpFromBlock(BlockState blockState, McMMOPlayer mcMMOPlayer) // { // for(PrimarySkillType skillType : PrimarySkillType.values()) // { // if(ExperienceConfig.getInstance().getXp(skillType, blockState.getType()) > 0) // { // mcMMOPlayer.applyXpGain(skillType, ExperienceConfig.getInstance().getXp(skillType, blockState.getType()), XPGainReason.PVE, XPGainSource.SELF); // } // } // } // // /** // * Will add the appropriate type of XP from the block to the player based on the material of the blocks given if it matches the given skillType // * @param blockState The target blockstate // * @param mcMMOPlayer The target player // * @param skillType target primary skill // */ // public static void addXpFromBlockBySkill(BlockState blockState, McMMOPlayer mcMMOPlayer, PrimarySkillType skillType) // { // if(ExperienceConfig.getInstance().getXp(skillType, blockState.getType()) > 0) // { // mcMMOPlayer.applyXpGain(skillType, ExperienceConfig.getInstance().getXp(skillType, blockState.getType()), XPGainReason.PVE, XPGainSource.SELF); // } // } // // // Utility methods follow. // private static void addOfflineXP(UUID playerUniqueId, PrimarySkillType skill, int XP) { // PlayerProfile profile = getOfflineProfile(playerUniqueId); // // profile.addXp(skill, XP); // profile.save(true); // } // // @Deprecated // private static void addOfflineXP(String playerName, PrimarySkillType skill, int XP) { // PlayerProfile profile = getOfflineProfile(playerName); // // profile.addXp(skill, XP); // profile.scheduleAsyncSave(); // } // // private static PlayerProfile getOfflineProfile(UUID uuid) throws InvalidPlayerException { // OfflinePlayer offlinePlayer = Bukkit.getServer().getOfflinePlayer(uuid); // String playerName = offlinePlayer.getName(); // PlayerProfile profile = mcMMO.getDatabaseManager().loadPlayerProfile(uuid, playerName); // // if (!profile.isLoaded()) { // throw new InvalidPlayerException(); // } // // return profile; // } // // @Deprecated // private static PlayerProfile getOfflineProfile(String playerName) throws InvalidPlayerException { // OfflinePlayer offlinePlayer = Bukkit.getServer().getOfflinePlayer(playerName); // UUID uuid = offlinePlayer.getUniqueId(); // PlayerProfile profile = mcMMO.getDatabaseManager().loadPlayerProfile(uuid, playerName); // // if (!profile.isLoaded()) { // throw new InvalidPlayerException(); // } // // return profile; // } // // private static PrimarySkillType getSkillType(String skillType) throws InvalidSkillException { // PrimarySkillType skill = PrimarySkillType.getSkill(skillType); // // if (skill == null) { // throw new InvalidSkillException(); // } // // return skill; // } // // private static PrimarySkillType getNonChildSkillType(String skillType) throws InvalidSkillException, UnsupportedOperationException { // PrimarySkillType skill = getSkillType(skillType); // // if (skill.isChildSkill()) { // throw new UnsupportedOperationException("Child skills do not have XP"); // } // // return skill; // } // // private static XPGainReason getXPGainReason(String reason) throws InvalidXPGainReasonException { // XPGainReason xpGainReason = XPGainReason.getXPGainReason(reason); // // if (xpGainReason == null) { // throw new InvalidXPGainReasonException(); // } // // return xpGainReason; // } // // private static FormulaType getFormulaType(String formula) throws InvalidFormulaTypeException { // FormulaType formulaType = FormulaType.getFormulaType(formula); // // if (formulaType == null) { // throw new InvalidFormulaTypeException(); // } // // return formulaType; // } // // /** // * @deprecated Use UserManager::getPlayer(Player player) instead // * @param player target player // * @return McMMOPlayer for that player if the profile is loaded, otherwise null // * @throws McMMOPlayerNotFoundException // */ // @Deprecated // private static McMMOPlayer getPlayer(Player player) throws McMMOPlayerNotFoundException { // if (!UserManager.hasPlayerDataKey(player)) { // throw new McMMOPlayerNotFoundException(player); // } // // return UserManager.getPlayer(player); // } //}