Add some more bulk edit commands

This commit is contained in:
Luck 2016-09-25 21:23:48 +01:00
parent 4c9abba5fa
commit b9ee206908
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B
6 changed files with 361 additions and 4 deletions

View File

@ -39,6 +39,7 @@ import me.lucko.luckperms.commands.track.DeleteTrack;
import me.lucko.luckperms.commands.track.ListTracks; import me.lucko.luckperms.commands.track.ListTracks;
import me.lucko.luckperms.commands.track.TrackMainCommand; import me.lucko.luckperms.commands.track.TrackMainCommand;
import me.lucko.luckperms.commands.user.UserMainCommand; import me.lucko.luckperms.commands.user.UserMainCommand;
import me.lucko.luckperms.commands.usersbulkedit.UsersBulkEditMainCommand;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
@ -64,6 +65,7 @@ public class CommandManager {
.add(new ExportCommand()) .add(new ExportCommand())
.add(new QueueCommand()) .add(new QueueCommand())
.add(new MigrationMainCommand()) .add(new MigrationMainCommand())
.add(new UsersBulkEditMainCommand())
.add(new CreateGroup()) .add(new CreateGroup())
.add(new DeleteGroup()) .add(new DeleteGroup())
.add(new ListGroups()) .add(new ListGroups())

View File

@ -63,6 +63,11 @@ public class UserBulkChange extends SubCommand<User> {
if (type.equals("world")) { if (type.equals("world")) {
while (iterator.hasNext()) { while (iterator.hasNext()) {
Node element = iterator.next(); Node element = iterator.next();
if (element.isGroupNode()) {
continue;
}
String world = element.getWorld().orElse("null"); String world = element.getWorld().orElse("null");
if (!world.equals(from)) { if (!world.equals(from)) {
continue; continue;
@ -74,6 +79,11 @@ public class UserBulkChange extends SubCommand<User> {
} else { } else {
while (iterator.hasNext()) { while (iterator.hasNext()) {
Node element = iterator.next(); Node element = iterator.next();
if (element.isGroupNode()) {
continue;
}
String server = element.getServer().orElse("global"); String server = element.getServer().orElse("global");
if (!server.equals(from)) { if (!server.equals(from)) {
continue; continue;

View File

@ -0,0 +1,94 @@
/*
* Copyright (c) 2016 Lucko (Luck) <luck@lucko.me>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package me.lucko.luckperms.commands.usersbulkedit;
import com.google.common.collect.ImmutableList;
import me.lucko.luckperms.LuckPermsPlugin;
import me.lucko.luckperms.commands.MainCommand;
import me.lucko.luckperms.commands.Sender;
import me.lucko.luckperms.commands.SubCommand;
import me.lucko.luckperms.commands.usersbulkedit.subcommands.BulkEditGroup;
import me.lucko.luckperms.commands.usersbulkedit.subcommands.BulkEditPermission;
import me.lucko.luckperms.storage.Datastore;
import java.util.Collections;
import java.util.List;
import java.util.Optional;
import java.util.stream.Collectors;
public class UsersBulkEditMainCommand extends MainCommand<Datastore> {
public UsersBulkEditMainCommand() {
super("UsersBulkEdit", "/%s usersbulkedit", 1, ImmutableList.<SubCommand<Datastore>>builder()
.add(new BulkEditGroup())
.add(new BulkEditPermission())
.build()
);
}
@Override
protected Datastore getTarget(String target, LuckPermsPlugin plugin, Sender sender) {
return plugin.getDatastore();
}
@Override
protected void cleanup(Datastore datastore, LuckPermsPlugin plugin) {
}
@Override
protected List<String> getObjects(LuckPermsPlugin plugin) {
return null;
}
@Override
protected List<String> onTabComplete(Sender sender, List<String> args, LuckPermsPlugin plugin) {
final List<SubCommand<Datastore>> subs = getSubCommands().stream()
.filter(s -> s.isAuthorized(sender))
.collect(Collectors.toList());
if (args.size() <= 1) {
if (args.isEmpty() || args.get(0).equalsIgnoreCase("")) {
return subs.stream()
.map(m -> m.getName().toLowerCase())
.collect(Collectors.toList());
}
return subs.stream()
.map(m -> m.getName().toLowerCase())
.filter(s -> s.toLowerCase().startsWith(args.get(0).toLowerCase()))
.collect(Collectors.toList());
}
Optional<SubCommand<Datastore>> o = subs.stream()
.filter(s -> s.getName().equalsIgnoreCase(args.get(0)))
.limit(1)
.findAny();
if (!o.isPresent()) {
return Collections.emptyList();
}
return o.get().onTabComplete(plugin, sender, args.subList(1, args.size()));
}
}

View File

@ -0,0 +1,128 @@
/*
* Copyright (c) 2016 Lucko (Luck) <luck@lucko.me>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package me.lucko.luckperms.commands.usersbulkedit.subcommands;
import me.lucko.luckperms.LuckPermsPlugin;
import me.lucko.luckperms.api.Node;
import me.lucko.luckperms.commands.CommandResult;
import me.lucko.luckperms.commands.Predicate;
import me.lucko.luckperms.commands.Sender;
import me.lucko.luckperms.commands.SubCommand;
import me.lucko.luckperms.constants.Message;
import me.lucko.luckperms.constants.Permission;
import me.lucko.luckperms.storage.Datastore;
import me.lucko.luckperms.users.User;
import java.util.*;
public class BulkEditGroup extends SubCommand<Datastore> {
public BulkEditGroup() {
super("group", "Bulk edit group memberships", "<group|null> <server|world> <from> <to>", Permission.USER_BULKCHANGE,
Predicate.not(4));
}
@Override
public CommandResult execute(LuckPermsPlugin plugin, Sender sender, Datastore datastore, List<String> args, String label) {
String group = args.get(0);
String type = args.get(1).toLowerCase();
String from = args.get(2);
String to = args.get(3);
if (to.equals("null")) {
to = null;
}
if (!type.equals("world") && !type.equals("server")) {
Message.BULK_CHANGE_TYPE_ERROR.send(sender);
return CommandResult.FAILURE;
}
Set<UUID> uuids = datastore.getUniqueUsers();
for (UUID u : uuids) {
plugin.getDatastore().loadUser(u, "null");
User user = plugin.getUserManager().get(u);
if (user == null) {
continue;
}
Set<Node> toAdd = new HashSet<>();
Iterator<Node> iterator = user.getNodes().iterator();
if (type.equals("world")) {
while (iterator.hasNext()) {
Node element = iterator.next();
if (!element.isGroupNode()) {
continue;
}
if (element.getGroupName().equals(user.getPrimaryGroup())) {
continue;
}
if (!group.equals("null") && !element.getGroupName().equals(group)) {
continue;
}
String world = element.getWorld().orElse("null");
if (!world.equals(from)) {
continue;
}
iterator.remove();
toAdd.add(me.lucko.luckperms.core.Node.builderFromExisting(element).setWorld(to).build());
}
} else {
while (iterator.hasNext()) {
Node element = iterator.next();
if (!element.isGroupNode()) {
continue;
}
if (element.getGroupName().equals(user.getPrimaryGroup())) {
continue;
}
if (!group.equals("null") && !element.getGroupName().equals(group)) {
continue;
}
String server = element.getServer().orElse("global");
if (!server.equals(from)) {
continue;
}
iterator.remove();
toAdd.add(me.lucko.luckperms.core.Node.builderFromExisting(element).setServer(to).build());
}
}
user.getNodes().addAll(toAdd);
plugin.getUserManager().cleanup(user);
plugin.getDatastore().saveUser(user);
}
Message.BULK_CHANGE_SUCCESS.send(sender, uuids.size());
return CommandResult.SUCCESS;
}
}

View File

@ -0,0 +1,120 @@
/*
* Copyright (c) 2016 Lucko (Luck) <luck@lucko.me>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package me.lucko.luckperms.commands.usersbulkedit.subcommands;
import me.lucko.luckperms.LuckPermsPlugin;
import me.lucko.luckperms.api.Node;
import me.lucko.luckperms.commands.CommandResult;
import me.lucko.luckperms.commands.Predicate;
import me.lucko.luckperms.commands.Sender;
import me.lucko.luckperms.commands.SubCommand;
import me.lucko.luckperms.constants.Message;
import me.lucko.luckperms.constants.Permission;
import me.lucko.luckperms.storage.Datastore;
import me.lucko.luckperms.users.User;
import java.util.*;
public class BulkEditPermission extends SubCommand<Datastore> {
public BulkEditPermission() {
super("permission", "Bulk edit permissions", "<node|null> <server|world> <from> <to>", Permission.USER_BULKCHANGE,
Predicate.not(4));
}
@Override
public CommandResult execute(LuckPermsPlugin plugin, Sender sender, Datastore datastore, List<String> args, String label) {
String node = args.get(0);
String type = args.get(1).toLowerCase();
String from = args.get(2);
String to = args.get(3);
if (to.equals("null")) {
to = null;
}
if (!type.equals("world") && !type.equals("server")) {
Message.BULK_CHANGE_TYPE_ERROR.send(sender);
return CommandResult.FAILURE;
}
Set<UUID> uuids = datastore.getUniqueUsers();
for (UUID u : uuids) {
plugin.getDatastore().loadUser(u, "null");
User user = plugin.getUserManager().get(u);
if (user == null) {
continue;
}
Set<Node> toAdd = new HashSet<>();
Iterator<Node> iterator = user.getNodes().iterator();
if (type.equals("world")) {
while (iterator.hasNext()) {
Node element = iterator.next();
if (element.isGroupNode()) {
continue;
}
if (!node.equals("null") && !element.getPermission().equals(node)) {
continue;
}
String world = element.getWorld().orElse("null");
if (!world.equals(from)) {
continue;
}
iterator.remove();
toAdd.add(me.lucko.luckperms.core.Node.builderFromExisting(element).setWorld(to).build());
}
} else {
while (iterator.hasNext()) {
Node element = iterator.next();
if (element.isGroupNode()) {
continue;
}
if (!node.equals("null") && !element.getPermission().equals(node)) {
continue;
}
String server = element.getServer().orElse("global");
if (!server.equals(from)) {
continue;
}
iterator.remove();
toAdd.add(me.lucko.luckperms.core.Node.builderFromExisting(element).setServer(to).build());
}
}
user.getNodes().addAll(toAdd);
plugin.getUserManager().cleanup(user);
plugin.getDatastore().saveUser(user);
}
Message.BULK_CHANGE_SUCCESS.send(sender, uuids.size());
return CommandResult.SUCCESS;
}
}

View File

@ -74,12 +74,15 @@ public abstract class UserManager extends AbstractManager<UUID, User> {
*/ */
public void giveDefaultIfNeeded(User user, boolean save) { public void giveDefaultIfNeeded(User user, boolean save) {
boolean hasGroup = false; boolean hasGroup = false;
if (user.getPrimaryGroup() != null && !user.getPrimaryGroup().isEmpty()) {
for (Node node : user.getPermissions(false)) { for (Node node : user.getPermissions(false)) {
if (node.isGroupNode()) { if (node.isGroupNode()) {
hasGroup = true; hasGroup = true;
break; break;
} }
} }
}
if (!hasGroup) { if (!hasGroup) {
user.setPrimaryGroup("default"); user.setPrimaryGroup("default");