Cleaning up

This commit is contained in:
Ardakaz
2026-05-19 15:49:03 +03:00
parent f59c484d6b
commit 8e28ba0b87
3 changed files with 167 additions and 185 deletions

View File

@@ -1,6 +1,6 @@
name: GriefAlert name: GriefAlert
main: net.ardakaz.griefalert.GriefAlert main: net.ardakaz.griefalert.GriefAlert
version: 0.5 version: 0.6
api-version: 1.21 api-version: 1.21
depends: [CoreProtect] depends: [CoreProtect]
softdepend: [DiscordSRV] softdepend: [DiscordSRV]

View File

@@ -3,8 +3,6 @@ package net.ardakaz.griefalert;
import net.coreprotect.CoreProtect; import net.coreprotect.CoreProtect;
import net.coreprotect.CoreProtectAPI; import net.coreprotect.CoreProtectAPI;
import net.coreprotect.CoreProtectAPI.ParseResult; import net.coreprotect.CoreProtectAPI.ParseResult;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.Location; import org.bukkit.Location;
@@ -12,52 +10,85 @@ import org.bukkit.Material;
import org.bukkit.block.Block; import org.bukkit.block.Block;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.command.TabCompleter;
import org.bukkit.entity.*; import org.bukkit.entity.*;
import org.bukkit.event.*; import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.block.Action; import org.bukkit.event.block.Action;
import org.bukkit.event.block.BlockBreakEvent; import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.event.entity.EntityDeathEvent;
import org.bukkit.event.entity.EntityDamageByEntityEvent; import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntityDeathEvent;
import org.bukkit.event.hanging.HangingBreakByEntityEvent; import org.bukkit.event.hanging.HangingBreakByEntityEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.event.inventory.InventoryAction; import org.bukkit.event.inventory.InventoryAction;
import org.bukkit.event.inventory.InventoryClickEvent; import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryType; import org.bukkit.event.inventory.InventoryType;
import org.bukkit.event.player.PlayerInteractAtEntityEvent; import org.bukkit.event.player.PlayerInteractAtEntityEvent;
import org.bukkit.event.player.PlayerInteractEntityEvent; import org.bukkit.event.player.PlayerInteractEntityEvent;
import org.bukkit.event.player.PlayerInteractEvent; import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.inventory.EntityEquipment;
import org.bukkit.inventory.Inventory; import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import java.sql.Connection; import java.sql.*;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Objects;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import org.bukkit.inventory.EntityEquipment;
public class GriefAlert extends JavaPlugin implements Listener { public class GriefAlert extends JavaPlugin implements Listener {
private static CoreProtectAPI coreProtectAPI; private static CoreProtectAPI coreProtectAPI;
private final String DB_FILE = "ignored_locations.db";
private Integer identicalAlerts = 1; private Integer identicalAlerts = 1;
private String lastAlert; private String lastAlert;
private Set<Material> EXCLUDED_BLOCKS; private Set<Material> EXCLUDED_BLOCKS;
private Set<InventoryType> VALID_CONTAINERS; private Set<InventoryType> VALID_CONTAINERS;
private String MAP_LINK; private String MAP_LINK;
private Boolean ALLOW_STEALING; private Boolean ALLOW_STEALING;
private Connection connection; private Connection connection;
private final String DB_FILE = "ignored_locations.db";
// Block inspector: only the most recent placement counts for ownership.
private static String inspectBlock(Block block, Player player) {
List<String[]> lookup = coreProtectAPI.blockLookup(block, 50000000);
if (lookup == null || lookup.isEmpty()) {
// Natural block
return null;
}
// Find the most recent placement event only
for (String[] result : lookup) {
ParseResult parseResult = coreProtectAPI.parseResult(result);
if (parseResult == null) continue;
if (parseResult.getActionId() == 1 && !parseResult.isRolledBack() && !parseResult.getPlayer().startsWith("#")) {
// If the current player placed it, it's theirs (no alert)
if (parseResult.getPlayer().equals(player.getName())) {
return null;
} else {
return parseResult.getPlayer();
}
}
// If we see a break before a placement, stop (block is gone)
if (parseResult.getActionId() == 0) {
break;
}
}
// No valid placement found
return null;
}
private static String getHumanWorldName(String worldName) {
String world = "";
if (worldName.endsWith("_nether")) {
world = " in the Nether";
} else if (worldName.endsWith("_the_end")) {
world = " in the End";
}
return world;
}
// Init GriefAlert // Init GriefAlert
@Override @Override
@@ -92,7 +123,10 @@ public class GriefAlert extends JavaPlugin implements Listener {
public void onDisable() { public void onDisable() {
getLogger().info("GriefAlert has been disabled."); getLogger().info("GriefAlert has been disabled.");
if (connection != null) { if (connection != null) {
try { connection.close(); } catch (SQLException ignored) {} try {
connection.close();
} catch (SQLException ignored) {
}
} }
} }
@@ -157,7 +191,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
} }
} }
@EventHandler (ignoreCancelled = true) @EventHandler(ignoreCancelled = true)
// Block break alerts // Block break alerts
public void onBlockBreak(BlockBreakEvent event) { public void onBlockBreak(BlockBreakEvent event) {
// Exclusion list // Exclusion list
@@ -182,7 +216,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
} }
// Stealing alerts // Stealing alerts
@EventHandler (ignoreCancelled = true) @EventHandler(ignoreCancelled = true)
public void onInventoryClick(InventoryClickEvent event) { public void onInventoryClick(InventoryClickEvent event) {
if (ALLOW_STEALING) { if (ALLOW_STEALING) {
return; return;
@@ -190,8 +224,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
boolean stealing; boolean stealing;
// Event parser for inv // Event parser for inv
if (!(event.getWhoClicked() instanceof Player)) return; if (!(event.getWhoClicked() instanceof Player player)) return;
Player player = (Player) event.getWhoClicked();
Inventory inventory = event.getInventory(); Inventory inventory = event.getInventory();
Inventory clickedInventory = event.getClickedInventory(); Inventory clickedInventory = event.getClickedInventory();
ItemStack item = event.getCurrentItem(); ItemStack item = event.getCurrentItem();
@@ -291,11 +324,11 @@ public class GriefAlert extends JavaPlugin implements Listener {
String action; String action;
//this works at the instance of interaction before items get moved around //this works at the instance of interaction before items get moved around
if (handEmpty && !armorEmpty) { if (handEmpty && !armorEmpty) {
action = "took " + armorItem.getType().toString(); action = "took " + armorItem.getType();
} else if (!handEmpty && armorEmpty) { } else if (!handEmpty && armorEmpty) {
action = "added " + handItem.getType().toString(); action = "added " + handItem.getType();
} else if (!handEmpty) { } else if (!handEmpty) {
action = "swapped " + armorItem.getType().toString() + " with " + handItem.getType().toString(); action = "swapped " + armorItem.getType() + " with " + handItem.getType();
} else { } else {
action = "interacted with"; action = "interacted with";
} }
@@ -303,10 +336,11 @@ public class GriefAlert extends JavaPlugin implements Listener {
alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName); alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName);
} }
} }
//event handler for item frames //event handler for item frames
@EventHandler(ignoreCancelled = true) @EventHandler(ignoreCancelled = true)
public void onPlayerInteractEntity(PlayerInteractEntityEvent event){ public void onPlayerInteractEntity(PlayerInteractEntityEvent event) {
if(!(event.getRightClicked() instanceof ItemFrame frame)) return; if (!(event.getRightClicked() instanceof ItemFrame frame)) return;
Player player = event.getPlayer(); Player player = event.getPlayer();
int x = frame.getLocation().getBlockX(); int x = frame.getLocation().getBlockX();
@@ -318,31 +352,28 @@ public class GriefAlert extends JavaPlugin implements Listener {
return; return;
} }
String target = inspectBlock(frame.getLocation().getBlock(), player); String target = inspectBlock(frame.getLocation().getBlock(), player);
if(target !=null){ if (target != null) {
ItemStack itemInFrame = frame.getItem(); ItemStack itemInFrame = frame.getItem();
ItemStack handItem = player.getInventory().getItemInMainHand(); ItemStack handItem = player.getInventory().getItemInMainHand();
boolean handEmpty = handItem ==null || handItem.getType() == Material.AIR; boolean handEmpty = handItem == null || handItem.getType() == Material.AIR;
boolean frameEmpty = itemInFrame ==null || itemInFrame.getType() == Material.AIR; boolean frameEmpty = itemInFrame == null || itemInFrame.getType() == Material.AIR;
String playerName = player.getName(); String playerName = player.getName();
String action; String action;
if (!handEmpty && frameEmpty) { if (!handEmpty && frameEmpty) {
action = "added " + handItem.getType(); action = "added " + handItem.getType();
} } else {
else {
return; return;
} }
String message = ChatColor.GRAY + playerName + " " + action + " an item to an item frame owned by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName); String message = ChatColor.GRAY + playerName + " " + action + " an item to an item frame placed by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName);
alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName); alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName);
} }
} }
// Breaking item frame item (uses a different event then placing an item) // Breaking item frame item (uses a different event then placing an item)
@EventHandler (ignoreCancelled = true) @EventHandler(ignoreCancelled = true)
public void onItemFrameDamage(EntityDamageByEntityEvent event) { public void onItemFrameDamage(EntityDamageByEntityEvent event) {
if (!(event.getEntity() instanceof ItemFrame frame)) return; if (!(event.getEntity() instanceof ItemFrame frame)) return;
if (!(event.getDamager() instanceof Player player)) return; if (!(event.getDamager() instanceof Player player)) return;
@@ -366,13 +397,12 @@ public class GriefAlert extends JavaPlugin implements Listener {
if (item.getType() == Material.AIR) return; if (item.getType() == Material.AIR) return;
// At this point, the player is removing the item // At this point, the player is removing the item
String action = "took " + item.getType(); String action = "took " + item.getType();
String message = ChatColor.GRAY + playerName + " " + action + " from item frame owned by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName); String message = ChatColor.GRAY + playerName + " " + action + " from an item frame placed by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName);
alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName); alert(message, playerName, "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, worldName);
} }
@EventHandler(ignoreCancelled = true) @EventHandler(ignoreCancelled = true)
public void onItemFrameBreak(HangingBreakByEntityEvent event){ public void onItemFrameBreak(HangingBreakByEntityEvent event) {
if (!(event.getEntity() instanceof ItemFrame frame)) return; if (!(event.getEntity() instanceof ItemFrame frame)) return;
if (!(event.getRemover() instanceof Player player)) return; if (!(event.getRemover() instanceof Player player)) return;
@@ -389,7 +419,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
return; return;
} }
String target = inspectBlock(loc.getBlock(), player); String target = inspectBlock(loc.getBlock(), player);
if (target ==null || target.equals(player.getName())) return; if (target == null || target.equals(player.getName())) return;
String action = "broke an item frame"; String action = "broke an item frame";
String message = ChatColor.GRAY + playerName + " " + action + " placed by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName); String message = ChatColor.GRAY + playerName + " " + action + " placed by " + target + " at " + x + " " + y + " " + z + getHumanWorldName(worldName);
@@ -397,9 +427,6 @@ public class GriefAlert extends JavaPlugin implements Listener {
} }
@Override @Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) { public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
if (!command.getName().equalsIgnoreCase("griefalert")) return false; if (!command.getName().equalsIgnoreCase("griefalert")) return false;
@@ -418,7 +445,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world."); sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world.");
return true; return true;
} }
world = ((Player)sender).getWorld().getName(); world = ((Player) sender).getWorld().getName();
try { try {
x = Integer.parseInt(args[1]); x = Integer.parseInt(args[1]);
y = Integer.parseInt(args[2]); y = Integer.parseInt(args[2]);
@@ -462,7 +489,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world."); sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world.");
return true; return true;
} }
world = ((Player)sender).getWorld().getName(); world = ((Player) sender).getWorld().getName();
try { try {
x = Integer.parseInt(args[1]); x = Integer.parseInt(args[1]);
y = Integer.parseInt(args[2]); y = Integer.parseInt(args[2]);
@@ -503,7 +530,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world."); sender.sendMessage(ChatColor.RED + "Only players can use this command without specifying a world.");
return true; return true;
} }
world = ((Player)sender).getWorld().getName(); world = ((Player) sender).getWorld().getName();
try { try {
x = Integer.parseInt(args[1]); x = Integer.parseInt(args[1]);
y = Integer.parseInt(args[2]); y = Integer.parseInt(args[2]);
@@ -612,42 +639,14 @@ public class GriefAlert extends JavaPlugin implements Listener {
lastAlert = realAlertMessage; lastAlert = realAlertMessage;
} }
// Block inspector: only the most recent placement counts for ownership.
private static String inspectBlock(Block block, Player player) {
List<String[]> lookup = coreProtectAPI.blockLookup(block, 50000000);
if (lookup == null || lookup.isEmpty()) {
// Natural block
return null;
}
// Find the most recent placement event only
for (String[] result : lookup) {
ParseResult parseResult = coreProtectAPI.parseResult(result);
if (parseResult == null) continue;
if (parseResult.getActionId() == 1 && !parseResult.isRolledBack() && !parseResult.getPlayer().startsWith("#")) {
// If the current player placed it, it's theirs (no alert)
if (parseResult.getPlayer().equals(player.getName())) {
return null;
} else {
return parseResult.getPlayer();
}
}
// If we see a break before a placement, stop (block is gone)
if (parseResult.getActionId() == 0) {
break;
}
}
// No valid placement found
return null;
}
//pet alert(dog and cat only) //pet alert(dog and cat only)
@EventHandler @EventHandler
public void onPetKill(EntityDeathEvent event){ public void onPetKill(EntityDeathEvent event) {
if (!(event.getEntity() instanceof Tameable tameable)) return; if (!(event.getEntity() instanceof Tameable tameable)) return;
if (!tameable.isTamed()) return; if (!tameable.isTamed()) return;
//checks if wolf or cat or not //checks if wolf or cat or not
if (!(event.getEntity() instanceof Wolf) && !(event.getEntity()instanceof Cat)) return; if (!(event.getEntity() instanceof Wolf) && !(event.getEntity() instanceof Cat)) return;
AnimalTamer Owner = tameable.getOwner(); AnimalTamer Owner = tameable.getOwner();
@@ -662,19 +661,20 @@ public class GriefAlert extends JavaPlugin implements Listener {
String worldName = event.getEntity().getWorld().getName(); String worldName = event.getEntity().getWorld().getName();
String pet = event.getEntity().getType().name(); String pet = event.getEntity().getType().name();
String message = ChatColor.GRAY + killer.getName() + " killed" +" " + pet + " in " + Owner.getName() + "'s build at " + x + " " + y + " " + z + getHumanWorldName(worldName); String message = ChatColor.GRAY + killer.getName() + " killed" + " " + pet + " in " + Owner.getName() + "'s build at " + x + " " + y + " " + z + getHumanWorldName(worldName);
alert(message, killer.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", Owner.getName(), x, y, z, worldName); alert(message, killer.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", Owner.getName(), x, y, z, worldName);
} }
//farm animal handler //farm animal handler
@EventHandler @EventHandler
public void onFarmAnimalDeath(EntityDeathEvent event){ public void onFarmAnimalDeath(EntityDeathEvent event) {
if(!(event.getEntity().getKiller() instanceof Player killer)) return; if (!(event.getEntity().getKiller() instanceof Player killer)) return;
List<String> alertanimals = getConfig().getStringList("triggered-animals"); List<String> alertanimals = getConfig().getStringList("triggered-animals");
String typeName = event.getEntityType().name(); String typeName = event.getEntityType().name();
if(! alertanimals.contains(typeName)) return; if (!alertanimals.contains(typeName)) return;
Block blockBelow = event.getEntity().getLocation().subtract(0, 1, 0).getBlock(); Block blockBelow = event.getEntity().getLocation().subtract(0, 1, 0).getBlock();
String animalOwner = inspectBlock(blockBelow, killer); String animalOwner = inspectBlock(blockBelow, killer);
@@ -690,12 +690,13 @@ public class GriefAlert extends JavaPlugin implements Listener {
String worldName = event.getEntity().getWorld().getName(); String worldName = event.getEntity().getWorld().getName();
String message = ChatColor.GRAY + killer.getName() + " killed" +" " + typeName + "in " + animalOwner + "'s build at " + x + " " + y + " " + z + getHumanWorldName(worldName); String message = ChatColor.GRAY + killer.getName() + " killed" + " " + typeName + "in " + animalOwner + "'s build at " + x + " " + y + " " + z + getHumanWorldName(worldName);
alert(message, killer.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", animalOwner, x, y, z, worldName); alert(message, killer.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + worldName + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", animalOwner, x, y, z, worldName);
} }
/*code i hope for copper waxing/unwaxing theres no proper onwax() or onUnWax() /*code i hope for copper waxing/unwaxing theres no proper onwax() or onUnWax()
so im kinda gonna try to just check a situation like, if ur holding an axe, left clicking a copper block so im kinda gonna try to just check a situation like, if ur holding an axe, left clicking a copper block
and its waxed, ill assume ur unwaxing, and therefor sending an alert and its waxed, ill assume ur unwaxing, and therefor sending an alert
@@ -720,7 +721,7 @@ public class GriefAlert extends JavaPlugin implements Listener {
String world = block.getWorld().getName(); String world = block.getWorld().getName();
if (isLocationIgnored(x, y, z, world)){ if (isLocationIgnored(x, y, z, world)) {
return; return;
} }
@@ -734,8 +735,8 @@ public class GriefAlert extends JavaPlugin implements Listener {
//boolean isAxe = item.getType().toString().endsWith("_AXE"); //boolean isAxe = item.getType().toString().endsWith("_AXE");
String target = inspectBlock(block, player); String target = inspectBlock(block, player);
if(target == player.getName()) return; if (Objects.equals(target, player.getName())) return;
if(target == null) return; if (target == null) return;
Bukkit.getScheduler().runTaskLater(this, () -> { Bukkit.getScheduler().runTaskLater(this, () -> {
String action; String action;
@@ -746,31 +747,26 @@ public class GriefAlert extends JavaPlugin implements Listener {
boolean wasWaxed = before.name().startsWith("WAXED_"); boolean wasWaxed = before.name().startsWith("WAXED_");
boolean isWaxed = after.name().startsWith("WAXED_"); boolean isWaxed = after.name().startsWith("WAXED_");
if(wasWaxed && !isWaxed){ if (wasWaxed && !isWaxed) {
action = "Unwaxed"; action = "Unwaxed";
} else if(!wasWaxed && isWaxed) { } else if (!wasWaxed && isWaxed) {
action = "Waxed"; action = "Waxed";
} else if (item !=null && item.getType().name().endsWith("_AXE")) { } else if (item != null && item.getType().name().endsWith("_AXE")) {
action = "undusted"; action = "undusted";
}else{ } else {
action = "error 404 check with kleedje30"; action = "error 404 check with kleedje30";
} }
String message = ChatColor.GRAY + player.getName() + action + " Copper " + " at " + x + " " + y + " " + z + getHumanWorldName(world); String message = ChatColor.GRAY + player.getName() + action + " Copper " + " at " + x + " " + y + " " + z + getHumanWorldName(world);
alert(message, player.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + world + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")",target, x, y, z, world); alert(message, player.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + world + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, world);
}, 1L); }, 1L);
} }
//stripping logs //stripping logs
@EventHandler @EventHandler
public void onLogStrip(PlayerInteractEvent event){ public void onLogStrip(PlayerInteractEvent event) {
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) return; if (event.getAction() != Action.RIGHT_CLICK_BLOCK) return;
Player player = event.getPlayer(); Player player = event.getPlayer();
@@ -788,51 +784,37 @@ public class GriefAlert extends JavaPlugin implements Listener {
boolean isWood = before.name().contains("LOG"); boolean isWood = before.name().contains("LOG");
if(!isWood) return; if (!isWood) return;
if (isLocationIgnored(x, y, z, world)){ if (isLocationIgnored(x, y, z, world)) {
return; return;
} }
String target = inspectBlock(block, player); String target = inspectBlock(block, player);
if(target == null) return; if (target == null) return;
if(target == player.getName()) return; if (target.equals(player.getName())) return;
Bukkit.getScheduler().runTaskLater(this, () -> { Bukkit.getScheduler().runTaskLater(this, () -> {
String action; String action;
Material after = block.getType(); Material after = block.getType();
if(before == after) return; if (before == after) return;
if(!before.name().contains("STRIPPED") && after.name().contains("STRIPPED")){ if (!before.name().contains("STRIPPED") && after.name().contains("STRIPPED")) {
action = "Stripped"; action = "Stripped";
} else{return;} } else {
return;
}
String message = ChatColor.GRAY + player.getName() + action + " a(n) " + before + " at " + x + " " + y + " " + z + getHumanWorldName(world); String message = ChatColor.GRAY + player.getName() + action + " a(n) " + before + " at " + x + " " + y + " " + z + getHumanWorldName(world);
alert(message, player.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + world + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")",target, x, y, z, world); alert(message, player.getName(), "[Map Link](" + MAP_LINK + "/?worldname=" + world + "&zoom=7&x=" + x + "&y=" + y + "&z=" + z + ")", target, x, y, z, world);
}, 1L); }, 1L);
} }
private static String getHumanWorldName(String worldName) {
String world = "";
if (worldName.endsWith("_nether")) {
world = " in the Nether";
}
else if (worldName.endsWith("_the_end")) {
world = " in the End";
}
return world;
}
private CoreProtectAPI getCoreProtect() { private CoreProtectAPI getCoreProtect() {
Plugin plugin = getServer().getPluginManager().getPlugin("CoreProtect"); Plugin plugin = getServer().getPluginManager().getPlugin("CoreProtect");