From 61fd14c816ea23a79149aaacbe47bbb96023e51e Mon Sep 17 00:00:00 2001 From: Luck Date: Wed, 21 Dec 2016 21:22:48 +0000 Subject: [PATCH] Add group setweight command - closes #94 --- .../commands/group/GroupMainCommand.java | 1 + .../common/commands/group/GroupSetWeight.java | 74 +++++++++++++++++++ .../luckperms/common/constants/Message.java | 1 + .../common/constants/Permission.java | 1 + default-lang.yml | 3 +- 5 files changed, 79 insertions(+), 1 deletion(-) create mode 100644 common/src/main/java/me/lucko/luckperms/common/commands/group/GroupSetWeight.java diff --git a/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupMainCommand.java b/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupMainCommand.java index fe56abef..f505ec47 100644 --- a/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupMainCommand.java +++ b/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupMainCommand.java @@ -45,6 +45,7 @@ public class GroupMainCommand extends MainCommand { .add(new CommandPermission<>(false)) .add(new CommandParent<>(false)) .add(new CommandMeta<>(false)) + .add(new GroupSetWeight()) .add(new HolderShowTracks<>(false)) .add(new GroupBulkChange()) .add(new GroupClear()) diff --git a/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupSetWeight.java b/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupSetWeight.java new file mode 100644 index 00000000..8091be41 --- /dev/null +++ b/common/src/main/java/me/lucko/luckperms/common/commands/group/GroupSetWeight.java @@ -0,0 +1,74 @@ +/* + * Copyright (c) 2016 Lucko (Luck) + * + * 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.common.commands.group; + +import me.lucko.luckperms.api.Node; +import me.lucko.luckperms.common.LuckPermsPlugin; +import me.lucko.luckperms.common.commands.Arg; +import me.lucko.luckperms.common.commands.CommandException; +import me.lucko.luckperms.common.commands.CommandResult; +import me.lucko.luckperms.common.commands.SubCommand; +import me.lucko.luckperms.common.commands.sender.Sender; +import me.lucko.luckperms.common.commands.utils.ArgumentUtils; +import me.lucko.luckperms.common.constants.Message; +import me.lucko.luckperms.common.constants.Permission; +import me.lucko.luckperms.common.core.NodeFactory; +import me.lucko.luckperms.common.core.model.Group; +import me.lucko.luckperms.common.utils.Predicates; +import me.lucko.luckperms.exceptions.ObjectAlreadyHasException; +import me.lucko.luckperms.exceptions.ObjectLacksException; + +import java.util.List; +import java.util.Set; +import java.util.stream.Collectors; + +public class GroupSetWeight extends SubCommand { + public GroupSetWeight() { + super("setweight", "Set the groups weight", Permission.GROUP_SETWEIGHT, Predicates.not(1), + Arg.list(Arg.create("weight", true, "the weight to set")) + ); + } + + @Override + public CommandResult execute(LuckPermsPlugin plugin, Sender sender, Group group, List args, String label) throws CommandException { + int weight = ArgumentUtils.handlePriority(0, args); + + Set existingWeightNodes = group.getNodes().stream() + .filter(n -> n.getPermission().startsWith("weight.")) + .collect(Collectors.toSet()); + + existingWeightNodes.forEach(n -> { + try { + group.unsetPermission(n); + } catch (ObjectLacksException ignored) {} + }); + + try { + group.setPermission(NodeFactory.newBuilder("weight." + weight).build()); + } catch (ObjectAlreadyHasException ignored) {} + + save(group, sender, plugin); + Message.GROUP_SET_WEIGHT.send(sender, weight, group.getDisplayName()); + return CommandResult.SUCCESS; + } +} diff --git a/common/src/main/java/me/lucko/luckperms/common/constants/Message.java b/common/src/main/java/me/lucko/luckperms/common/constants/Message.java index 05b7f073..a9106245 100644 --- a/common/src/main/java/me/lucko/luckperms/common/constants/Message.java +++ b/common/src/main/java/me/lucko/luckperms/common/constants/Message.java @@ -334,6 +334,7 @@ public enum Message { "{PREFIX}&f- &3Meta: &a{6}", false ), + GROUP_SET_WEIGHT("&aSet weight to &b{0}&a for group &b{1}&a.", true), TRACK_INFO( "{PREFIX}&b&l> &bShowing Track: &f{0}" + "\n" + diff --git a/common/src/main/java/me/lucko/luckperms/common/constants/Permission.java b/common/src/main/java/me/lucko/luckperms/common/constants/Permission.java index 1e933e67..2a78b8a3 100644 --- a/common/src/main/java/me/lucko/luckperms/common/constants/Permission.java +++ b/common/src/main/java/me/lucko/luckperms/common/constants/Permission.java @@ -115,6 +115,7 @@ public enum Permission { GROUP_META_REMOVETEMP_SUFFIX(l("meta.removetempsuffix", "removetempsuffix"), Type.GROUP), GROUP_META_CLEAR(l("meta.clear", "clearmeta"), Type.GROUP), GROUP_SHOWTRACKS(l("showtracks"), Type.GROUP), + GROUP_SETWEIGHT(l("setweight"), Type.GROUP), GROUP_BULKCHANGE(l("bulkchange"), Type.GROUP), GROUP_CLEAR(l("clear"), Type.GROUP), GROUP_RENAME(l("rename"), Type.GROUP), diff --git a/default-lang.yml b/default-lang.yml index 4a169f81..cb3a8608 100644 --- a/default-lang.yml +++ b/default-lang.yml @@ -271,7 +271,7 @@ user-demote-error-malformed: > user-demote-error-not-contain-group: "Demotions are done based on primary groups. The users primary group is not on the track specified." user-showpos: "&aShowing &b{0}&a's position on track &b{1}&a.{2}" -user-info-general: > +group-info-general: > {PREFIX}&b&l> &bGroup Info: &f{0}\n {PREFIX}&f- &3Diaplay Name: &f{1}\n {PREFIX}&f- &aCounts:\n @@ -280,6 +280,7 @@ user-info-general: > {PREFIX}&f- &3Prefixes: &a{4}\n {PREFIX}&f- &3Suffixes: &a{5}\n {PREFIX}&f- &3Meta: &a{6} +group-set-weight: "&aSet weight to &b{0}&a for group &b{1}&a." track-info: > {PREFIX}&b&l> &bShowing Track: &f{0}\n