keepinv supoort
This commit is contained in:
parent
99fa769314
commit
64afcad8c7
@ -1,5 +1,6 @@
|
|||||||
package expvintl.tools;
|
package expvintl.tools;
|
||||||
|
|
||||||
|
import expvintl.tools.listeners.LoginHandler;
|
||||||
import org.bukkit.*;
|
import org.bukkit.*;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
@ -8,7 +9,6 @@ import org.bukkit.entity.Player;
|
|||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
|
||||||
import java.math.BigInteger;
|
import java.math.BigInteger;
|
||||||
import java.security.MessageDigest;
|
import java.security.MessageDigest;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -20,37 +20,57 @@ import java.util.regex.Pattern;
|
|||||||
public final class Tools extends JavaPlugin {
|
public final class Tools extends JavaPlugin {
|
||||||
private LoginHandler loginHandler;
|
private LoginHandler loginHandler;
|
||||||
public static YamlConfiguration loginConfig;
|
public static YamlConfiguration loginConfig;
|
||||||
|
public static YamlConfiguration settingsCfg;
|
||||||
|
private boolean enableLogin;
|
||||||
//玩家登录数据
|
//玩家登录数据
|
||||||
private final String cfgPath=getDataFolder().getPath()+"/PlayerLoginData.yml";
|
private final String loginDataPath =getDataFolder().getPath()+"/PlayerLoginData.yml";
|
||||||
|
private final String settingsPath=getDataFolder().getPath()+"/settings.yml";
|
||||||
Logger logger=getLogger();
|
Logger logger=getLogger();
|
||||||
//传送请求队列
|
//传送请求队列
|
||||||
private final Map<String,String> reqQueue=new HashMap<>();
|
private final Map<String,String> reqQueue=new HashMap<>();
|
||||||
|
private void initConfigs(){
|
||||||
|
if(!getDataFolder().exists()) getDataFolder().mkdir();
|
||||||
|
File loginData=new File(this.loginDataPath);
|
||||||
|
File settingsPath=new File(this.settingsPath);
|
||||||
|
try {
|
||||||
|
if(!loginData.exists()) {
|
||||||
|
if (!loginData.createNewFile()) {
|
||||||
|
logger.warning("无法创建登录数据文件!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!settingsPath.exists()){
|
||||||
|
if (!settingsPath.createNewFile()) {
|
||||||
|
logger.warning("无法创建配置文件!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//初始化参数
|
||||||
|
settingsCfg=new YamlConfiguration();
|
||||||
|
settingsCfg.load(this.settingsPath);
|
||||||
|
settingsCfg.set("enableLogin",true);
|
||||||
|
settingsCfg.save(settingsPath);
|
||||||
|
settingsCfg=null;
|
||||||
|
}
|
||||||
|
loginConfig = new YamlConfiguration();
|
||||||
|
settingsCfg=new YamlConfiguration();
|
||||||
|
settingsCfg.load(this.settingsPath);
|
||||||
|
loginConfig.load(this.loginDataPath);
|
||||||
|
logger.info("已加载配置!");
|
||||||
|
enableLogin=settingsCfg.getBoolean("enableLogin");
|
||||||
|
if(enableLogin){
|
||||||
|
//注册事件监听器
|
||||||
|
loginHandler=new LoginHandler(this);
|
||||||
|
getServer().getPluginManager().registerEvents(loginHandler,this);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.warning(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
// Plugin startup logic
|
// Plugin startup logic
|
||||||
logger.info("expvintl:Tools 插件已启用!");
|
logger.info("expvintl:Tools 插件已启用!");
|
||||||
loginHandler=new LoginHandler(this);
|
initConfigs();
|
||||||
getServer().getPluginManager().registerEvents(loginHandler,this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoad() {
|
|
||||||
if(!getDataFolder().exists()) getDataFolder().mkdir();
|
|
||||||
File conf=new File(cfgPath);
|
|
||||||
if(!conf.exists()) {
|
|
||||||
try {
|
|
||||||
if(!conf.createNewFile()) return;
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.warning(e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
loginConfig = new YamlConfiguration();
|
|
||||||
loginConfig.load(cfgPath);
|
|
||||||
logger.info("已加载配置!");
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.warning(e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -62,6 +82,10 @@ public final class Tools extends JavaPlugin {
|
|||||||
}
|
}
|
||||||
switch(label) {
|
switch(label) {
|
||||||
case "reg":
|
case "reg":
|
||||||
|
if(!enableLogin) {
|
||||||
|
sender.sendMessage("未启用登录功能!");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
if (args.length == 2) {
|
if (args.length == 2) {
|
||||||
if (loginHandler.isRegistered(sender.getName())||loginHandler.isLogged(sender.getName())) {
|
if (loginHandler.isRegistered(sender.getName())||loginHandler.isLogged(sender.getName())) {
|
||||||
sender.sendMessage("你已经注册过了!");
|
sender.sendMessage("你已经注册过了!");
|
||||||
@ -83,7 +107,7 @@ public final class Tools extends JavaPlugin {
|
|||||||
MessageDigest md=MessageDigest.getInstance("MD5");
|
MessageDigest md=MessageDigest.getInstance("MD5");
|
||||||
String passMd=new BigInteger(1,md.digest(args[0].getBytes())).toString(16);
|
String passMd=new BigInteger(1,md.digest(args[0].getBytes())).toString(16);
|
||||||
loginConfig.set(sender.getName(), passMd);
|
loginConfig.set(sender.getName(), passMd);
|
||||||
loginConfig.save(cfgPath);
|
loginConfig.save(loginDataPath);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.warning(e.getMessage());
|
logger.warning(e.getMessage());
|
||||||
sender.sendMessage("密码保存失败!");
|
sender.sendMessage("密码保存失败!");
|
||||||
@ -98,6 +122,10 @@ public final class Tools extends JavaPlugin {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
case "l":
|
case "l":
|
||||||
|
if(!enableLogin) {
|
||||||
|
sender.sendMessage("未启用登录功能!");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
if(args.length==1){
|
if(args.length==1){
|
||||||
if(loginHandler.isLogged(sender.getName())){
|
if(loginHandler.isLogged(sender.getName())){
|
||||||
sender.sendMessage("你似乎已经登录过了?");
|
sender.sendMessage("你似乎已经登录过了?");
|
||||||
@ -129,6 +157,10 @@ public final class Tools extends JavaPlugin {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
case "cp":
|
case "cp":
|
||||||
|
if(!enableLogin) {
|
||||||
|
sender.sendMessage("未启用登录功能!");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
if(args.length==1){
|
if(args.length==1){
|
||||||
if(loginHandler.isRegistered(sender.getName())&&loginHandler.isLogged(sender.getName())){
|
if(loginHandler.isRegistered(sender.getName())&&loginHandler.isLogged(sender.getName())){
|
||||||
if (args[0].length() < 6 || args[0].length() > 16) {
|
if (args[0].length() < 6 || args[0].length() > 16) {
|
||||||
@ -143,7 +175,7 @@ public final class Tools extends JavaPlugin {
|
|||||||
MessageDigest md=MessageDigest.getInstance("MD5");
|
MessageDigest md=MessageDigest.getInstance("MD5");
|
||||||
String passMd=new BigInteger(1,md.digest(args[0].getBytes())).toString(16);
|
String passMd=new BigInteger(1,md.digest(args[0].getBytes())).toString(16);
|
||||||
loginConfig.set(sender.getName(),passMd);
|
loginConfig.set(sender.getName(),passMd);
|
||||||
loginConfig.save(cfgPath);
|
loginConfig.save(loginDataPath);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.warning(e.getMessage());
|
logger.warning(e.getMessage());
|
||||||
sender.sendMessage("密码保存失败!");
|
sender.sendMessage("密码保存失败!");
|
||||||
@ -158,40 +190,6 @@ public final class Tools extends JavaPlugin {
|
|||||||
sender.sendMessage("缺少参数!");
|
sender.sendMessage("缺少参数!");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
case "kill":
|
|
||||||
if(args.length>0){
|
|
||||||
sender.sendMessage(args[0]+" 死了");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
player.setHealth(0);
|
|
||||||
return true;
|
|
||||||
case "tp":
|
|
||||||
if(args.length==4){
|
|
||||||
try {
|
|
||||||
double x = Double.parseDouble(args[1]);
|
|
||||||
double y = Double.parseDouble(args[2]);
|
|
||||||
double z = Double.parseDouble(args[3]);
|
|
||||||
player.teleport(new Location(player.getWorld(),x,y,z));
|
|
||||||
getServer().broadcastMessage(String.format("%s 传送到了 X:%.2f Y:%.2f Z:%.2f",player.getName(),x,y,z));
|
|
||||||
}catch (NumberFormatException f) {
|
|
||||||
sender.sendMessage("错误的数字格式!");
|
|
||||||
}
|
|
||||||
}else if(args.length==3) {
|
|
||||||
try {
|
|
||||||
double x = Double.parseDouble(args[0]);
|
|
||||||
double y = Double.parseDouble(args[1]);
|
|
||||||
double z = Double.parseDouble(args[2]);
|
|
||||||
player.teleport(new Location(player.getWorld(), x, y, z));
|
|
||||||
getServer().broadcastMessage(String.format("%s 传送到了 X:%.2f Y:%.2f Z:%.2f", player.getName(), x, y, z));
|
|
||||||
} catch (NumberFormatException f) {
|
|
||||||
sender.sendMessage("错误的数字格式!");
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
sender.sendMessage("缺少应有的坐标参数!");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
|
|
||||||
case "tpa":
|
case "tpa":
|
||||||
if(args.length==1){
|
if(args.length==1){
|
||||||
Player target=getServer().getPlayer(args[0]);
|
Player target=getServer().getPlayer(args[0]);
|
||||||
@ -263,6 +261,18 @@ public final class Tools extends JavaPlugin {
|
|||||||
}
|
}
|
||||||
sender.sendMessage("没有传送请求或请求已过期!");
|
sender.sendMessage("没有传送请求或请求已过期!");
|
||||||
return true;
|
return true;
|
||||||
|
case "keepinv":
|
||||||
|
if(args.length==1){
|
||||||
|
Bukkit.getWorlds().forEach(world -> {
|
||||||
|
boolean result=Boolean.parseBoolean(args[0]);
|
||||||
|
world.setGameRule(GameRule.KEEP_INVENTORY,result);
|
||||||
|
sender.sendMessage(String.format("已为 %s %s死亡不掉落",world.getName(), Boolean.TRUE.equals(world.getGameRuleValue(GameRule.KEEP_INVENTORY)) ?"开启":"关闭"));
|
||||||
|
});
|
||||||
|
}else{
|
||||||
|
sender.sendMessage("参数不够!");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package expvintl.tools;
|
package expvintl.tools.listeners;
|
||||||
|
|
||||||
|
import expvintl.tools.Tools;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.configuration.file.YamlConfiguration;
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
@ -15,7 +16,7 @@ import java.util.List;
|
|||||||
|
|
||||||
public class LoginHandler implements Listener {
|
public class LoginHandler implements Listener {
|
||||||
private final List<String> loggedPlayer=new ArrayList<>();
|
private final List<String> loggedPlayer=new ArrayList<>();
|
||||||
private final YamlConfiguration cfg=Tools.loginConfig;
|
private final YamlConfiguration cfg= Tools.loginConfig;
|
||||||
private final Plugin plugin;
|
private final Plugin plugin;
|
||||||
public LoginHandler(Plugin plugin){
|
public LoginHandler(Plugin plugin){
|
||||||
this.plugin=plugin;
|
this.plugin=plugin;
|
@ -5,12 +5,10 @@ api-version: 1.15
|
|||||||
authors: [ expvintl ]
|
authors: [ expvintl ]
|
||||||
description: Tools
|
description: Tools
|
||||||
commands:
|
commands:
|
||||||
kill: #指令名
|
keepinv:
|
||||||
description: "杀死自己" #指令的注解
|
description: "开关所有世界的死亡不掉落"
|
||||||
usage: "用法: /kill"
|
usage: "用法: /keepInv [true/false]"
|
||||||
tp:
|
permission: op
|
||||||
description: "传送到某个位置"
|
|
||||||
usage: "用法: /tp <玩家名> <x> <y> <z>"
|
|
||||||
reg:
|
reg:
|
||||||
description: "注册用户"
|
description: "注册用户"
|
||||||
usage: "用法: /reg 密码 确认密码"
|
usage: "用法: /reg 密码 确认密码"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user