Fix BungeePerms migration to account for group weights and negated permissions

This commit is contained in:
Luck 2017-03-12 20:00:02 +00:00
parent f5007f94dc
commit 11465a4ce9
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B

View File

@ -22,13 +22,13 @@
package me.lucko.luckperms.bungee.migration; package me.lucko.luckperms.bungee.migration;
import me.lucko.luckperms.api.MetaUtils;
import me.lucko.luckperms.api.event.cause.CreationCause; import me.lucko.luckperms.api.event.cause.CreationCause;
import me.lucko.luckperms.common.commands.CommandException; import me.lucko.luckperms.common.commands.CommandException;
import me.lucko.luckperms.common.commands.CommandResult; import me.lucko.luckperms.common.commands.CommandResult;
import me.lucko.luckperms.common.commands.SubCommand; import me.lucko.luckperms.common.commands.SubCommand;
import me.lucko.luckperms.common.commands.sender.Sender; import me.lucko.luckperms.common.commands.sender.Sender;
import me.lucko.luckperms.common.constants.Permission; import me.lucko.luckperms.common.constants.Permission;
import me.lucko.luckperms.common.core.NodeFactory;
import me.lucko.luckperms.common.plugin.LuckPermsPlugin; import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
import me.lucko.luckperms.common.utils.Predicates; import me.lucko.luckperms.common.utils.Predicates;
import me.lucko.luckperms.common.utils.ProgressLogger; import me.lucko.luckperms.common.utils.ProgressLogger;
@ -63,53 +63,68 @@ public class MigrationBungeePerms extends SubCommand<Object> {
return CommandResult.STATE_ERROR; return CommandResult.STATE_ERROR;
} }
List<Group> groups = bp.getPermissionsManager().getBackEnd().loadGroups();
log.log("Calculating group weightings.");
int maxWeight = 0;
for (Group group : groups) {
maxWeight = Math.max(maxWeight, group.getRank());
}
maxWeight += 5;
// Migrate all groups. // Migrate all groups.
log.log("Starting group migration."); log.log("Starting group migration.");
AtomicInteger groupCount = new AtomicInteger(0); AtomicInteger groupCount = new AtomicInteger(0);
for (Group g : bp.getPermissionsManager().getBackEnd().loadGroups()) { for (Group g : groups) {
int groupWeight = maxWeight - g.getRank();
// Make a LuckPerms group for the one being migrated // Make a LuckPerms group for the one being migrated
plugin.getStorage().createAndLoadGroup(g.getName().toLowerCase(), CreationCause.INTERNAL).join(); plugin.getStorage().createAndLoadGroup(g.getName().toLowerCase(), CreationCause.INTERNAL).join();
me.lucko.luckperms.common.core.model.Group group = plugin.getGroupManager().getIfLoaded(g.getName().toLowerCase()); me.lucko.luckperms.common.core.model.Group group = plugin.getGroupManager().getIfLoaded(g.getName().toLowerCase());
group.removeIf(n -> n.getPermission().startsWith("weight."));
group.setPermissionUnchecked(NodeFactory.make("weight." + groupWeight, true));
// Migrate global perms // Migrate global perms
for (String perm : g.getPerms()) { for (String perm : g.getPerms()) {
try { boolean value = true;
group.setPermission(perm, true); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
group.setPermissionUnchecked(NodeFactory.make(perm, value));
} }
// Migrate per-server perms // Migrate per-server perms
for (Map.Entry<String, Server> e : g.getServers().entrySet()) { for (Map.Entry<String, Server> e : g.getServers().entrySet()) {
for (String perm : e.getValue().getPerms()) { for (String perm : e.getValue().getPerms()) {
try { boolean value = true;
group.setPermission(perm, true, e.getKey()); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
group.setPermissionUnchecked(NodeFactory.make(perm, value, e.getKey()));
} }
// Migrate per-world perms // Migrate per-world perms
for (Map.Entry<String, World> we : e.getValue().getWorlds().entrySet()) { for (Map.Entry<String, World> we : e.getValue().getWorlds().entrySet()) {
for (String perm : we.getValue().getPerms()) { for (String perm : we.getValue().getPerms()) {
try { boolean value = true;
group.setPermission(perm, true, e.getKey(), we.getKey()); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
group.setPermissionUnchecked(NodeFactory.make(perm, value, e.getKey(), we.getKey()));
} }
} }
} }
// Migrate any parent groups // Migrate any parent groups
for (String inherit : g.getInheritances()) { for (String inherit : g.getInheritances()) {
try { group.setPermissionUnchecked(NodeFactory.make("group." + inherit));
group.setPermission("group." + inherit, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
// Migrate prefix and suffix // Migrate prefix and suffix
@ -117,25 +132,14 @@ public class MigrationBungeePerms extends SubCommand<Object> {
String suffix = g.getSuffix(); String suffix = g.getSuffix();
if (prefix != null && !prefix.equals("")) { if (prefix != null && !prefix.equals("")) {
prefix = MetaUtils.escapeCharacters(prefix); group.setPermissionUnchecked(NodeFactory.makePrefixNode(groupWeight, prefix).build());
try {
group.setPermission("prefix.50." + prefix, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
if (suffix != null && !suffix.equals("")) { if (suffix != null && !suffix.equals("")) {
suffix = MetaUtils.escapeCharacters(suffix); group.setPermissionUnchecked(NodeFactory.makeSuffixNode(groupWeight, suffix).build());
try {
group.setPermission("suffix.50." + suffix, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
plugin.getStorage().saveGroup(group); plugin.getStorage().saveGroup(group);
log.logAllProgress("Migrated {} groups so far.", groupCount.incrementAndGet()); log.logAllProgress("Migrated {} groups so far.", groupCount.incrementAndGet());
} }
log.log("Migrated " + groupCount.get() + " groups"); log.log("Migrated " + groupCount.get() + " groups");
@ -143,6 +147,10 @@ public class MigrationBungeePerms extends SubCommand<Object> {
// Migrate all users. // Migrate all users.
log.log("Starting user migration."); log.log("Starting user migration.");
AtomicInteger userCount = new AtomicInteger(0); AtomicInteger userCount = new AtomicInteger(0);
// Increment the max weight from the group migrations. All user meta should override.
maxWeight += 5;
for (User u : bp.getPermissionsManager().getBackEnd().loadUsers()) { for (User u : bp.getPermissionsManager().getBackEnd().loadUsers()) {
if (u.getUUID() == null) { if (u.getUUID() == null) {
log.logErr("Could not parse UUID for user: " + u.getName()); log.logErr("Could not parse UUID for user: " + u.getName());
@ -155,42 +163,44 @@ public class MigrationBungeePerms extends SubCommand<Object> {
// Migrate global perms // Migrate global perms
for (String perm : u.getPerms()) { for (String perm : u.getPerms()) {
try { boolean value = true;
user.setPermission(perm, true); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
user.setPermissionUnchecked(NodeFactory.make(perm, value));
} }
// Migrate per-server perms // Migrate per-server perms
for (Map.Entry<String, Server> e : u.getServers().entrySet()) { for (Map.Entry<String, Server> e : u.getServers().entrySet()) {
for (String perm : e.getValue().getPerms()) { for (String perm : e.getValue().getPerms()) {
try { boolean value = true;
user.setPermission(perm, true, e.getKey()); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
user.setPermissionUnchecked(NodeFactory.make(perm, value, e.getKey()));
} }
// Migrate per-world perms // Migrate per-world perms
for (Map.Entry<String, World> we : e.getValue().getWorlds().entrySet()) { for (Map.Entry<String, World> we : e.getValue().getWorlds().entrySet()) {
for (String perm : we.getValue().getPerms()) { for (String perm : we.getValue().getPerms()) {
try { boolean value = true;
user.setPermission(perm, true, e.getKey(), we.getKey()); if (perm.startsWith("-") || perm.startsWith("!")) {
} catch (Exception ex) { perm = perm.substring(1);
log.handleException(ex); value = false;
} }
user.setPermissionUnchecked(NodeFactory.make(perm, value, e.getKey(), we.getKey()));
} }
} }
} }
// Migrate groups // Migrate groups
for (String group : u.getGroupsString()) { for (String group : u.getGroupsString()) {
try { user.setPermissionUnchecked(NodeFactory.make("group." + group));
user.setPermission("group." + group, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
// Migrate prefix & suffix // Migrate prefix & suffix
@ -198,21 +208,11 @@ public class MigrationBungeePerms extends SubCommand<Object> {
String suffix = u.getSuffix(); String suffix = u.getSuffix();
if (prefix != null && !prefix.equals("")) { if (prefix != null && !prefix.equals("")) {
prefix = MetaUtils.escapeCharacters(prefix); user.setPermissionUnchecked(NodeFactory.makePrefixNode(maxWeight, prefix).build());
try {
user.setPermission("prefix.100." + prefix, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
if (suffix != null && !suffix.equals("")) { if (suffix != null && !suffix.equals("")) {
suffix = MetaUtils.escapeCharacters(suffix); user.setPermissionUnchecked(NodeFactory.makeSuffixNode(maxWeight, suffix).build());
try {
user.setPermission("suffix.100." + suffix, true);
} catch (Exception ex) {
log.handleException(ex);
}
} }
plugin.getStorage().saveUser(user); plugin.getStorage().saveUser(user);