mirror of
https://github.com/CarmJos/cn2b2t-project.git
synced 2024-09-19 22:05:45 +00:00
完善User
This commit is contained in:
parent
80443a30ca
commit
d678ce3750
@ -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" />
|
||||
|
@ -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>
|
@ -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;
|
||||
@ -93,6 +94,12 @@ public class ServersManager
|
||||
}.runTaskLater(Main.getInstance(), 20L * t);
|
||||
}
|
||||
|
||||
|
||||
|
||||
public static void goAFK(Player p) {
|
||||
teleport(p, "SYSTEM.LIMBO");
|
||||
}
|
||||
|
||||
public static void backToLobby(Player p) {
|
||||
teleport(p, "lobby");
|
||||
}
|
||||
|
@ -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");
|
||||
|
25
2b2t-core/src/main/java/org.cn2b2t.core/utils/UUIDUtils.java
Normal file
25
2b2t-core/src/main/java/org.cn2b2t.core/utils/UUIDUtils.java
Normal 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
15
2b2t-proxy/pom.xml
Normal 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
61
ImperialGuards/pom.xml
Normal 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>
|
46
ImperialGuards/src/main/java/cn/moci/ig/Main.java
Normal file
46
ImperialGuards/src/main/java/cn/moci/ig/Main.java
Normal 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());
|
||||
}
|
||||
|
||||
|
||||
}
|
66
ImperialGuards/src/main/java/cn/moci/ig/commands/IG.java
Normal file
66
ImperialGuards/src/main/java/cn/moci/ig/commands/IG.java
Normal 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;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
8
ImperialGuards/src/main/resources/plugin.yml
Normal file
8
ImperialGuards/src/main/resources/plugin.yml
Normal 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]
|
Loading…
Reference in New Issue
Block a user