mirror of
https://github.com/TotalFreedomMC/TF-EssentialsX.git
synced 2025-04-25 16:09:44 +00:00
Attempt PermissionsHandler cleanup, attempt to support Vault installed but no working perms/chat setup situations
This commit is contained in:
parent
db6724acdf
commit
6ca3712b79
13 changed files with 123 additions and 130 deletions
|
@ -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.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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 {
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue