1
mirror of https://github.com/CarmJos/cn2b2t-project.git synced 2026-06-04 08:48:16 +08:00

完善User

This commit is contained in:
carm
2020-05-27 00:08:58 +08:00
parent 80443a30ca
commit d678ce3750
11 changed files with 328 additions and 45 deletions
@@ -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());
}
}
}