mirror of
https://github.com/JonasunderscoreJones/YetAnotherDiscordChatLink.git
synced 2025-10-24 00:59:18 +02:00
Port to JDA and bug fixes
This commit is contained in:
parent
428e49d259
commit
3faec0166c
5 changed files with 125 additions and 82 deletions
|
@ -15,17 +15,17 @@ public class YetAnotherDiscordChatLink implements ModInitializer {
|
|||
public static final String MOD_ID = "yadcl";
|
||||
public static final Logger LOGGER = LoggerFactory.getLogger(MOD_ID);
|
||||
|
||||
public static DiscordBot discordBot;
|
||||
public static final long startTime = System.currentTimeMillis();
|
||||
|
||||
@Override
|
||||
public void onInitialize() {
|
||||
// Register the config
|
||||
ModConfigs.registerConfigs();
|
||||
|
||||
// Set the token and channel id
|
||||
DiscordBot.setToken(ModConfigs.TOKEN);
|
||||
DiscordBot.setTargetChannelId(ModConfigs.CHANNEL_ID);
|
||||
|
||||
// Start the bot
|
||||
DiscordBot.startBot();
|
||||
discordBot = new DiscordBot(ModConfigs.TOKEN, ModConfigs.CHANNEL_ID);
|
||||
discordBot.startBot();
|
||||
// send starting message
|
||||
sendToDiscord("Server is starting up.");
|
||||
}
|
||||
|
|
|
@ -17,7 +17,7 @@ public class ModConfigs {
|
|||
//public static Boolean PLAYER_COMMAND_MSG;
|
||||
public static Boolean SERVER_START_STOP_MSG;
|
||||
|
||||
//public static String BOT_STATUS;
|
||||
public static String BOT_STATUS;
|
||||
|
||||
public static void registerConfigs() {
|
||||
configs = new ModConfigProvider();
|
||||
|
@ -37,7 +37,7 @@ public class ModConfigs {
|
|||
configs.addKeyValuePair(new Pair<>("bot.player_chat_msgs", true), "Should the bot send a message when a player sends a chat message");
|
||||
//configs.addKeyValuePair(new Pair<>("bot.player_command_msgs", true), "Should the bot send a message when a player sends a command");
|
||||
configs.addKeyValuePair(new Pair<>("bot.server_start_stop_msgs", true), "Should the bot send a message when the server starts or stops");
|
||||
//configs.addKeyValuePair(new Pair<>("bot.status", "PlayerCount"), "What status should the bot display [None, PlayerCount, IP, Uptime]");
|
||||
configs.addKeyValuePair(new Pair<>("bot.status", "PlayerCount"), "What status should the bot display [None, PlayerCount, IP, Uptime]");
|
||||
}
|
||||
|
||||
private static void assignConfigs() {
|
||||
|
@ -49,7 +49,7 @@ public class ModConfigs {
|
|||
PLAYER_CHAT_MSG = CONFIG.getOrDefault("bot.player_chat_msgs", true);
|
||||
//PLAYER_COMMAND_MSG = CONFIG.getOrDefault("bot.player_command_msgs", true);
|
||||
SERVER_START_STOP_MSG = CONFIG.getOrDefault("bot.server_start_stop_msgs", true);
|
||||
//BOT_STATUS = CONFIG.getOrDefault("bot.status", "PlayerCount");
|
||||
BOT_STATUS = CONFIG.getOrDefault("bot.status", "PlayerCount");
|
||||
|
||||
YetAnotherDiscordChatLink.LOGGER.info("All " + configs.getConfigsList().size() + " Configs have been set properly");
|
||||
}
|
||||
|
|
|
@ -1,54 +1,55 @@
|
|||
package dev.jonasjones.yadcl.dcbot;
|
||||
|
||||
import dev.jonasjones.yadcl.config.ModConfigs;
|
||||
import lombok.Setter;
|
||||
import lombok.Getter;
|
||||
import net.dv8tion.jda.api.JDA;
|
||||
import net.dv8tion.jda.api.JDABuilder;
|
||||
import net.dv8tion.jda.api.entities.Activity;
|
||||
import net.dv8tion.jda.api.entities.channel.concrete.TextChannel;
|
||||
import net.dv8tion.jda.api.hooks.ListenerAdapter;
|
||||
import net.dv8tion.jda.api.requests.GatewayIntent;
|
||||
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerLifecycleEvents;
|
||||
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerTickEvents;
|
||||
import net.minecraft.server.MinecraftServer;
|
||||
import net.minecraft.text.Text;
|
||||
import org.javacord.api.DiscordApi;
|
||||
import org.javacord.api.DiscordApiBuilder;
|
||||
import org.javacord.api.entity.channel.TextChannel;
|
||||
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import static dev.jonasjones.yadcl.YetAnotherDiscordChatLink.LOGGER;
|
||||
import static dev.jonasjones.yadcl.YetAnotherDiscordChatLink.startTime;
|
||||
|
||||
public class DiscordBot {
|
||||
@Setter
|
||||
public class DiscordBot extends ListenerAdapter {
|
||||
private static String token;
|
||||
@Setter
|
||||
@Getter
|
||||
private static String targetChannelId;
|
||||
private static DiscordApi api;
|
||||
private static JDA jda;
|
||||
@Getter
|
||||
private static MinecraftServer minecraftServer;
|
||||
@Getter
|
||||
private static Boolean isBotRunning = false;
|
||||
|
||||
public DiscordBot(String token, String targetChannelId) {
|
||||
this.token = token;
|
||||
this.targetChannelId = targetChannelId;
|
||||
// Register Minecraft Server events
|
||||
registerEvents();
|
||||
}
|
||||
|
||||
public static void startBot() {
|
||||
if (isBotRunning) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
registerEvents();
|
||||
api = new DiscordApiBuilder().setToken(token).setAllIntents().login().join();
|
||||
api.addMessageCreateListener(event -> {
|
||||
// Check if the message is from the specific channel by comparing channel IDs
|
||||
if (String.valueOf(event.getChannel().getId()).equals(targetChannelId)) {
|
||||
//check if message author is the bot
|
||||
if (event.getMessageAuthor().isBotUser()) {
|
||||
return;
|
||||
}
|
||||
String discordMessage = "[" + event.getMessageAuthor().getDisplayName() + "] " + event.getMessageContent();
|
||||
// Broadcast the message to Minecraft chat
|
||||
// You can implement a method to broadcast messages to Minecraft players
|
||||
minecraftServer.getPlayerManager().broadcast(Text.of(discordMessage), false);
|
||||
}
|
||||
});
|
||||
// Create the bot
|
||||
jda = JDABuilder.createDefault(token)
|
||||
.addEventListeners(new MessageListener())
|
||||
.enableIntents(GatewayIntent.MESSAGE_CONTENT)
|
||||
.build();
|
||||
// Set the bot status
|
||||
/*if (ModConfigs.BOT_STATUS.equals("Uptime")) {
|
||||
if (ModConfigs.BOT_STATUS.equals("Uptime") || ModConfigs.BOT_STATUS.equals("PlayerCount")) {
|
||||
new Thread(() -> {
|
||||
while (isBotRunning) {
|
||||
botStatus(ModConfigs.BOT_STATUS);
|
||||
setBotStatus(ModConfigs.BOT_STATUS);
|
||||
try {
|
||||
Thread.sleep(60000);
|
||||
} catch (InterruptedException e) {
|
||||
|
@ -57,8 +58,8 @@ public class DiscordBot {
|
|||
}
|
||||
}).start();
|
||||
} else {
|
||||
botStatus(ModConfigs.BOT_STATUS);
|
||||
}*/
|
||||
setBotStatus(ModConfigs.BOT_STATUS);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
LOGGER.error("Failed to start Discord bot. Check the provided discord token in the config file.");
|
||||
return;
|
||||
|
@ -70,7 +71,7 @@ public class DiscordBot {
|
|||
if (!isBotRunning) {
|
||||
return;
|
||||
}
|
||||
api.disconnect();
|
||||
jda.shutdown();
|
||||
isBotRunning = false;
|
||||
}
|
||||
|
||||
|
@ -80,12 +81,12 @@ public class DiscordBot {
|
|||
}
|
||||
// Get the text channel by its ID
|
||||
try {
|
||||
TextChannel channel = api.getTextChannelById(targetChannelId).orElse(null);
|
||||
TextChannel channel = jda.getTextChannelById(targetChannelId);
|
||||
// Check if the channel exists and send the message
|
||||
if (channel != null) {
|
||||
channel.sendMessage(message);
|
||||
channel.sendMessage(message).queue();
|
||||
} else {
|
||||
throw new Exception("Discord Channel does not exist!");
|
||||
//throw new Exception("Discord Channel does not exist!");
|
||||
}
|
||||
} catch (Exception e) {
|
||||
LOGGER.error("Discord Channel does not exist!");
|
||||
|
@ -95,7 +96,7 @@ public class DiscordBot {
|
|||
private static void registerEvents() {
|
||||
ServerTickEvents.START_SERVER_TICK.register(server -> {
|
||||
// This code is executed on every server tick
|
||||
minecraftServer = server;
|
||||
DiscordBot.minecraftServer = server;
|
||||
});
|
||||
|
||||
ServerLifecycleEvents.SERVER_STARTED.register(server -> {
|
||||
|
@ -104,57 +105,55 @@ public class DiscordBot {
|
|||
|
||||
ServerLifecycleEvents.SERVER_STOPPED.register(server -> {
|
||||
sendToDiscord("Server is stopped!");
|
||||
//wait for 2 seconds to make sure the message is sent
|
||||
try {
|
||||
Thread.sleep(2000);
|
||||
} catch (InterruptedException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
stopBot();
|
||||
});
|
||||
}
|
||||
|
||||
/*public static void botStatus(String status) {
|
||||
if (!isBotRunning) {
|
||||
public static void setBotStatus(String statusType) {
|
||||
if (!isBotRunning || DiscordBot.minecraftServer == null) {
|
||||
return;
|
||||
}
|
||||
switch (status) {
|
||||
case "None" -> api.updateActivity("");
|
||||
case "PlayerCount" ->
|
||||
api.updateActivity("Player Count: " + minecraftServer.getCurrentPlayerCount() + "/" + minecraftServer.getMaxPlayerCount());
|
||||
case "IP" -> api.updateActivity("IP: " + minecraftServer.getServerIp());
|
||||
case "Uptime" -> api.updateActivity("Uptime: " + calculateUptime());
|
||||
default -> api.updateActivity(null);
|
||||
switch (statusType) {
|
||||
case "PlayerCount" -> jda.getPresence().setActivity(Activity.playing("with " + DiscordBot.minecraftServer.getCurrentPlayerCount() + "/"+ DiscordBot.minecraftServer.getMaxPlayerCount() + " Players"));
|
||||
case "Uptime" -> jda.getPresence().setActivity(Activity.playing("for " + calculateUptime()));
|
||||
}
|
||||
}
|
||||
|
||||
private static String calculateUptime() {
|
||||
long secs = System.currentTimeMillis() - minecraftServer.getTicks() / 20;
|
||||
long days = TimeUnit.SECONDS.toDays(secs);
|
||||
secs -= TimeUnit.DAYS.toMillis(days);
|
||||
long hours = TimeUnit.SECONDS.toHours(secs);
|
||||
secs -= TimeUnit.HOURS.toMillis(hours);
|
||||
long minutes = TimeUnit.SECONDS.toMinutes(secs);
|
||||
try {
|
||||
long secs = (System.currentTimeMillis() - startTime) / 1000;
|
||||
long days = TimeUnit.SECONDS.toDays(secs);
|
||||
secs -= TimeUnit.DAYS.toMillis(days);
|
||||
long hours = TimeUnit.SECONDS.toHours(secs);
|
||||
secs -= TimeUnit.HOURS.toMillis(hours);
|
||||
long minutes = TimeUnit.SECONDS.toMinutes(secs);
|
||||
|
||||
StringBuilder duration = new StringBuilder();
|
||||
if (days > 0) {
|
||||
duration.append(days).append(" Days, ");
|
||||
}
|
||||
if (hours > 0 || days > 0) {
|
||||
if (hours == 1) {
|
||||
duration.append(hours).append(" Hour, ");
|
||||
} else {
|
||||
duration.append(hours).append(" Hours, ");
|
||||
StringBuilder duration = new StringBuilder();
|
||||
if (days > 0) {
|
||||
duration.append(days).append(" Days, ");
|
||||
}
|
||||
}
|
||||
if (minutes > 0 || hours > 0 || days > 0) {
|
||||
if (minutes == 1) {
|
||||
duration.append(minutes).append(" Minute, ");
|
||||
} else {
|
||||
duration.append(minutes).append(" Minutes, ");
|
||||
if (hours > 0 || days > 0) {
|
||||
if (hours == 1) {
|
||||
duration.append(hours).append(" Hour, ");
|
||||
} else {
|
||||
duration.append(hours).append(" Hours, ");
|
||||
}
|
||||
}
|
||||
if (minutes > 0 || hours > 0 || days > 0) {
|
||||
if (minutes == 1) {
|
||||
duration.append(minutes).append(" Minute");
|
||||
} else {
|
||||
duration.append(minutes).append(" Minutes");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return duration.toString();
|
||||
}*/
|
||||
}
|
||||
if (duration.isEmpty()) {
|
||||
return "less than a minute";
|
||||
}
|
||||
|
||||
return duration.toString();
|
||||
} catch (Exception e) {
|
||||
return "-";
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,22 @@
|
|||
package dev.jonasjones.yadcl.dcbot;
|
||||
|
||||
import net.dv8tion.jda.api.entities.channel.middleman.MessageChannel;
|
||||
import net.dv8tion.jda.api.events.message.MessageReceivedEvent;
|
||||
import net.dv8tion.jda.api.hooks.ListenerAdapter;
|
||||
import net.minecraft.text.Text;
|
||||
|
||||
import static dev.jonasjones.yadcl.YetAnotherDiscordChatLink.discordBot;
|
||||
|
||||
public class MessageListener extends ListenerAdapter {
|
||||
@Override
|
||||
public void onMessageReceived(MessageReceivedEvent event) {
|
||||
if (!DiscordBot.getIsBotRunning()) return; // Ignore messages if the bot is not running
|
||||
if (event.getAuthor().isBot()) return; // Ignore messages from other bots
|
||||
|
||||
// Check if the message was sent in the trigger channel
|
||||
if (event.getChannel().getId().equals(DiscordBot.getTargetChannelId())) {
|
||||
// Send the message to the server
|
||||
DiscordBot.getMinecraftServer().getPlayerManager().broadcast(Text.of("[" +event.getAuthor().getName() + "]: " + event.getMessage().getContentRaw()), false);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue