Attempt PermissionsHandler cleanup, attempt to support Vault installed but no working perms/chat setup situations

This commit is contained in:
vemacs 2015-06-19 09:14:46 -04:00
parent db6724acdf
commit 6ca3712b79
13 changed files with 123 additions and 130 deletions

View file

@ -1,6 +1,5 @@
package com.earth2me.essentials; package com.earth2me.essentials;
import com.earth2me.essentials.perm.PermissionsHandler;
import com.earth2me.essentials.register.payment.Methods; import com.earth2me.essentials.register.payment.Methods;
import net.ess3.api.IEssentials; import net.ess3.api.IEssentials;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
@ -36,14 +35,10 @@ public class EssentialsPluginListener implements Listener, IConf {
if (event.getPlugin().getName().equals("EssentialsChat")) { if (event.getPlugin().getName().equals("EssentialsChat")) {
ess.getSettings().setEssentialsChatActive(false); ess.getSettings().setEssentialsChatActive(false);
} }
PermissionsHandler permHandler = ess.getPermissionsHandler();
if (permHandler != null) {
permHandler.checkPermissions();
}
ess.getAlternativeCommandsHandler().removePlugin(event.getPlugin()); ess.getAlternativeCommandsHandler().removePlugin(event.getPlugin());
// Check to see if the plugin thats being disabled is the one we are using // Check to see if the plugin thats being disabled is the one we are using
if (ess.getPaymentMethod() != null && Methods.hasMethod() && Methods.checkDisabled(event.getPlugin())) { if (ess.getPaymentMethod() != null && Methods.hasMethod() && Methods.checkDisabled(event.getPlugin())) {
ess.getPaymentMethod().reset(); Methods.reset();
ess.getLogger().log(Level.INFO, "Payment method was disabled. No longer accepting payments."); ess.getLogger().log(Level.INFO, "Payment method was disabled. No longer accepting payments.");
} }
} }

View file

@ -19,4 +19,6 @@ public interface IPermissionsHandler {
String getPrefix(Player base); String getPrefix(Player base);
String getSuffix(Player base); String getSuffix(Player base);
boolean tryProvider();
} }

View file

@ -1,44 +0,0 @@
package com.earth2me.essentials.perm;
import org.bukkit.entity.Player;
import java.util.Collections;
import java.util.List;
public class NullPermissionsHandler implements IPermissionsHandler {
@Override
public String getGroup(final Player base) {
return null;
}
@Override
public List<String> getGroups(final Player base) {
return Collections.emptyList();
}
@Override
public boolean canBuild(final Player base, final String group) {
return false;
}
@Override
public boolean inGroup(final Player base, final String group) {
return false;
}
@Override
public boolean hasPermission(final Player base, final String node) {
return false;
}
@Override
public String getPrefix(final Player base) {
return null;
}
@Override
public String getSuffix(final Player base) {
return null;
}
}

View file

