Update from Git Manager GUI
This commit is contained in:
69
src/main/java/dev/viper/telegramchat/BedrockSupport.java
Normal file
69
src/main/java/dev/viper/telegramchat/BedrockSupport.java
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
package dev.viper.telegramchat;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.geysermc.floodgate.api.FloodgateApi;
|
||||||
|
import org.geysermc.floodgate.api.player.FloodgatePlayer;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hilfsklasse zur Unterstützung von Bedrock-Spielern via Floodgate.
|
||||||
|
*/
|
||||||
|
public class BedrockSupport {
|
||||||
|
|
||||||
|
private static FloodgateApi floodgateApi = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialisiert die Floodgate-API, falls das Plugin auf dem Server existiert.
|
||||||
|
*/
|
||||||
|
public static void init() {
|
||||||
|
if (Bukkit.getPluginManager().getPlugin("Floodgate") != null) {
|
||||||
|
try {
|
||||||
|
floodgateApi = FloodgateApi.getInstance();
|
||||||
|
Bukkit.getLogger().info("[" + TelegramChatBridge.getInstance().getName() + "] Floodgate erkannt! Bedrock-Support aktiviert.");
|
||||||
|
} catch (Exception e) {
|
||||||
|
Bukkit.getLogger().warning("[" + TelegramChatBridge.getInstance().getName() + "] Konnte Floodgate-API nicht laden: " + e.getMessage());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Bukkit.getLogger().info("[" + TelegramChatBridge.getInstance().getName() + "] Kein Floodgate gefunden. Nur Java-Support aktiv.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gibt den Anzeigenamen des Spielers zurück.
|
||||||
|
* Wenn es ein Bedrock-Spieler ist, wird der Bedrock-Name zurückgegeben, sonst der Java-Name.
|
||||||
|
*/
|
||||||
|
public static String getDisplayName(Player player) {
|
||||||
|
if (floodgateApi != null) {
|
||||||
|
// Prüfen ob der Spieler ein Floodgate-Spieler ist
|
||||||
|
if (floodgateApi.isFloodgatePlayer(player.getUniqueId())) {
|
||||||
|
FloodgatePlayer fp = floodgateApi.getPlayer(player.getUniqueId());
|
||||||
|
if (fp != null) {
|
||||||
|
return fp.getUsername(); // Echter Bedrock-Name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return player.getName(); // Standard Java-Name
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gibt den Namen für eine UUID zurück (auch für Offline-Spieler, z.B. in der API-Logik).
|
||||||
|
*/
|
||||||
|
public static String getDisplayName(UUID uuid) {
|
||||||
|
if (floodgateApi != null) {
|
||||||
|
try {
|
||||||
|
if (floodgateApi.isFloodgatePlayer(uuid)) {
|
||||||
|
FloodgatePlayer fp = floodgateApi.getPlayer(uuid);
|
||||||
|
if (fp != null) {
|
||||||
|
return fp.getUsername();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// Falls API-Aufruf fehlschlägt, Fallback nutzen
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Fallback auf Bukkit OfflinePlayer
|
||||||
|
return Bukkit.getOfflinePlayer(uuid).getName();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
package dev.viper.telegramchat;
|
package dev.viper.telegramchat;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
|
||||||
@@ -11,20 +13,36 @@ public class ChatListener implements Listener {
|
|||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler(priority = EventPriority.HIGHEST)
|
||||||
public void onChat(AsyncPlayerChatEvent event) {
|
public void onChat(AsyncPlayerChatEvent event) {
|
||||||
|
// Sicherheitscheck: Falls ein Plugin das Event bereits cancelt hat (z.B. EssentialsChat Local), tun wir nichts
|
||||||
|
if (event.isCancelled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
var player = event.getPlayer();
|
var player = event.getPlayer();
|
||||||
var mode = plugin.getChatModeManager().getMode(player.getUniqueId());
|
var mode = plugin.getChatModeManager().getMode(player.getUniqueId());
|
||||||
|
|
||||||
String username = player.getName();
|
// DEBUG LOGGING
|
||||||
|
// Wir loggen jetzt JEDE Nachricht, damit wir wissen, ob der Spieler tippt
|
||||||
|
plugin.getLogger().info("Chat-Event: Spieler '" + BedrockSupport.getDisplayName(player) + "' schreibt: '" + event.getMessage() + "'");
|
||||||
|
plugin.getLogger().info("Aktueller Modus: " + mode);
|
||||||
|
|
||||||
|
String username = BedrockSupport.getDisplayName(player);
|
||||||
String message = event.getMessage();
|
String message = event.getMessage();
|
||||||
|
|
||||||
if (mode == ChatModeManager.ChatMode.TELEGRAM) {
|
if (mode == ChatModeManager.ChatMode.TELEGRAM) {
|
||||||
// Nachricht an Telegram senden und im Minecraft-Chat unterdrücken
|
plugin.getLogger().info("-> Modus ist TELEGRAM. Sende an Telegram und cancelle MC-Chat.");
|
||||||
plugin.getBotHandler().sendMessageToTelegram(username, message);
|
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Im Minecraft-Modus passiert nichts weiter – Nachricht wird normal angezeigt
|
// Nachricht asynchron an Telegram senden (wichtig!)
|
||||||
|
Bukkit.getScheduler().runTaskAsynchronously(plugin, () -> {
|
||||||
|
plugin.getBotHandler().sendMessageToTelegram(username, message);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Nachricht im MC-Chat unterdrücken
|
||||||
|
event.setCancelled(true);
|
||||||
|
} else {
|
||||||
|
plugin.getLogger().info("-> Modus ist MINECRAFT. Nachricht geht normal weiter.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,9 +2,9 @@ package dev.viper.telegramchat;
|
|||||||
|
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
import org.bukkit.event.player.PlayerQuitEvent;
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
import org.bukkit.event.entity.PlayerDeathEvent;
|
|
||||||
|
|
||||||
public class PlayerEventListener implements Listener {
|
public class PlayerEventListener implements Listener {
|
||||||
|
|
||||||
@@ -18,7 +18,8 @@ public class PlayerEventListener implements Listener {
|
|||||||
public void onPlayerJoin(PlayerJoinEvent event) {
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
if (!plugin.getConfig().getBoolean("messages.joinAndLeaveEvent", true)) return;
|
if (!plugin.getConfig().getBoolean("messages.joinAndLeaveEvent", true)) return;
|
||||||
|
|
||||||
String message = event.getPlayer().getName() + " ist dem Server beigetreten.";
|
String playerName = BedrockSupport.getDisplayName(event.getPlayer());
|
||||||
|
String message = playerName + " ist dem Server beigetreten.";
|
||||||
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -26,7 +27,8 @@ public class PlayerEventListener implements Listener {
|
|||||||
public void onPlayerQuit(PlayerQuitEvent event) {
|
public void onPlayerQuit(PlayerQuitEvent event) {
|
||||||
if (!plugin.getConfig().getBoolean("messages.joinAndLeaveEvent", true)) return;
|
if (!plugin.getConfig().getBoolean("messages.joinAndLeaveEvent", true)) return;
|
||||||
|
|
||||||
String message = event.getPlayer().getName() + " hat den Server verlassen.";
|
String playerName = BedrockSupport.getDisplayName(event.getPlayer());
|
||||||
|
String message = playerName + " hat den Server verlassen.";
|
||||||
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -34,7 +36,8 @@ public class PlayerEventListener implements Listener {
|
|||||||
public void onPlayerDeath(PlayerDeathEvent event) {
|
public void onPlayerDeath(PlayerDeathEvent event) {
|
||||||
if (!plugin.getConfig().getBoolean("messages.deathEvent", true)) return;
|
if (!plugin.getConfig().getBoolean("messages.deathEvent", true)) return;
|
||||||
|
|
||||||
String message = event.getDeathMessage();
|
String playerName = BedrockSupport.getDisplayName(event.getEntity());
|
||||||
|
String message = playerName + " ist gestorben: " + event.getDeathMessage();
|
||||||
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
plugin.getBotHandler().sendMessageToTelegram("Server", message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -112,9 +112,16 @@ public class TelegramBotHandler extends TelegramLongPollingBot {
|
|||||||
}
|
}
|
||||||
|
|
||||||
UUID uuid = plugin.getAccountLinkManager().findUUIDByTelegramId(telegramId);
|
UUID uuid = plugin.getAccountLinkManager().findUUIDByTelegramId(telegramId);
|
||||||
String from = uuid != null && Bukkit.getOfflinePlayer(uuid).getName() != null
|
|
||||||
? Bukkit.getOfflinePlayer(uuid).getName()
|
// Name-Ermittlung: Zuerst versuchen den verknüpften Spielernamen zu nutzen (inkl. Bedrock-Check)
|
||||||
: msg.getFrom().getFirstName();
|
// Falls nicht verknüpft, den Telegram Vornamen nutzen
|
||||||
|
String from = msg.getFrom().getFirstName();
|
||||||
|
if (uuid != null) {
|
||||||
|
String playerName = BedrockSupport.getDisplayName(uuid);
|
||||||
|
if (playerName != null) {
|
||||||
|
from = playerName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
String formatted = plugin.getTelegramToMinecraftFormat()
|
String formatted = plugin.getTelegramToMinecraftFormat()
|
||||||
.replace("{username}", from)
|
.replace("{username}", from)
|
||||||
@@ -133,9 +140,15 @@ public class TelegramBotHandler extends TelegramLongPollingBot {
|
|||||||
String args = split.length > 1 ? split[1] : "";
|
String args = split.length > 1 ? split[1] : "";
|
||||||
|
|
||||||
UUID uuid = plugin.getAccountLinkManager().findUUIDByTelegramId(telegramId);
|
UUID uuid = plugin.getAccountLinkManager().findUUIDByTelegramId(telegramId);
|
||||||
String from = uuid != null && Bukkit.getOfflinePlayer(uuid).getName() != null
|
String from = msg.getFrom().getFirstName(); // Standardname für Antworten
|
||||||
? Bukkit.getOfflinePlayer(uuid).getName()
|
|
||||||
: msg.getFrom().getFirstName();
|
// Wenn verknüpft, versuchen den echten Spielernamen (Bedrock oder Java) zu holen
|
||||||
|
if (uuid != null) {
|
||||||
|
String playerName = BedrockSupport.getDisplayName(uuid);
|
||||||
|
if (playerName != null) {
|
||||||
|
from = playerName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case "/verify":
|
case "/verify":
|
||||||
@@ -235,7 +248,7 @@ public class TelegramBotHandler extends TelegramLongPollingBot {
|
|||||||
private void handleOtherCommands(String cmd, String args, String from, Message msg, UUID uuid) {
|
private void handleOtherCommands(String cmd, String args, String from, Message msg, UUID uuid) {
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case "/online":
|
case "/online":
|
||||||
List<String> players = Bukkit.getOnlinePlayers().stream().map(Player::getName).collect(Collectors.toList());
|
List<String> players = Bukkit.getOnlinePlayers().stream().map(p -> BedrockSupport.getDisplayName(p)).collect(Collectors.toList());
|
||||||
String msgText = players.isEmpty()
|
String msgText = players.isEmpty()
|
||||||
? getConfigMessage("messages.telegram.command.online-empty")
|
? getConfigMessage("messages.telegram.command.online-empty")
|
||||||
: getConfigMessage("messages.telegram.command.online-list").replace("{list}", String.join(", ", players));
|
: getConfigMessage("messages.telegram.command.online-list").replace("{list}", String.join(", ", players));
|
||||||
@@ -324,16 +337,27 @@ public class TelegramBotHandler extends TelegramLongPollingBot {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void sendMessageToTelegram(String username, String message) {
|
public void sendMessageToTelegram(String username, String message) {
|
||||||
|
// DEBUG: Prüfen ob Chat-IDs geladen wurden
|
||||||
|
if (chatIds.isEmpty()) {
|
||||||
|
plugin.getLogger().severe("Keine Chat-IDs gefunden! Bitte prüfe die config.yml unter telegram.chat-id");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
String formatted = plugin.getMinecraftToTelegramFormat()
|
String formatted = plugin.getMinecraftToTelegramFormat()
|
||||||
.replace("{username}", username)
|
.replace("{username}", username)
|
||||||
.replace("{message}", message);
|
.replace("{message}", message);
|
||||||
String telegramMessage = formatted.replaceAll("&[0-9a-fk-or]", "");
|
String telegramMessage = formatted.replaceAll("&[0-9a-fk-or]", "");
|
||||||
|
|
||||||
|
plugin.getLogger().info("Versuche Nachricht an " + chatIds.size() + " Chat(s) zu senden...");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (String id : chatIds) {
|
for (String id : chatIds) {
|
||||||
execute(new SendMessage(id, telegramMessage));
|
execute(new SendMessage(id, telegramMessage));
|
||||||
|
plugin.getLogger().info("Erfolgreich an Chat-ID gesendet: " + id);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
plugin.getLogger().warning("Fehler beim Senden an Telegram: " + e.getMessage());
|
plugin.getLogger().severe("Fehler beim Senden an Telegram: " + e.getMessage());
|
||||||
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,10 @@ public class TelegramChatBridge extends JavaPlugin {
|
|||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
instance = this;
|
instance = this;
|
||||||
|
|
||||||
|
// Bedrock-Support initialisieren
|
||||||
|
BedrockSupport.init();
|
||||||
|
|
||||||
saveDefaultConfig();
|
saveDefaultConfig();
|
||||||
|
|
||||||
chatModeManager = new ChatModeManager();
|
chatModeManager = new ChatModeManager();
|
||||||
|
|||||||
Reference in New Issue
Block a user