Implement more customizable primary groups
This commit is contained in:
parent
46b122a167
commit
d1863fa714
@ -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) {
|
||||||
|
@ -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.
|
||||||
*/
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
public class VaultPermissionHook extends Permission {
|
public class VaultPermissionHook extends Permission {
|
||||||
|
|
||||||
@Getter
|
|
||||||
@Setter
|
|
||||||
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
|
||||||
|
@ -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:
|
||||||
|
@ -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()));
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
Loading…
Reference in New Issue
Block a user