@ -1,36 +1,25 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm;
import com.earth2me.essentials.Essentials; import com.earth2me.essentials.Essentials;
import com.earth2me.essentials.perm.impl.*;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.PluginManager;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.logging.Level; import java.util.logging.Level;
public class PermissionsHandler implements IPermissionsHandler { public class PermissionsHandler implements IPermissionsHandler {
private transient IPermissionsHandler handler = new NullPermissionsHandler(); private transient IPermissionsHandler handler = null;
private transient String defaultGroup = "default"; private transient String defaultGroup = "default";
private final transient Essentials ess; private final transient Essentials ess;
private transient boolean useSuperperms = false; private transient boolean useSuperperms = false;
public PermissionsHandler(final Essentials plugin) {
this.ess = plugin;
}
public PermissionsHandler(final Essentials plugin, final boolean useSuperperms) { public PermissionsHandler(final Essentials plugin, final boolean useSuperperms) {
this.ess = plugin; this.ess = plugin;
this.useSuperperms = useSuperperms; this.useSuperperms = useSuperperms;
} }
public PermissionsHandler(final Essentials plugin, final String defaultGroup) {
this.ess = plugin;
this.defaultGroup = defaultGroup;
}
@Override @Override
public String getGroup(final Player base) { public String getGroup(final Player base) {
final long start = System.nanoTime(); final long start = System.nanoTime();
@ -93,68 +82,55 @@ public class PermissionsHandler implements IPermissionsHandler {
return suffix; return suffix;
} }
@Override
public boolean tryProvider() {
return true;
}
public void checkPermissions() { public void checkPermissions() {
final PluginManager pluginManager = ess.getServer().getPluginManager(); // load and assign a handler
String enabledPermsPlugin = ""; List<Class<? extends SuperpermsHandler>> providerClazz = Arrays.asList(
List<String> specialCasePlugins = Arrays.asList("PermissionsEx", "GroupManager", BPermissions2Handler.class,
"SimplyPerms", "Privileges", "bPermissions", "zPermissions", "PermissionsBukkit", GroupManagerHandler.class,
"DroxPerms", "xPerms"); PermissionsExHandler.class,
for (Plugin plugin : pluginManager.getPlugins()) { PrivilegesHandler.class,
if (specialCasePlugins.contains(plugin.getName())) { SimplyPermsHandler.class,
enabledPermsPlugin = plugin.getName(); GenericVaultHandler.class,
break; SuperpermsHandler.class
} );
} for (Class<? extends IPermissionsHandler> providerClass : providerClazz) {
final Plugin vaultAPI = pluginManager.getPlugin("Vault"); try {
if (vaultAPI != null && vaultAPI.isEnabled()) { IPermissionsHandler provider = providerClass.newInstance();
if (!(handler instanceof AbstractVaultHandler)) { this.handler = provider;
AbstractVaultHandler vaultHandler; if (provider.tryProvider()) {
switch (enabledPermsPlugin) { break;
case "PermissionsEx":
vaultHandler = new PermissionsExHandler();
break;
case "GroupManager":
vaultHandler = new GroupManagerHandler();
break;
case "SimplyPerms":
vaultHandler = new SimplyPermsHandler();
break;
case "Privileges":
vaultHandler = new PrivilegesHandler();
break;
case "bPermissions":
vaultHandler = new BPermissions2Handler();
break;
default:
vaultHandler = new GenericVaultHandler();
break;
} }
if (enabledPermsPlugin.equals("")) { } catch (Throwable ignored) {
enabledPermsPlugin = "generic";
}
vaultHandler.setupProviders();
ess.getLogger().info("Using Vault based permissions (" + enabledPermsPlugin + ")");
handler = vaultHandler;
} }
return;
} }
if (!enabledPermsPlugin.equals("") && !(handler instanceof SuperpermsHandler)) { if (handler == null) {
ess.getLogger().warning("Detected supported permissions plugin " + enabledPermsPlugin + " without Vault installed."); handler = new ConfigPermissionsHandler(ess);
ess.getLogger().warning("Features such as chat prefixes/suffixes and group-related functionality will not " +
"work until you install Vault.");
useSuperperms = true;
} }
if (useSuperperms) { if (useSuperperms && handler instanceof ConfigPermissionsHandler) {
if (!(handler instanceof SuperpermsHandler)) { handler = new SuperpermsHandler();
ess.getLogger().info("Using superperms based permissions."); }
handler = new SuperpermsHandler(); // output handler info
} if (handler instanceof GenericVaultHandler) {
} else { String enabledPermsPlugin = ((GenericVaultHandler) handler).getEnabledPermsPlugin();
if (!(handler instanceof ConfigPermissionsHandler)) { if (enabledPermsPlugin == null) enabledPermsPlugin = "generic";
ess.getLogger().info("Using config file enhanced permissions."); ess.getLogger().info("Using Vault based permissions (" + enabledPermsPlugin + ")");
ess.getLogger().info("Permissions listed in as player-commands will be given to all users."); } else if (handler instanceof SuperpermsHandler) {
handler = new ConfigPermissionsHandler(ess); if (handler.tryProvider()) {
ess.getLogger().warning("Detected supported permissions plugin " +
((SuperpermsHandler) handler).getEnabledPermsPlugin() + " without Vault installed.");
ess.getLogger().warning("Features such as chat prefixes/suffixes and group-related functionality will not " +
"work until you install Vault.");
} else {
ess.getLogger().info("Using superperms-based permissions.");
} }
} else if (handler instanceof ConfigPermissionsHandler) {
ess.getLogger().info("Using config file enhanced permissions.");
ess.getLogger().info("Permissions listed in as player-commands will be given to all users.");
} }
} }
@ -163,7 +139,7 @@ public class PermissionsHandler implements IPermissionsHandler {
} }
public String getName() { public String getName() {
return handler.getClass().getSimpleName().replace("Handler", ""); return handler.getClass().getSimpleName().replace("Provider", "");
} }
private void checkPermLag(long start, String summary) { private void checkPermLag(long start, String summary) {

View file

@ -1,4 +1,4 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import net.milkbowl.vault.chat.Chat; import net.milkbowl.vault.chat.Chat;
import net.milkbowl.vault.permission.Permission; import net.milkbowl.vault.permission.Permission;
@ -64,4 +64,12 @@ public abstract class AbstractVaultHandler extends SuperpermsHandler {
return playerSuffix; return playerSuffix;
} }
} }
public boolean canLoad() {
try {
return setupProviders();
} catch (Throwable t) {
return false;
}
}
} }

View file

@ -1,5 +1,6 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -8,4 +9,9 @@ public class BPermissions2Handler extends AbstractVaultHandler {
public boolean canBuild(final Player base, final String group) { public boolean canBuild(final Player base, final String group) {
return hasPermission(base, "bPermissions.build"); return hasPermission(base, "bPermissions.build");
} }
@Override
public boolean tryProvider() {
return super.canLoad() && Bukkit.getPluginManager().getPlugin("bPermissions") != null;
}
} }

