mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2025-01-23 21:52:31 +01:00
Update Flag command to current API state
This commit is contained in:
parent
aa64d7b135
commit
408e1eb5d6
@ -2,27 +2,22 @@ package com.github.intellectualsites.plotsquared.plot.commands;
|
|||||||
|
|
||||||
import com.github.intellectualsites.plotsquared.commands.CommandDeclaration;
|
import com.github.intellectualsites.plotsquared.commands.CommandDeclaration;
|
||||||
import com.github.intellectualsites.plotsquared.plot.PlotSquared;
|
import com.github.intellectualsites.plotsquared.plot.PlotSquared;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.CaptionUtility;
|
||||||
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
import com.github.intellectualsites.plotsquared.plot.config.Settings;
|
import com.github.intellectualsites.plotsquared.plot.config.Settings;
|
||||||
import com.github.intellectualsites.plotsquared.plot.database.DBFunc;
|
import com.github.intellectualsites.plotsquared.plot.flags.FlagParseException;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.BlockStateListFlag;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.FlagManager;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.Flags;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.GlobalFlagContainer;
|
import com.github.intellectualsites.plotsquared.plot.flags.GlobalFlagContainer;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.implementations.PlotWeatherFlag;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.types.BlockTypeListFlag;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.types.IntegerFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.types.IntegerFlag;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.types.ListFlag;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.Location;
|
import com.github.intellectualsites.plotsquared.plot.object.Location;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.Plot;
|
import com.github.intellectualsites.plotsquared.plot.object.Plot;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.PlotPlayer;
|
import com.github.intellectualsites.plotsquared.plot.object.PlotPlayer;
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.MainUtil;
|
import com.github.intellectualsites.plotsquared.plot.util.MainUtil;
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.MathMan;
|
import com.github.intellectualsites.plotsquared.plot.util.MathMan;
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.Permissions;
|
import com.github.intellectualsites.plotsquared.plot.util.Permissions;
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.PlotWeather;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.StringComparison;
|
import com.github.intellectualsites.plotsquared.plot.util.StringComparison;
|
||||||
import com.github.intellectualsites.plotsquared.plot.util.StringMan;
|
import com.github.intellectualsites.plotsquared.plot.util.StringMan;
|
||||||
import com.sk89q.worldedit.world.block.BlockType;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
@ -32,49 +27,51 @@ import java.util.HashMap;
|
|||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.StringJoiner;
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
@CommandDeclaration(command = "setflag", aliases = {"f", "flag",
|
@CommandDeclaration(command = "flag", aliases = {"f",
|
||||||
"setflag"}, usage = "/plot flag <set|remove|add|list|info> <flag> <value>", description = "Set plot flags", category = CommandCategory.SETTINGS, requiredType = RequiredType.NONE, permission = "plots.flag")
|
"flag"}, usage = "/plot flag <set|remove|add|list|info> <flag> <value>",
|
||||||
|
description = "Set plot flags",
|
||||||
|
category = CommandCategory.SETTINGS,
|
||||||
|
requiredType = RequiredType.NONE,
|
||||||
|
permission = "plots.flag")
|
||||||
public class FlagCmd extends SubCommand {
|
public class FlagCmd extends SubCommand {
|
||||||
|
|
||||||
private boolean checkPermValue(PlotPlayer player, PlotFlag<?> flag, String key, String value) {
|
private boolean checkPermValue(PlotPlayer player, PlotFlag<?, ?> flag, String key, String value) {
|
||||||
key = key.toLowerCase();
|
key = key.toLowerCase();
|
||||||
value = value.toLowerCase();
|
value = value.toLowerCase();
|
||||||
String perm = Captions
|
String perm = CaptionUtility
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(), value.toLowerCase());
|
||||||
value.toLowerCase());
|
|
||||||
if (flag instanceof IntegerFlag && MathMan.isInteger(value)) {
|
if (flag instanceof IntegerFlag && MathMan.isInteger(value)) {
|
||||||
try {
|
try {
|
||||||
int numeric = Integer.parseInt(value);
|
int numeric = Integer.parseInt(value);
|
||||||
perm = perm.substring(0, perm.length() - value.length() - 1);
|
perm = perm.substring(0, perm.length() - value.length() - 1);
|
||||||
if (numeric > 0) {
|
if (numeric > 0) {
|
||||||
int checkRange = PlotSquared.get().getPlatform().equalsIgnoreCase("bukkit") ?
|
int checkRange =
|
||||||
numeric :
|
PlotSquared.get().getPlatform().equalsIgnoreCase("bukkit") ? numeric : Settings.Limit.MAX_PLOTS;
|
||||||
Settings.Limit.MAX_PLOTS;
|
|
||||||
final boolean result = player.hasPermissionRange(perm, checkRange) >= numeric;
|
final boolean result = player.hasPermissionRange(perm, checkRange) >= numeric;
|
||||||
if (!result) {
|
if (!result) {
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, CaptionUtility
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
||||||
key.toLowerCase(), value.toLowerCase()));
|
value.toLowerCase()));
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (NumberFormatException ignore) {
|
} catch (NumberFormatException ignore) {
|
||||||
}
|
}
|
||||||
} else if (flag instanceof BlockTypeListFlag) {
|
// TODO is this required at all?
|
||||||
|
/* } else if (flag instanceof BlockTypeListFlag) {
|
||||||
final BlockTypeListFlag blockListFlag = (BlockTypeListFlag) flag;
|
final BlockTypeListFlag blockListFlag = (BlockTypeListFlag) flag;
|
||||||
try {
|
try {
|
||||||
List<BlockType> parsedBlocks = blockListFlag.parse(value);
|
BlockTypeListFlag parsedFlag = blockListFlag.parse(value);
|
||||||
for (final BlockType block : parsedBlocks) {
|
for (final BlockType block : parsedFlag.getValue()) {
|
||||||
final String permission = Captions
|
final String permission = CaptionUtility
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
||||||
key.toLowerCase(), block.toString().toLowerCase());
|
key.toLowerCase(), block.toString().toLowerCase());
|
||||||
final boolean result = Permissions.hasPermission(player, permission);
|
final boolean result = Permissions.hasPermission(player, permission);
|
||||||
if (!result) {
|
if (!result) {
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, CaptionUtility
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
||||||
key.toLowerCase(), value.toLowerCase()));
|
key.toLowerCase(), value.toLowerCase()));
|
||||||
return false;
|
return false;
|
||||||
@ -83,11 +80,31 @@ public class FlagCmd extends SubCommand {
|
|||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
return true;*/
|
||||||
|
} else if (flag instanceof ListFlag) {
|
||||||
|
final ListFlag<?, ?> listFlag = (ListFlag<?, ?>) flag;
|
||||||
|
try {
|
||||||
|
PlotFlag<? extends List<?>, ?> parsedFlag = listFlag.parse(value);
|
||||||
|
for (final Object entry : parsedFlag.getValue()) {
|
||||||
|
final String permission = CaptionUtility
|
||||||
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
||||||
|
entry.toString().toLowerCase());
|
||||||
|
final boolean result = Permissions.hasPermission(player, permission);
|
||||||
|
if (!result) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, CaptionUtility
|
||||||
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
||||||
|
value.toLowerCase()));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
final boolean result = Permissions.hasPermission(player, perm);
|
final boolean result = Permissions.hasPermission(player, perm);
|
||||||
if (!result) {
|
if (!result) {
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, CaptionUtility
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(), key.toLowerCase(),
|
||||||
value.toLowerCase()));
|
value.toLowerCase()));
|
||||||
}
|
}
|
||||||
@ -117,20 +134,18 @@ public class FlagCmd extends SubCommand {
|
|||||||
sendMessage(player, Captions.PLOT_NOT_CLAIMED);
|
sendMessage(player, Captions.PLOT_NOT_CLAIMED);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!plot.isOwner(player.getUUID()) && !Permissions
|
if (!plot.isOwner(player.getUUID()) && !Permissions.hasPermission(player, Captions.PERMISSION_SET_FLAG_OTHER)) {
|
||||||
.hasPermission(player, Captions.PERMISSION_SET_FLAG_OTHER)) {
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG_OTHER);
|
||||||
MainUtil
|
|
||||||
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG_OTHER);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
PlotFlag<?, ?> flag = null;
|
PlotFlag flag = null;
|
||||||
if (args.length > 1) {
|
if (args.length > 1) {
|
||||||
flag = GlobalFlagContainer.getInstance().getFlagFromString(args[1]);
|
flag = GlobalFlagContainer.getInstance().getFlagFromString(args[1]);
|
||||||
if (flag == null || flag.isReserved()) {
|
if (flag == null) {
|
||||||
boolean suggested = false;
|
boolean suggested = false;
|
||||||
try {
|
try {
|
||||||
StringComparison<PlotFlag<?>> stringComparison =
|
StringComparison<PlotFlag<?, ?>> stringComparison =
|
||||||
new StringComparison<>(args[1], Flags.getFlags());
|
new StringComparison<>(args[1], GlobalFlagContainer.getInstance().getFlagMap().values());
|
||||||
String best = stringComparison.getBestMatch();
|
String best = stringComparison.getBestMatch();
|
||||||
if (best != null) {
|
if (best != null) {
|
||||||
MainUtil.sendMessage(player, Captions.NOT_VALID_FLAG_SUGGESTED, best);
|
MainUtil.sendMessage(player, Captions.NOT_VALID_FLAG_SUGGESTED, best);
|
||||||
@ -145,6 +160,156 @@ public class FlagCmd extends SubCommand {
|
|||||||
}
|
}
|
||||||
switch (args[0].toLowerCase()) {
|
switch (args[0].toLowerCase()) {
|
||||||
case "info": {
|
case "info": {
|
||||||
|
return info(player, args, flag);
|
||||||
|
}
|
||||||
|
case "set": {
|
||||||
|
if (!Permissions.hasPermission(player, Captions.PERMISSION_SET_FLAG)) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (args.length < 3) {
|
||||||
|
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, "/plot flag set <flag> <value>");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
||||||
|
if (!checkPermValue(player, flag, args[1], value)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
PlotFlag<?, ?> parsed;
|
||||||
|
try {
|
||||||
|
parsed = flag.parse(value);
|
||||||
|
} catch (FlagParseException e) {
|
||||||
|
MainUtil.sendMessage(player, "&c" + e.getErrorMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
plot.setFlag(parsed);
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_ADDED);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "remove": {
|
||||||
|
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_REMOVE)) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_FLAG_REMOVE);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (args.length != 2 && args.length != 3) {
|
||||||
|
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, "/plot flag remove <flag> [values]");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!Permissions.hasPermission(player,
|
||||||
|
CaptionUtility.format(Captions.PERMISSION_SET_FLAG_KEY.getTranslated(), args[1].toLowerCase()))) {
|
||||||
|
if (args.length != 3) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, CaptionUtility
|
||||||
|
.format(Captions.PERMISSION_SET_FLAG_KEY.getTranslated(), args[1].toLowerCase()));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (args.length == 3 && flag instanceof ListFlag) {
|
||||||
|
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
||||||
|
final ListFlag<?, ?> listFlag = (ListFlag<?, ?>) flag;
|
||||||
|
final List<?> list = plot.getFlag((Class<? extends ListFlag<?, ?>>) listFlag.getClass());
|
||||||
|
final PlotFlag<? extends List<?>, ?> parsedFlag;
|
||||||
|
try {
|
||||||
|
parsedFlag = listFlag.parse(value);
|
||||||
|
} catch (FlagParseException e) {
|
||||||
|
MainUtil.sendMessage(player, "&c" + e.getErrorMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (parsedFlag.getValue().isEmpty()) {
|
||||||
|
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
||||||
|
}
|
||||||
|
if (list.removeAll(parsedFlag.getValue())) {
|
||||||
|
if (list.isEmpty()) {
|
||||||
|
if (plot.removeFlag(flag)) {
|
||||||
|
return MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
||||||
|
} else {
|
||||||
|
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
||||||
|
}
|
||||||
|
// TODO reimplement somewhere else: DBFunc.setFlags(plot, plot.getFlags());
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
boolean result = plot.removeFlag(flag);
|
||||||
|
if (!result) {
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* TODO reimplement, maybe handle it with events?
|
||||||
|
if (flag == Flags.TIME) {
|
||||||
|
player.setTime(Long.MAX_VALUE);
|
||||||
|
} else if (flag == Flags.WEATHER) {
|
||||||
|
player.setWeather(PlotWeather.RESET);
|
||||||
|
}*/
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "add":
|
||||||
|
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_ADD)) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_FLAG_ADD);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (args.length < 3) {
|
||||||
|
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, "/plot flag add <flag> <values>");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
for (String entry : args[2].split(",")) {
|
||||||
|
if (!checkPermValue(player, flag, args[1], entry)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
||||||
|
PlotFlag<?, ?> parsed;
|
||||||
|
try {
|
||||||
|
parsed = flag.parse(value);
|
||||||
|
} catch (FlagParseException e) {
|
||||||
|
MainUtil.sendMessage(player, "&c" + flag.getFlagDescription().getTranslated());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
boolean result = plot.setFlag(flag.merge(parsed.getValue()));
|
||||||
|
if (!result) {
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
MainUtil.sendMessage(player, Captions.FLAG_ADDED);
|
||||||
|
return true;
|
||||||
|
case "list":
|
||||||
|
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_LIST)) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_FLAG_LIST);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (args.length > 1) {
|
||||||
|
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, "/plot flag list");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final Map<String, ArrayList<String>> flags = new HashMap<>();
|
||||||
|
for (PlotFlag<?, ?> plotFlag : GlobalFlagContainer.getInstance().getRecognizedPlotFlags()) {
|
||||||
|
final String category = plotFlag.getFlagCategory().getTranslated();
|
||||||
|
final Collection<String> flagList = flags.computeIfAbsent(category, k -> new ArrayList<>());
|
||||||
|
flagList.add(plotFlag.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
final Iterator<Map.Entry<String, ArrayList<String>>> iterator = flags.entrySet().iterator();
|
||||||
|
final StringJoiner message = new StringJoiner("\n");
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
final Map.Entry<String, ArrayList<String>> flagsEntry = iterator.next();
|
||||||
|
final List<String> flagNames = flagsEntry.getValue();
|
||||||
|
Collections.sort(flagNames);
|
||||||
|
message.add(String.format(Captions.FLAG_LIST_ENTRY.formatted(), flagsEntry.getKey(),
|
||||||
|
StringMan.join(flagNames, ", ")));
|
||||||
|
}
|
||||||
|
MainUtil.sendMessage(player, message.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, getUsage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean info(PlotPlayer player, String[] args, PlotFlag<?, ?> flag) {
|
||||||
if (!Permissions.hasPermission(player, Captions.PERMISSION_SET_FLAG)) {
|
if (!Permissions.hasPermission(player, Captions.PERMISSION_SET_FLAG)) {
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, "plots.flag.info");
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, "plots.flag.info");
|
||||||
return false;
|
return false;
|
||||||
@ -158,192 +323,7 @@ public class FlagCmd extends SubCommand {
|
|||||||
// flag type
|
// flag type
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_TYPE, flag.getClass().getSimpleName());
|
MainUtil.sendMessage(player, Captions.FLAG_TYPE, flag.getClass().getSimpleName());
|
||||||
// Flag type description
|
// Flag type description
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_DESC, flag.getValueDescription());
|
MainUtil.sendMessage(player, Captions.FLAG_DESC, flag.getFlagDescription().getTranslated());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
case "set": {
|
|
||||||
if (!Permissions.hasPermission(player, Captions.PERMISSION_SET_FLAG)) {
|
|
||||||
MainUtil
|
|
||||||
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (args.length < 3) {
|
|
||||||
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX,
|
|
||||||
"/plot flag set <flag> <value>");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
|
||||||
if (!checkPermValue(player, flag, args[1], value)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
Object parsed = flag.parseValue(value);
|
|
||||||
if (parsed == null) {
|
|
||||||
MainUtil.sendMessage(player, "&c" + flag.getValueDescription());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (flag instanceof ListFlag) {
|
|
||||||
if (!(parsed instanceof Collection) || ((Collection) parsed).isEmpty()) {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
boolean result = plot.setFlag(flag, parsed);
|
|
||||||
if (!result) {
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_ADDED);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
case "remove": {
|
|
||||||
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_REMOVE)) {
|
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION,
|
|
||||||
Captions.PERMISSION_FLAG_REMOVE);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (args.length != 2 && args.length != 3) {
|
|
||||||
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX,
|
|
||||||
"/plot flag remove <flag> [values]");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!Permissions.hasPermission(player, Captions
|
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY.getTranslated(),
|
|
||||||
args[1].toLowerCase()))) {
|
|
||||||
if (args.length != 3) {
|
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY.getTranslated(),
|
|
||||||
args[1].toLowerCase()));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
for (String entry : args[2].split(",")) {
|
|
||||||
if (!checkPermValue(player, flag, args[1], entry)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (args.length == 3 && flag instanceof ListFlag) {
|
|
||||||
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
|
||||||
final ListFlag<? extends Collection> listFlag = (ListFlag<? extends Collection>) flag;
|
|
||||||
final Optional<? extends Collection> collectionOptional = plot.getFlag(listFlag);
|
|
||||||
if (collectionOptional.isPresent()) {
|
|
||||||
final Collection parsedCollection = (Collection) flag.parseValue(value);
|
|
||||||
if (parsedCollection.isEmpty()) {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
|
||||||
}
|
|
||||||
final Collection flagCollection = collectionOptional.get();
|
|
||||||
if (flagCollection.removeAll(parsedCollection)) {
|
|
||||||
if (flagCollection.isEmpty()) {
|
|
||||||
if (plot.removeFlag(flag)) {
|
|
||||||
return MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
|
||||||
} else {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
DBFunc.setFlags(plot, plot.getFlags());
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
boolean result = plot.removeFlag(flag);
|
|
||||||
if (!result) {
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_NOT_REMOVED);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (flag.) {
|
|
||||||
player.setTime(Long.MAX_VALUE);
|
|
||||||
} else if (flag instanceof PlotWeatherFlag) {
|
|
||||||
player.setWeather(PlotWeather.RESET);
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_REMOVED);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
case "add":
|
|
||||||
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_ADD)) {
|
|
||||||
MainUtil
|
|
||||||
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_FLAG_ADD);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (args.length < 3) {
|
|
||||||
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX,
|
|
||||||
"/plot flag add <flag> <values>");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
for (String entry : args[2].split(",")) {
|
|
||||||
if (!checkPermValue(player, flag, args[1], entry)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String value = StringMan.join(Arrays.copyOfRange(args, 2, args.length), " ");
|
|
||||||
Object parsed = flag.parseValue(value);
|
|
||||||
if (parsed == null) {
|
|
||||||
MainUtil.sendMessage(player, "&c" + flag.getValueDescription());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
Object val = parsed;
|
|
||||||
if (flag instanceof ListFlag) {
|
|
||||||
final Collection parsedCollection = (Collection<?>) parsed;
|
|
||||||
if (parsedCollection.isEmpty()) {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
|
||||||
}
|
|
||||||
final ListFlag<? extends Collection> listFlag = (ListFlag<? extends Collection>) flag;
|
|
||||||
final Optional<? extends Collection> collectionOptional = plot.getFlag(listFlag);
|
|
||||||
if (collectionOptional.isPresent()) {
|
|
||||||
final Collection flagCollection = collectionOptional.get();
|
|
||||||
if (flagCollection.addAll(parsedCollection)) {
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_ADDED);
|
|
||||||
val = flagCollection;
|
|
||||||
} else {
|
|
||||||
return !MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
boolean result = plot.setFlag(flag, val);
|
|
||||||
if (!result) {
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_NOT_ADDED);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(player, Captions.FLAG_ADDED);
|
|
||||||
return true;
|
|
||||||
case "list":
|
|
||||||
if (!Permissions.hasPermission(player, Captions.PERMISSION_FLAG_LIST)) {
|
|
||||||
MainUtil
|
|
||||||
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_FLAG_LIST);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (args.length > 1) {
|
|
||||||
MainUtil.sendMessage(player, Captions.COMMAND_SYNTAX, "/plot flag list");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
final Map<String, ArrayList<String>> flags = new HashMap<>();
|
|
||||||
for (Flag<?> flag1 : Flags.getFlags()) {
|
|
||||||
final String category = flag1.getCategoryCaption();
|
|
||||||
final Collection<String> flagList =
|
|
||||||
flags.computeIfAbsent(category, k -> new ArrayList<>());
|
|
||||||
flagList.add(flag1.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
final StringBuilder message = new StringBuilder();
|
|
||||||
final Iterator<Map.Entry<String, ArrayList<String>>> iterator =
|
|
||||||
flags.entrySet().iterator();
|
|
||||||
while (iterator.hasNext()) {
|
|
||||||
final Map.Entry<String, ArrayList<String>> flagsEntry = iterator.next();
|
|
||||||
final List<String> flagNames = flagsEntry.getValue();
|
|
||||||
Collections.sort(flagNames);
|
|
||||||
message.append(String.format(Captions.FLAG_LIST_ENTRY.formatted(),
|
|
||||||
flagsEntry.getKey(), StringMan.join(flagNames, ", ")));
|
|
||||||
if (iterator.hasNext()) {
|
|
||||||
message.append("\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(player, message.toString());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
MainUtil
|
|
||||||
.sendMessage(player, Captions.COMMAND_SYNTAX, getUsage());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -3157,4 +3157,8 @@ public class Plot {
|
|||||||
return this.flagContainer.getFlag(flagClass).getValue();
|
return this.flagContainer.getFlag(flagClass).getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean setFlag(PlotFlag<?, ?> plotFlag) {
|
||||||
|
flagContainer.addFlag(plotFlag);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user