forked from SteamWar/SteamWar
Fix stuff in DiscordBot
This commit is contained in:
@@ -41,7 +41,6 @@ import net.dv8tion.jda.api.entities.Role;
|
|||||||
import net.dv8tion.jda.api.entities.emoji.Emoji;
|
import net.dv8tion.jda.api.entities.emoji.Emoji;
|
||||||
import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
|
import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
|
||||||
import net.dv8tion.jda.api.exceptions.ErrorResponseException;
|
import net.dv8tion.jda.api.exceptions.ErrorResponseException;
|
||||||
import net.dv8tion.jda.api.interactions.commands.Command;
|
|
||||||
import net.dv8tion.jda.api.interactions.commands.OptionType;
|
import net.dv8tion.jda.api.interactions.commands.OptionType;
|
||||||
import net.dv8tion.jda.api.interactions.commands.build.CommandData;
|
import net.dv8tion.jda.api.interactions.commands.build.CommandData;
|
||||||
import net.dv8tion.jda.api.interactions.commands.build.Commands;
|
import net.dv8tion.jda.api.interactions.commands.build.Commands;
|
||||||
@@ -49,13 +48,14 @@ import net.dv8tion.jda.api.interactions.commands.build.OptionData;
|
|||||||
import net.dv8tion.jda.api.interactions.components.ActionRow;
|
import net.dv8tion.jda.api.interactions.components.ActionRow;
|
||||||
import net.dv8tion.jda.api.interactions.components.buttons.Button;
|
import net.dv8tion.jda.api.interactions.components.buttons.Button;
|
||||||
import net.dv8tion.jda.api.requests.GatewayIntent;
|
import net.dv8tion.jda.api.requests.GatewayIntent;
|
||||||
import net.dv8tion.jda.api.requests.restaction.CommandListUpdateAction;
|
|
||||||
import net.dv8tion.jda.api.utils.MemberCachePolicy;
|
import net.dv8tion.jda.api.utils.MemberCachePolicy;
|
||||||
import net.dv8tion.jda.api.utils.messages.MessageCreateBuilder;
|
import net.dv8tion.jda.api.utils.messages.MessageCreateBuilder;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
@@ -67,9 +67,10 @@ public class DiscordBot {
|
|||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
private static final Map<String, SWCommand> commands = new HashMap<>();
|
private static final Map<String, SWCommand> commands = new HashMap<>();
|
||||||
|
private final OptionData commandArgument = new OptionData(OptionType.STRING, ARGUMENT_NAME, "Command arguments", false);
|
||||||
|
|
||||||
public static void withBot(Consumer<DiscordBot> consumer) {
|
public static void withBot(Consumer<DiscordBot> consumer) {
|
||||||
if(instance != null)
|
if (instance != null)
|
||||||
consumer.accept(instance);
|
consumer.accept(instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -141,7 +142,7 @@ public class DiscordBot {
|
|||||||
ActionRow.of(Button.link("https://steamwar.de", "Website"), Button.link("https://steamwar.de/youtube", "YouTube")),
|
ActionRow.of(Button.link("https://steamwar.de", "Website"), Button.link("https://steamwar.de/youtube", "YouTube")),
|
||||||
ActionRow.of(Button.primary("auth", Emoji.fromUnicode("U+2705")).withLabel("Minecraft verknüpfen"))
|
ActionRow.of(Button.primary("auth", Emoji.fromUnicode("U+2705")).withLabel("Minecraft verknüpfen"))
|
||||||
), event -> {
|
), event -> {
|
||||||
if(event.getComponentId().equals("auth"))
|
if (event.getComponentId().equals("auth"))
|
||||||
event.reply("Gebe innerhalb der nächsten 10 Minuten ``/verify " + AuthManager.createDiscordAuthToken(event.getUser()) + "`` auf dem Minecraft Server ein").setEphemeral(true).queue();
|
event.reply("Gebe innerhalb der nächsten 10 Minuten ``/verify " + AuthManager.createDiscordAuthToken(event.getUser()) + "`` auf dem Minecraft Server ein").setEphemeral(true).queue();
|
||||||
});
|
});
|
||||||
List<ActionRow> actionRows = new ArrayList<>();
|
List<ActionRow> actionRows = new ArrayList<>();
|
||||||
@@ -202,42 +203,24 @@ public class DiscordBot {
|
|||||||
vacationCommand
|
vacationCommand
|
||||||
);
|
);
|
||||||
|
|
||||||
commandSetup(jda.retrieveCommands().complete(), jda.updateCommands());
|
jda.updateCommands()
|
||||||
|
.addCommands(commands.keySet()
|
||||||
|
.stream()
|
||||||
|
.filter(command -> command.matches("^[\\w-]+$"))
|
||||||
|
.map(command -> Commands.slash(command, command).addOptions(commandArgument))
|
||||||
|
.toArray(CommandData[]::new))
|
||||||
|
.queue();
|
||||||
|
jda.getGuildById(690530484920385586L).updateCommands().queue();
|
||||||
|
|
||||||
jda.getGuildById(1241489896909180998L)
|
jda.getGuildById(1241489896909180998L)
|
||||||
.upsertCommand(vacationCommand.COMMAND)
|
.upsertCommand(vacationCommand.COMMAND)
|
||||||
.queue();
|
.queue();
|
||||||
}
|
}
|
||||||
|
|
||||||
private final OptionData commandArgument = new OptionData(OptionType.STRING, ARGUMENT_NAME, "Command arguments", false);
|
|
||||||
private void commandSetup(List<Command> existing, CommandListUpdateAction updateCommands) {
|
|
||||||
Set<String> correctCommands = new HashSet<>();
|
|
||||||
for(Command command : existing) {
|
|
||||||
if(!commands.containsKey(command.getName())) {
|
|
||||||
command.delete().complete();
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
List<Command.Option> options = command.getOptions();
|
|
||||||
if(options.size() != 1 || options.get(0).getType() != OptionType.STRING)
|
|
||||||
command.editCommand().clearOptions().addOptions(commandArgument).complete();
|
|
||||||
|
|
||||||
correctCommands.add(command.getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
updateCommands
|
|
||||||
.addCommands(commands
|
|
||||||
.keySet().stream()
|
|
||||||
.filter(command -> !correctCommands.contains(command))
|
|
||||||
.filter(command -> command.matches("^[\\w-]+$"))
|
|
||||||
.map(command -> Commands.slash(command, command).addOptions(commandArgument))
|
|
||||||
.toArray(CommandData[]::new))
|
|
||||||
.queue();
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean activityToggle = false;
|
private boolean activityToggle = false;
|
||||||
|
|
||||||
private void activity() {
|
private void activity() {
|
||||||
if(activityToggle) {
|
if (activityToggle) {
|
||||||
Event event = Event.get();
|
Event event = Event.get();
|
||||||
jda.getPresence().setActivity(event != null ? Activity.competing("dem Event " + event.getEventName()) : Activity.playing("auf SteamWar.de"));
|
jda.getPresence().setActivity(event != null ? Activity.competing("dem Event " + event.getEventName()) : Activity.playing("auf SteamWar.de"));
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
Reference in New Issue
Block a user