Implement more customizable primary groups

This commit is contained in:
Luck 2016-10-26 17:19:33 +01:00
parent 46b122a167
commit d1863fa714
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B
5 changed files with 111 additions and 13 deletions

View File

@ -43,6 +43,10 @@ public class VaultHook {
permissionHook.setServer(plugin.getConfiguration().getVaultServer()); permissionHook.setServer(plugin.getConfiguration().getVaultServer());
permissionHook.setIncludeGlobal(plugin.getConfiguration().isVaultIncludingGlobal()); permissionHook.setIncludeGlobal(plugin.getConfiguration().isVaultIncludingGlobal());
permissionHook.setIgnoreWorld(plugin.getConfiguration().isVaultIgnoreWorld()); permissionHook.setIgnoreWorld(plugin.getConfiguration().isVaultIgnoreWorld());
permissionHook.setPgo(plugin.getConfiguration().isVaultPrimaryGroupOverrides());
permissionHook.setPgoCheckInherited(plugin.getConfiguration().isVaultPrimaryGroupOverridesCheckInherited());
permissionHook.setPgoCheckExists(plugin.getConfiguration().isVaultPrimaryGroupOverridesCheckExists());
permissionHook.setPgoCheckMemberOf(plugin.getConfiguration().isVaultPrimaryGroupOverridesCheckMemberOf());
permissionHook.setup(); permissionHook.setup();
if (chatHook == null) { if (chatHook == null) {

View File

@ -22,11 +22,15 @@
package me.lucko.luckperms.bukkit.vault; package me.lucko.luckperms.bukkit.vault;
import lombok.AccessLevel;
import lombok.Getter; import lombok.Getter;
import lombok.NonNull; import lombok.NonNull;
import lombok.Setter; import lombok.Setter;
import me.lucko.luckperms.api.Contexts; import me.lucko.luckperms.api.Contexts;
import me.lucko.luckperms.api.LocalizedNode;
import me.lucko.luckperms.api.Node; import me.lucko.luckperms.api.Node;
import me.lucko.luckperms.api.Tristate;
import me.lucko.luckperms.api.caching.PermissionData;
import me.lucko.luckperms.api.context.ContextSet; import me.lucko.luckperms.api.context.ContextSet;
import me.lucko.luckperms.bukkit.LPBukkitPlugin; import me.lucko.luckperms.bukkit.LPBukkitPlugin;
import me.lucko.luckperms.common.core.PermissionHolder; import me.lucko.luckperms.common.core.PermissionHolder;
@ -43,27 +47,24 @@ import java.util.Map;
* The LuckPerms Vault Permission implementation * The LuckPerms Vault Permission implementation
* Most lookups are cached. * Most lookups are cached.
*/ */
public class VaultPermissionHook extends Permission {
@Getter @Getter
@Setter @Setter
public class VaultPermissionHook extends Permission {
private LPBukkitPlugin plugin; private LPBukkitPlugin plugin;
@Getter @Setter(value = AccessLevel.NONE)
private VaultScheduler scheduler; private VaultScheduler scheduler;
@Getter
@Setter
private String server = "global"; private String server = "global";
@Getter
@Setter
private boolean includeGlobal = true; private boolean includeGlobal = true;
@Getter
@Setter
private boolean ignoreWorld = false; private boolean ignoreWorld = false;
// Primary Group override settings
private boolean pgo = false;
private boolean pgoCheckInherited = false;
private boolean pgoCheckExists = true;
private boolean pgoCheckMemberOf = true;
public void setup() { public void setup() {
scheduler = new VaultScheduler(plugin); scheduler = new VaultScheduler(plugin);
} }
@ -311,9 +312,73 @@ public class VaultPermissionHook extends Permission {
@Override @Override
public String getPrimaryGroup(String world, @NonNull String player) { public String getPrimaryGroup(String world, @NonNull String player) {
world = ignoreWorld ? null : world; // Correct world value
log("Getting primary group of player: " + player); log("Getting primary group of player: " + player);
final User user = plugin.getUserManager().get(player); final User user = plugin.getUserManager().get(player);
return (user == null) ? null : user.getPrimaryGroup();
if (user == null) {
return null;
}
if (!pgo) {
return user.getPrimaryGroup();
}
if (pgoCheckInherited) {
PermissionData data = user.getUserData().getPermissionData(createContext(server, world));
for (Map.Entry<String, Boolean> e : data.getImmutableBacking().entrySet()) {
if (!e.getKey().toLowerCase().startsWith("vault.primarygroup.")) {
continue;
}
String group = e.getKey().substring("vault.primarygroup.".length());
if (pgoCheckExists) {
if (!plugin.getGroupManager().isLoaded(group)) {
continue;
}
}
if (pgoCheckMemberOf) {
if (data.getPermissionValue("group." + group) != Tristate.TRUE) {
continue;
}
}
return group;
}
} else {
for (LocalizedNode node : user.getPermissions(true)) {
if (!node.getPermission().toLowerCase().startsWith("vault.primarygroup.")) {
continue;
}
if (!node.shouldApplyOnServer(server, isIncludeGlobal(), false)) {
continue;
}
if (!node.shouldApplyOnWorld(world, true, false)) {
continue;
}
String group = node.getPermission().substring("vault.primarygroup.".length());
if (pgoCheckExists) {
if (!plugin.getGroupManager().isLoaded(group)) {
continue;
}
}
if (pgoCheckMemberOf) {
if (!user.getLocalGroups(server, world).contains(group.toLowerCase())) {
continue;
}
}
return group;
}
}
// Fallback
return user.getPrimaryGroup();
} }
@Override @Override

View File

@ -112,6 +112,19 @@ vault-include-global: true
# If Vault operations should ignore any world arguments if supplied. # If Vault operations should ignore any world arguments if supplied.
vault-ignore-world: false vault-ignore-world: false
# This block controls the Primary Group override feature
# See the wiki for more information.
vault-primary-groups-overrides:
# If the feature is enabled
enabled: false
# If the check should query the user's inherited permissions.
# (a value of false only checks the permissions they explicitly have)
check-inherited-permissions: false
# If LuckPerms should check if the group exists
check-group-exists: true
# If LuckPerms should check if the user is actually a member of the group
check-user-member-of: true
# Mirrors world names. Whenever LuckPerms checks what world a user is in, if the world name is in this list, the value assigned # Mirrors world names. Whenever LuckPerms checks what world a user is in, if the world name is in this list, the value assigned
# will be sent forward for permission calculation instead. # will be sent forward for permission calculation instead.
world-rewrite: world-rewrite:

View File

@ -67,6 +67,10 @@ public abstract class AbstractConfiguration<T extends LuckPermsPlugin> implement
private String vaultServer; private String vaultServer;
private boolean vaultIncludingGlobal; private boolean vaultIncludingGlobal;
private boolean vaultIgnoreWorld; private boolean vaultIgnoreWorld;
private boolean vaultPrimaryGroupOverrides;
private boolean vaultPrimaryGroupOverridesCheckInherited;
private boolean vaultPrimaryGroupOverridesCheckExists;
private boolean vaultPrimaryGroupOverridesCheckMemberOf;
private Map<String, String> worldRewrites; private Map<String, String> worldRewrites;
private Map<String, String> groupNameRewrites; private Map<String, String> groupNameRewrites;
private List<Rule> defaultAssignments; private List<Rule> defaultAssignments;
@ -113,6 +117,10 @@ public abstract class AbstractConfiguration<T extends LuckPermsPlugin> implement
vaultServer = getString("vault-server", "global"); vaultServer = getString("vault-server", "global");
vaultIncludingGlobal = getBoolean("vault-include-global", true); vaultIncludingGlobal = getBoolean("vault-include-global", true);
vaultIgnoreWorld = getBoolean("vault-ignore-world", false); vaultIgnoreWorld = getBoolean("vault-ignore-world", false);
vaultPrimaryGroupOverrides = getBoolean("vault-primary-groups-overrides.enabled", false);
vaultPrimaryGroupOverridesCheckInherited = getBoolean("vault-primary-groups-overrides.check-inherited-permissions", false);
vaultPrimaryGroupOverridesCheckExists = getBoolean("vault-primary-groups-overrides.check-group-exists", true);
vaultPrimaryGroupOverridesCheckMemberOf = getBoolean("vault-primary-groups-overrides.check-user-member-of", true);
worldRewrites = ImmutableMap.copyOf(getMap("world-rewrite", Collections.emptyMap())); worldRewrites = ImmutableMap.copyOf(getMap("world-rewrite", Collections.emptyMap()));
groupNameRewrites = ImmutableMap.copyOf(getMap("group-name-rewrite", Collections.emptyMap())); groupNameRewrites = ImmutableMap.copyOf(getMap("group-name-rewrite", Collections.emptyMap()));

View File

@ -78,6 +78,14 @@ public interface LPConfiguration {
boolean isVaultIgnoreWorld(); boolean isVaultIgnoreWorld();
boolean isVaultPrimaryGroupOverrides();
boolean isVaultPrimaryGroupOverridesCheckInherited();
boolean isVaultPrimaryGroupOverridesCheckExists();
boolean isVaultPrimaryGroupOverridesCheckMemberOf();
Map<String, String> getWorldRewrites(); Map<String, String> getWorldRewrites();
Map<String, String> getGroupNameRewrites(); Map<String, String> getGroupNameRewrites();