mirror of
https://github.com/TotalFreedomMC/TF-EssentialsX.git
synced 2025-08-05 12:02:53 +00:00
179 lines
6.7 KiB
Java
179 lines
6.7 KiB
Java
package com.earth2me.essentials.perm;
|
|
|
|
import com.earth2me.essentials.Essentials;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.plugin.Plugin;
|
|
import org.bukkit.plugin.PluginManager;
|
|
|
|
import java.util.Arrays;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
import java.util.logging.Level;
|
|
|
|
|
|
public class PermissionsHandler implements IPermissionsHandler {
|
|
private transient IPermissionsHandler handler = new NullPermissionsHandler();
|
|
private transient String defaultGroup = "default";
|
|
private final transient Essentials ess;
|
|
private transient boolean useSuperperms = false;
|
|
|
|
public PermissionsHandler(final Essentials plugin) {
|
|
this.ess = plugin;
|
|
}
|
|
|
|
public PermissionsHandler(final Essentials plugin, final boolean useSuperperms) {
|
|
this.ess = plugin;
|
|
this.useSuperperms = useSuperperms;
|
|
}
|
|
|
|
public PermissionsHandler(final Essentials plugin, final String defaultGroup) {
|
|
this.ess = plugin;
|
|
this.defaultGroup = defaultGroup;
|
|
}
|
|
|
|
@Override
|
|
public String getGroup(final Player base) {
|
|
final long start = System.nanoTime();
|
|
String group = handler.getGroup(base);
|
|
if (group == null) {
|
|
group = defaultGroup;
|
|
}
|
|
checkPermLag(start, String.format("Getting group for %s", base.getName()));
|
|
return group;
|
|
}
|
|
|
|
@Override
|
|
public List<String> getGroups(final Player base) {
|
|
final long start = System.nanoTime();
|
|
List<String> groups = handler.getGroups(base);
|
|
if (groups == null || groups.isEmpty()) {
|
|
groups = Collections.singletonList(defaultGroup);
|
|
}
|
|
checkPermLag(start, String.format("Getting groups for %s", base.getName()));
|
|
return Collections.unmodifiableList(groups);
|
|
}
|
|
|
|
@Override
|
|
public boolean canBuild(final Player base, final String group) {
|
|
return handler.canBuild(base, group);
|
|
}
|
|
|
|
@Override
|
|
public boolean inGroup(final Player base, final String group) {
|
|
final long start = System.nanoTime();
|
|
final boolean result = handler.inGroup(base, group);
|
|
checkPermLag(start, String.format("Checking if %s is in group %s", base.getName(), group));
|
|
return result;
|
|
}
|
|
|
|
@Override
|
|
public boolean hasPermission(final Player base, final String node) {
|
|
return handler.hasPermission(base, node);
|
|
}
|
|
|
|
@Override
|
|
public String getPrefix(final Player base) {
|
|
final long start = System.nanoTime();
|
|
String prefix = handler.getPrefix(base);
|
|
if (prefix == null) {
|
|
prefix = "";
|
|
}
|
|
checkPermLag(start, String.format("Getting prefix for %s", base.getName()));
|
|
return prefix;
|
|
}
|
|
|
|
@Override
|
|
public String getSuffix(final Player base) {
|
|
final long start = System.nanoTime();
|
|
String suffix = handler.getSuffix(base);
|
|
if (suffix == null) {
|
|
suffix = "";
|
|
}
|
|
checkPermLag(start, String.format("Getting suffix for %s", base.getName()));
|
|
return suffix;
|
|
}
|
|
|
|
public void checkPermissions() {
|
|
final PluginManager pluginManager = ess.getServer().getPluginManager();
|
|
String enabledPermsPlugin = "";
|
|
List<String> specialCasePlugins = Arrays.asList("PermissionsEx", "GroupManager",
|
|
"SimplyPerms", "Privileges", "bPermissions", "zPermissions", "PermissionsBukkit",
|
|
"DroxPerms", "xPerms");
|
|
for (Plugin plugin : pluginManager.getPlugins()) {
|
|
if (specialCasePlugins.contains(plugin.getName())) {
|
|
enabledPermsPlugin = plugin.getName();
|
|
break;
|
|
}
|
|
}
|
|
final Plugin vaultAPI = pluginManager.getPlugin("Vault");
|
|
if (vaultAPI != null && vaultAPI.isEnabled()) {
|
|
if (!(handler instanceof AbstractVaultHandler)) {
|
|
AbstractVaultHandler vaultHandler;
|
|
switch (enabledPermsPlugin) {
|
|
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("")) {
|
|
enabledPermsPlugin = "generic";
|
|
}
|
|
vaultHandler.setupProviders();
|
|
ess.getLogger().info("Using Vault based permissions (" + enabledPermsPlugin + ")");
|
|
handler = vaultHandler;
|
|
}
|
|
return;
|
|
}
|
|
if (!enabledPermsPlugin.equals("") && !(handler instanceof SuperpermsHandler)) {
|
|
ess.getLogger().warning("Detected supported permissions plugin " + enabledPermsPlugin + " without Vault installed.");
|
|
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 (!(handler instanceof SuperpermsHandler)) {
|
|
ess.getLogger().info("Using superperms based permissions.");
|
|
handler = new SuperpermsHandler();
|
|
}
|
|
} 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.");
|
|
handler = new ConfigPermissionsHandler(ess);
|
|
}
|
|
}
|
|
}
|
|
|
|
public void setUseSuperperms(final boolean useSuperperms) {
|
|
this.useSuperperms = useSuperperms;
|
|
}
|
|
|
|
public String getName() {
|
|
return handler.getClass().getSimpleName().replace("Handler", "");
|
|
}
|
|
|
|
private void checkPermLag(long start, String summary) {
|
|
final long elapsed = System.nanoTime() - start;
|
|
if (elapsed > ess.getSettings().getPermissionsLagWarning()) {
|
|
ess.getLogger().log(Level.WARNING, String.format("Permissions lag notice with (%s). Response took %fms. Summary: %s", getName(), elapsed / 1000000.0, summary));
|
|
}
|
|
}
|
|
|
|
private void checkPermLag(long start) {
|
|
checkPermLag(start, "not defined");
|
|
}
|
|
}
|