Add world filter whitelist option

This commit is contained in:
GeorgH93 2020-05-17 00:37:09 +02:00
parent 2eee3b5fb4
commit e685f28680
No known key found for this signature in database
GPG Key ID: D1630D37F9E4B3C8
5 changed files with 96 additions and 22 deletions

View File

@ -148,10 +148,12 @@ ItemFilter:
# These settings allow control over how the plugin behave in different worlds
WorldSettings:
# Options: blacklist (all worlds listed in FilteredWorlds will be blocked), whitelist (all worlds listed in FilteredWorlds will be allowed)
FilterType: "blacklist"
# All worlds listed here will not have the plugin usable
# Blacklist: ["creative_world"]
# Blacklist: ["creative_world1", "creative_world2"]
Blacklist: []
# FilteredWorlds: ["creative_world"]
# FilteredWorlds: ["creative_world1", "creative_world2"]
FilteredWorlds: []
# Defines how the Blacklist will be enforced
# Options:
# Message = The player will see a message that the usage of the backpack is not allowed in this world.
@ -159,7 +161,7 @@ WorldSettings:
# NoPlugin = The plugin will not be available at all and act as if it was not installed.
# This also exclude players with permission to bypass the world restriction from using it!
# It will not disable the Shulkerboxes filter!
BlacklistMode: "Message"
BlockMode: "Message"
# Gives the players an item they can interact with to open their backpack. Only works on MC 1.8 or newer.
ItemShortcut:
@ -210,4 +212,4 @@ Misc:
UseBungeeCord: false
# Config file version. Don't touch it!
Version: 30
Version: 31

View File

