mirror of
https://github.com/garbagemule/MobArena.git
synced 2025-01-23 08:41:19 +01:00
Use implicit permissions checks for classes and arenas.
Removes the dynamic registration of permissions for classes and arenas. This means that it is no longer enough to just check whether a Player.hasPermission("mobarena.classes.Knight"), but we also need to check if the Player.isPermissionSet("mobarena.classes.Knight"), which it won't be by default. To make the stringly typed parts of this dynamic permissions checking more focused, ArenaClass and Arena now both have hasPermission(Player) methods, so the actual permissions checking happens on the objects themselves, rather than from the caller of these methods.
This commit is contained in:
parent
31aa4c15a1
commit
94d198c4d0
@ -137,6 +137,11 @@ public class ArenaClass
|
|||||||
this.armor = armor;
|
this.armor = armor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean hasPermission(Player p) {
|
||||||
|
String perm = "mobarena.classes." + configName;
|
||||||
|
return !p.isPermissionSet(perm) || p.hasPermission(perm);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Grants all of the class items and armor to the given player.
|
* Grants all of the class items and armor to the given player.
|
||||||
* The normal items will be added to the inventory normally, while the
|
* The normal items will be added to the inventory normally, while the
|
||||||
|
@ -63,9 +63,9 @@ import java.util.LinkedList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.Random;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.PriorityBlockingQueue;
|
import java.util.concurrent.PriorityBlockingQueue;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public class ArenaImpl implements Arena
|
public class ArenaImpl implements Arena
|
||||||
{
|
{
|
||||||
@ -657,6 +657,12 @@ public class ArenaImpl implements Arena
|
|||||||
cleanup();
|
cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean hasPermission(Player p) {
|
||||||
|
String perm = "mobarena.arenas." + name;
|
||||||
|
return !p.isPermissionSet(perm) || p.hasPermission(perm);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean playerJoin(Player p, Location loc)
|
public boolean playerJoin(Player p, Location loc)
|
||||||
{
|
{
|
||||||
@ -1353,21 +1359,19 @@ public class ArenaImpl implements Arena
|
|||||||
@Override
|
@Override
|
||||||
public void assignRandomClass(Player p)
|
public void assignRandomClass(Player p)
|
||||||
{
|
{
|
||||||
Random r = new Random();
|
List<ArenaClass> classes = this.classes.values().stream()
|
||||||
List<String> classes = new LinkedList<>(this.classes.keySet());
|
.filter(c -> c.hasPermission(p))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
String className = classes.remove(r.nextInt(classes.size()));
|
if (classes.isEmpty()) {
|
||||||
while (!plugin.has(p, "mobarena.classes." + className))
|
plugin.getLogger().info("Player '" + p.getName() + "' has no class permissions!");
|
||||||
{
|
playerLeave(p);
|
||||||
if (classes.isEmpty())
|
return;
|
||||||
{
|
|
||||||
plugin.getLogger().info("Player '" + p.getName() + "' has no class permissions!");
|
|
||||||
playerLeave(p);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
className = classes.remove(r.nextInt(classes.size()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int index = MobArena.random.nextInt(classes.size());
|
||||||
|
String className = classes.get(index).getConfigName();
|
||||||
|
|
||||||
assignClass(p, className);
|
assignClass(p, className);
|
||||||
messenger.tell(p, Msg.LOBBY_CLASS_PICKED, this.classes.get(className).getConfigName());
|
messenger.tell(p, Msg.LOBBY_CLASS_PICKED, this.classes.get(className).getConfigName());
|
||||||
}
|
}
|
||||||
@ -1621,7 +1625,7 @@ public class ArenaImpl implements Arena
|
|||||||
messenger.tell(p, Msg.JOIN_ALREADY_PLAYING);
|
messenger.tell(p, Msg.JOIN_ALREADY_PLAYING);
|
||||||
else if (running)
|
else if (running)
|
||||||
messenger.tell(p, Msg.JOIN_ARENA_IS_RUNNING);
|
messenger.tell(p, Msg.JOIN_ARENA_IS_RUNNING);
|
||||||
else if (!plugin.has(p, "mobarena.arenas." + configName()))
|
else if (!hasPermission(p))
|
||||||
messenger.tell(p, Msg.JOIN_ARENA_PERMISSION);
|
messenger.tell(p, Msg.JOIN_ARENA_PERMISSION);
|
||||||
else if (getMaxPlayers() > 0 && lobbyPlayers.size() >= getMaxPlayers())
|
else if (getMaxPlayers() > 0 && lobbyPlayers.size() >= getMaxPlayers())
|
||||||
messenger.tell(p, Msg.JOIN_PLAYER_LIMIT_REACHED);
|
messenger.tell(p, Msg.JOIN_PLAYER_LIMIT_REACHED);
|
||||||
|
@ -1061,14 +1061,15 @@ public class ArenaListener
|
|||||||
if (!arena.getClasses().containsKey(className) && !className.equals("random"))
|
if (!arena.getClasses().containsKey(className) && !className.equals("random"))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
ArenaClass newAC = arena.getClasses().get(className);
|
||||||
|
|
||||||
// Check for permission.
|
// Check for permission.
|
||||||
if (!plugin.has(p, "mobarena.classes." + className) && !className.equals("random")) {
|
if (!newAC.hasPermission(p) && !className.equals("random")) {
|
||||||
arena.getMessenger().tell(p, Msg.LOBBY_CLASS_PERMISSION);
|
arena.getMessenger().tell(p, Msg.LOBBY_CLASS_PERMISSION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ArenaClass oldAC = arena.getArenaPlayer(p).getArenaClass();
|
ArenaClass oldAC = arena.getArenaPlayer(p).getArenaClass();
|
||||||
ArenaClass newAC = arena.getClasses().get(className);
|
|
||||||
|
|
||||||
// Same class, do nothing.
|
// Same class, do nothing.
|
||||||
if (newAC.equals(oldAC)) {
|
if (newAC.equals(oldAC)) {
|
||||||
|
@ -19,9 +19,6 @@ import org.bukkit.entity.Entity;
|
|||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.PlayerInventory;
|
import org.bukkit.inventory.PlayerInventory;
|
||||||
import org.bukkit.permissions.Permission;
|
|
||||||
import org.bukkit.permissions.PermissionDefault;
|
|
||||||
import org.bukkit.plugin.PluginManager;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
@ -140,7 +137,7 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
public List<Arena> getPermittedArenas(Player p) {
|
public List<Arena> getPermittedArenas(Player p) {
|
||||||
List<Arena> result = new ArrayList<>(arenas.size());
|
List<Arena> result = new ArrayList<>(arenas.size());
|
||||||
for (Arena arena : arenas)
|
for (Arena arena : arenas)
|
||||||
if (plugin.has(p, "mobarena.arenas." + arena.configName()))
|
if (arena.hasPermission(p))
|
||||||
result.add(arena);
|
result.add(arena);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -148,7 +145,7 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
public List<Arena> getEnabledAndPermittedArenas(Player p) {
|
public List<Arena> getEnabledAndPermittedArenas(Player p) {
|
||||||
List<Arena> result = new ArrayList<>(arenas.size());
|
List<Arena> result = new ArrayList<>(arenas.size());
|
||||||
for (Arena arena : arenas)
|
for (Arena arena : arenas)
|
||||||
if (arena.isEnabled() && plugin.has(p, "mobarena.arenas." + arena.configName()))
|
if (arena.isEnabled() && arena.hasPermission(p))
|
||||||
result.add(arena);
|
result.add(arena);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -338,9 +335,6 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
loadClassPermissions(arenaClass, section);
|
loadClassPermissions(arenaClass, section);
|
||||||
loadClassLobbyPermissions(arenaClass, section);
|
loadClassLobbyPermissions(arenaClass, section);
|
||||||
|
|
||||||
// Register the permission.
|
|
||||||
registerPermission("mobarena.classes." + lowercase, PermissionDefault.TRUE).addParent("mobarena.classes", true);
|
|
||||||
|
|
||||||
// Check for class chests
|
// Check for class chests
|
||||||
Location cc = parseLocation(section, "classchest", null);
|
Location cc = parseLocation(section, "classchest", null);
|
||||||
arenaClass.setClassChest(cc);
|
arenaClass.setClassChest(cc);
|
||||||
@ -486,8 +480,6 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
|
|
||||||
// Remove the class from the map.
|
// Remove the class from the map.
|
||||||
classes.remove(lowercase);
|
classes.remove(lowercase);
|
||||||
|
|
||||||
unregisterPermission("mobarena.arenas." + lowercase);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean addClassPermission(String classname, String perm) {
|
public boolean addClassPermission(String classname, String perm) {
|
||||||
@ -621,7 +613,6 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
ConfigUtils.addIfEmpty(plugin, "waves.yml", makeSection(section, "waves"));
|
ConfigUtils.addIfEmpty(plugin, "waves.yml", makeSection(section, "waves"));
|
||||||
|
|
||||||
Arena arena = new ArenaImpl(plugin, section, arenaname, world);
|
Arena arena = new ArenaImpl(plugin, section, arenaname, world);
|
||||||
registerPermission("mobarena.arenas." + arenaname.toLowerCase(), PermissionDefault.TRUE);
|
|
||||||
arenas.add(arena);
|
arenas.add(arena);
|
||||||
plugin.getLogger().info("Loaded arena '" + arenaname + "'");
|
plugin.getLogger().info("Loaded arena '" + arenaname + "'");
|
||||||
return arena;
|
return arena;
|
||||||
@ -669,7 +660,6 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
|
|
||||||
public void removeArenaNode(Arena arena) {
|
public void removeArenaNode(Arena arena) {
|
||||||
arenas.remove(arena);
|
arenas.remove(arena);
|
||||||
unregisterPermission("mobarena.arenas." + arena.configName());
|
|
||||||
|
|
||||||
config.set("arenas." + arena.configName(), null);
|
config.set("arenas." + arena.configName(), null);
|
||||||
plugin.saveConfig();
|
plugin.saveConfig();
|
||||||
@ -690,20 +680,4 @@ public class ArenaMasterImpl implements ArenaMaster
|
|||||||
public void saveConfig() {
|
public void saveConfig() {
|
||||||
plugin.saveConfig();
|
plugin.saveConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
private Permission registerPermission(String permString, PermissionDefault value) {
|
|
||||||
PluginManager pm = plugin.getServer().getPluginManager();
|
|
||||||
|
|
||||||
Permission perm = pm.getPermission(permString);
|
|
||||||
if (perm == null) {
|
|
||||||
perm = new Permission(permString);
|
|
||||||
perm.setDefault(value);
|
|
||||||
pm.addPermission(perm);
|
|
||||||
}
|
|
||||||
return perm;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void unregisterPermission(String s) {
|
|
||||||
plugin.getServer().getPluginManager().removePermission(s);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ public class PickClassCommand implements Command
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Check for permission.
|
// Check for permission.
|
||||||
if (!am.getPlugin().has(p, "mobarena.classes." + lowercase) && !lowercase.equals("random")) {
|
if (!ac.hasPermission(p) && !lowercase.equals("random")) {
|
||||||
arena.getMessenger().tell(p, Msg.LOBBY_CLASS_PERMISSION);
|
arena.getMessenger().tell(p, Msg.LOBBY_CLASS_PERMISSION);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -147,6 +147,8 @@ public interface Arena
|
|||||||
void forceStart();
|
void forceStart();
|
||||||
|
|
||||||
void forceEnd();
|
void forceEnd();
|
||||||
|
|
||||||
|
boolean hasPermission(Player p);
|
||||||
|
|
||||||
boolean playerJoin(Player p, Location loc);
|
boolean playerJoin(Player p, Location loc);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user