mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2025-04-03 18:16:23 +02:00
use cloud-requirements
This commit is contained in:
parent
3a1b373c8e
commit
92a00ef60a
@ -29,8 +29,9 @@ import com.google.inject.TypeLiteral;
|
|||||||
import com.plotsquared.bukkit.BukkitPlatform;
|
import com.plotsquared.bukkit.BukkitPlatform;
|
||||||
import com.plotsquared.bukkit.commands.BukkitSenderMapper;
|
import com.plotsquared.bukkit.commands.BukkitSenderMapper;
|
||||||
import com.plotsquared.bukkit.util.BukkitUtil;
|
import com.plotsquared.bukkit.util.BukkitUtil;
|
||||||
|
import com.plotsquared.core.commands.CommandRequirement;
|
||||||
import com.plotsquared.core.commands.PlotSquaredCaptionProvider;
|
import com.plotsquared.core.commands.PlotSquaredCaptionProvider;
|
||||||
import com.plotsquared.core.commands.processing.CommandRequirementPostprocessor;
|
import com.plotsquared.core.commands.PlotSquaredRequirementFailureHandler;
|
||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
||||||
import com.plotsquared.core.player.ConsolePlayer;
|
import com.plotsquared.core.player.ConsolePlayer;
|
||||||
import com.plotsquared.core.player.PlotPlayer;
|
import com.plotsquared.core.player.PlotPlayer;
|
||||||
@ -40,6 +41,7 @@ import org.bukkit.Bukkit;
|
|||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
import org.incendo.cloud.requirement.RequirementPostprocessor;
|
||||||
|
|
||||||
public class CloudModule extends AbstractModule {
|
public class CloudModule extends AbstractModule {
|
||||||
|
|
||||||
@ -80,7 +82,8 @@ public class CloudModule extends AbstractModule {
|
|||||||
commandManager.registerAsynchronousCompletions();
|
commandManager.registerAsynchronousCompletions();
|
||||||
}
|
}
|
||||||
|
|
||||||
final CommandRequirementPostprocessor requirementPostprocessor = new CommandRequirementPostprocessor();
|
final RequirementPostprocessor<PlotPlayer<?>, CommandRequirement> requirementPostprocessor =
|
||||||
|
RequirementPostprocessor.of(CommandRequirement.REQUIREMENTS_KEY, new PlotSquaredRequirementFailureHandler());
|
||||||
commandManager.registerCommandPostProcessor(requirementPostprocessor);
|
commandManager.registerCommandPostProcessor(requirementPostprocessor);
|
||||||
|
|
||||||
// TODO(City): Override parsing errors using MM parsing.
|
// TODO(City): Override parsing errors using MM parsing.
|
||||||
|
@ -18,6 +18,7 @@ dependencies {
|
|||||||
// Cloud
|
// Cloud
|
||||||
api(libs.cloud)
|
api(libs.cloud)
|
||||||
api(libs.cloudMinecraftExtras)
|
api(libs.cloudMinecraftExtras)
|
||||||
|
api(libs.cloudRequirements)
|
||||||
|
|
||||||
// Guice
|
// Guice
|
||||||
api(libs.guice) {
|
api(libs.guice) {
|
||||||
|
@ -19,19 +19,32 @@
|
|||||||
package com.plotsquared.core.commands;
|
package com.plotsquared.core.commands;
|
||||||
|
|
||||||
import cloud.commandframework.context.CommandContext;
|
import cloud.commandframework.context.CommandContext;
|
||||||
|
import cloud.commandframework.keys.CloudKey;
|
||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
||||||
import com.plotsquared.core.permissions.Permission;
|
import com.plotsquared.core.permissions.Permission;
|
||||||
import com.plotsquared.core.player.PlotPlayer;
|
import com.plotsquared.core.player.PlotPlayer;
|
||||||
|
import io.leangen.geantyref.TypeToken;
|
||||||
import net.kyori.adventure.text.minimessage.tag.Tag;
|
import net.kyori.adventure.text.minimessage.tag.Tag;
|
||||||
import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver;
|
import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver;
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
import org.incendo.cloud.requirement.Requirement;
|
||||||
|
import org.incendo.cloud.requirement.Requirements;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Something that is required for a command to be executed.
|
* Something that is required for a command to be executed.
|
||||||
*/
|
*/
|
||||||
public interface CommandRequirement {
|
public interface CommandRequirement extends Requirement<PlotPlayer<?>, CommandRequirement> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The key used to store the requirements in the {@link cloud.commandframework.meta.CommandMeta}.
|
||||||
|
*/
|
||||||
|
CloudKey<Requirements<PlotPlayer<?>, CommandRequirement>> REQUIREMENTS_KEY = CloudKey.of(
|
||||||
|
"requirements",
|
||||||
|
new TypeToken<Requirements<PlotPlayer<?>, CommandRequirement>>() {
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the caption sent when the requirement is not met.
|
* Returns the caption sent when the requirement is not met.
|
||||||
@ -40,14 +53,6 @@ public interface CommandRequirement {
|
|||||||
*/
|
*/
|
||||||
@NonNull TranslatableCaption failureCaption();
|
@NonNull TranslatableCaption failureCaption();
|
||||||
|
|
||||||
/**
|
|
||||||
* Evaluates whether the requirement is met.
|
|
||||||
*
|
|
||||||
* @param context command context to evaluate
|
|
||||||
* @return {@code true} if the requirement is met, else {@code false}
|
|
||||||
*/
|
|
||||||
boolean evaluate(final @NonNull CommandContext<PlotPlayer<?>> context);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the placeholder values.
|
* Returns the placeholder values.
|
||||||
*
|
*
|
||||||
@ -57,15 +62,6 @@ public interface CommandRequirement {
|
|||||||
return new TagResolver[0];
|
return new TagResolver[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the list of parent requirements that should be evaluated before this requirement.
|
|
||||||
*
|
|
||||||
* @return the requirements
|
|
||||||
*/
|
|
||||||
default @NonNull List<@NonNull CommandRequirement> parents() {
|
|
||||||
return List.of();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a requirement that evaluates to {@code true} if the sender has the given {@code permission} or if
|
* Returns a requirement that evaluates to {@code true} if the sender has the given {@code permission} or if
|
||||||
* this requirement evaluates to {@code true}.
|
* this requirement evaluates to {@code true}.
|
||||||
@ -94,8 +90,8 @@ public interface CommandRequirement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(final @NonNull CommandContext<PlotPlayer<?>> context) {
|
public boolean evaluateRequirement(final @NonNull CommandContext<PlotPlayer<?>> context) {
|
||||||
return context.sender().hasPermission(permission) || thisRequirement.evaluate(context);
|
return context.sender().hasPermission(permission) || thisRequirement.evaluateRequirement(context);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,72 +0,0 @@
|
|||||||
/*
|
|
||||||
* PlotSquared, a land and world management plugin for Minecraft.
|
|
||||||
* Copyright (C) IntellectualSites <https://intellectualsites.com>
|
|
||||||
* Copyright (C) IntellectualSites team and contributors
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.plotsquared.core.commands;
|
|
||||||
|
|
||||||
import cloud.commandframework.keys.CloudKey;
|
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Holder of {@link CommandRequirement} requirements.
|
|
||||||
*/
|
|
||||||
public final class CommandRequirements implements Iterable<@NonNull CommandRequirement> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The key used to store the requirements in the {@link cloud.commandframework.meta.CommandMeta}.
|
|
||||||
*/
|
|
||||||
public static final CloudKey<CommandRequirements> REQUIREMENTS_KEY = CloudKey.of(
|
|
||||||
"requirements",
|
|
||||||
CommandRequirements.class
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new instance.
|
|
||||||
*
|
|
||||||
* @param requirements the requirements
|
|
||||||
* @return the instance
|
|
||||||
*/
|
|
||||||
public static @NonNull CommandRequirements create(final @NonNull List<@NonNull CommandRequirement> requirements) {
|
|
||||||
return new CommandRequirements(requirements);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static @NonNull List<@NonNull CommandRequirement> extractRequirements(
|
|
||||||
final @NonNull List<@NonNull CommandRequirement> requirements
|
|
||||||
) {
|
|
||||||
final List<CommandRequirement> extractedRequirements = new ArrayList<>();
|
|
||||||
for (final CommandRequirement requirement : requirements) {
|
|
||||||
extractedRequirements.addAll(extractRequirements(requirement.parents()));
|
|
||||||
extractedRequirements.add(requirement);
|
|
||||||
}
|
|
||||||
return extractedRequirements;
|
|
||||||
}
|
|
||||||
|
|
||||||
private final List<CommandRequirement> requirements;
|
|
||||||
|
|
||||||
private CommandRequirements(final @NonNull List<@NonNull CommandRequirement> requirements) {
|
|
||||||
this.requirements = List.copyOf(extractRequirements(requirements));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public @NonNull Iterator<@NonNull CommandRequirement> iterator() {
|
|
||||||
return this.requirements.iterator();
|
|
||||||
}
|
|
||||||
}
|
|
@ -75,7 +75,7 @@ public enum CommonCommandRequirement implements CommandRequirement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean evaluate(final @NonNull CommandContext<PlotPlayer<?>> context) {
|
public boolean evaluateRequirement(final @NonNull CommandContext<PlotPlayer<?>> context) {
|
||||||
return this.predicate.test(context);
|
return this.predicate.test(context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,11 +24,16 @@ import cloud.commandframework.CommandProperties;
|
|||||||
import com.plotsquared.core.command.CommandCategory;
|
import com.plotsquared.core.command.CommandCategory;
|
||||||
import com.plotsquared.core.player.PlotPlayer;
|
import com.plotsquared.core.player.PlotPlayer;
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
import org.incendo.cloud.requirement.RequirementApplicable;
|
||||||
|
import org.incendo.cloud.requirement.Requirements;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public abstract class PlotSquaredCommandBean extends CommandBean<PlotPlayer<?>> {
|
public abstract class PlotSquaredCommandBean extends CommandBean<PlotPlayer<?>> {
|
||||||
|
|
||||||
|
private final RequirementApplicable.RequirementApplicableFactory<PlotPlayer<?>, CommandRequirement>
|
||||||
|
requirementApplicableFactory = RequirementApplicable.factory(CommandRequirement.REQUIREMENTS_KEY);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the category of the command.
|
* Returns the category of the command.
|
||||||
*
|
*
|
||||||
@ -64,7 +69,7 @@ public abstract class PlotSquaredCommandBean extends CommandBean<PlotPlayer<?>>
|
|||||||
@Override
|
@Override
|
||||||
protected final Command.@NonNull Builder<PlotPlayer<?>> configure(final Command.@NonNull Builder<PlotPlayer<?>> builder) {
|
protected final Command.@NonNull Builder<PlotPlayer<?>> configure(final Command.@NonNull Builder<PlotPlayer<?>> builder) {
|
||||||
return this.configurePlotCommand(this.prepare(builder.meta(PlotSquaredCommandMeta.META_CATEGORY, this.category())))
|
return this.configurePlotCommand(this.prepare(builder.meta(PlotSquaredCommandMeta.META_CATEGORY, this.category())))
|
||||||
.meta(CommandRequirements.REQUIREMENTS_KEY, CommandRequirements.create(this.requirements()));
|
.apply(this.requirementApplicableFactory.create(Requirements.of(this.requirements())));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract Command.@NonNull Builder<PlotPlayer<?>> configurePlotCommand(
|
protected abstract Command.@NonNull Builder<PlotPlayer<?>> configurePlotCommand(
|
||||||
|
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* PlotSquared, a land and world management plugin for Minecraft.
|
||||||
|
* Copyright (C) IntellectualSites <https://intellectualsites.com>
|
||||||
|
* Copyright (C) IntellectualSites team and contributors
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.plotsquared.core.commands;
|
||||||
|
|
||||||
|
import cloud.commandframework.context.CommandContext;
|
||||||
|
import com.plotsquared.core.player.PlotPlayer;
|
||||||
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
import org.incendo.cloud.requirement.RequirementFailureHandler;
|
||||||
|
|
||||||
|
public final class PlotSquaredRequirementFailureHandler implements RequirementFailureHandler<PlotPlayer<?>, CommandRequirement> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handleFailure(
|
||||||
|
final @NonNull CommandContext<PlotPlayer<?>> context,
|
||||||
|
final @NonNull CommandRequirement requirement
|
||||||
|
) {
|
||||||
|
context.sender().sendMessage(requirement.failureCaption(), requirement.tagResolvers());
|
||||||
|
}
|
||||||
|
}
|
@ -1,52 +0,0 @@
|
|||||||
/*
|
|
||||||
* PlotSquared, a land and world management plugin for Minecraft.
|
|
||||||
* Copyright (C) IntellectualSites <https://intellectualsites.com>
|
|
||||||
* Copyright (C) IntellectualSites team and contributors
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.plotsquared.core.commands.processing;
|
|
||||||
|
|
||||||
import cloud.commandframework.execution.postprocessor.CommandPostprocessingContext;
|
|
||||||
import cloud.commandframework.execution.postprocessor.CommandPostprocessor;
|
|
||||||
import cloud.commandframework.services.types.ConsumerService;
|
|
||||||
import com.plotsquared.core.commands.CommandRequirement;
|
|
||||||
import com.plotsquared.core.commands.CommandRequirements;
|
|
||||||
import com.plotsquared.core.player.PlotPlayer;
|
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Processor that evaluates registered {@link CommandRequirement command requirements} before a command is executed.
|
|
||||||
*/
|
|
||||||
public final class CommandRequirementPostprocessor implements CommandPostprocessor<PlotPlayer<?>> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void accept(final @NonNull CommandPostprocessingContext<PlotPlayer<?>> processingContext) {
|
|
||||||
final CommandRequirements requirements = processingContext.command().commandMeta().getOrDefault(
|
|
||||||
CommandRequirements.REQUIREMENTS_KEY,
|
|
||||||
null
|
|
||||||
);
|
|
||||||
if (requirements == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (final CommandRequirement requirement : requirements) {
|
|
||||||
if (requirement.evaluate(processingContext.commandContext())) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
processingContext.commandContext().sender().sendMessage(requirement.failureCaption(), requirement.tagResolvers());
|
|
||||||
// Not allowed :(
|
|
||||||
ConsumerService.interrupt();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -32,6 +32,7 @@ informative-annotations = "1.4"
|
|||||||
vault = "1.7.1"
|
vault = "1.7.1"
|
||||||
serverlib = "2.3.4"
|
serverlib = "2.3.4"
|
||||||
cloud = "2.0.0-SNAPSHOT"
|
cloud = "2.0.0-SNAPSHOT"
|
||||||
|
cloudRequirements = "1.0.0-SNAPSHOT"
|
||||||
|
|
||||||
# Gradle plugins
|
# Gradle plugins
|
||||||
shadow = "8.1.1"
|
shadow = "8.1.1"
|
||||||
@ -81,6 +82,7 @@ serverlib = { group = "dev.notmyfault.serverlib", name = "ServerLib", version.re
|
|||||||
cloud = { group = "cloud.commandframework", name = "cloud-core", version.ref = "cloud" }
|
cloud = { group = "cloud.commandframework", name = "cloud-core", version.ref = "cloud" }
|
||||||
cloudPaper = { group = "cloud.commandframework", name = "cloud-paper", version.ref = "cloud" }
|
cloudPaper = { group = "cloud.commandframework", name = "cloud-paper", version.ref = "cloud" }
|
||||||
cloudMinecraftExtras = { group = "cloud.commandframework", name = "cloud-minecraft-extras", version.ref = "cloud" }
|
cloudMinecraftExtras = { group = "cloud.commandframework", name = "cloud-minecraft-extras", version.ref = "cloud" }
|
||||||
|
cloudRequirements = { group = "org.incendo", name = "cloud-requirements", version.ref = "cloudRequirements" }
|
||||||
|
|
||||||
[plugins]
|
[plugins]
|
||||||
shadow = { id = "com.github.johnrengelman.shadow", version.ref = "shadow" }
|
shadow = { id = "com.github.johnrengelman.shadow", version.ref = "shadow" }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user