@ -27,9 +27,7 @@
import at.pcgamingfreaks.Minepacks.Bukkit.ShrinkApproach;
import at.pcgamingfreaks.YamlFileManager;
import org.bukkit.ChatColor;
import org.bukkit.GameMode;
import org.bukkit.Sound;
import org.bukkit.*;
import org.bukkit.plugin.java.JavaPlugin;
import org.jetbrains.annotations.NotNull;
@ -38,7 +36,7 @@
public class Config extends Configuration implements DatabaseConnectionConfiguration
{
private static final int CONFIG_VERSION = 30, UPGRADE_THRESHOLD = CONFIG_VERSION, PRE_V2_VERSION = 20;
private static final int CONFIG_VERSION = 31, UPGRADE_THRESHOLD = CONFIG_VERSION, PRE_V2_VERSION = 20;
public Config(JavaPlugin plugin)
{
@ -65,6 +63,11 @@ protected void doUpgrade(@NotNull YamlFileManager oldConfig)
Map<String, String> remappedKeys = new HashMap<>();
if(oldConfig.getVersion() <= 23) remappedKeys.put("ItemFilter.Materials", "ItemFilter.Blacklist");
if(oldConfig.getVersion() <= 28) remappedKeys.put("Misc.AutoUpdate.Enabled", "Misc.AutoUpdate");
if(oldConfig.getVersion() <= 30)
{
remappedKeys.put("WorldSettings.FilteredWorlds", "WorldSettings.Blacklist");
remappedKeys.put("WorldSettings.BockMode", "WorldSettings.BlacklistMode");
}
Collection<String> keysToKeep = oldConfig.getYamlE().getKeysFiltered("Database\\.SQL\\.(MaxLifetime|IdleTimeout)");
keysToKeep.addAll(oldConfig.getYamlE().getKeysFiltered("Database\\.Tables\\.Fields\\..+"));
doUpgrade(oldConfig, remappedKeys, keysToKeep);
@ -359,19 +362,39 @@ public boolean isItemFilterModeWhitelist()
//endregion
//region World settings
public Collection<String> getWorldBlacklist()
public boolean isWorldWhitelistMode()
{
HashSet<String> blacklist = new HashSet<>();
for(String world : getConfigE().getStringList("WorldSettings.Blacklist", new LinkedList<>()))
return getConfigE().getString("WorldSettings.FilterType", "blacklist").equalsIgnoreCase("whitelist");
}
public Set<String> getWorldFilteredList()
{
blacklist.add(world.toLowerCase(Locale.ROOT));
Set<String> worldList = new HashSet<>();
for(String world : getConfigE().getStringList("WorldSettings.FilteredWorlds", new ArrayList<>(0)))
{
worldList.add(world.toLowerCase(Locale.ROOT));
}
return worldList;
}
public Set<String> getWorldBlacklist()
{
if(isWorldWhitelistMode())
{
Set<String> whitelist = getWorldFilteredList(), blacklist = new HashSet<>();
for(World world : Bukkit.getServer().getWorlds())
{
String worldName = world.getName().toLowerCase(Locale.ROOT);
if(!whitelist.contains(worldName)) blacklist.add(worldName);
}
return blacklist;
}
else return getWorldFilteredList();
}
public WorldBlacklistMode getWorldBlacklistMode()
public WorldBlacklistMode getWorldBlockMode()
{
String mode = getConfigE().getString("WorldSettings.BlacklistMode", "Message");
String mode = getConfigE().getString("WorldSettings.BlockMode", "Message");
WorldBlacklistMode blacklistMode = WorldBlacklistMode.Message;
try
{
@ -379,7 +402,7 @@ public WorldBlacklistMode getWorldBlacklistMode()
}
catch(IllegalArgumentException ignored)
{
logger.warning(ConsoleColor.YELLOW + "Unsupported mode \"" + mode + "\" for option \"WorldSettings.BlacklistMode\"" + ConsoleColor.RESET);
logger.warning(ConsoleColor.YELLOW + "Unsupported mode \"" + mode + "\" for option \"WorldSettings.BlockMode\"" + ConsoleColor.RESET);
}
return blacklistMode;
}

View File

@ -0,0 +1,45 @@
/*
* Copyright (C) 2020 GeorgH93
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package at.pcgamingfreaks.Minepacks.Bukkit.Listener;
import at.pcgamingfreaks.Minepacks.Bukkit.Minepacks;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.world.WorldInitEvent;
import org.jetbrains.annotations.NotNull;
import lombok.AllArgsConstructor;
import java.util.Locale;
@AllArgsConstructor
public class WorldBlacklistUpdater implements Listener
{
private final @NotNull Minepacks plugin;
@EventHandler
public void onWorldInit(final WorldInitEvent event)
{
String worldName = event.getWorld().getName().toLowerCase(Locale.ROOT);
if(!plugin.getConfiguration().getWorldFilteredList().contains(worldName))
{
plugin.getWorldBlacklist().add(worldName);
}
}
}

View File

@ -49,9 +49,12 @@
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import lombok.Getter;
import java.io.File;
import java.util.Collection;
import java.util.Locale;
import java.util.Set;
public class Minepacks extends JavaPlugin implements MinepacksPlugin
{
@ -65,7 +68,7 @@ public class Minepacks extends JavaPlugin implements MinepacksPlugin
public Message messageNoPermission, messageInvalidBackpack, messageWorldDisabled, messageNotFromConsole, messageNotANumber;
private int maxSize;
private Collection<String> worldBlacklist;
@Getter private Set<String> worldBlacklist;
private WorldBlacklistMode worldBlacklistMode;
private ItemsCollector collector;
private CommandManager commandManager;
@ -190,10 +193,11 @@ private void load()
}
if(config.isShulkerboxesDisable()) pluginManager.registerEvents(new DisableShulkerboxes(this), this);
if(config.isItemShortcutEnabled()) pluginManager.registerEvents(new ItemShortcut(this), this);
if(config.isWorldWhitelistMode()) pluginManager.registerEvents(new WorldBlacklistUpdater(this), this);
//endregion
if(config.getFullInvCollect()) collector = new ItemsCollector(this);
worldBlacklist = config.getWorldBlacklist();
worldBlacklistMode = (worldBlacklist.size() == 0) ? WorldBlacklistMode.None : config.getWorldBlacklistMode();
worldBlacklistMode = (worldBlacklist.size() == 0) ? WorldBlacklistMode.None : config.getWorldBlockMode();
gameModes = config.getAllowedGameModes();
if(config.getCommandCooldown() > 0) cooldownManager = new CooldownManager(this);

View File

@ -7,7 +7,7 @@
<packaging>pom</packaging>
<properties>
<revision>2.3.8-RC1</revision>
<revision>2.3.8-RC2</revision>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>