forked from SteamWar/SteamWar
Add ClientVersionPacket
This commit is contained in:
@@ -35,7 +35,6 @@ import de.steamwar.sql.SteamwarUser;
|
||||
import de.steamwar.sql.internal.Statement;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
|
||||
@@ -53,10 +52,6 @@ public class Core extends JavaPlugin {
|
||||
return Reflection.MAJOR_VERSION;
|
||||
}
|
||||
|
||||
public static boolean isBedrockPlayer(Player player) {
|
||||
return player.getName().startsWith(".");
|
||||
}
|
||||
|
||||
private static JavaPlugin instance;
|
||||
public static JavaPlugin getInstance() {
|
||||
return instance;
|
||||
|
||||
@@ -19,47 +19,43 @@
|
||||
|
||||
package de.steamwar.core;
|
||||
|
||||
import com.google.gson.Gson;
|
||||
import com.google.gson.JsonObject;
|
||||
import de.steamwar.network.packets.PacketHandler;
|
||||
import de.steamwar.network.packets.server.ClientVersionPacket;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.EventPriority;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.player.PlayerQuitEvent;
|
||||
import org.bukkit.plugin.messaging.PluginMessageListener;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
|
||||
public class PlayerVersion implements PluginMessageListener, Listener {
|
||||
public class PlayerVersion extends PacketHandler implements Listener {
|
||||
|
||||
private static final String PLAYER_VERSION_CHANNEL = "vv:proxy_details";
|
||||
private static final Gson GSON = new Gson();
|
||||
private static final Map<Player, Integer> playerVersions = new HashMap<>();
|
||||
private static final Map<UUID, Integer> playerVersions = new HashMap<>();
|
||||
|
||||
public static int getVersion(Player player) {
|
||||
return playerVersions.getOrDefault(player, -1);
|
||||
return playerVersions.getOrDefault(player.getUniqueId(), -1);
|
||||
}
|
||||
|
||||
public static boolean isBedrock(Player player) {
|
||||
return player.getName().startsWith(".");
|
||||
}
|
||||
|
||||
public PlayerVersion() {
|
||||
Core.getInstance().getServer().getMessenger().registerIncomingPluginChannel(Core.getInstance(), PLAYER_VERSION_CHANNEL, this);
|
||||
Bukkit.getPluginManager().registerEvents(this, Core.getInstance());
|
||||
register();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPluginMessageReceived(String channel, Player player, byte[] bytes) {
|
||||
if (!channel.equals(PLAYER_VERSION_CHANNEL)) {
|
||||
return;
|
||||
}
|
||||
|
||||
final JsonObject payload = GSON.fromJson(new String(bytes), JsonObject.class);
|
||||
final String version = payload.get("versionName").getAsString();
|
||||
playerVersions.put(player, Integer.parseInt(version.split("-")[0].split("\\.")[1]));
|
||||
@Handler
|
||||
public void handlePacket(ClientVersionPacket clientVersionPacket) {
|
||||
playerVersions.put(clientVersionPacket.getPlayer(), clientVersionPacket.getVersion());
|
||||
}
|
||||
|
||||
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||
public void onPlayerQuit(PlayerQuitEvent event) {
|
||||
playerVersions.remove(event.getPlayer());
|
||||
playerVersions.remove(event.getPlayer().getUniqueId());
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,7 +27,7 @@ public interface WorldEditRendererWrapper {
|
||||
WorldEditRendererWrapper impl = VersionDependent.getVersionImpl(Core.getInstance());
|
||||
|
||||
static void safeDraw(Player player, boolean scheduled, boolean clipboard, Vector pos1, Vector pos2) {
|
||||
if (Core.isBedrockPlayer(player) || PlayerVersion.getVersion(player) < 20) {
|
||||
if (PlayerVersion.isBedrock(player) || PlayerVersion.getVersion(player) < 20) {
|
||||
fallback.draw(player, scheduled, clipboard, pos1, pos2);
|
||||
} else {
|
||||
impl.draw(player, scheduled, clipboard, pos1, pos2);
|
||||
|
||||
Reference in New Issue
Block a user