1
mirror of https://github.com/CarmJos/cn2b2t-project.git synced 2024-09-19 22:05:45 +00: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

View File

@ -6,6 +6,8 @@
<sourceOutputDir name="target/generated-sources/annotations" />
<sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
<outputRelativeToContentRoot value="true" />
<module name="ImperialGuards" />
<module name="2b2t-proxy" />
<module name="2b2t-core" />
<module name="2b2t-faction" />
<module name="2b2t-common" />

View File

@ -8,5 +8,9 @@
<file url="file://$PROJECT_DIR$/2b2t-core/src/main/resources" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/2b2t-faction/src/main/java" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/2b2t-faction/src/main/resources" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/2b2t-proxy/src/main/java" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/2b2t-proxy/src/main/resources" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/ImperialGuards/src/main/java" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/ImperialGuards/src/main/resources" charset="UTF-8" />
</component>
</project>

View File

@ -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));
}
}

View File

@ -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");

View File

@ -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());
}
}
}

15
2b2t-proxy/pom.xml Normal file
View File

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>cn2b2t</artifactId>
<groupId>org.cn2b2t</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>2b2t-proxy</artifactId>
</project>

61
ImperialGuards/pom.xml Normal file
View File

@ -0,0 +1,61 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>cn2b2t</artifactId>
<groupId>org.cn2b2t</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>ImperialGuards</artifactId>
<packaging>jar</packaging>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>8</source>
<target>8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.comphenix</groupId>
<artifactId>ProtocolLib</artifactId>
<version>4.3.0</version>
<scope>system</scope>
<systemPath>${basedir}/../_lib/ProtocolLib.jar</systemPath>
</dependency>
<dependency>
<groupId>com.comphenix</groupId>
<artifactId>PacketWrapper</artifactId>
<version>1.0</version>
<scope>system</scope>
<systemPath>${basedir}/../_lib/PacketWrapper.jar</systemPath>
</dependency>
<dependency>
<groupId>org.spigotmc</groupId>
<artifactId>spigot</artifactId>
<version>1.12.2-R0.1-SNAPSHOT</version>
<systemPath>${basedir}/../_lib/spigot.jar</systemPath>
<scope>system</scope>
</dependency>
<dependency>
<groupId>org.cn2b2t</groupId>
<artifactId>2b2t-core</artifactId>
<version>1.0-SNAPSHOT</version>
<scope>compile</scope>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,46 @@
package cn.moci.ig;
import cn.moci.ig.commands.IG;
import com.comphenix.protocol.ProtocolLibrary;
import com.comphenix.protocol.ProtocolManager;
import org.bukkit.ChatColor;
import org.bukkit.plugin.java.JavaPlugin;
public class Main extends JavaPlugin {
//<editor-fold defaultstate="collapsed" desc="定义和基础方法">
public static String pluginName = "ImperialGuards";
public static String pluginVersion = "dev-SNAPSHOT";
private static Main instance;
public ProtocolManager protocolManager;
public static Main getInstance() {
return Main.instance;
}
public static String color(final String text) {
return text.replaceAll("&", "§");
}
private void pluginMessage(String s) {
this.getServer().getConsoleSender().sendMessage(ChatColor.DARK_GRAY + "[" + ChatColor.RED + "!" + ChatColor.DARK_GRAY + "] " + ChatColor.AQUA + pluginName + " " + ChatColor.WHITE + pluginVersion + ChatColor.GRAY + s);
}
//</editor-fold>
@Override
public void onEnable() {
protocolManager = ProtocolLibrary.getProtocolManager();
Main.instance = this;
regCmds();
pluginMessage("已启用。");
}
private void regCmds() {
this.getCommand("ig").setExecutor(new IG());
}
}

View File

@ -0,0 +1,66 @@
package cn.moci.ig.commands;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.cn2b2t.core.managers.utils.ServersManager;
import org.cn2b2t.core.utils.ColorParser;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;
/**
* 最终解释权归 墨瓷工作室
*
* @author Cam, LSeng.
*/
public class IG implements CommandExecutor {
public static List<String> queue = new ArrayList<>();
@Override
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
if (sender instanceof Player) {
return true;
} // /IG condition KUMR killaura 1000 5 -1 Hitbox(Killaura) kick %(Player) #ac Task #00001 for IG generated an exception
if (args.length < 1) {
return true;
}
switch (args[0]) {
case "notify": {
// /IG notify {player} HackType
if (args.length < 2) {
return true;
}
String username = args[1];
String reason = Arrays.stream(args, 2, args.length - 1).collect(Collectors.joining());
return true;
}
case "punish": {
// /IG punish {player} HackType
String username = args[1];
if (Bukkit.getPlayer(username) != null) {
Player p = Bukkit.getPlayer(username);
if (!p.hasPermission("ig.bypass")) {
ServersManager.goAFK(p);
for (Player onlinePlayer : Bukkit.getOnlinePlayers()) {
onlinePlayer.sendMessage(ColorParser.parse("&7玩家 &f" + p.getName() + " &7因&c疑似作弊&7被移出本局游戏。"));
onlinePlayer.sendMessage(ColorParser.parse("&7保持良好游戏环境需要各位的努力感谢各位的支持。"));
}
}
}
return true;
}
default: {
return true;
}
}
}
}

View File

@ -0,0 +1,8 @@
name: ImperialGuards
main: cn.moci.ig.Main
version: 1.0.0 - SNAPSHOT
author: Moci
depend: [ProtocolLib]
commands:
ig:
aliases: [imperialguards]

View File

@ -13,6 +13,8 @@
<module>2b2t-common</module>
<module>2b2t-core</module>
<module>2b2t-faction</module>
<module>2b2t-proxy</module>
<module>ImperialGuards</module>
</modules>
<properties>