properly do black/whitelist feature based on feedback

This commit is contained in:
hyperdefined
2026-01-26 15:23:20 -05:00
parent 9755ac2035
commit 58a74a0cdd
22 changed files with 72 additions and 25 deletions

View File

@@ -46,7 +46,7 @@ public class BlockBreak implements Listener {
return;
}
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -52,7 +52,7 @@ public class BlockDispenseEvent implements Listener {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -50,7 +50,7 @@ public class ChunkPopulate implements Listener {
return;
}
World world = event.getChunk().getWorld();
if (toolStats.config.getStringList("blacklist-worlds").contains(world.getName())) {
if (!toolStats.configTools.checkWorld(world.getName())) {
return;
}
// this is delayed because entities are not loaded instantly

View File

@@ -50,7 +50,7 @@ public class CraftItem implements Listener {
return;
}
Player player = (Player) event.getWhoClicked();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -45,7 +45,7 @@ public class CreativeEvent implements Listener {
@EventHandler
public void onCreativeEvent(InventoryCreativeEvent event) {
Player player = (Player) event.getWhoClicked();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
// make sure they are in creative mode

View File

@@ -56,7 +56,7 @@ public class EntityDamage implements Listener {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(mobBeingAttacked.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(mobBeingAttacked.getWorld().getName())) {
return;
}

View File

@@ -49,7 +49,7 @@ public class EntityDeath implements Listener {
if (livingEntity instanceof Player) {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(livingEntity.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(livingEntity.getWorld().getName())) {
return;
}
UUID livingEntityUUID = event.getEntity().getUniqueId();

View File

@@ -50,7 +50,7 @@ public class GenerateLoot implements Listener {
return;
}
Location lootLocation = event.getLootContext().getLocation();
if (toolStats.config.getStringList("blacklist-worlds").contains(lootLocation.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(lootLocation.getWorld().getName())) {
return;
}
Chunk lootChunk = lootLocation.getChunk();

View File

@@ -57,7 +57,7 @@ public class InventoryClose implements Listener {
}
Player player = (Player) event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
Inventory closedInventory = event.getInventory();

View File

@@ -48,7 +48,7 @@ public class InventoryOpen implements Listener {
Inventory inventory = event.getInventory();
Player player = (Player) event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
for (ItemStack itemStack : inventory) {

View File

@@ -54,7 +54,7 @@ public class PickupItem implements Listener {
}
Entity entity = event.getEntity();
if (entity instanceof Player player) {
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -57,7 +57,7 @@ public class PlayerFish implements Listener {
}
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -62,7 +62,7 @@ public class PlayerInteract implements Listener {
}
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -42,7 +42,7 @@ public class PlayerJoin implements Listener {
@EventHandler
public void onJoin(PlayerJoinEvent event) {
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}

View File

@@ -42,7 +42,7 @@ public class PlayerMove implements Listener {
@EventHandler(priority = EventPriority.MONITOR)
public void onMove(PlayerMoveEvent event) {
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
// player starts to fly

View File

@@ -41,7 +41,7 @@ public class ProjectileShoot implements Listener {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(tridentEntity.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(tridentEntity.getWorld().getName())) {
return;
}

View File

@@ -45,7 +45,7 @@ public class SheepShear implements Listener {
return;
}
Player player = event.getPlayer();
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -46,7 +46,7 @@ public class ShootBow implements Listener {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE && !toolStats.config.getBoolean("allow-creative")) {

View File

@@ -56,7 +56,7 @@ public class VillagerTrade implements Listener {
if (!(event.getWhoClicked() instanceof Player player)) {
return;
}
if (toolStats.config.getStringList("blacklist-worlds").contains(player.getWorld().getName())) {
if (!toolStats.configTools.checkWorld(player.getWorld().getName())) {
return;
}
if (player.getGameMode() == GameMode.CREATIVE || player.getGameMode() == GameMode.SPECTATOR) {

View File

@@ -94,6 +94,47 @@ public class ConfigTools {
};
}
/**
* Check the status of a world from the config.
*
* @param worldName The world to check.
* @return True if we can work in this world, false if not.
*/
public boolean checkWorld(String worldName) {
boolean enabled = toolStats.config.getBoolean("world-limit.enabled");
// if the system is disabled, all worlds are allowed
if (!enabled) {
return true;
}
String mode = toolStats.config.getString("worlds.mode");
if (mode == null) {
toolStats.logger.info("worlds.mode is not set, not allowing any worlds by default.");
return false;
}
List<String> worlds = toolStats.config.getStringList("worlds.worlds");
// if no worlds are defined, deny them
if (worlds.isEmpty()) {
return false;
}
if (mode.equalsIgnoreCase("blacklist")) {
// this world is on list and mode = blacklisted
// don't allow this world, allow others not on list
return !worlds.contains(worldName);
}
if (mode.equalsIgnoreCase("whitelist")) {
// this world is on list and mode = whitelisted
// allow it. if the world is not on list, don't allow it
return worlds.contains(worldName);
}
toolStats.logger.warn("Unknown worlds.mode '{}', denying by default.", mode);
return false;
}
/**
* Format a string to be ready for lore usage.
*

View File

@@ -130,9 +130,11 @@ public class Version15 {
toolStats.config.set("messages.trident-throws", "&7Times thrown: &8{times}");
// blacklist feature
toolStats.logger.info("Adding new blacklist-worlds feature");
toolStats.logger.info("Adding new world-limit feature, which is disabled by default");
List<String> worlds = Arrays.asList("world_1", "world_2");
toolStats.config.set("blacklist-worlds", worlds);
toolStats.config.set("world-limit.enabled", false);
toolStats.config.set("world-limit.mode", "blacklist");
toolStats.config.set("world-limit.worlds", worlds);
try {
toolStats.config.save("plugins" + File.separator + "ToolStats" + File.separator + "config.yml");

View File

@@ -409,9 +409,13 @@ normalize-time-creation: false
# Allows stats and origins to be tracked if the player is in creative mode.
allow-creative: false
# Allows you to turn off ToolStats in the worlds on the list.
blacklist-worlds:
- world_1
- world_2
# Allows you to change what worlds ToolStats works in.
# Mode is blacklist or whitelist.
world-limit:
enabled: false
mode: "blacklist"
worlds:
- world_1
- world_2
config-version: 15