mirror of
https://e.coding.net/circlecloud/CTZServerBridge.git
synced 2024-12-27 19:08:46 +00:00
use CTZServerCommon...
Signed-off-by: 502647092 <jtb1@163.com>
This commit is contained in:
parent
4b11a9ddfe
commit
7231ef6cd3
7
pom.xml
7
pom.xml
@ -28,6 +28,7 @@
|
|||||||
<artifactId>maven-shade-plugin</artifactId>
|
<artifactId>maven-shade-plugin</artifactId>
|
||||||
<version>2.3</version>
|
<version>2.3</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
|
<createDependencyReducedPom>false</createDependencyReducedPom>
|
||||||
<minimizeJar>true</minimizeJar>
|
<minimizeJar>true</minimizeJar>
|
||||||
<artifactSet>
|
<artifactSet>
|
||||||
<includes>
|
<includes>
|
||||||
@ -73,6 +74,12 @@
|
|||||||
<type>jar</type>
|
<type>jar</type>
|
||||||
<version>1.0</version>
|
<version>1.0</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.citycraft</groupId>
|
||||||
|
<artifactId>CTZServerCommon</artifactId>
|
||||||
|
<type>jar</type>
|
||||||
|
<version>1.0</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<properties>
|
<properties>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
package cn.citycraft.CTZServerBridge;
|
package cn.citycraft.CTZServerBridge;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.command.ConsoleCommandSender;
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
import org.bukkit.plugin.PluginManager;
|
import org.bukkit.plugin.PluginManager;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
import cn.citycraft.CTZServerBridge.listen.PlayerListen;
|
import cn.citycraft.CTZServerBridge.listen.PlayerListen;
|
||||||
import cn.citycraft.PluginHelper.sql.KeyValue;
|
import cn.citycraft.CTZServerCommon.CTZAuth;
|
||||||
import cn.citycraft.PluginHelper.sql.MySQLHelper;
|
import cn.citycraft.PluginHelper.config.FileConfig;
|
||||||
import cn.citycraft.PluginHelper.sql.SQLHelper;
|
import cn.citycraft.PluginHelper.sql.SQLHelper;
|
||||||
|
|
||||||
public class CTZServerBridge extends JavaPlugin {
|
public class CTZServerBridge extends JavaPlugin {
|
||||||
|
|
||||||
ConsoleCommandSender ccs;
|
ConsoleCommandSender ccs;
|
||||||
SQLHelper sql;
|
SQLHelper sql;
|
||||||
|
public FileConfig config;
|
||||||
|
|
||||||
public SQLHelper getSql() {
|
public SQLHelper getSql() {
|
||||||
return sql;
|
return sql;
|
||||||
@ -23,7 +23,7 @@ public class CTZServerBridge extends JavaPlugin {
|
|||||||
@Override
|
@Override
|
||||||
public void onDisable() {
|
public void onDisable() {
|
||||||
super.onDisable();
|
super.onDisable();
|
||||||
}
|
};
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
@ -31,6 +31,11 @@ public class CTZServerBridge extends JavaPlugin {
|
|||||||
this.initListener();
|
this.initListener();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onLoad() {
|
||||||
|
config = new FileConfig(this);
|
||||||
|
}
|
||||||
|
|
||||||
private void initListener() {
|
private void initListener() {
|
||||||
PluginManager pm = Bukkit.getPluginManager();
|
PluginManager pm = Bukkit.getPluginManager();
|
||||||
pm.registerEvents(new PlayerListen(this), this);
|
pm.registerEvents(new PlayerListen(this), this);
|
||||||
@ -40,32 +45,6 @@ public class CTZServerBridge extends JavaPlugin {
|
|||||||
* 初始化数据库
|
* 初始化数据库
|
||||||
*/
|
*/
|
||||||
void initDatabase() {
|
void initDatabase() {
|
||||||
String dbtable = "ctzserver";
|
CTZAuth.init(sql, "127.0.0.1", 3306, "ctzserver", "root", "325325");
|
||||||
ccs.sendMessage(ChatColor.GREEN + "初始化数据库连接...");
|
|
||||||
sql = new MySQLHelper("127.0.0.1", 3306, "minecraft", "root", "325325");
|
|
||||||
if (!sql.dbConnection()) {
|
|
||||||
ccs.sendMessage(ChatColor.RED + "数据库连接失败...");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ccs.sendMessage(ChatColor.GREEN + "数据库连接成功,检查数据表是否存在...");
|
|
||||||
if (!sql.isTableExists(dbtable)) {
|
|
||||||
ccs.sendMessage(ChatColor.RED + "数据表不存在,新建表" + dbtable + "...");
|
|
||||||
KeyValue kv = new KeyValue("player", "VARCHAR(16) NOT NULL")
|
|
||||||
.add("password", "VARCHAR(50) NOT NULL")
|
|
||||||
.add("ip", "VARCHAR(40) NOT NULL DEFAULT '127.0.0.1'")
|
|
||||||
.add("lastloginout", "BIGINT(20) NOT NULL DEFAULT 0")
|
|
||||||
.add("x", "DOUBLE NOT NULL DEFAULT 0")
|
|
||||||
.add("y", "DOUBLE NOT NULL DEFAULT 0")
|
|
||||||
.add("z", "DOUBLE NOT NULL DEFAULT 0")
|
|
||||||
.add("email", "VARCHAR(50) NOT NULL DEFAULT 'mc@mc.com'")
|
|
||||||
.add("world", "VARCHAR(20) DEFAULT 'world'")
|
|
||||||
.add("islogged", "SMALLINT(6) NOT NULL DEFAULT 0")
|
|
||||||
.add("allowlogin", "SMALLINT(6) NOT NULL DEFAULT 0");
|
|
||||||
String Conditions = "UNIQUE (`player`)";
|
|
||||||
if (!sql.createTables(dbtable, kv, Conditions))
|
|
||||||
ccs.sendMessage(ChatColor.RED + "数据表 " + dbtable + " 创建失败,请尝试手动创建并重启服务器...");
|
|
||||||
else
|
|
||||||
ccs.sendMessage(ChatColor.GREEN + "数据表 " + dbtable + " 创建成功...");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,11 +3,13 @@ package cn.citycraft.CTZServerBridge.listen;
|
|||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
import org.bukkit.event.player.PlayerLoginEvent;
|
import org.bukkit.event.player.PlayerLoginEvent;
|
||||||
import org.bukkit.event.player.PlayerLoginEvent.Result;
|
import org.bukkit.event.player.PlayerLoginEvent.Result;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
import cn.citycraft.CTZServerBridge.CTZServerBridge;
|
import cn.citycraft.CTZServerBridge.CTZServerBridge;
|
||||||
import cn.citycraft.PluginHelper.sql.KeyValue;
|
import cn.citycraft.CTZServerCommon.CTZAuth;
|
||||||
|
|
||||||
public class PlayerListen implements Listener {
|
public class PlayerListen implements Listener {
|
||||||
static final String TableName = "ctzserver";
|
static final String TableName = "ctzserver";
|
||||||
@ -20,54 +22,25 @@ public class PlayerListen implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void Join(PlayerLoginEvent e) {
|
public void PlayerJoin(PlayerJoinEvent e) {
|
||||||
Player p = e.getPlayer();
|
Player p = e.getPlayer();
|
||||||
String result = plugin.getSql().dbSelectFirst(TableName, "islogged", new KeyValue(UserField, p.getName()));
|
p.sendMessage("§b欢迎回来,已帮您已经自动登录到服务器!");
|
||||||
if (result == null && !result.equalsIgnoreCase("1")) {
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void PlayerLogin(PlayerLoginEvent e) {
|
||||||
|
Player p = e.getPlayer();
|
||||||
|
if (CTZAuth.checkLastLogout(p.getName(), 10))
|
||||||
|
return;
|
||||||
|
if (!CTZAuth.allowLogin(p.getName(), plugin.config.getBoolean("checkip") ? p.getAddress().getAddress().getHostAddress() : null)) {
|
||||||
e.setKickMessage("§6[§bCTZLS§6] §c禁止入服 请使用服务器专用启动器进入游戏!");
|
e.setKickMessage("§6[§bCTZLS§6] §c禁止入服 请使用服务器专用启动器进入游戏!");
|
||||||
e.setResult(Result.KICK_WHITELIST);
|
e.setResult(Result.KICK_WHITELIST);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void PlayerQuit(PlayerQuitEvent e) {
|
||||||
|
Player p = e.getPlayer();
|
||||||
|
CTZAuth.setLastLogout(p.getName(), System.currentTimeMillis());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// private long getNowTime() {
|
|
||||||
// return System.currentTimeMillis() / 1000;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @EventHandler
|
|
||||||
// public void PlayerLogin(PlayerLoginEvent e) {
|
|
||||||
// String name = e.getPlayer().getName().toLowerCase();
|
|
||||||
// long lasttime = lastquittime.get(name) == null ? 0 : lastquittime.get(name);
|
|
||||||
// e.setKickMessage("§6[§bCTZLS§6] §c禁止入服 请使用服务器专用启动器进入游戏!");
|
|
||||||
// if (getNowTime() - lasttime < Config.getInstance().getInt("server.timeout")) {
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// if (CTZLoginQueue.canLogin(name, e.getAddress().getHostAddress())) {
|
|
||||||
// return;
|
|
||||||
// } else {
|
|
||||||
// if (CTZLoginQueue.canLogin(name))
|
|
||||||
// if (CTZLoginQueue.isCheckIP())
|
|
||||||
// e.setKickMessage("§6[§bCTZLS§6] §c禁止入服 申请登录的IP与客户端IP不同!");
|
|
||||||
// else
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// if (!Config.getInstance().getBoolean("config.forceclient"))
|
|
||||||
// return;
|
|
||||||
// e.setResult(Result.KICK_WHITELIST);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @EventHandler(priority = EventPriority.LOWEST)
|
|
||||||
// public void PlayerJoin(PlayerJoinEvent e) {
|
|
||||||
// String name = e.getPlayer().getName().toLowerCase();
|
|
||||||
// if (lastquittime.containsKey(name)) {
|
|
||||||
// API.forceLogin(e.getPlayer());
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
// if (CTZLoginQueue.Login(name)) {
|
|
||||||
// API.forceLogin(e.getPlayer());
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @EventHandler
|
|
||||||
// public void PlayerQuit(PlayerQuitEvent e) {
|
|
||||||
// lastquittime.put(e.getPlayer().getName().toLowerCase(), getNowTime());
|
|
||||||
// }
|
|
Loading…
Reference in New Issue
Block a user