Make botinfo support both slash and message commands
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
parent
89fc2aa0a6
commit
c7208eef84
@ -6,7 +6,6 @@ import net.dv8tion.jda.api.OnlineStatus;
|
|||||||
import net.dv8tion.jda.api.entities.Activity;
|
import net.dv8tion.jda.api.entities.Activity;
|
||||||
import net.dv8tion.jda.api.requests.GatewayIntent;
|
import net.dv8tion.jda.api.requests.GatewayIntent;
|
||||||
import sun.misc.Signal;
|
import sun.misc.Signal;
|
||||||
import wtf.beatrice.hidekobot.commands.message.CommandsCommand;
|
|
||||||
import wtf.beatrice.hidekobot.commands.message.HelloCommand;
|
import wtf.beatrice.hidekobot.commands.message.HelloCommand;
|
||||||
import wtf.beatrice.hidekobot.commands.slash.*;
|
import wtf.beatrice.hidekobot.commands.slash.*;
|
||||||
import wtf.beatrice.hidekobot.datasource.ConfigurationSource;
|
import wtf.beatrice.hidekobot.datasource.ConfigurationSource;
|
||||||
@ -115,7 +114,7 @@ public class HidekoBot
|
|||||||
// register message commands
|
// register message commands
|
||||||
MessageCommandListener messageCommandListener = new MessageCommandListener();
|
MessageCommandListener messageCommandListener = new MessageCommandListener();
|
||||||
messageCommandListener.registerCommand(new HelloCommand());
|
messageCommandListener.registerCommand(new HelloCommand());
|
||||||
messageCommandListener.registerCommand(new CommandsCommand());
|
messageCommandListener.registerCommand(new wtf.beatrice.hidekobot.commands.message.BotInfoCommand());
|
||||||
messageCommandListener.registerCommand(new wtf.beatrice.hidekobot.commands.message.CoinFlipCommand());
|
messageCommandListener.registerCommand(new wtf.beatrice.hidekobot.commands.message.CoinFlipCommand());
|
||||||
messageCommandListener.registerCommand(new wtf.beatrice.hidekobot.commands.message.ClearCommand());
|
messageCommandListener.registerCommand(new wtf.beatrice.hidekobot.commands.message.ClearCommand());
|
||||||
Cache.setMessageCommandListener(messageCommandListener);
|
Cache.setMessageCommandListener(messageCommandListener);
|
||||||
|
@ -0,0 +1,75 @@
|
|||||||
|
package wtf.beatrice.hidekobot.commands.base;
|
||||||
|
|
||||||
|
import net.dv8tion.jda.api.EmbedBuilder;
|
||||||
|
import net.dv8tion.jda.api.entities.MessageEmbed;
|
||||||
|
import wtf.beatrice.hidekobot.Cache;
|
||||||
|
import wtf.beatrice.hidekobot.HidekoBot;
|
||||||
|
import wtf.beatrice.hidekobot.util.FormatUtil;
|
||||||
|
|
||||||
|
import java.lang.management.ManagementFactory;
|
||||||
|
import java.text.DecimalFormat;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class BotInfo
|
||||||
|
{
|
||||||
|
public static MessageEmbed generateEmbed(List<String> commandLabels)
|
||||||
|
{
|
||||||
|
EmbedBuilder embedBuilder = new EmbedBuilder();
|
||||||
|
embedBuilder.setColor(Cache.getBotColor());
|
||||||
|
embedBuilder.setTitle(Cache.getBotName());
|
||||||
|
|
||||||
|
// thumbnail
|
||||||
|
String botAvatarUrl = HidekoBot.getAPI().getSelfUser().getAvatarUrl();
|
||||||
|
if(botAvatarUrl != null) embedBuilder.setThumbnail(botAvatarUrl);
|
||||||
|
|
||||||
|
// help field
|
||||||
|
long ownerId = Cache.getBotOwnerId();
|
||||||
|
embedBuilder.addField("Getting started",
|
||||||
|
"This instance is run by <@" + ownerId + ">.\nType `/help` for help! ",
|
||||||
|
false);
|
||||||
|
|
||||||
|
// commands list field
|
||||||
|
StringBuilder commandsListBuilder = new StringBuilder();
|
||||||
|
commandsListBuilder.append(commandLabels.size()).append( " total - ");
|
||||||
|
for(int i = 0; i < commandLabels.size(); i++)
|
||||||
|
{
|
||||||
|
commandsListBuilder.append("`").append(commandLabels.get(i)).append("`");
|
||||||
|
|
||||||
|
if(i + 1 != commandLabels.size()) // don't add comma in last iteration
|
||||||
|
{
|
||||||
|
commandsListBuilder.append(", ");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
embedBuilder.addField("Commands", commandsListBuilder.toString(), false);
|
||||||
|
|
||||||
|
// version field
|
||||||
|
embedBuilder.addField("Version", "v" + Cache.getBotVersion(), true);
|
||||||
|
|
||||||
|
// jvm version field
|
||||||
|
String jvmVersion = ManagementFactory.getRuntimeMXBean().getVmVersion();
|
||||||
|
// only keep the important part "v19.0.1" and omit "v19.0.1+10"
|
||||||
|
jvmVersion = jvmVersion.replaceAll("\\+.*", "");
|
||||||
|
embedBuilder.addField("JVM Version", "v" + jvmVersion, true);
|
||||||
|
|
||||||
|
// used ram field
|
||||||
|
long usedRamBytes = (Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory());
|
||||||
|
double usedRamMB = usedRamBytes / 1024.0 / 1024.0; // bytes -> kB -> MB
|
||||||
|
DecimalFormat ramMBFormatter = new DecimalFormat("#.##");
|
||||||
|
embedBuilder.addField("RAM Usage", ramMBFormatter.format(usedRamMB) + " MB", true);
|
||||||
|
|
||||||
|
// developer field
|
||||||
|
String developerMention = "<@" + Cache.getBotMaintainerId() + ">";
|
||||||
|
embedBuilder.addField("Maintainer", developerMention, true);
|
||||||
|
|
||||||
|
// uptime field
|
||||||
|
embedBuilder.addField("Uptime", FormatUtil.getNiceUptime(), true);
|
||||||
|
|
||||||
|
// issue tracker field
|
||||||
|
embedBuilder.addField("Support",
|
||||||
|
"[Issue tracker](https://git.beatrice.wtf/mind-overflow/HidekoBot/issues)",
|
||||||
|
true); //todo: we should probably make this a final field in the config class
|
||||||
|
|
||||||
|
return embedBuilder.build();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
package wtf.beatrice.hidekobot.commands.message;
|
||||||
|
|
||||||
|
import net.dv8tion.jda.api.Permission;
|
||||||
|
import net.dv8tion.jda.api.entities.MessageEmbed;
|
||||||
|
import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
import wtf.beatrice.hidekobot.Cache;
|
||||||
|
import wtf.beatrice.hidekobot.commands.base.BotInfo;
|
||||||
|
import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class BotInfoCommand implements MessageCommand
|
||||||
|
{
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public LinkedList<String> getCommandLabels() {
|
||||||
|
return new LinkedList<>(Collections.singletonList("botinfo"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public List<Permission> getPermissions() {
|
||||||
|
return null; // anyone can use it
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean passRawArgs() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runCommand(MessageReceivedEvent event, String label, String[] args) {
|
||||||
|
|
||||||
|
// run in a thread because we might use thread-locking things
|
||||||
|
new Thread(() -> {
|
||||||
|
// get a list of message commands
|
||||||
|
LinkedList<MessageCommand> messageCommands = Cache.getMessageCommandListener().getRegisteredCommands();
|
||||||
|
LinkedList<String> commandNames = new LinkedList<>();
|
||||||
|
for (MessageCommand command : messageCommands) {
|
||||||
|
commandNames.add(command.getCommandLabels().get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
// send the list
|
||||||
|
MessageEmbed embed = BotInfo.generateEmbed(commandNames);
|
||||||
|
event.getMessage().replyEmbeds(embed).queue();
|
||||||
|
}).start();
|
||||||
|
}
|
||||||
|
}
|
@ -1,46 +0,0 @@
|
|||||||
package wtf.beatrice.hidekobot.commands.message;
|
|
||||||
|
|
||||||
import net.dv8tion.jda.api.Permission;
|
|
||||||
import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
|
|
||||||
import wtf.beatrice.hidekobot.Cache;
|
|
||||||
import wtf.beatrice.hidekobot.objects.commands.MessageCommand;
|
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class CommandsCommand implements MessageCommand
|
|
||||||
{
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public LinkedList<String> getCommandLabels() {
|
|
||||||
return new LinkedList<>(Collections.singletonList("commands"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<Permission> getPermissions() { return null; }
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean passRawArgs() { return false; }
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void runCommand(MessageReceivedEvent event, String label, String[] args) {
|
|
||||||
|
|
||||||
StringBuilder commandsList = new StringBuilder();
|
|
||||||
commandsList.append("Recognized message commands: ");
|
|
||||||
|
|
||||||
LinkedList<MessageCommand> messageCommands = Cache.getMessageCommandListener().getRegisteredCommands();
|
|
||||||
for(int i = 0; i < messageCommands.size(); i++)
|
|
||||||
{
|
|
||||||
commandsList.append("`")
|
|
||||||
.append(messageCommands.get(i).getCommandLabels().get(0))
|
|
||||||
.append("`");
|
|
||||||
if(i+1 != messageCommands.size())
|
|
||||||
{ commandsList.append(", "); }
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
event.getMessage().reply(commandsList.toString()).queue();
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,18 +1,16 @@
|
|||||||
package wtf.beatrice.hidekobot.commands.slash;
|
package wtf.beatrice.hidekobot.commands.slash;
|
||||||
|
|
||||||
import net.dv8tion.jda.api.EmbedBuilder;
|
import net.dv8tion.jda.api.entities.MessageEmbed;
|
||||||
import net.dv8tion.jda.api.events.interaction.command.SlashCommandInteractionEvent;
|
import net.dv8tion.jda.api.events.interaction.command.SlashCommandInteractionEvent;
|
||||||
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;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import wtf.beatrice.hidekobot.Cache;
|
import wtf.beatrice.hidekobot.Cache;
|
||||||
import wtf.beatrice.hidekobot.HidekoBot;
|
import wtf.beatrice.hidekobot.commands.base.BotInfo;
|
||||||
import wtf.beatrice.hidekobot.objects.commands.SlashCommand;
|
import wtf.beatrice.hidekobot.objects.commands.SlashCommand;
|
||||||
import wtf.beatrice.hidekobot.objects.commands.SlashCommandImpl;
|
import wtf.beatrice.hidekobot.objects.commands.SlashCommandImpl;
|
||||||
import wtf.beatrice.hidekobot.util.FormatUtil;
|
|
||||||
|
|
||||||
import java.lang.management.ManagementFactory;
|
import java.util.LinkedList;
|
||||||
import java.text.DecimalFormat;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class BotInfoCommand extends SlashCommandImpl
|
public class BotInfoCommand extends SlashCommandImpl
|
||||||
@ -25,74 +23,23 @@ public class BotInfoCommand extends SlashCommandImpl
|
|||||||
@Override
|
@Override
|
||||||
public void runSlashCommand(@NotNull SlashCommandInteractionEvent event)
|
public void runSlashCommand(@NotNull SlashCommandInteractionEvent event)
|
||||||
{
|
{
|
||||||
|
// run in a thread because we might use thread-locking things
|
||||||
|
new Thread(() -> {
|
||||||
// defer reply because this might take a moment
|
// defer reply because this might take a moment
|
||||||
event.deferReply().queue();
|
event.deferReply().queue();
|
||||||
|
|
||||||
|
// get a list of slash commands
|
||||||
List<SlashCommand> registeredCommands = Cache.getSlashCommandListener().getRegisteredCommands();
|
List<SlashCommand> registeredCommands = Cache.getSlashCommandListener().getRegisteredCommands();
|
||||||
|
LinkedList<String> registeredCommandNames = new LinkedList<>();
|
||||||
EmbedBuilder embedBuilder = new EmbedBuilder();
|
for(SlashCommand command : registeredCommands)
|
||||||
|
|
||||||
// embed processing
|
|
||||||
{
|
{
|
||||||
embedBuilder.setColor(Cache.getBotColor());
|
// node: adding slash so people realize that this is specific about slash commands.
|
||||||
embedBuilder.setTitle(Cache.getBotName());
|
registeredCommandNames.add("/" + command.getCommandName());
|
||||||
|
|
||||||
// thumbnail
|
|
||||||
String botAvatarUrl = HidekoBot.getAPI().getSelfUser().getAvatarUrl();
|
|
||||||
if(botAvatarUrl != null) embedBuilder.setThumbnail(botAvatarUrl);
|
|
||||||
|
|
||||||
// help field
|
|
||||||
long ownerId = Cache.getBotOwnerId();
|
|
||||||
embedBuilder.addField("Getting started",
|
|
||||||
"This instance is run by <@" + ownerId + ">.\nType `/help` for help! ",
|
|
||||||
false);
|
|
||||||
|
|
||||||
// commands list field
|
|
||||||
StringBuilder commandsListBuilder = new StringBuilder();
|
|
||||||
commandsListBuilder.append(registeredCommands.size()).append( " total - ");
|
|
||||||
for(int i = 0; i < registeredCommands.size(); i++)
|
|
||||||
{
|
|
||||||
SlashCommand cmd = registeredCommands.get(i);
|
|
||||||
commandsListBuilder.append("`").append(cmd.getCommandName()).append("`");
|
|
||||||
|
|
||||||
if(i + 1 != registeredCommands.size()) // don't add comma in last iteration
|
|
||||||
{
|
|
||||||
commandsListBuilder.append(", ");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
// send the list
|
||||||
embedBuilder.addField("Commands", commandsListBuilder.toString(), false);
|
MessageEmbed embed = BotInfo.generateEmbed(registeredCommandNames);
|
||||||
|
event.getHook().editOriginalEmbeds(embed).queue();
|
||||||
// version field
|
}).start();
|
||||||
embedBuilder.addField("Version", "v" + Cache.getBotVersion(), true);
|
|
||||||
|
|
||||||
// jvm version field
|
|
||||||
String jvmVersion = ManagementFactory.getRuntimeMXBean().getVmVersion();
|
|
||||||
// only keep the important part "v19.0.1" and omit "v19.0.1+10"
|
|
||||||
jvmVersion = jvmVersion.replaceAll("\\+.*", "");
|
|
||||||
embedBuilder.addField("JVM Version", "v" + jvmVersion, true);
|
|
||||||
|
|
||||||
// used ram field
|
|
||||||
long usedRamBytes = (Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory());
|
|
||||||
double usedRamMB = usedRamBytes / 1024.0 / 1024.0; // bytes -> kB -> MB
|
|
||||||
DecimalFormat ramMBFormatter = new DecimalFormat("#.##");
|
|
||||||
embedBuilder.addField("RAM Usage", ramMBFormatter.format(usedRamMB) + " MB", true);
|
|
||||||
|
|
||||||
// developer field
|
|
||||||
String developerMention = "<@" + Cache.getBotMaintainerId() + ">";
|
|
||||||
embedBuilder.addField("Maintainer", developerMention, true);
|
|
||||||
|
|
||||||
// uptime field
|
|
||||||
embedBuilder.addField("Uptime", FormatUtil.getNiceUptime(), true);
|
|
||||||
|
|
||||||
// issue tracker field
|
|
||||||
embedBuilder.addField("Support",
|
|
||||||
"[Issue tracker](https://git.beatrice.wtf/mind-overflow/HidekoBot/issues)",
|
|
||||||
true); //todo: we should probably make this a final field in the config class
|
|
||||||
}
|
|
||||||
|
|
||||||
event.getHook().editOriginalEmbeds(embedBuilder.build()).queue();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user