Compare commits
3 Commits
49bd873392
...
882e58e38e
Author | SHA1 | Date | |
---|---|---|---|
882e58e38e | |||
f5d60cd7e4 | |||
2d7192ae9b |
@ -78,6 +78,11 @@ public final class STPlugin extends JavaPlugin implements CommandExecutor, Liste
|
|||||||
private void scheduleTasks() {
|
private void scheduleTasks() {
|
||||||
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, new TPS(), 0, 1);
|
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, new TPS(), 0, 1);
|
||||||
|
|
||||||
|
if (this.config.getBoolean("ClearDropItems.enabled")) {
|
||||||
|
new ClearDropItemsTask(this).runTaskTimer(this, 20L, 20L);
|
||||||
|
this.log.info(ChatColor.stripColor(this.getPrefix()) + "Clear dropped items enabled!");
|
||||||
|
}
|
||||||
|
|
||||||
if (this.config.getBoolean("Saving.enabled") && this.config.getInt("Saving.interval") > 0) {
|
if (this.config.getBoolean("Saving.enabled") && this.config.getInt("Saving.interval") > 0) {
|
||||||
long intervalTicks = Math.convert(Math.Convert.SECONDS, Math.Convert.TICKS, instance.config.getInt("Saving.interval"));
|
long intervalTicks = Math.convert(Math.Convert.SECONDS, Math.Convert.TICKS, instance.config.getInt("Saving.interval"));
|
||||||
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, new SaveHandler(), 0L, intervalTicks);
|
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, new SaveHandler(), 0L, intervalTicks);
|
||||||
|
@ -0,0 +1,76 @@
|
|||||||
|
package hu.ditservices.handlers;
|
||||||
|
|
||||||
|
import hu.ditservices.STPlugin;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.entity.Item;
|
||||||
|
import org.bukkit.scheduler.BukkitRunnable;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class ClearDropItemsTask extends BukkitRunnable {
|
||||||
|
private final STPlugin plugin;
|
||||||
|
private int countdown;
|
||||||
|
private final int interval; // In seconds
|
||||||
|
private final List<String> exceptItemList;
|
||||||
|
private final List<String> exceptWorldList;
|
||||||
|
private final boolean shouldBroadcast;
|
||||||
|
|
||||||
|
public ClearDropItemsTask(STPlugin plugin) {
|
||||||
|
this.plugin = plugin;
|
||||||
|
this.interval = plugin.getConfig().getInt("ClearDropItems.interval", 300);
|
||||||
|
this.countdown = this.interval;
|
||||||
|
// Get the exception list from the config (should be a list of item type names, e.g., ["DIAMOND", "GOLD_INGOT"])
|
||||||
|
this.exceptItemList = plugin.getConfig().getStringList("ClearDropItems.except");
|
||||||
|
this.exceptWorldList = plugin.getConfig().getStringList("ClearDropItems.skipWorlds");
|
||||||
|
this.shouldBroadcast = plugin.getConfig().getBoolean("ClearDropItems.broadcastMsg", true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (this.shouldBroadcast) {
|
||||||
|
if (countdown == 60) {
|
||||||
|
Bukkit.broadcastMessage(plugin.getPrefix() + ChatColor.RED + plugin.getTranslatedText("cleardropitems.oneMin"));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (countdown == 10) {
|
||||||
|
Bukkit.broadcastMessage(plugin.getPrefix() + ChatColor.RED + plugin.getTranslatedText("cleardropitems.tenSec"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (countdown <= 0) {
|
||||||
|
int removed = 0;
|
||||||
|
|
||||||
|
for (World world : Bukkit.getWorlds()) {
|
||||||
|
if (this.exceptWorldList.contains(world.getName())) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
for (Entity entity : world.getEntities()) {
|
||||||
|
|
||||||
|
if (entity instanceof Item) {
|
||||||
|
Item item = (Item) entity;
|
||||||
|
String itemType = item.getItemStack().getType().toString();
|
||||||
|
// Check if the item is in the exception list
|
||||||
|
boolean isException = this.exceptItemList.stream()
|
||||||
|
.anyMatch(ex -> ex.equalsIgnoreCase(itemType));
|
||||||
|
if (!isException) {
|
||||||
|
item.remove();
|
||||||
|
removed++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (this.shouldBroadcast) {
|
||||||
|
Bukkit.broadcastMessage(plugin.getPrefix() + ChatColor.GREEN + plugin.getTranslatedText("cleardropitems.cleared").replace("%REMOVECOUNT%",String.valueOf(removed)));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset the countdown to the interval for the next cycle
|
||||||
|
countdown = interval;
|
||||||
|
} else {
|
||||||
|
countdown--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -25,9 +25,19 @@ public class ServerPasswordEvents implements Listener {
|
|||||||
this.config = plugin.getConfig();
|
this.config = plugin.getConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean skipIfOpPlayer(Player player)
|
||||||
|
{
|
||||||
|
return player.isOp() && config.getBoolean("ServerPassword.exceptOps");
|
||||||
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onPlayerJoin(PlayerJoinEvent event) {
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
Player player = event.getPlayer();
|
Player player = event.getPlayer();
|
||||||
|
|
||||||
|
if (skipIfOpPlayer(player)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if ((!config.getBoolean("ServerPassword.rememberUntilRestart"))
|
if ((!config.getBoolean("ServerPassword.rememberUntilRestart"))
|
||||||
|| (!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(player.getUniqueId(),false))) {
|
|| (!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(player.getUniqueId(),false))) {
|
||||||
plugin.getServerPasswordData().getAuthenticatedPlayers().put(player.getUniqueId(),false);
|
plugin.getServerPasswordData().getAuthenticatedPlayers().put(player.getUniqueId(),false);
|
||||||
@ -57,6 +67,9 @@ public class ServerPasswordEvents implements Listener {
|
|||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onPlayerMove(PlayerMoveEvent event) {
|
public void onPlayerMove(PlayerMoveEvent event) {
|
||||||
|
if (skipIfOpPlayer(event.getPlayer())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
||||||
&& config.getBoolean("ServerPassword.preventMove")) {
|
&& config.getBoolean("ServerPassword.preventMove")) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
@ -65,6 +78,9 @@ public class ServerPasswordEvents implements Listener {
|
|||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onBlockBreak(BlockBreakEvent event) {
|
public void onBlockBreak(BlockBreakEvent event) {
|
||||||
|
if (skipIfOpPlayer(event.getPlayer())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
||||||
&& config.getBoolean("ServerPassword.preventBuild")) {
|
&& config.getBoolean("ServerPassword.preventBuild")) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
@ -73,6 +89,9 @@ public class ServerPasswordEvents implements Listener {
|
|||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onBlockPlace(BlockPlaceEvent event) {
|
public void onBlockPlace(BlockPlaceEvent event) {
|
||||||
|
if (skipIfOpPlayer(event.getPlayer())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
if ((!plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(event.getPlayer().getUniqueId(),false))
|
||||||
&& config.getBoolean("ServerPassword.preventBuild")) {
|
&& config.getBoolean("ServerPassword.preventBuild")) {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
@ -84,6 +103,10 @@ public class ServerPasswordEvents implements Listener {
|
|||||||
Player player = event.getPlayer();
|
Player player = event.getPlayer();
|
||||||
UUID uuid = player.getUniqueId();
|
UUID uuid = player.getUniqueId();
|
||||||
|
|
||||||
|
if (skipIfOpPlayer(player)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(uuid, false)) {
|
if (plugin.getServerPasswordData().getAuthenticatedPlayers().getOrDefault(uuid, false)) {
|
||||||
if (!config.getBoolean("ServerPassword.rememberUntilRestart")) {
|
if (!config.getBoolean("ServerPassword.rememberUntilRestart")) {
|
||||||
plugin.getServerPasswordData().getAuthenticatedPlayers().remove(uuid);
|
plugin.getServerPasswordData().getAuthenticatedPlayers().remove(uuid);
|
||||||
|
@ -91,12 +91,28 @@ ServerPassword:
|
|||||||
preventMove: true
|
preventMove: true
|
||||||
preventBuild: true
|
preventBuild: true
|
||||||
|
|
||||||
|
# Dropped items clearing options
|
||||||
|
ClearDropItems:
|
||||||
|
enabled: false
|
||||||
|
interval: 300 # Interval in seconds between each clear cycle
|
||||||
|
broadcastMsg: true # Broadcasts alerts before clearing 1 minutes and 10 seconds before and when cleared. Set this to 'false' to make cleaning silently.
|
||||||
|
# Dropped items that should always be kept (never cleared)
|
||||||
|
except:
|
||||||
|
- DIAMOND
|
||||||
|
- GOLD_INGOT
|
||||||
|
# - COAL
|
||||||
|
# - IRON_INGOT
|
||||||
|
# - BREAD
|
||||||
|
# Worlds to skip (dropped items in these worlds won't be cleared)
|
||||||
|
skipWorlds:
|
||||||
|
- world_nether
|
||||||
|
- world_the_end
|
||||||
|
|
||||||
# Cooldown options (only applicable for this plugin!)
|
# Cooldown options (only applicable for this plugin!)
|
||||||
Cooldown:
|
Cooldown:
|
||||||
enabled: true
|
enabled: true
|
||||||
# The time must be passed between using this plugin commands.
|
# The time must be passed between using this plugin commands.
|
||||||
seconds: 2 #The command cooldown in seconds
|
seconds: 1 #The command cooldown in seconds
|
||||||
Msg: '{PREFIX} Please wait {SECONDS} seconds!' # The message when the user spamming a command
|
Msg: '{PREFIX} Please wait {SECONDS} seconds!' # The message when the user spamming a command
|
||||||
#
|
#
|
||||||
# Plugin Manager - Enable/Disable plugins without server restart
|
# Plugin Manager - Enable/Disable plugins without server restart
|
||||||
|
@ -36,4 +36,7 @@ pmanager.already.enabled: " already enabled!"
|
|||||||
pmanager.success.enabled: " successfully enabled!"
|
pmanager.success.enabled: " successfully enabled!"
|
||||||
pmanager.already.disabled: " already disabled!"
|
pmanager.already.disabled: " already disabled!"
|
||||||
pmanager.success.disabled: " successfully disabled!"
|
pmanager.success.disabled: " successfully disabled!"
|
||||||
list.help: "To list all SimplifyTools commands use the '/help SIMPLIFYTOOLS' command!"
|
list.help: "To list all SimplifyTools commands use the '/help SIMPLIFYTOOLS' command!"
|
||||||
|
cleardropitems.oneMin: "Attention: Dropped items will be cleared in 1 minute!"
|
||||||
|
cleardropitems.tenSec: "Attention: Dropped items will be cleared in 10 seconds!"
|
||||||
|
cleardropitems.cleared: "Dropped items have been cleared (%REMOVECOUNT% items removed)."
|
@ -36,4 +36,7 @@ pmanager.already.enabled: " már eddig is engedélyezve volt!"
|
|||||||
pmanager.success.enabled: " sikeresen engedélyezve!"
|
pmanager.success.enabled: " sikeresen engedélyezve!"
|
||||||
pmanager.already.disabled: " már kivolt kapcsolva eddig is!"
|
pmanager.already.disabled: " már kivolt kapcsolva eddig is!"
|
||||||
pmanager.success.disabled: " sikeresen kikapcsolva!"
|
pmanager.success.disabled: " sikeresen kikapcsolva!"
|
||||||
list.help: "Használd a '/help SIMPLIFYTOOLS' parancsot a plugin parancsainak listázásához!"
|
list.help: "Használd a '/help SIMPLIFYTOOLS' parancsot a plugin parancsainak listázásához!"
|
||||||
|
cleardropitems.oneMin: "Figyelem! Az eldobott tárgyak 1 perc múlva törlésre kerülnek!"
|
||||||
|
cleardropitems.tenSec: "Figyelem! Az eldobott tárgyak 10 másodpercen belül törlésre kerülnek!"
|
||||||
|
cleardropitems.cleared: "Az eldobott tárgyak törlésre kerültek. (%REMOVECOUNT% tárgy lett eltávolítva)."
|
Loading…
x
Reference in New Issue
Block a user