View file

@ -1,4 +1,4 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import net.ess3.api.IEssentials; import net.ess3.api.IEssentials;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -23,4 +23,8 @@ public class ConfigPermissionsHandler extends SuperpermsHandler {
return ess.getSettings().isPlayerCommand(cmds[cmds.length - 1]) || super.hasPermission(base, node); return ess.getSettings().isPlayerCommand(cmds[cmds.length - 1]) || super.hasPermission(base, node);
} }
@Override
public boolean tryProvider() {
return true;
}
} }

View file

@ -1,4 +1,4 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
public class GenericVaultHandler extends AbstractVaultHandler { public class GenericVaultHandler extends AbstractVaultHandler {
} }

View file

@ -1,11 +1,10 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import org.anjocaido.groupmanager.GroupManager; import org.anjocaido.groupmanager.GroupManager;
import org.anjocaido.groupmanager.dataholder.worlds.WorldsHolder; import org.anjocaido.groupmanager.dataholder.worlds.WorldsHolder;
import org.anjocaido.groupmanager.permissions.AnjoPermissionsHandler; import org.anjocaido.groupmanager.permissions.AnjoPermissionsHandler;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
public class GroupManagerHandler extends AbstractVaultHandler { public class GroupManagerHandler extends AbstractVaultHandler {
@ -32,4 +31,9 @@ public class GroupManagerHandler extends AbstractVaultHandler {
return null; return null;
} }
} }
@Override
public boolean tryProvider() {
return super.canLoad() && groupManager != null;
}
} }

View file

@ -1,5 +1,6 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import ru.tehkode.permissions.PermissionUser; import ru.tehkode.permissions.PermissionUser;
import ru.tehkode.permissions.bukkit.PermissionsEx; import ru.tehkode.permissions.bukkit.PermissionsEx;
@ -10,4 +11,9 @@ public class PermissionsExHandler extends AbstractVaultHandler {
final PermissionUser user = PermissionsEx.getPermissionManager().getUser(base.getUniqueId()); final PermissionUser user = PermissionsEx.getPermissionManager().getUser(base.getUniqueId());
return user != null && user.getOptionBoolean("build", base.getWorld().getName(), false); return user != null && user.getOptionBoolean("build", base.getWorld().getName(), false);
} }
@Override
public boolean tryProvider() {
return super.canLoad() && Bukkit.getPluginManager().getPlugin("PermissionsEx") != null;
}
} }

View file

@ -1,5 +1,6 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
public class PrivilegesHandler extends AbstractVaultHandler { public class PrivilegesHandler extends AbstractVaultHandler {
@ -7,4 +8,9 @@ public class PrivilegesHandler extends AbstractVaultHandler {
public boolean canBuild(Player base, String group) { public boolean canBuild(Player base, String group) {
return hasPermission(base, "privileges.build"); return hasPermission(base, "privileges.build");
} }
@Override
public boolean tryProvider() {
return super.canLoad() && Bukkit.getPluginManager().getPlugin("Privileges") != null;
}
} }

View file

@ -1,5 +1,6 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
public class SimplyPermsHandler extends AbstractVaultHandler { public class SimplyPermsHandler extends AbstractVaultHandler {
@ -7,4 +8,9 @@ public class SimplyPermsHandler extends AbstractVaultHandler {
public boolean canBuild(Player base, String group) { public boolean canBuild(Player base, String group) {
return hasPermission(base, "permissions.allow.build"); return hasPermission(base, "permissions.allow.build");
} }
@Override
public boolean tryProvider() {
return super.canLoad() && Bukkit.getPluginManager().getPlugin("SimplyPerms") != null;
}
} }

View file

@ -1,7 +1,11 @@
package com.earth2me.essentials.perm; package com.earth2me.essentials.perm.impl;
import com.earth2me.essentials.perm.IPermissionsHandler;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
import java.util.Arrays;
import java.util.List; import java.util.List;
@ -54,4 +58,24 @@ public class SuperpermsHandler implements IPermissionsHandler {
public String getSuffix(final Player base) { public String getSuffix(final Player base) {
return null; return null;
} }
@Override
public boolean tryProvider() {
return getEnabledPermsPlugin() != null;
}
public String getEnabledPermsPlugin() {
String enabledPermsPlugin = null;
List<String> specialCasePlugins = Arrays.asList("PermissionsEx", "GroupManager",
"SimplyPerms", "Privileges", "bPermissions", "zPermissions", "PermissionsBukkit",
"DroxPerms", "xPerms");
for (Plugin plugin : Bukkit.getPluginManager().getPlugins()) {
if (specialCasePlugins.contains(plugin.getName())) {
enabledPermsPlugin = plugin.getName();
break;
}
}
return enabledPermsPlugin;
}
} }