mirror of
https://github.com/CarmJos/cn2b2t-project.git
synced 2026-06-04 08:48:16 +08:00
完善User
This commit is contained in:
@@ -1,9 +1,10 @@
|
||||
package org.cn2b2t.core.managers.utils;
|
||||
|
||||
import org.cn2b2t.core.Main;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.scheduler.BukkitRunnable;
|
||||
import org.cn2b2t.core.Main;
|
||||
import org.cn2b2t.core.managers.users.UserValueManager;
|
||||
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.DataOutputStream;
|
||||
@@ -19,12 +20,12 @@ public class ServersManager
|
||||
{
|
||||
|
||||
|
||||
public static List<Player> requests = new ArrayList<>();
|
||||
public static List<String> allPlayers = new ArrayList<>();
|
||||
public static List<Player> requests = new ArrayList<>();
|
||||
public static List<String> allPlayers = new ArrayList<>();
|
||||
|
||||
public static void init() {
|
||||
Main.getInstance().getServer().getMessenger().registerOutgoingPluginChannel(Main.getInstance(), "BungeeCord");
|
||||
Bukkit.getMessenger().registerOutgoingPluginChannel(Main.getInstance(), "BeeSwitch");
|
||||
public static void init() {
|
||||
Main.getInstance().getServer().getMessenger().registerOutgoingPluginChannel(Main.getInstance(), "BungeeCord");
|
||||
Bukkit.getMessenger().registerOutgoingPluginChannel(Main.getInstance(), "BeeSwitch");
|
||||
// Core.getInstance().getServer().getMessenger().registerIncomingPluginChannel(Core.getInstance(), "BungeeCord", new ServersManager());
|
||||
// new BukkitRunnable() {
|
||||
// @Override
|
||||
@@ -34,7 +35,7 @@ public class ServersManager
|
||||
//
|
||||
// }
|
||||
// }.runTaskTimer(Core.getInstance(), 60L, 200L);
|
||||
}
|
||||
}
|
||||
|
||||
// public static void sendGetPlayerList() {
|
||||
// ByteArrayOutputStream b = new ByteArrayOutputStream();
|
||||
@@ -66,40 +67,46 @@ public class ServersManager
|
||||
// }
|
||||
// }
|
||||
|
||||
public static void teleport(Player p, String server) {
|
||||
ByteArrayOutputStream b = new ByteArrayOutputStream();
|
||||
DataOutputStream out = new DataOutputStream(b);
|
||||
try {
|
||||
out.writeUTF("ConnectOther");
|
||||
out.writeUTF(p.getName());
|
||||
out.writeUTF(server);
|
||||
} catch (IOException ex) {
|
||||
Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
|
||||
}
|
||||
p.sendPluginMessage(Main.getInstance(), "BungeeCord", b.toByteArray());
|
||||
}
|
||||
public static void teleport(Player p, String server) {
|
||||
ByteArrayOutputStream b = new ByteArrayOutputStream();
|
||||
DataOutputStream out = new DataOutputStream(b);
|
||||
try {
|
||||
out.writeUTF("ConnectOther");
|
||||
out.writeUTF(p.getName());
|
||||
out.writeUTF(server);
|
||||
} catch (IOException ex) {
|
||||
Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
|
||||
}
|
||||
p.sendPluginMessage(Main.getInstance(), "BungeeCord", b.toByteArray());
|
||||
}
|
||||
|
||||
public static void teleport(Player player, String server, int t) {
|
||||
requests.add(player);
|
||||
new BukkitRunnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
if (requests.contains(player) && player.isOnline()) {
|
||||
teleport(player, server);
|
||||
requests.remove(player);
|
||||
}
|
||||
cancel();
|
||||
}
|
||||
}.runTaskLater(Main.getInstance(), 20L * t);
|
||||
}
|
||||
public static void teleport(Player player, String server, int t) {
|
||||
requests.add(player);
|
||||
new BukkitRunnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
if (requests.contains(player) && player.isOnline()) {
|
||||
teleport(player, server);
|
||||
requests.remove(player);
|
||||
}
|
||||
cancel();
|
||||
}
|
||||
}.runTaskLater(Main.getInstance(), 20L * t);
|
||||
}
|
||||
|
||||
public static void backToLobby(Player p) {
|
||||
teleport(p, "lobby");
|
||||
}
|
||||
|
||||
public static void switchServer(Player p, String targetServerIp) {
|
||||
p.sendPluginMessage(Main.getInstance(), "BeeSwitch", targetServerIp.getBytes(StandardCharsets.UTF_8));
|
||||
}
|
||||
|
||||
public static void goAFK(Player p) {
|
||||
teleport(p, "SYSTEM.LIMBO");
|
||||
}
|
||||
|
||||
public static void backToLobby(Player p) {
|
||||
teleport(p, "lobby");
|
||||
}
|
||||
|
||||
public static void switchServer(Player p, String targetServerIp) {
|
||||
p.sendPluginMessage(Main.getInstance(), "BeeSwitch", targetServerIp.getBytes(StandardCharsets.UTF_8));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -1,20 +1,20 @@
|
||||
package org.cn2b2t.core.modules.users;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.scheduler.BukkitRunnable;
|
||||
import org.cn2b2t.core.Main;
|
||||
import org.cn2b2t.core.events.UserLoadedEvent;
|
||||
import org.cn2b2t.core.managers.utils.DataManager;
|
||||
import org.cn2b2t.core.managers.utils.UserManager;
|
||||
import org.cn2b2t.core.managers.utils.scoreboard.CeramicScoreboard;
|
||||
import org.cn2b2t.core.managers.utils.scoreboard.ScoreBoardRender;
|
||||
import org.cn2b2t.core.modules.gui.GUI;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.scheduler.BukkitRunnable;
|
||||
import org.cn2b2t.core.utils.UUIDUtils;
|
||||
import org.spigotmc.AsyncCatcher;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.sql.ResultSet;
|
||||
import java.util.*;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
|
||||
@@ -22,6 +22,10 @@ public class User {
|
||||
|
||||
private final Player player;
|
||||
|
||||
private int inkID;
|
||||
private UUID mojangUUID;
|
||||
private boolean onlineMode;
|
||||
|
||||
private Map<String, Object> handler = new HashMap<>();
|
||||
|
||||
public GUI openedGUI;
|
||||
@@ -50,6 +54,34 @@ public class User {
|
||||
});
|
||||
|
||||
|
||||
try {
|
||||
ResultSet accountResult = DataManager.getConnection().SQLquery("nl2_users",
|
||||
"uuid", player.getUniqueId().toString().replace("-", ""));
|
||||
if (accountResult != null) {
|
||||
if (accountResult.next()) {
|
||||
User.this.inkID = accountResult.getInt("id");
|
||||
String muuid = accountResult.getString("mojanguuid");
|
||||
if (muuid != null && !muuid.isEmpty() && !muuid.equalsIgnoreCase("null")) {
|
||||
User.this.mojangUUID = UUIDUtils.toUUID(muuid);
|
||||
}
|
||||
User.this.onlineMode = mojangUUID != null;
|
||||
} else {
|
||||
accountResult.close();
|
||||
throw new NullPointerException("Cannot find user profile. name=" + player.getName() + " uuid=" + player.getUniqueId());
|
||||
}
|
||||
accountResult.close();
|
||||
}
|
||||
} catch (Exception ex) {
|
||||
ex.printStackTrace();
|
||||
new BukkitRunnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
getPlayer().kickPlayer("关键信息加载失败,请联系管理员\nKey information loading failed. Please turn to administrator.");
|
||||
}
|
||||
}.runTask(Main.getInstance());
|
||||
}
|
||||
|
||||
|
||||
new BukkitRunnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
@@ -71,6 +103,17 @@ public class User {
|
||||
}
|
||||
|
||||
|
||||
public boolean isFullLoaded() {
|
||||
return fullLoaded;
|
||||
}
|
||||
|
||||
public boolean isOnlineMode() {
|
||||
return onlineMode;
|
||||
}
|
||||
|
||||
public UUID getMojangUUID() {
|
||||
return mojangUUID;
|
||||
}
|
||||
|
||||
public List<CeramicScoreboard> getScoreboards() {
|
||||
return this.scoreboards;
|
||||
@@ -119,6 +162,10 @@ public class User {
|
||||
}
|
||||
}
|
||||
|
||||
public int getInkID() {
|
||||
return inkID;
|
||||
}
|
||||
|
||||
public <T> T getHandler(String s, Class T) {
|
||||
if (isUnregistered()) {
|
||||
AsyncCatcher.catchOp("handler get when user unloaded");
|
||||
|
||||
@@ -0,0 +1,25 @@
|
||||
package org.cn2b2t.core.utils;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
public class UUIDUtils {
|
||||
|
||||
public static UUID toUUID(String s){
|
||||
if(s.length() == 36){
|
||||
return UUID.fromString(s);
|
||||
} else {
|
||||
StringBuilder sb = new StringBuilder(36);
|
||||
sb.append(s, 0, 8)
|
||||
.append('-')
|
||||
.append(s, 8, 12)
|
||||
.append('-')
|
||||
.append(s, 12, 16)
|
||||
.append('-')
|
||||
.append(s, 16, 20)
|
||||
.append('-')
|
||||
.append(s.substring(20));
|
||||
return UUID.fromString(sb.toString());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user