From 1f691f448cb2cf3d8dc05a9c733d9aee751d64fa Mon Sep 17 00:00:00 2001 From: Zrips Date: Wed, 9 Mar 2022 14:25:51 +0200 Subject: [PATCH] Lets not remove block ownership on hopper transfer We will only disable payments for this block until next player interaction or server restart. --- .../jobs/commands/list/ownedblocks.java | 5 +- .../jobs/config/GeneralConfigManager.java | 4 +- .../jobs/config/LanguageManager.java | 4 ++ .../blockOwnerShip/BlockOwnerShip.java | 60 +++++++++++++++++-- .../jobs/listeners/JobsPaymentListener.java | 37 +++++++++++- .../com/gamingmesh/jobs/stuff/blockLoc.java | 32 ++++++---- 6 files changed, 122 insertions(+), 20 deletions(-) diff --git a/src/main/java/com/gamingmesh/jobs/commands/list/ownedblocks.java b/src/main/java/com/gamingmesh/jobs/commands/list/ownedblocks.java index dab82f84..82f31bfd 100644 --- a/src/main/java/com/gamingmesh/jobs/commands/list/ownedblocks.java +++ b/src/main/java/com/gamingmesh/jobs/commands/list/ownedblocks.java @@ -73,9 +73,12 @@ public class ownedblocks implements Cmd { CMILocation loc = CMILocation.fromString(record.getKey(), ":"); rm.addText(Jobs.getLanguage().getMessage("command.ownedblocks.output.list", "[place]", i, "[type]", material.getName(), "[location]", LC.Location_Full.getLocale((Location) loc))); - rm.addHover(Jobs.getLanguage().getMessage("command.ownedblocks.output.listHover", "[location]", LC.Location_Full.getLocale((Location) loc))); rm.addCommand(JobsCommands.LABEL + " " + clearownership.class.getSimpleName() + " " + jp.getName() + " " + record.getKey()); + if (record.getValue().isDisabled()) { + rm.addText(Jobs.getLanguage().getMessage("command.ownedblocks.output.disabled")); + rm.addHover(Jobs.getLanguage().getMessage("command.ownedblocks.output.disabledHover")); + } } } rm.show(sender); diff --git a/src/main/java/com/gamingmesh/jobs/config/GeneralConfigManager.java b/src/main/java/com/gamingmesh/jobs/config/GeneralConfigManager.java index 3bfa2626..33c09964 100644 --- a/src/main/java/com/gamingmesh/jobs/config/GeneralConfigManager.java +++ b/src/main/java/com/gamingmesh/jobs/config/GeneralConfigManager.java @@ -853,10 +853,10 @@ public class GeneralConfigManager { } c.addComment("ExploitProtections.Smelt.PreventHopperFillUps", "Prevent payments when hoppers moving items into furnace", "Player will not get paid, but items will be smelted"); - PreventHopperFillUps = c.get("ExploitProtections.Smelt.PreventHopperFillUps", true); + PreventHopperFillUps = c.get("ExploitProtections.Smelt.PreventHopperFillUps", false); c.addComment("ExploitProtections.Smelt.PreventMagmaCubeSplit", "Prevent payments when hoppers moving items into brewing stands", "Player will not get paid, but items will be brewd as they supose too"); - PreventBrewingStandFillUps = c.get("ExploitProtections.Brew.PreventBrewingStandFillUps", true); + PreventBrewingStandFillUps = c.get("ExploitProtections.Brew.PreventBrewingStandFillUps", false); c.addComment("use-breeder-finder", "Breeder finder.", "If you are not using breeding payment, you can disable this to save little resources. Really little."); diff --git a/src/main/java/com/gamingmesh/jobs/config/LanguageManager.java b/src/main/java/com/gamingmesh/jobs/config/LanguageManager.java index 2bab7cd0..bcc39181 100644 --- a/src/main/java/com/gamingmesh/jobs/config/LanguageManager.java +++ b/src/main/java/com/gamingmesh/jobs/config/LanguageManager.java @@ -101,7 +101,9 @@ public class LanguageManager { c.get("general.error.worldisdisabled", "&cYou can't use command in this world!"); c.get("general.error.newRegistration", "&eRegistered new ownership for [block] &7[current]&e/&f[max]"); + c.get("general.error.reenabledBlock", "&eReenabled ownership"); c.get("general.error.noRegistration", "&cYou've reached max [block] count!"); + c.get("general.error.blockDisabled", "&6Payments from &e[type] &6got disabled. &2[location]"); c.get("command.help.output.info", "Type /jobs [cmd] ? for more information about a command."); c.get("command.help.output.cmdUsage", "&2Usage: &7[command]"); @@ -488,6 +490,8 @@ public class LanguageManager { Jobs.getGCManager().getCommandArgs().put("ownedblocks", Arrays.asList("[playername]")); c.get("command.ownedblocks.output.list", "&6[place]. &e[type] -> [location]"); c.get("command.ownedblocks.output.listHover", "&6Click to remove: [location]"); + c.get("command.ownedblocks.output.disabled", "&6(disabled)"); + c.get("command.ownedblocks.output.disabledHover", "&6This block got disabled due to hopper actions"); c.get("command.clearownership.help.info", "Clear block ownership"); c.get("command.clearownership.help.args", "[playername]"); diff --git a/src/main/java/com/gamingmesh/jobs/container/blockOwnerShip/BlockOwnerShip.java b/src/main/java/com/gamingmesh/jobs/container/blockOwnerShip/BlockOwnerShip.java index 3c359874..cfad0efe 100644 --- a/src/main/java/com/gamingmesh/jobs/container/blockOwnerShip/BlockOwnerShip.java +++ b/src/main/java/com/gamingmesh/jobs/container/blockOwnerShip/BlockOwnerShip.java @@ -81,6 +81,18 @@ public class BlockOwnerShip { return blockOwnerShips; } + public boolean isDisabled(UUID uuid, Location loc) { + HashMap records = getBlockOwnerShips().get(uuid); + if (records == null) + return false; + + blockLoc old = records.get(CMILocation.toString(loc, ":", true, true)); + if (old == null) + return false; + + return old.isDisabled(); + } + public ownershipFeedback register(Player player, Block block) { if (type != BlockTypes.getFromCMIMaterial(CMIMaterial.get(block))) { return ownershipFeedback.invalid; @@ -93,8 +105,17 @@ public class BlockOwnerShip { UUID ownerUUID = this.getOwnerByLocation(block.getLocation()); - if (ownerUUID != null && ownerUUID.equals(player.getUniqueId())) + if (ownerUUID != null && ownerUUID.equals(player.getUniqueId())) { + HashMap records = getBlockOwnerShips().get(ownerUUID); + if (records != null) { + blockLoc old = records.get(CMILocation.toString(block.getLocation(), ":", true, true)); + if (old != null && old.isDisabled()) { + old.setDisabled(false); + return ownershipFeedback.reenabled; + } + } return ownershipFeedback.old; + } if (ownerUUID != null && !ownerUUID.equals(player.getUniqueId())) { if (Jobs.getGCManager().blockOwnershipTakeOver) { @@ -158,6 +179,37 @@ public class BlockOwnerShip { return ownershipFeedback.newReg; } + public boolean disable(Block block) { + UUID uuid = getOwnerByLocation(block.getLocation()); + if (uuid == null) { + List data = getBlockMetadatas(block); + if (!data.isEmpty()) { + try { + uuid = UUID.fromString(data.get(0).asString()); + } catch (IllegalArgumentException e) { + } + } + } + if (uuid == null) { + return false; + } + return disable(uuid, block); + } + + public boolean disable(UUID uuid, Block block) { + if (uuid == null) { + return false; + } + HashMap ls = blockOwnerShips.getOrDefault(uuid, new HashMap()); + String blockLoc = CMILocation.toString(block.getLocation(), ":", true, true); + com.gamingmesh.jobs.stuff.blockLoc record = ls.get(blockLoc); + if (record != null) { + record.setDisabled(true); + return true; + } + return false; + } + public boolean remove(Block block) { UUID uuid = getOwnerByLocation(block.getLocation()); @@ -193,11 +245,11 @@ public class BlockOwnerShip { } public UUID getOwnerByLocation(Location loc) { - blockLoc bl = new blockLoc(loc); - Map record = ownerMapByLocation.get(bl.getWorldName()); + Map record = ownerMapByLocation.get(loc.getWorld().getName()); if (record == null) { return null; } + blockLoc bl = new blockLoc(loc); return record.get(bl.toVectorString()); } @@ -378,6 +430,6 @@ public class BlockOwnerShip { } public enum ownershipFeedback { - invalid, tooMany, newReg, old, notOwn + invalid, tooMany, newReg, old, notOwn, reenabled } } diff --git a/src/main/java/com/gamingmesh/jobs/listeners/JobsPaymentListener.java b/src/main/java/com/gamingmesh/jobs/listeners/JobsPaymentListener.java index e8f592e7..fa95d0b9 100644 --- a/src/main/java/com/gamingmesh/jobs/listeners/JobsPaymentListener.java +++ b/src/main/java/com/gamingmesh/jobs/listeners/JobsPaymentListener.java @@ -128,7 +128,9 @@ import net.Zrips.CMILib.Container.CMILocation; import net.Zrips.CMILib.Entities.CMIEntityType; import net.Zrips.CMILib.Items.CMIItemStack; import net.Zrips.CMILib.Items.CMIMaterial; +import net.Zrips.CMILib.Locale.LC; import net.Zrips.CMILib.Logs.CMIDebug; +import net.Zrips.CMILib.Messages.CMIMessages; import net.Zrips.CMILib.Version.Version; public final class JobsPaymentListener implements Listener { @@ -1107,7 +1109,21 @@ public final class JobsPaymentListener implements Listener { return; final Block finalBlock = block; - plugin.getBlockOwnerShip(CMIMaterial.get(finalBlock)).ifPresent(os -> os.remove(finalBlock)); + plugin.getBlockOwnerShip(CMIMaterial.get(finalBlock)).ifPresent(os -> { + + if (os.disable(finalBlock)) { + + UUID uuid = plugin.getBlockOwnerShip(CMIMaterial.get(finalBlock)).get().getOwnerByLocation(finalBlock.getLocation()); + Player player = Bukkit.getPlayer(uuid); + if (player == null || !player.isOnline()) + return; + + CMIMessages.sendMessage(player, Jobs.getLanguage().getMessage("general.error.blockDisabled", + "[type]", CMIMaterial.get(finalBlock).getName(), + "[location]", LC.Location_Full.getLocale(finalBlock.getLocation()))); + } + + }); } @EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true) @@ -1121,7 +1137,19 @@ public final class JobsPaymentListener implements Listener { final BrewingStand stand = (BrewingStand) event.getDestination().getHolder(); if (Jobs.getGCManager().canPerformActionInWorld(stand.getWorld())) - plugin.getBlockOwnerShip(CMIMaterial.get(stand.getBlock())).ifPresent(os -> os.remove(stand.getBlock())); + plugin.getBlockOwnerShip(CMIMaterial.get(stand.getBlock())).ifPresent(os -> { + if (os.disable(stand.getBlock())) { + + UUID uuid = plugin.getBlockOwnerShip(CMIMaterial.get(stand.getBlock())).get().getOwnerByLocation(stand.getLocation()); + Player player = Bukkit.getPlayer(uuid); + if (player == null || !player.isOnline()) + return; + + CMIMessages.sendMessage(player, Jobs.getLanguage().getMessage("general.error.blockDisabled", + "[type]", CMIMaterial.get(stand.getBlock()).getName(), + "[location]", LC.Location_Full.getLocale(stand.getLocation()))); + } + }); } @EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true) @@ -1162,6 +1190,9 @@ public final class JobsPaymentListener implements Listener { if (player == null || !player.isOnline()) return; + if (bos.isDisabled(uuid, block.getLocation())) + return; + if (Jobs.getGCManager().blockOwnershipRange > 0 && Util.getDistance(player.getLocation(), block.getLocation()) > Jobs.getGCManager().blockOwnershipRange) return; @@ -1756,6 +1787,8 @@ public final class JobsPaymentListener implements Listener { CMIActionBar.send(p, Jobs.getLanguage().getMessage("general.error.newRegistration", "[block]", name, "[current]", blockOwner.getTotal(jPlayer.getUniqueId()), "[max]", jPlayer.getMaxOwnerShipAllowed(blockOwner.getType()) == 0 ? "-" : jPlayer.getMaxOwnerShipAllowed(blockOwner.getType()))); + } else if (done == ownershipFeedback.reenabled && jPlayer != null) { + CMIActionBar.send(p, Jobs.getLanguage().getMessage("general.error.reenabledBlock")); } } else if (!block.getType().toString().startsWith("STRIPPED_") && event.getAction() == Action.RIGHT_CLICK_BLOCK && jPlayer != null && hand.toString().endsWith("_AXE")) { diff --git a/src/main/java/com/gamingmesh/jobs/stuff/blockLoc.java b/src/main/java/com/gamingmesh/jobs/stuff/blockLoc.java index 7ff8e3ea..1cfb2a94 100644 --- a/src/main/java/com/gamingmesh/jobs/stuff/blockLoc.java +++ b/src/main/java/com/gamingmesh/jobs/stuff/blockLoc.java @@ -9,8 +9,8 @@ public class blockLoc { private int x; private int y; private int z; - private String worldName; private World w; + private boolean disabled = false; public blockLoc(String loc) { fromString(loc); @@ -21,15 +21,10 @@ public class blockLoc { y = loc.getBlockY(); z = loc.getBlockZ(); w = loc.getWorld(); - worldName = loc.getWorld().getName(); } public String getWorldName() { - return worldName; - } - - public void setWorldName(String worldName) { - this.worldName = worldName; + return w != null ? w.getName() : "__"; } public void setX(int x) { @@ -46,7 +41,7 @@ public class blockLoc { @Override public String toString() { - return (w == null ? worldName : w.getName()) + ":" + x + ":" + y + ":" + z; + return (w == null ? getWorldName() : w.getName()) + ":" + x + ":" + y + ":" + z; } public String toVectorString() { @@ -63,7 +58,6 @@ public class blockLoc { if (w == null) return false; this.w = w; - this.worldName = w.getName(); if (split.length < 4) { return false; @@ -85,11 +79,11 @@ public class blockLoc { } public Location getLocation() { - if (worldName == null && w == null) + if (getWorldName() == null && w == null) return null; // Make sure cached world is loaded - World w = this.w == null ? Bukkit.getWorld(worldName) : Bukkit.getWorld(this.w.getName()); + World w = this.w == null ? Bukkit.getWorld(getWorldName()) : Bukkit.getWorld(this.w.getName()); if (w == null) return null; @@ -97,4 +91,20 @@ public class blockLoc { return new Location(w, x, y, z); } + + public boolean isDisabled() { + return disabled; + } + + public void setDisabled(boolean disabled) { + this.disabled = disabled; + } + + public World getWorld() { + return w; + } + + public void setWorld(World world) { + this.w = world; + } }