Adds increased scrapper cost when used excessively
All checks were successful
EpicKnarvik97/Blacksmith/pipeline/head This commit looks good
All checks were successful
EpicKnarvik97/Blacksmith/pipeline/head This commit looks good
This commit is contained in:
parent
7e17122bb2
commit
42ca42c571
15
pom.xml
15
pom.xml
@ -92,6 +92,11 @@
|
|||||||
<version>5.10.2</version>
|
<version>5.10.2</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>net.objecthunter</groupId>
|
||||||
|
<artifactId>exp4j</artifactId>
|
||||||
|
<version>0.4.8</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<!-- Build information -->
|
<!-- Build information -->
|
||||||
@ -127,6 +132,10 @@
|
|||||||
<pattern>org.jetbrains.annotations</pattern>
|
<pattern>org.jetbrains.annotations</pattern>
|
||||||
<shadedPattern>net.knarcraft.blacksmith.lib.annotations</shadedPattern>
|
<shadedPattern>net.knarcraft.blacksmith.lib.annotations</shadedPattern>
|
||||||
</relocation>
|
</relocation>
|
||||||
|
<relocation>
|
||||||
|
<pattern>net.objecthunter.exp4j</pattern>
|
||||||
|
<shadedPattern>net.knarcraft.blacksmith.lib.exp4j</shadedPattern>
|
||||||
|
</relocation>
|
||||||
</relocations>
|
</relocations>
|
||||||
<filters>
|
<filters>
|
||||||
<filter>
|
<filter>
|
||||||
@ -141,6 +150,12 @@
|
|||||||
<include>org/jetbrains/annotations/**</include>
|
<include>org/jetbrains/annotations/**</include>
|
||||||
</includes>
|
</includes>
|
||||||
</filter>
|
</filter>
|
||||||
|
<filter>
|
||||||
|
<artifact>net.objecthunter:exp4j</artifact>
|
||||||
|
<includes>
|
||||||
|
<include>net/objecthunter/exp4j/**</include>
|
||||||
|
</includes>
|
||||||
|
</filter>
|
||||||
</filters>
|
</filters>
|
||||||
</configuration>
|
</configuration>
|
||||||
</execution>
|
</execution>
|
||||||
|
@ -20,6 +20,7 @@ import net.knarcraft.blacksmith.formatting.BlacksmithTranslatableMessage;
|
|||||||
import net.knarcraft.blacksmith.listener.NPCClickListener;
|
import net.knarcraft.blacksmith.listener.NPCClickListener;
|
||||||
import net.knarcraft.blacksmith.listener.PlayerListener;
|
import net.knarcraft.blacksmith.listener.PlayerListener;
|
||||||
import net.knarcraft.blacksmith.manager.EconomyManager;
|
import net.knarcraft.blacksmith.manager.EconomyManager;
|
||||||
|
import net.knarcraft.blacksmith.manager.PlayerUsageManager;
|
||||||
import net.knarcraft.blacksmith.trait.BlacksmithTrait;
|
import net.knarcraft.blacksmith.trait.BlacksmithTrait;
|
||||||
import net.knarcraft.blacksmith.trait.ScrapperTrait;
|
import net.knarcraft.blacksmith.trait.ScrapperTrait;
|
||||||
import net.knarcraft.blacksmith.util.ConfigHelper;
|
import net.knarcraft.blacksmith.util.ConfigHelper;
|
||||||
@ -27,6 +28,7 @@ import net.knarcraft.knarlib.formatting.StringFormatter;
|
|||||||
import net.knarcraft.knarlib.formatting.TranslatableTimeUnit;
|
import net.knarcraft.knarlib.formatting.TranslatableTimeUnit;
|
||||||
import net.knarcraft.knarlib.formatting.Translator;
|
import net.knarcraft.knarlib.formatting.Translator;
|
||||||
import net.knarcraft.knarlib.util.UpdateChecker;
|
import net.knarcraft.knarlib.util.UpdateChecker;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandExecutor;
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.PluginCommand;
|
import org.bukkit.command.PluginCommand;
|
||||||
import org.bukkit.command.TabCompleter;
|
import org.bukkit.command.TabCompleter;
|
||||||
@ -183,6 +185,10 @@ public class BlacksmithPlugin extends JavaPlugin {
|
|||||||
//Alert about an update in the console
|
//Alert about an update in the console
|
||||||
UpdateChecker.checkForUpdate(this, "https://api.spigotmc.org/legacy/update.php?resource=105938",
|
UpdateChecker.checkForUpdate(this, "https://api.spigotmc.org/legacy/update.php?resource=105938",
|
||||||
() -> this.getDescription().getVersion(), null);
|
() -> this.getDescription().getVersion(), null);
|
||||||
|
|
||||||
|
// Remove expired scrapper usage data
|
||||||
|
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, () -> PlayerUsageManager.removeExpiredData(
|
||||||
|
System.currentTimeMillis() - 3600000), 36000, 36000);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package net.knarcraft.blacksmith.command;
|
package net.knarcraft.blacksmith.command;
|
||||||
|
|
||||||
import net.knarcraft.blacksmith.BlacksmithPlugin;
|
import net.knarcraft.blacksmith.BlacksmithPlugin;
|
||||||
|
import net.knarcraft.blacksmith.container.ActionCost;
|
||||||
|
import net.knarcraft.blacksmith.formatting.BlacksmithTranslatableMessage;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.command.TabExecutor;
|
import org.bukkit.command.TabExecutor;
|
||||||
@ -22,17 +24,13 @@ public class CostCommand implements TabExecutor {
|
|||||||
if (arguments.length < 2) {
|
if (arguments.length < 2) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ActionCost actionCost;
|
||||||
|
|
||||||
switch (arguments[0]) {
|
switch (arguments[0]) {
|
||||||
case "simple":
|
case "simple":
|
||||||
// TODO: Expect the next argument to be the cost
|
// TODO: Do something with the cost
|
||||||
try {
|
double cost = parseSimpleCost(commandSender, arguments[1]);
|
||||||
Double cost = Double.parseDouble(arguments[1]);
|
|
||||||
|
|
||||||
} catch (NumberFormatException exception) {
|
|
||||||
// TODO: Make this translatable?
|
|
||||||
BlacksmithPlugin.getStringFormatter().displayErrorMessage(commandSender, "You must supply a numeric (double) cost");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "advanced":
|
case "advanced":
|
||||||
switch (arguments[1]) {
|
switch (arguments[1]) {
|
||||||
@ -57,8 +55,32 @@ public class CostCommand implements TabExecutor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @Nullable List<String> onTabComplete(@NotNull CommandSender commandSender, @NotNull Command command, @NotNull String s, @NotNull String[] strings) {
|
public @Nullable List<String> onTabComplete(@NotNull CommandSender commandSender, @NotNull Command command,
|
||||||
|
@NotNull String s, @NotNull String[] strings) {
|
||||||
return List.of();
|
return List.of();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses a simple double cost
|
||||||
|
*
|
||||||
|
* @param commandSender <p>The command sender to notify of any problems</p>
|
||||||
|
* @param costString <p>The string to parse into a cost</p>
|
||||||
|
* @return <p>The parsed cost</p>
|
||||||
|
* @throws IllegalArgumentException <p>If the specified cost is invalid</p>
|
||||||
|
*/
|
||||||
|
private double parseSimpleCost(@NotNull CommandSender commandSender,
|
||||||
|
@NotNull String costString) throws IllegalArgumentException {
|
||||||
|
try {
|
||||||
|
double cost = Double.parseDouble(costString);
|
||||||
|
if (cost < 0) {
|
||||||
|
throw new NumberFormatException();
|
||||||
|
}
|
||||||
|
return cost;
|
||||||
|
} catch (NumberFormatException exception) {
|
||||||
|
BlacksmithPlugin.getStringFormatter().displayErrorMessage(commandSender,
|
||||||
|
BlacksmithTranslatableMessage.DOUBLE_COST_REQUIRED);
|
||||||
|
throw new IllegalArgumentException("Invalid cost given");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -213,30 +213,21 @@ public class GlobalScrapperSettings implements Settings<ScrapperSetting> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the base cost of salvaging an enchanted book
|
* Gets the math formula for the increase in salvage cost
|
||||||
*
|
*
|
||||||
* @return <p>The enchanted book salvage base cost</p>
|
* @return <p>The salvage cost increase formula</p>
|
||||||
*/
|
*/
|
||||||
public double getEnchantedBookSalvageCost() {
|
public String getSalvageCostIncrease() {
|
||||||
return asDouble(ScrapperSetting.ENCHANTED_BOOK_SALVAGE_BASE_COST);
|
return asString(ScrapperSetting.SALVAGE_COST_INCREASE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to multiply the cost of salvaging enchanted books based on the number of enchantments
|
* Gets the math formula for the increase in salvage cooldown
|
||||||
*
|
*
|
||||||
* @return <p>Whether to multiply the cost of salvaging enchanted books based on the number of enchantments</p>
|
* @return <p>The salvage cooldown increase formula</p>
|
||||||
*/
|
*/
|
||||||
public boolean multiplyEnchantedBookSalvageCost() {
|
public String getSalvageCooldownIncrease() {
|
||||||
return asBoolean(ScrapperSetting.ENCHANTED_BOOK_SALVAGE_MULTIPLY);
|
return asString(ScrapperSetting.SALVAGE_COOLDOWN_INCREASE);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Whether to require both a monetary and item-based cost when salvaging enchanted books
|
|
||||||
*
|
|
||||||
* @return <p>Whether to require both a monetary and item-based cost when salvaging enchanted books</p>
|
|
||||||
*/
|
|
||||||
public boolean requireMoneyAndItemForEnchantedBookSalvage() {
|
|
||||||
return asBoolean(ScrapperSetting.ENCHANTED_BOOK_SALVAGE_REQUIRE_BOTH);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -302,4 +293,15 @@ public class GlobalScrapperSettings implements Settings<ScrapperSetting> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the string value of the given setting
|
||||||
|
*
|
||||||
|
* @param setting <p>The setting to get the value of</p>
|
||||||
|
* @return <p>The value of the given setting as a string</p>
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
private String asString(@NotNull ScrapperSetting setting) {
|
||||||
|
return getValue(setting).toString();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -292,28 +292,18 @@ public enum ScrapperSetting implements Setting {
|
|||||||
"The cost of using the scrapper to remove netherite from an item", false, false),
|
"The cost of using the scrapper to remove netherite from an item", false, false),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The setting for the enchanted book salvage cost
|
* The mathematical formula for increasing salvage cost
|
||||||
*/
|
*/
|
||||||
ENCHANTED_BOOK_SALVAGE_BASE_COST("enchantedBookSalvageBasePrice", SettingValueType.POSITIVE_DOUBLE, 10,
|
SALVAGE_COST_INCREASE("salvageCostIncrease", SettingValueType.STRING, "{cost}*{timesUsed}",
|
||||||
"The per-enchantment cost of splitting an enchanted book", false, false),
|
"The mathematical formula for salvage cost increase when continually used within the same hour. " +
|
||||||
|
"This is necessary for some servers where items can be easily farmed. Set to {cost} to disable behavior.", false, false),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The setting for the enchanted book item cost
|
* The mathematical formula for increasing salvage cooldown
|
||||||
*/
|
*/
|
||||||
ENCHANTED_BOOK_SALVAGE_ITEM_COST("enchantedBookSalvageCost", SettingValueType.ADVANCED_COST, null,
|
SALVAGE_COOLDOWN_INCREASE("salvageCooldownIncrease", SettingValueType.STRING, "{cooldown}*{timesUsed}",
|
||||||
"The cost to pay in order to salvage an enchanted book", false, false),
|
"The mathematical formula for salvage cooldown increase when continually used within the same hour. " +
|
||||||
|
"This is necessary for some servers where items can be easily farmed. Set to {cooldown} to disable behavior.", false, false),
|
||||||
/**
|
|
||||||
* The setting for whether to multiply enchanted book cost
|
|
||||||
*/
|
|
||||||
ENCHANTED_BOOK_SALVAGE_MULTIPLY("enchantedBookSalvageMultiplyByEnchantmentNumber", SettingValueType.BOOLEAN,
|
|
||||||
true, "Whether to multiply the cost of salvaging an enchanted book by the number of enchantments on the book", false, false),
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The setting for whether to require both monetary and item payment for salvaging enchanted books
|
|
||||||
*/
|
|
||||||
ENCHANTED_BOOK_SALVAGE_REQUIRE_BOTH("enchantedBookSalvageRequireMoneyAndItem", SettingValueType.BOOLEAN,
|
|
||||||
true, "Whether salvaging an enchanted book will cost both the configured money amount and the configured item", false, false),
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether to display exact time in minutes and seconds when displaying a remaining cool-down
|
* Whether to display exact time in minutes and seconds when displaying a remaining cool-down
|
||||||
|
@ -143,7 +143,12 @@ public enum BlacksmithTranslatableMessage implements TranslatableMessage {
|
|||||||
/**
|
/**
|
||||||
* The format to use for formatting any message spoken by a blacksmith NPC
|
* The format to use for formatting any message spoken by a blacksmith NPC
|
||||||
*/
|
*/
|
||||||
NPC_TALK_FORMAT;
|
NPC_TALK_FORMAT,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The text to display when explaining that a cost must be a positive double
|
||||||
|
*/
|
||||||
|
DOUBLE_COST_REQUIRED;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the message to display when displaying the raw value of messages
|
* Gets the message to display when displaying the raw value of messages
|
||||||
|
@ -5,8 +5,10 @@ import net.knarcraft.blacksmith.config.blacksmith.GlobalBlacksmithSettings;
|
|||||||
import net.knarcraft.blacksmith.config.scrapper.GlobalScrapperSettings;
|
import net.knarcraft.blacksmith.config.scrapper.GlobalScrapperSettings;
|
||||||
import net.knarcraft.blacksmith.property.SalvageMethod;
|
import net.knarcraft.blacksmith.property.SalvageMethod;
|
||||||
import net.knarcraft.blacksmith.util.ItemHelper;
|
import net.knarcraft.blacksmith.util.ItemHelper;
|
||||||
import net.knarcraft.blacksmith.util.SalvageHelper;
|
import net.knarcraft.knarlib.formatting.StringReplacer;
|
||||||
import net.milkbowl.vault.economy.Economy;
|
import net.milkbowl.vault.economy.Economy;
|
||||||
|
import net.objecthunter.exp4j.Expression;
|
||||||
|
import net.objecthunter.exp4j.ExpressionBuilder;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.enchantments.Enchantment;
|
import org.bukkit.enchantments.Enchantment;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -59,7 +61,8 @@ public class EconomyManager {
|
|||||||
* @return <p>Whether the player cannot pay for the salvage</p>
|
* @return <p>Whether the player cannot pay for the salvage</p>
|
||||||
*/
|
*/
|
||||||
public static boolean cannotPayForSalvage(@NotNull Player player, @NotNull SalvageMethod salvageMethod, @NotNull ItemStack item) {
|
public static boolean cannotPayForSalvage(@NotNull Player player, @NotNull SalvageMethod salvageMethod, @NotNull ItemStack item) {
|
||||||
return economy.getBalance(player) - getSalvageCost(salvageMethod, item) < 0;
|
// TODO: Account for advanced cost options
|
||||||
|
return economy.getBalance(player) - getSalvageCost(salvageMethod, item, player) < 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -79,11 +82,13 @@ public class EconomyManager {
|
|||||||
*
|
*
|
||||||
* @param salvageMethod <p>The salvage method to get the cost for</p>
|
* @param salvageMethod <p>The salvage method to get the cost for</p>
|
||||||
* @param item <p>The item to be salvaged</p>
|
* @param item <p>The item to be salvaged</p>
|
||||||
|
* @param player <p>The player to provide the cost to</p>
|
||||||
* @return <p>The formatted cost</p>
|
* @return <p>The formatted cost</p>
|
||||||
*/
|
*/
|
||||||
@NotNull
|
@NotNull
|
||||||
public static String formatSalvageCost(@NotNull SalvageMethod salvageMethod, @NotNull ItemStack item) {
|
public static String formatSalvageCost(@NotNull SalvageMethod salvageMethod, @NotNull ItemStack item,
|
||||||
return economy.format(getSalvageCost(salvageMethod, item));
|
@NotNull Player player) {
|
||||||
|
return economy.format(getSalvageCost(salvageMethod, item, player));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -112,16 +117,25 @@ public class EconomyManager {
|
|||||||
* Gets the cost of salvaging using the specified method
|
* Gets the cost of salvaging using the specified method
|
||||||
*
|
*
|
||||||
* @param salvageMethod <p>The salvage method to get cost for</p>
|
* @param salvageMethod <p>The salvage method to get cost for</p>
|
||||||
|
* @param item <p>The item to be salvaged</p>
|
||||||
* @return <p>The salvage cost</p>
|
* @return <p>The salvage cost</p>
|
||||||
*/
|
*/
|
||||||
private static double getSalvageCost(@NotNull SalvageMethod salvageMethod, @NotNull ItemStack item) {
|
private static double getSalvageCost(@NotNull SalvageMethod salvageMethod, @NotNull ItemStack item,
|
||||||
|
@NotNull Player player) {
|
||||||
GlobalScrapperSettings settings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
GlobalScrapperSettings settings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
||||||
return switch (salvageMethod) {
|
double baseCost = switch (salvageMethod) {
|
||||||
case SALVAGE, EXTENDED_SALVAGE -> settings.getSalvageCost();
|
case SALVAGE, EXTENDED_SALVAGE -> settings.getSalvageCost();
|
||||||
case NETHERITE -> settings.getNetheriteSalvageCost();
|
case NETHERITE -> settings.getNetheriteSalvageCost();
|
||||||
case ARMOR_TRIM -> settings.getArmorTrimSalvageCost();
|
case ARMOR_TRIM -> settings.getArmorTrimSalvageCost();
|
||||||
case ENCHANTED_BOOK -> getEnchantedBookSalvageCost(item);
|
case ENCHANTED_BOOK -> getEnchantedBookSalvageCost(item);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
StringReplacer replacer = new StringReplacer(settings.getSalvageCostIncrease());
|
||||||
|
replacer.add("{cost}", String.valueOf(baseCost));
|
||||||
|
replacer.add("{timesUsed}", String.valueOf(PlayerUsageManager.getUsages(player,
|
||||||
|
System.currentTimeMillis() - 3600000)));
|
||||||
|
Expression expression = new ExpressionBuilder(replacer.replace()).build();
|
||||||
|
return Math.max(expression.evaluate(), baseCost);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -145,7 +159,7 @@ public class EconomyManager {
|
|||||||
* @param salvageMethod <p>The salvage method to withdraw for</p>
|
* @param salvageMethod <p>The salvage method to withdraw for</p>
|
||||||
*/
|
*/
|
||||||
public static void withdrawScrapper(@NotNull Player player, @NotNull SalvageMethod salvageMethod) {
|
public static void withdrawScrapper(@NotNull Player player, @NotNull SalvageMethod salvageMethod) {
|
||||||
double cost = getSalvageCost(salvageMethod, player.getInventory().getItemInMainHand());
|
double cost = getSalvageCost(salvageMethod, player.getInventory().getItemInMainHand(), player);
|
||||||
if (cost > 0) {
|
if (cost > 0) {
|
||||||
economy.withdrawPlayer(player, cost);
|
economy.withdrawPlayer(player, cost);
|
||||||
}
|
}
|
||||||
@ -230,12 +244,15 @@ public class EconomyManager {
|
|||||||
* @return <p>The cost of scrapping the enchanted book</p>
|
* @return <p>The cost of scrapping the enchanted book</p>
|
||||||
*/
|
*/
|
||||||
private static double getEnchantedBookSalvageCost(@NotNull ItemStack item) {
|
private static double getEnchantedBookSalvageCost(@NotNull ItemStack item) {
|
||||||
GlobalScrapperSettings settings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
// TODO: Properly implement this
|
||||||
|
/*GlobalScrapperSettings settings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
||||||
|
|
||||||
double cost = settings.getEnchantedBookSalvageCost();
|
double cost = settings.getEnchantedBookSalvageCost();
|
||||||
if (settings.multiplyEnchantedBookSalvageCost()) {
|
if (settings.multiplyEnchantedBookSalvageCost()) {
|
||||||
cost *= SalvageHelper.getEnchantmentCount(item) - 1;
|
cost *= SalvageHelper.getEnchantmentCount(item) - 1;
|
||||||
}
|
}
|
||||||
return SalvageHelper.getEnchantmentCount(item) * cost;
|
return SalvageHelper.getEnchantmentCount(item) * cost;*/
|
||||||
|
return 1000000;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -0,0 +1,75 @@
|
|||||||
|
package net.knarcraft.blacksmith.manager;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A manager for keeping track of players using scrappers
|
||||||
|
*/
|
||||||
|
public class PlayerUsageManager {
|
||||||
|
|
||||||
|
private static final Map<Player, Set<Long>> playerUsages = new HashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register that a player has used a scrapper
|
||||||
|
*
|
||||||
|
* @param player <p>The player using a scrapper</p>
|
||||||
|
*/
|
||||||
|
public static void registerUsage(@NotNull Player player) {
|
||||||
|
playerUsages.putIfAbsent(player, new HashSet<>());
|
||||||
|
Set<Long> usages = playerUsages.get(player);
|
||||||
|
usages.add(System.currentTimeMillis());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets how many times the given player has used a scrapper after the given timestamp
|
||||||
|
*
|
||||||
|
* @param player <p>The player to check usages for</p>
|
||||||
|
* @param afterTimestamp <p>The timestamp of when to start looking for usages</p>
|
||||||
|
* @return <p>The number of scrapper uses for the given player</p>
|
||||||
|
*/
|
||||||
|
public static int getUsages(@NotNull Player player, @NotNull Long afterTimestamp) {
|
||||||
|
Set<Long> usages = playerUsages.get(player);
|
||||||
|
if (usages == null) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int uses = 0;
|
||||||
|
Set<Long> expired = new HashSet<>();
|
||||||
|
for (Long usageTime : usages) {
|
||||||
|
if (usageTime < afterTimestamp) {
|
||||||
|
expired.add(usageTime);
|
||||||
|
} else {
|
||||||
|
uses++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove expired data
|
||||||
|
usages.removeAll(expired);
|
||||||
|
|
||||||
|
return uses;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes all expired timestamps
|
||||||
|
*
|
||||||
|
* @param afterTimestamp <p>The timestamp for the earliest time of valid timestamps</p>
|
||||||
|
*/
|
||||||
|
public static void removeExpiredData(@NotNull Long afterTimestamp) {
|
||||||
|
for (Set<Long> usageSet : playerUsages.values()) {
|
||||||
|
Set<Long> expired = new HashSet<>();
|
||||||
|
for (Long item : usageSet) {
|
||||||
|
if (item < afterTimestamp) {
|
||||||
|
expired.add(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
usageSet.removeAll(expired);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -6,9 +6,13 @@ import net.knarcraft.blacksmith.config.scrapper.ScrapperNPCSettings;
|
|||||||
import net.knarcraft.blacksmith.event.ScrapperSalvageFailEvent;
|
import net.knarcraft.blacksmith.event.ScrapperSalvageFailEvent;
|
||||||
import net.knarcraft.blacksmith.event.ScrapperSalvageSucceedEvent;
|
import net.knarcraft.blacksmith.event.ScrapperSalvageSucceedEvent;
|
||||||
import net.knarcraft.blacksmith.manager.EconomyManager;
|
import net.knarcraft.blacksmith.manager.EconomyManager;
|
||||||
|
import net.knarcraft.blacksmith.manager.PlayerUsageManager;
|
||||||
import net.knarcraft.blacksmith.property.SalvageMethod;
|
import net.knarcraft.blacksmith.property.SalvageMethod;
|
||||||
import net.knarcraft.blacksmith.util.ItemHelper;
|
import net.knarcraft.blacksmith.util.ItemHelper;
|
||||||
import net.knarcraft.blacksmith.util.SalvageHelper;
|
import net.knarcraft.blacksmith.util.SalvageHelper;
|
||||||
|
import net.knarcraft.knarlib.formatting.StringReplacer;
|
||||||
|
import net.objecthunter.exp4j.Expression;
|
||||||
|
import net.objecthunter.exp4j.ExpressionBuilder;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.Sound;
|
import org.bukkit.Sound;
|
||||||
import org.bukkit.entity.LivingEntity;
|
import org.bukkit.entity.LivingEntity;
|
||||||
@ -124,8 +128,14 @@ public class SalvageSession extends Session implements Runnable {
|
|||||||
|
|
||||||
// Start cool-down
|
// Start cool-down
|
||||||
Calendar wait = Calendar.getInstance();
|
Calendar wait = Calendar.getInstance();
|
||||||
wait.add(Calendar.SECOND, this.config.getSalvageCoolDown());
|
StringReplacer replacer = new StringReplacer(BlacksmithPlugin.getInstance().getGlobalScrapperSettings().getSalvageCooldownIncrease());
|
||||||
|
replacer.add("{cooldown}", String.valueOf(this.config.getSalvageCoolDown()));
|
||||||
|
replacer.add("{timesUsed}", String.valueOf(PlayerUsageManager.getUsages(player, System.currentTimeMillis() - 3600000)));
|
||||||
|
Expression expression = new ExpressionBuilder(replacer.replace()).build();
|
||||||
|
|
||||||
|
wait.add(Calendar.SECOND, Math.max((int) expression.evaluate(), this.config.getSalvageCoolDown()));
|
||||||
this.scrapperTrait.addCoolDown(this.player.getUniqueId(), wait);
|
this.scrapperTrait.addCoolDown(this.player.getUniqueId(), wait);
|
||||||
|
PlayerUsageManager.registerUsage(this.player);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -119,7 +119,7 @@ public class ScrapperTrait extends CustomTrait<ScrapperSetting> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Print the cost to the player
|
// Print the cost to the player
|
||||||
printCostMessage(player, itemInHand, EconomyManager.formatSalvageCost(result.salvageMethod(), itemInHand),
|
printCostMessage(player, itemInHand, EconomyManager.formatSalvageCost(result.salvageMethod(), itemInHand, player),
|
||||||
result.salvageMethod());
|
result.salvageMethod());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -327,14 +327,14 @@ public class ScrapperTrait extends CustomTrait<ScrapperSetting> {
|
|||||||
// TODO: If an item requirement is set, print the item requirement
|
// TODO: If an item requirement is set, print the item requirement
|
||||||
|
|
||||||
GlobalScrapperSettings scrapperSettings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
GlobalScrapperSettings scrapperSettings = BlacksmithPlugin.getInstance().getGlobalScrapperSettings();
|
||||||
String moneyCost = EconomyManager.format(scrapperSettings.getEnchantedBookSalvageCost());
|
/*String moneyCost = EconomyManager.format(scrapperSettings.getEnchantedBookSalvageCost());
|
||||||
//ItemStack itemCost = scrapperSettings.
|
//ItemStack itemCost = scrapperSettings.
|
||||||
if (scrapperSettings.requireMoneyAndItemForEnchantedBookSalvage()) {
|
if (scrapperSettings.requireMoneyAndItemForEnchantedBookSalvage()) {
|
||||||
// TODO: Print both with a + between them (if item has a special name, use that instead of the material name)
|
// TODO: Print both with a + between them (if item has a special name, use that instead of the material name)
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// TODO: If the item is not null, print it, otherwise print the monetary cost
|
// TODO: If the item is not null, print it, otherwise print the monetary cost
|
||||||
}
|
}*/
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,17 +142,13 @@ scrapper:
|
|||||||
# The cost of using the scrapper to remove netherite from an item
|
# The cost of using the scrapper to remove netherite from an item
|
||||||
netheriteSalvagePrice: 15
|
netheriteSalvagePrice: 15
|
||||||
|
|
||||||
# The per-enchantment cost of splitting an enchanted book
|
# The mathematical formula for salvage cost increase when continually used within the same hour. This is necessary
|
||||||
enchantedBookSalvageBasePrice: 10
|
# for some servers where items can be easily farmed. Set to {cost} to disable behavior.
|
||||||
|
salvageCostIncrease: "{cost}*{timesUsed}"
|
||||||
|
|
||||||
# The item that needs to be provided to pay for splitting an enchanted book
|
# The mathematical formula for salvage cooldown increase when continually used within the same hour. This is
|
||||||
enchantedBookSalvageItemCost: null
|
# necessary for some servers where items can be easily farmed. Set to {cooldown} to disable behavior.
|
||||||
|
salvageCooldownIncrease: "{cooldown}*{timesUsed}"
|
||||||
# Whether to multiply the initial cost with the number of enchantments on the book
|
|
||||||
enchantedBookSalvageMultiplyByEnchantmentNumber: true
|
|
||||||
|
|
||||||
# Whether to require both a monetary sum and providing an item in order to pay for salvaging an enchanted book
|
|
||||||
enchantedBookSalvageRequireMoneyAndItem: false
|
|
||||||
|
|
||||||
# The settings which are set to any new scrapper NPC. To change any of these settings for an existing NPC, you must
|
# The settings which are set to any new scrapper NPC. To change any of these settings for an existing NPC, you must
|
||||||
# change the Citizens NPC file, or use the /scrapper command
|
# change the Citizens NPC file, or use the /scrapper command
|
||||||
|
@ -90,3 +90,5 @@ en:
|
|||||||
INTERVAL_MORE_THAN_5_MINUTES: "in quite a while"
|
INTERVAL_MORE_THAN_5_MINUTES: "in quite a while"
|
||||||
# The marker shown when displaying values overridden for the selected NPC (not shown if the NPC inherits the default value)
|
# The marker shown when displaying values overridden for the selected NPC (not shown if the NPC inherits the default value)
|
||||||
SETTING_OVERRIDDEN_MARKER: " [NPC]"
|
SETTING_OVERRIDDEN_MARKER: " [NPC]"
|
||||||
|
# The translation of the text displayed when a cost is expected, but a non-number is provided
|
||||||
|
DOUBLE_COST_REQUIRED: "You must supply a numeric (double) cost"
|
Loading…
x
Reference in New Issue
Block a user