diff --git a/pom.xml b/pom.xml
index e02a3bae..7182eff4 100644
--- a/pom.xml
+++ b/pom.xml
@@ -13,6 +13,11 @@
http://dev.bukkit.org/bukkit-plugins/authme-reloaded/
+
+ AuthMe-Team
+ https://github.com/AuthMe-Team
+
+
scm:git:https://github.com/Xephi/AuthMeReloaded.git
scm:git:git@github.com:Xephi/AuthMeReloaded.git
@@ -56,6 +61,14 @@
*.yml
+
+ ./messages/
+ false
+ ${basedir}/src/main/resources/messages/
+
+ *.yml
+
+
@@ -74,13 +87,12 @@
- com.maxmind.geoip:*
- javax.mail:*
- com.sun.mail:*
- com.comphenix.attribute:*
- org.mcstats.*:*
- com.zaxxer:*
- org.slf4j:*
+ com.zaxxer:HikariCP
+ org.slf4j:slf4j-simple
+ com.maxmind.geoip:geoip-api
+ com.sun.mail:javax.mail
+ com.comphenix.attribute:AttributeStorage
+ org.mcstats.bukkit:metrics
@@ -164,42 +176,27 @@
http://repo.mcstats.org/content/repositories/snapshots/
+
+
+ hikaricp-log4j-releases
+ http://nexus-sgdc3.rhcloud.com/nexus/content/repositories/hikaricp-log4j-releases/
+
+
-
-
- mysql
- mysql-connector-java
- 5.1.36
-
-
- org.slf4j
- slf4j-simple
- 1.7.12
- compile
-
+
com.zaxxer
HikariCP
2.4.1
compile
-
-
- org.slf4j
- slf4j-api
-
-
- org.slf4j
- slf4j-simple
-
-
-
+
org.xerial
sqlite-jdbc
@@ -207,7 +204,13 @@
compile
-
+
+
+ javax.mail
+ javax.mail-api
+ 1.5.4
+ compile
+
com.sun.mail
javax.mail
@@ -557,9 +560,7 @@
simplechestlock
-
- com.webkonsept.bukkit.simplechestlock
-
+ com.webkonsept.bukkit.simplechestlock
commandbook
diff --git a/src/main/java/fr/xephi/authme/AuthMe.java b/src/main/java/fr/xephi/authme/AuthMe.java
index 7ed3dd9f..131991dc 100644
--- a/src/main/java/fr/xephi/authme/AuthMe.java
+++ b/src/main/java/fr/xephi/authme/AuthMe.java
@@ -10,6 +10,7 @@ import java.io.OutputStream;
import java.lang.reflect.InvocationTargetException;
import java.net.URL;
import java.net.URLConnection;
+import java.sql.SQLException;
import java.util.Calendar;
import java.util.Collection;
import java.util.Date;
@@ -34,6 +35,7 @@ import org.mcstats.Metrics;
import com.earth2me.essentials.Essentials;
import com.maxmind.geoip.LookupService;
import com.onarandombox.MultiverseCore.MultiverseCore;
+import com.zaxxer.hikari.pool.PoolInitializationException;
import fr.xephi.authme.api.API;
import fr.xephi.authme.api.NewAPI;
@@ -214,7 +216,18 @@ public class AuthMe extends JavaPlugin {
else ConsoleLogger.showError("Error while performing the backup!");
}
- setupDatabase();
+ try {
+ setupDatabase();
+ } catch (ClassNotFoundException nfe) {
+ ConsoleLogger.showError("Fatal error occurred! Authme initialization ABORTED!");
+ return;
+ } catch (SQLException sqle) {
+ ConsoleLogger.showError("Fatal error occurred! Authme initialization ABORTED!");
+ return;
+ } catch (PoolInitializationException pie) {
+ ConsoleLogger.showError("Fatal error occurred! Authme initialization ABORTED!");
+ return;
+ }
dataManager = new DataManager(this);
@@ -800,7 +813,7 @@ public class AuthMe extends JavaPlugin {
return realIP;
}
- public void setupDatabase() {
+ public void setupDatabase() throws ClassNotFoundException, PoolInitializationException, SQLException {
/*
* Backend MYSQL - FILE - SQLITE
*/
diff --git a/src/main/java/fr/xephi/authme/DataManager.java b/src/main/java/fr/xephi/authme/DataManager.java
index 8f9db6d8..472a29e8 100644
--- a/src/main/java/fr/xephi/authme/DataManager.java
+++ b/src/main/java/fr/xephi/authme/DataManager.java
@@ -134,10 +134,13 @@ public class DataManager {
playerFile.delete();
i++;
} else {
- playerFile = new File(plugin.ess.getDataFolder() + File.separator + "userdata" + File.separator + Bukkit.getOfflinePlayer(name).getUniqueId() + ".yml");
- if (playerFile.exists()) {
- playerFile.delete();
- i++;
+ try {
+ playerFile = new File(plugin.ess.getDataFolder() + File.separator + "userdata" + File.separator + Bukkit.getOfflinePlayer(name).getUniqueId() + ".yml");
+ if (playerFile.exists()) {
+ playerFile.delete();
+ i++;
+ }
+ } catch (Exception e) { // Don't do nothing if the method getUniqueId() isn't avariable ( MC version < 1.7.5 )
}
}
} catch (Exception e) {
diff --git a/src/main/java/fr/xephi/authme/cache/backup/FileCache.java b/src/main/java/fr/xephi/authme/cache/backup/FileCache.java
index 2a4b09eb..f06b63f0 100644
--- a/src/main/java/fr/xephi/authme/cache/backup/FileCache.java
+++ b/src/main/java/fr/xephi/authme/cache/backup/FileCache.java
@@ -505,8 +505,12 @@ public class FileCache {
else armours[i] = item;
}
} catch (final RuntimeException e) {
+ //verbose
+ e.printStackTrace();
ConsoleLogger.showError("Error while reading file for " + player.getName() + ", some wipe inventory incoming...");
} catch (final Exception e) {
+ //verbose
+ e.printStackTrace();
ConsoleLogger.showError("Error while reading file for " + player.getName() + ", some wipe inventory incoming...");
} finally {
if (reader != null)
@@ -515,9 +519,13 @@ public class FileCache {
return new DataFileCache(inv, armours, group, op, flying);
}
} catch (RuntimeException e) {
+ // Verbose
+ e.printStackTrace();
ConsoleLogger.showError("Error while reading file for " + player.getName() + ", some wipe inventory incoming...");
return null;
} catch (Exception e) {
+ // Verbose
+ e.printStackTrace();
ConsoleLogger.showError("Error while reading file for " + player.getName() + ", some wipe inventory incoming...");
return null;
}
diff --git a/src/main/java/fr/xephi/authme/commands/AdminCommand.java b/src/main/java/fr/xephi/authme/commands/AdminCommand.java
index cdcbf997..1cc04829 100644
--- a/src/main/java/fr/xephi/authme/commands/AdminCommand.java
+++ b/src/main/java/fr/xephi/authme/commands/AdminCommand.java
@@ -4,6 +4,7 @@ import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.security.NoSuchAlgorithmException;
+import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
@@ -22,6 +23,8 @@ import org.bukkit.potion.PotionEffectType;
import org.bukkit.scheduler.BukkitScheduler;
import org.bukkit.scheduler.BukkitTask;
+import com.zaxxer.hikari.pool.PoolInitializationException;
+
import fr.xephi.authme.AuthMe;
import fr.xephi.authme.ConsoleLogger;
import fr.xephi.authme.Utils;
@@ -143,7 +146,38 @@ public class AdminCommand implements CommandExecutor {
Settings.reloadConfigOptions(newConfig);
m.reloadMessages();
plugin.database.close();
- plugin.setupDatabase();
+
+ try {
+ plugin.setupDatabase();
+ } catch (ClassNotFoundException nfe) {
+ ConsoleLogger.showError("Fatal error occurred! Authme instance ABORTED!");
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ return false;
+ } catch (SQLException sqle) {
+ ConsoleLogger.showError("Fatal error occurred! Authme instance ABORTED!");
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ return false;
+ } catch (PoolInitializationException pie) {
+ ConsoleLogger.showError("Fatal error occurred! Authme instance ABORTED!");
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ return false;
+ }
+
m.send(sender, "reload");
} else if (args[0].equalsIgnoreCase("lastlogin")) {
if (args.length != 2) {
diff --git a/src/main/java/fr/xephi/authme/datasource/MySQL.java b/src/main/java/fr/xephi/authme/datasource/MySQL.java
index 1588ac6b..24e37dbc 100644
--- a/src/main/java/fr/xephi/authme/datasource/MySQL.java
+++ b/src/main/java/fr/xephi/authme/datasource/MySQL.java
@@ -8,7 +8,6 @@ import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
-import java.util.concurrent.TimeoutException;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
@@ -45,7 +44,7 @@ public class MySQL implements DataSource {
private HikariDataSource ds;
private String columnRealName;
- public MySQL() {
+ public MySQL() throws ClassNotFoundException, SQLException, PoolInitializationException {
this.host = Settings.getMySQLHost;
this.port = Settings.getMySQLPort;
this.username = Settings.getMySQLUsername;
@@ -67,73 +66,112 @@ public class MySQL implements DataSource {
this.columnID = Settings.getMySQLColumnId;
this.columnLogged = Settings.getMySQLColumnLogged;
this.columnRealName = Settings.getMySQLColumnRealName;
+
+ // Set the connection arguments (and check if connection is ok)
try {
- this.connect();
- this.setup();
- } catch (ClassNotFoundException e) {
- ConsoleLogger.showError(e.getMessage());
+ this.setConnectionArguments();
+ } catch (ClassNotFoundException ne) {
+ ConsoleLogger.showError(ne.getMessage());
+ ConsoleLogger.showError("Can't use the Hikari Connection Pool! Please, report this error to the developer! SHUTDOWN...");
+ this.close();
if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use MySQL... Please input correct MySQL informations ! SHUTDOWN...");
AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new ClassNotFoundException(ne.getMessage());
+ } catch (IllegalArgumentException ae) { // This means that there are problems with the hikaricp pool arguments!
+ ConsoleLogger.showError(ae.getMessage());
+ ConsoleLogger.showError("Invalid database arguments! Please check your configuration!");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new IllegalArgumentException(ae);
+ } catch (PoolInitializationException ie) { // Can't initialize the connection pool!
+ ConsoleLogger.showError(ie.getMessage());
+ ConsoleLogger.showError("Can't connect to the MySql database! Please check your configuration!");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new PoolInitializationException(ie);
+ }
+
+ // Initialize the database
+ try {
+ this.setupConnection();
} catch (SQLException e) {
ConsoleLogger.showError(e.getMessage());
+ ConsoleLogger.showError("Can't initialize the MySQL database... Please check your database settings in the config.yml file! SHUTDOWN...");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use MySQL... Please input correct MySQL informations ! SHUTDOWN...");
AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
- } catch (TimeoutException e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use MySQL... Please input correct MySQL informations ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
+ } else {
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
- } catch (PoolInitializationException e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use MySQL... Please input correct MySQL informations ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
}
- if (!Settings.isStopEnabled)
- AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
+ throw new SQLException(e);
}
}
- private synchronized void connect()
- throws ClassNotFoundException, SQLException, TimeoutException,
- NumberFormatException, PoolInitializationException {
+ private synchronized void setConnectionArguments()
+ throws ClassNotFoundException, IllegalArgumentException {
HikariConfig config = new HikariConfig();
- config.setDriverClassName("com.mysql.jdbc.Driver");
+ config.setPoolName("AuthMeMYSQLPool");
+ config.setDataSourceClassName("com.mysql.jdbc.jdbc2.optional.MysqlDataSource");
config.setJdbcUrl("jdbc:mysql://" + this.host + ":" + this.port + "/" + this.database);
config.setUsername(this.username);
config.setPassword(this.password);
- config.setPoolName("AuthMeMYSQLPool");
config.addDataSourceProperty("cachePrepStmts", "true");
config.addDataSourceProperty("prepStmtCacheSize", "250");
- config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");
- config.addDataSourceProperty("autoReconnect", true);
- config.setMaxLifetime(30000);
- config.setInitializationFailFast(false);
+ config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");
+ config.addDataSourceProperty("autoReconnect", false);
+ config.setInitializationFailFast(true); // Don't start the plugin if the database is unavariable
+ config.setMaxLifetime(180000); // 3 Min
+ config.setIdleTimeout(60000); // 1 Min
+ config.setMaximumPoolSize(50); // 50 (including idle connections)
ds = new HikariDataSource(config);
- ConsoleLogger.info("Connection pool ready");
+ ConsoleLogger.info("Connection arguments loaded, Hikari ConnectionPool ready!");
}
- private synchronized void setup() throws SQLException {
+ private synchronized void reloadArguments()
+ throws ClassNotFoundException, IllegalArgumentException {
+ if (ds != null){
+ ds.close();
+ }
+ setConnectionArguments();
+ ConsoleLogger.info("Hikari ConnectionPool arguments reloaded!");
+ }
+
+ private synchronized Connection getConnection() {
+ Connection con = null;
+ while(con == null){
+ try {
+ con = ds.getConnection();
+ } catch (SQLException ce) {
+ return null;
+ }
+ }
+ return con;
+ }
+
+ private synchronized void setupConnection() throws SQLException {
Connection con = null;
Statement st = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
st = con.createStatement();
st.executeUpdate("CREATE TABLE IF NOT EXISTS " + tableName + " (" + columnID + " INTEGER AUTO_INCREMENT," + columnName + " VARCHAR(255) NOT NULL UNIQUE," + columnPassword + " VARCHAR(255) NOT NULL," + columnIp + " VARCHAR(40) NOT NULL DEFAULT '127.0.0.1'," + columnLastLogin + " BIGINT NOT NULL DEFAULT '" + System.currentTimeMillis() + "'," + lastlocX + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocY + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocZ + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocWorld + " VARCHAR(255) NOT NULL DEFAULT '" + Settings.defaultWorld + "'," + columnEmail + " VARCHAR(255) DEFAULT 'your@email.com'," + columnLogged + " SMALLINT NOT NULL DEFAULT '0'," + "CONSTRAINT table_const_prim PRIMARY KEY (" + columnID + "));");
rs = con.getMetaData().getColumns(null, null, tableName, columnPassword);
@@ -185,6 +223,7 @@ public class MySQL implements DataSource {
close(st);
close(con);
}
+ ConsoleLogger.info("MySQL Setup finished");
}
@Override
@@ -193,7 +232,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE LOWER(" + columnName + ")=LOWER(?);");
pst.setString(1, user);
rs = pst.executeQuery();
@@ -217,7 +256,7 @@ public class MySQL implements DataSource {
PlayerAuth pAuth = null;
int id = -1;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE LOWER(" + columnName + ")=LOWER(?);");
pst.setString(1, user);
rs = pst.executeQuery();
@@ -264,7 +303,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
if ((columnSalt == null || columnSalt.isEmpty()) || (auth.getSalt() == null || auth.getSalt().isEmpty())) {
pst = con.prepareStatement("INSERT INTO " + tableName + "(" + columnName + "," + columnPassword + "," + columnIp + "," + columnLastLogin + "," + columnRealName + ") VALUES (?,?,?,?,?);");
pst.setString(1, auth.getNickname());
@@ -473,7 +512,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnPassword + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, auth.getHash());
pst.setString(2, auth.getNickname());
@@ -518,7 +557,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnIp + "=?, " + columnLastLogin + "=?, " + columnRealName + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, auth.getIp());
pst.setLong(2, auth.getLastLogin());
@@ -540,7 +579,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("DELETE FROM " + tableName + " WHERE " + columnLastLogin + ";");
pst.setLong(1, until);
return pst.executeUpdate();
@@ -560,7 +599,7 @@ public class MySQL implements DataSource {
ResultSet rs = null;
List list = new ArrayList();
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnLastLogin + ";");
pst.setLong(1, until);
rs = pst.executeQuery();
@@ -587,7 +626,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
if (Settings.getPasswordHash == HashAlgorithm.XENFORO) {
int id;
ResultSet rs = null;
@@ -623,7 +662,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + lastlocX + " =?, " + lastlocY + "=?, " + lastlocZ + "=?, " + lastlocWorld + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setDouble(1, auth.getQuitLocX());
pst.setDouble(2, auth.getQuitLocY());
@@ -648,7 +687,7 @@ public class MySQL implements DataSource {
ResultSet rs = null;
int countIp = 0;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnIp + "=?;");
pst.setString(1, ip);
rs = pst.executeQuery();
@@ -671,7 +710,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnEmail + " =? WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, auth.getEmail());
pst.setString(2, auth.getNickname());
@@ -694,7 +733,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnSalt + " =? WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, auth.getSalt());
pst.setString(2, auth.getNickname());
@@ -709,6 +748,21 @@ public class MySQL implements DataSource {
return true;
}
+ @Override
+ public void reload() {
+ try {
+ reloadArguments();
+ } catch (Exception e) {
+ ConsoleLogger.showError(e.getMessage());
+ ConsoleLogger.showError("Can't reconnect to MySQL database... Please check your MySQL informations ! SHUTDOWN...");
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ }
+ if (!Settings.isStopEnabled)
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ }
+
@Override
public synchronized void close() {
try {
@@ -718,21 +772,6 @@ public class MySQL implements DataSource {
}
}
- @Override
- public void reload() {
- try {
- reconnect(true);
- } catch (Exception e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't reconnect to MySQL database... Please check your MySQL informations ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
- AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- }
- }
-
private void close(Statement st) {
if (st != null) {
try {
@@ -770,7 +809,7 @@ public class MySQL implements DataSource {
ResultSet rs = null;
List countIp = new ArrayList();
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnIp + "=?;");
pst.setString(1, auth.getIp());
rs = pst.executeQuery();
@@ -795,7 +834,7 @@ public class MySQL implements DataSource {
ResultSet rs = null;
List countIp = new ArrayList();
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnIp + "=?;");
pst.setString(1, ip);
rs = pst.executeQuery();
@@ -820,7 +859,7 @@ public class MySQL implements DataSource {
ResultSet rs = null;
List countEmail = new ArrayList();
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnEmail + "=?;");
pst.setString(1, email);
rs = pst.executeQuery();
@@ -844,7 +883,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
try {
for (String name : banned) {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("DELETE FROM " + tableName + " WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, name);
pst.executeUpdate();
@@ -857,75 +896,6 @@ public class MySQL implements DataSource {
}
}
- private synchronized Connection makeSureConnectionIsReady() {
- Connection con = null;
- try {
- con = ds.getConnection();
- } catch (Exception te) {
- try {
- con = null;
- reconnect(false);
- } catch (Exception e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't reconnect to MySQL database... Please check your MySQL informations ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
- AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- }
- } catch (AssertionError ae) {
- // Make sure assertionerror is caused by the connectionpoolmanager,
- // else re-throw it
- if (!ae.getMessage().equalsIgnoreCase("AuthMeDatabaseError"))
- throw new AssertionError(ae.getMessage());
- try {
- con = null;
- reconnect(false);
- } catch (Exception e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't reconnect to MySQL database... Please check your MySQL informations ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
- AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- }
- }
- while (con == null)
- try {
- con = ds.getConnection();
- } catch (Exception e) {
- try {
- reconnect(false);
- con = ds.getConnection();
- } catch (Exception ex) {
- }
- }
- return con;
- }
-
- private synchronized void reconnect(boolean reload)
- throws ClassNotFoundException, SQLException, TimeoutException,
- PoolInitializationException {
- if (ds != null)
- ds.close();
- HikariConfig config = new HikariConfig();
- config.setJdbcUrl("jdbc:mysql://" + this.host + ":" + this.port + "/" + this.database);
- config.setUsername(this.username);
- config.setPassword(this.password);
- config.addDataSourceProperty("cachePrepStmts", "true");
- config.addDataSourceProperty("prepStmtCacheSize", "250");
- config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");
- config.addDataSourceProperty("autoReconnect", true);
- config.setInitializationFailFast(false);
- config.setMaxLifetime(12000);
- config.setPoolName("AuthMeMYSQLPool");
- ds = new HikariDataSource(config);
- if (!reload)
- ConsoleLogger.info("ConnectionPool was unavailable... Reconnected!");
- }
-
@Override
public DataSourceType getType() {
return DataSourceType.MYSQL;
@@ -937,7 +907,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, user);
rs = pst.executeQuery();
@@ -959,7 +929,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnLogged + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setInt(1, 1);
pst.setString(2, user);
@@ -980,7 +950,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
if (user != null)
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnLogged + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setInt(1, 0);
pst.setString(2, user);
@@ -1000,7 +970,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnLogged + "=? WHERE " + columnLogged + "=?;");
pst.setInt(1, 0);
pst.setInt(2, 1);
@@ -1022,7 +992,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT COUNT(*) FROM " + tableName + ";");
rs = pst.executeQuery();
if (rs != null && rs.next()) {
@@ -1043,7 +1013,7 @@ public class MySQL implements DataSource {
Connection con = null;
PreparedStatement pst = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnName + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setString(1, newone);
pst.setString(2, oldone);
@@ -1065,7 +1035,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + ";");
rs = pst.executeQuery();
while (rs.next()) {
@@ -1116,7 +1086,7 @@ public class MySQL implements DataSource {
PreparedStatement pst = null;
ResultSet rs = null;
try {
- con = makeSureConnectionIsReady();
+ con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnLogged + "=1;");
rs = pst.executeQuery();
while (rs.next()) {
diff --git a/src/main/java/fr/xephi/authme/datasource/SQLite_HIKARI.java b/src/main/java/fr/xephi/authme/datasource/SQLite_HIKARI.java
index 6f1350e3..2b6ea386 100644
--- a/src/main/java/fr/xephi/authme/datasource/SQLite_HIKARI.java
+++ b/src/main/java/fr/xephi/authme/datasource/SQLite_HIKARI.java
@@ -1,6 +1,5 @@
package fr.xephi.authme.datasource;
-import java.io.EOFException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
@@ -8,10 +7,10 @@ import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
-import java.util.Properties;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
+import com.zaxxer.hikari.pool.PoolInitializationException;
import fr.xephi.authme.AuthMe;
import fr.xephi.authme.ConsoleLogger;
@@ -38,7 +37,7 @@ public class SQLite_HIKARI implements DataSource {
private String columnLogged;
private String columnRealName;
- public SQLite_HIKARI() {
+ public SQLite_HIKARI() throws ClassNotFoundException, SQLException, PoolInitializationException {
this.database = Settings.getMySQLDatabase;
this.tableName = Settings.getMySQLTablename;
this.columnName = Settings.getMySQLColumnName;
@@ -56,65 +55,127 @@ public class SQLite_HIKARI implements DataSource {
this.columnLogged = Settings.getMySQLColumnLogged;
this.columnRealName = Settings.getMySQLColumnRealName;
+ // Set the connection arguments (and check if connection is ok)
try {
- this.connect();
- this.setup();
- } catch (ClassNotFoundException e) {
- ConsoleLogger.showError(e.getMessage());
+ this.setConnectionArguments();
+ } catch (ClassNotFoundException ne) {
+ ConsoleLogger.showError(ne.getMessage());
+ ConsoleLogger.showError("Can't use the Hikari Connection Pool! Please, report this error to the developer! SHUTDOWN...");
+ this.close();
if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use SQLITE... ! SHUTDOWN...");
AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new ClassNotFoundException(ne.getMessage());
+ } catch (IllegalArgumentException ae) { // This means that there are problems with the hikaricp pool arguments!
+ ConsoleLogger.showError(ae.getMessage());
+ ConsoleLogger.showError("Invalid database arguments! Please check your configuration!");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new IllegalArgumentException(ae);
+ } catch (PoolInitializationException ie) { // Can't initialize the connection pool!
+ ConsoleLogger.showError(ie.getMessage());
+ ConsoleLogger.showError("Can't connect to the SQLite database! Please check your configuration!");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ throw new PoolInitializationException(ie);
+ }
+
+ // Initialize the database
+ try {
+ this.setupConnection();
} catch (SQLException e) {
ConsoleLogger.showError(e.getMessage());
+ ConsoleLogger.showError("Can't initialize the MySQL database... Please check your database settings in the config.yml file! SHUTDOWN...");
+ ConsoleLogger.showError("If this error persists, please report it to the developer! SHUTDOWN...");
+ this.close();
if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use SQLITE... ! SHUTDOWN...");
AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
- } catch (EOFException e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't use SQLITE... ! SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
+ } else {
AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- return;
+ }
+ throw new SQLException(e);
}
}
- private Connection getConnection() throws SQLException, EOFException {
- return this.ds.getConnection();
+ @Override
+ public DataSourceType getType() {
+ return DataSourceType.SQLITE;
}
- private synchronized void connect()
- throws ClassNotFoundException, SQLException, EOFException {
- /*
- * Class.forName("org.sqlite.JDBC"); ConsoleLogger.info(
- * "SQLite driver loaded"); this.con =
- * DriverManager.getConnection("jdbc:sqlite:plugins/AuthMe/" + database
- * + ".db");
- */
- Properties props = new Properties();
- props.setProperty("dataSourceClassName", "org.sqlite.SQLiteDataSource");
- HikariConfig config = new HikariConfig(props);
- config.setPoolName("AuthMeSQLiteLPool");
+ private synchronized void setConnectionArguments()
+ throws ClassNotFoundException, IllegalArgumentException {
+ HikariConfig config = new HikariConfig();
+ config.setPoolName("AuthMeSQLitePool");
+ config.setDataSourceClassName("org.sqlite.SQLiteDataSource");
+ config.setJdbcUrl("jdbc:sqlite:plugins/AuthMe/" + database + ".db");
+ config.setInitializationFailFast(true); // Don't start the plugin if the database is unavariable
+ config.setConnectionTestQuery("SELECT 1");
+ config.setMaxLifetime(180000); // 3 Min
+ config.setIdleTimeout(60000); // 1 Min
+ config.setMaximumPoolSize(50); // 50 (including idle connections)
ds = new HikariDataSource(config);
- ConsoleLogger.info("Connection pool ready");
+ ConsoleLogger.info("Connection arguments loaded, Hikari ConnectionPool ready!");
}
- private synchronized void setup() throws SQLException, EOFException {
+ private synchronized Connection getRawConnection() {
+ Connection con = null;
+ while(con == null){
+ try {
+ con = ds.getConnection();
+ } catch (SQLException ce) {
+ return null;
+ }
+ }
+ return con;
+ }
+
+ private synchronized Connection getConnection() {
+ Connection con;
+ con = getRawConnection();
+ if(con == null){
+ ds.close();
+ ConsoleLogger.showError("Database connection is LOST! SHUTDOWN...");
+ if (Settings.isStopEnabled) {
+ AuthMe.getInstance().getServer().shutdown();
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ }
+ return con;
+ }
+
+ private synchronized void setupConnection() throws SQLException {
Connection con = null;
Statement st = null;
ResultSet rs = null;
try {
- con = getConnection();
+ con = getRawConnection();
+ if(con == null){
+ ds.close();
+ if (Settings.isStopEnabled) {
+ ConsoleLogger.showError("Can't connect to the SQLite database... Please check your database settings in the config.yml file! SHUTDOWN...");
+ AuthMe.getInstance().getServer().shutdown();
+ } else {
+ AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
+ }
+ return;
+ }
st = con.createStatement();
st.executeUpdate("CREATE TABLE IF NOT EXISTS " + tableName + " (" + columnID + " INTEGER AUTO_INCREMENT," + columnName + " VARCHAR(255) NOT NULL UNIQUE," + columnPassword + " VARCHAR(255) NOT NULL," + columnIp + " VARCHAR(40) NOT NULL," + columnLastLogin + " BIGINT," + lastlocX + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocY + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocZ + " DOUBLE NOT NULL DEFAULT '0.0'," + lastlocWorld + " VARCHAR(255) NOT NULL DEFAULT '" + Settings.defaultWorld + "'," + columnEmail + " VARCHAR(255) DEFAULT 'your@email.com'," + "CONSTRAINT table_const_prim PRIMARY KEY (" + columnID + "));");
rs = con.getMetaData().getColumns(null, null, tableName, columnPassword);
@@ -166,14 +227,6 @@ public class SQLite_HIKARI implements DataSource {
ConsoleLogger.info("SQLite Setup finished");
}
- private void close(Connection con) {
- try {
- if (con != null)
- con.close();
- } catch (Exception e) {
- }
- }
-
@Override
public synchronized boolean isAuthAvailable(String user) {
Connection con = null;
@@ -185,7 +238,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(1, user);
rs = pst.executeQuery();
return rs.next();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -218,7 +271,7 @@ public class SQLite_HIKARI implements DataSource {
} else {
return null;
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return null;
} finally {
@@ -230,8 +283,8 @@ public class SQLite_HIKARI implements DataSource {
@Override
public synchronized boolean saveAuth(PlayerAuth auth) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
if (columnSalt.isEmpty() && auth.getSalt().isEmpty()) {
@@ -252,7 +305,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(6, auth.getRealName());
pst.executeUpdate();
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -272,7 +325,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(1, auth.getHash());
pst.setString(2, auth.getNickname());
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -294,7 +347,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(3, auth.getRealName());
pst.setString(4, auth.getNickname());
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -313,7 +366,7 @@ public class SQLite_HIKARI implements DataSource {
pst = con.prepareStatement("DELETE FROM " + tableName + " WHERE " + columnLastLogin + ";");
pst.setLong(1, until);
return pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return 0;
} finally {
@@ -337,7 +390,7 @@ public class SQLite_HIKARI implements DataSource {
list.add(rs.getString(columnName));
}
return list;
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return new ArrayList();
} finally {
@@ -349,14 +402,14 @@ public class SQLite_HIKARI implements DataSource {
@Override
public synchronized boolean removeAuth(String user) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("DELETE FROM " + tableName + " WHERE " + columnName + "=?;");
pst.setString(1, user);
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -368,8 +421,8 @@ public class SQLite_HIKARI implements DataSource {
@Override
public boolean updateQuitLoc(PlayerAuth auth) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + lastlocX + "=?, " + lastlocY + "=?, " + lastlocZ + "=?, " + lastlocWorld + "=? WHERE " + columnName + "=?;");
@@ -379,7 +432,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(4, auth.getWorld());
pst.setString(5, auth.getNickname());
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -391,9 +444,9 @@ public class SQLite_HIKARI implements DataSource {
@Override
public int getIps(String ip) {
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
int countIp = 0;
try {
con = getConnection();
@@ -404,7 +457,7 @@ public class SQLite_HIKARI implements DataSource {
countIp++;
}
return countIp;
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return 0;
} finally {
@@ -416,15 +469,15 @@ public class SQLite_HIKARI implements DataSource {
@Override
public boolean updateEmail(PlayerAuth auth) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnEmail + "=? WHERE " + columnName + "=?;");
pst.setString(1, auth.getEmail());
pst.setString(2, auth.getNickname());
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -447,7 +500,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(1, auth.getSalt());
pst.setString(2, auth.getNickname());
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -457,56 +510,11 @@ public class SQLite_HIKARI implements DataSource {
return true;
}
- @Override
- public synchronized void close() {
- try {
- if (ds != null)
- ds.close();
- } catch (Exception e) {
- }
- }
-
- @Override
- public void reload() {
- try {
- connect();
- setup();
- } catch (Exception e) {
- ConsoleLogger.showError(e.getMessage());
- if (Settings.isStopEnabled) {
- ConsoleLogger.showError("Can't reconnect to SQLite database... SHUTDOWN...");
- AuthMe.getInstance().getServer().shutdown();
- }
- if (!Settings.isStopEnabled)
- AuthMe.getInstance().getServer().getPluginManager().disablePlugin(AuthMe.getInstance());
- }
- }
-
- private void close(Statement st) {
- if (st != null) {
- try {
- st.close();
- } catch (SQLException ex) {
- ConsoleLogger.showError(ex.getMessage());
- }
- }
- }
-
- private void close(ResultSet rs) {
- if (rs != null) {
- try {
- rs.close();
- } catch (SQLException ex) {
- ConsoleLogger.showError(ex.getMessage());
- }
- }
- }
-
@Override
public List getAllAuthsByName(PlayerAuth auth) {
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
List countIp = new ArrayList();
try {
con = getConnection();
@@ -517,11 +525,11 @@ public class SQLite_HIKARI implements DataSource {
countIp.add(rs.getString(columnName));
}
return countIp;
- } catch (NullPointerException ex) {
- return new ArrayList();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return new ArrayList();
+ } catch (NullPointerException npe) {
+ return new ArrayList();
} finally {
close(rs);
close(pst);
@@ -531,9 +539,9 @@ public class SQLite_HIKARI implements DataSource {
@Override
public List getAllAuthsByIp(String ip) {
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
List countIp = new ArrayList();
try {
con = getConnection();
@@ -544,11 +552,11 @@ public class SQLite_HIKARI implements DataSource {
countIp.add(rs.getString(columnName));
}
return countIp;
- } catch (NullPointerException ex) {
- return new ArrayList();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return new ArrayList();
+ } catch (NullPointerException npe) {
+ return new ArrayList();
} finally {
close(rs);
close(pst);
@@ -558,9 +566,9 @@ public class SQLite_HIKARI implements DataSource {
@Override
public List getAllAuthsByEmail(String email) {
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
List countEmail = new ArrayList();
try {
con = getConnection();
@@ -571,11 +579,11 @@ public class SQLite_HIKARI implements DataSource {
countEmail.add(rs.getString(columnName));
}
return countEmail;
- } catch (NullPointerException ex) {
- return new ArrayList();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return new ArrayList();
+ } catch (NullPointerException npe) {
+ return new ArrayList();
} finally {
close(rs);
close(pst);
@@ -585,8 +593,8 @@ public class SQLite_HIKARI implements DataSource {
@Override
public void purgeBanned(List banned) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
for (String name : banned) {
@@ -594,7 +602,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setString(1, name);
pst.executeUpdate();
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
} finally {
close(pst);
@@ -602,16 +610,11 @@ public class SQLite_HIKARI implements DataSource {
}
}
- @Override
- public DataSourceType getType() {
- return DataSourceType.SQLITE;
- }
-
@Override
public boolean isLogged(String user) {
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
try {
con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE LOWER(" + columnName + ")=?;");
@@ -619,7 +622,7 @@ public class SQLite_HIKARI implements DataSource {
rs = pst.executeQuery();
if (rs.next())
return (rs.getInt(columnLogged) == 1);
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return false;
} finally {
@@ -632,15 +635,15 @@ public class SQLite_HIKARI implements DataSource {
@Override
public void setLogged(String user) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnLogged + "=? WHERE LOWER(" + columnName + ")=?;");
pst.setInt(1, 1);
pst.setString(2, user);
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return;
} finally {
@@ -652,8 +655,8 @@ public class SQLite_HIKARI implements DataSource {
@Override
public void setUnlogged(String user) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
if (user != null)
try {
con = getConnection();
@@ -661,7 +664,7 @@ public class SQLite_HIKARI implements DataSource {
pst.setInt(1, 0);
pst.setString(2, user);
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return;
} finally {
@@ -673,15 +676,15 @@ public class SQLite_HIKARI implements DataSource {
@Override
public void purgeLogged() {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnLogged + "=? WHERE " + columnLogged + "=?;");
pst.setInt(1, 0);
pst.setInt(2, 1);
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return;
} finally {
@@ -693,10 +696,10 @@ public class SQLite_HIKARI implements DataSource {
@Override
public int getAccountsRegistered() {
- int result = 0;
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
+ int result = 0;
try {
con = getConnection();
pst = con.prepareStatement("SELECT COUNT(*) FROM " + tableName + ";");
@@ -704,7 +707,7 @@ public class SQLite_HIKARI implements DataSource {
if (rs != null && rs.next()) {
result = rs.getInt(1);
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return result;
} finally {
@@ -716,15 +719,15 @@ public class SQLite_HIKARI implements DataSource {
@Override
public void updateName(String oldone, String newone) {
- PreparedStatement pst = null;
Connection con = null;
+ PreparedStatement pst = null;
try {
con = getConnection();
pst = con.prepareStatement("UPDATE " + tableName + " SET " + columnName + "=? WHERE " + columnName + "=?;");
pst.setString(1, newone);
pst.setString(2, oldone);
pst.executeUpdate();
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return;
} finally {
@@ -736,10 +739,10 @@ public class SQLite_HIKARI implements DataSource {
@Override
public List getAllAuths() {
- List auths = new ArrayList();
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
+ List auths = new ArrayList();
try {
con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + ";");
@@ -758,7 +761,7 @@ public class SQLite_HIKARI implements DataSource {
if (pAuth != null)
auths.add(pAuth);
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return auths;
} finally {
@@ -770,10 +773,10 @@ public class SQLite_HIKARI implements DataSource {
@Override
public List getLoggedPlayers() {
- List auths = new ArrayList();
+ Connection con = null;
PreparedStatement pst = null;
ResultSet rs = null;
- Connection con = null;
+ List auths = new ArrayList();
try {
con = getConnection();
pst = con.prepareStatement("SELECT * FROM " + tableName + " WHERE " + columnLogged + "=1;");
@@ -792,7 +795,7 @@ public class SQLite_HIKARI implements DataSource {
if (pAuth != null)
auths.add(pAuth);
}
- } catch (Exception ex) {
+ } catch (SQLException ex) {
ConsoleLogger.showError(ex.getMessage());
return auths;
} finally {
@@ -801,4 +804,47 @@ public class SQLite_HIKARI implements DataSource {
}
return auths;
}
+
+ @Override
+ public void reload() {
+ }
+
+ @Override
+ public synchronized void close() {
+ try {
+ if (ds != null)
+ ds.close();
+ } catch (Exception e) {
+ }
+ }
+
+ private void close(Statement st) {
+ if (st != null) {
+ try {
+ st.close();
+ } catch (Exception ex) {
+ ConsoleLogger.showError(ex.getMessage());
+ }
+ }
+ }
+
+ private void close(ResultSet rs) {
+ if (rs != null) {
+ try {
+ rs.close();
+ } catch (Exception ex) {
+ ConsoleLogger.showError(ex.getMessage());
+ }
+ }
+ }
+
+ private void close(Connection con) {
+ if (con != null) {
+ try {
+ con.close();
+ } catch (Exception ex) {
+ ConsoleLogger.showError(ex.getMessage());
+ }
+ }
+ }
}
diff --git a/src/main/java/fr/xephi/authme/modules/ModuleManager.java b/src/main/java/fr/xephi/authme/modules/ModuleManager.java
index fc1d07f6..25c750b3 100644
--- a/src/main/java/fr/xephi/authme/modules/ModuleManager.java
+++ b/src/main/java/fr/xephi/authme/modules/ModuleManager.java
@@ -48,9 +48,11 @@ public class ModuleManager implements Module {
@Override
public boolean load() {
File dir = new File(plugin.getDataFolder() + File.separator + "modules");
- if (dir == null || !dir.exists() || !dir.isDirectory() || dir.listFiles() == null || dir.listFiles().length <= 0)
+ String[] files = dir.list();
+ if (files == null || files.length == 0){
return false;
- for (File pathToJar : dir.listFiles()) {
+ }
+ for (File pathToJar : dir.listFiles()) { // FindBugs: "possible null pointers" O_o ?
JarFile jarFile = null;
try {
jarFile = new JarFile(pathToJar);
diff --git a/src/main/java/fr/xephi/authme/settings/Messages.java b/src/main/java/fr/xephi/authme/settings/Messages.java
index 75db7b7c..1845d739 100644
--- a/src/main/java/fr/xephi/authme/settings/Messages.java
+++ b/src/main/java/fr/xephi/authme/settings/Messages.java
@@ -1,12 +1,9 @@
package fr.xephi.authme.settings;
import java.io.File;
-import java.io.InputStream;
-
import org.bukkit.command.CommandSender;
import org.bukkit.configuration.file.YamlConfiguration;
-import fr.xephi.authme.AuthMe;
import fr.xephi.authme.ConsoleLogger;
public class Messages extends CustomConfiguration {
@@ -29,13 +26,11 @@ public class Messages extends CustomConfiguration {
* @param filename
* The filename to open
*/
- @SuppressWarnings("deprecation")
public final void loadDefaults(File file) {
- InputStream stream = AuthMe.getInstance().getResource(file.getName());
- if (stream == null)
- return;
-
- setDefaults(YamlConfiguration.loadConfiguration(stream));
+ if(file.isFile()){
+ setDefaults(YamlConfiguration.loadConfiguration(file));
+ }
+ return;
}
/**
diff --git a/src/main/java/fr/xephi/authme/settings/Settings.java b/src/main/java/fr/xephi/authme/settings/Settings.java
index 54dcf2c1..41fbaff7 100644
--- a/src/main/java/fr/xephi/authme/settings/Settings.java
+++ b/src/main/java/fr/xephi/authme/settings/Settings.java
@@ -28,7 +28,7 @@ public final class Settings extends YamlConfiguration {
public static String PLUGIN_FOLDER = "." + File.separator + "plugins" + File.separator + "AuthMe";
public static final String CACHE_FOLDER = Settings.PLUGIN_FOLDER + File.separator + "cache";
public static final String AUTH_FILE = Settings.PLUGIN_FOLDER + File.separator + "auths.db";
- public static final String MESSAGE_FILE = Settings.PLUGIN_FOLDER + File.separator + "messages";
+ public static final String MESSAGE_FILE = Settings.PLUGIN_FOLDER + File.separator + "messages" + File.separator + "messages";
public static final String SETTINGS_FILE = Settings.PLUGIN_FOLDER + File.separator + "config.yml";
public static List allowCommands = null;
public static List getJoinPermissions = null;
diff --git a/src/main/resources/messages_bg.yml b/src/main/resources/messages/messages_bg.yml
similarity index 100%
rename from src/main/resources/messages_bg.yml
rename to src/main/resources/messages/messages_bg.yml
diff --git a/src/main/resources/messages_br.yml b/src/main/resources/messages/messages_br.yml
similarity index 100%
rename from src/main/resources/messages_br.yml
rename to src/main/resources/messages/messages_br.yml
diff --git a/src/main/resources/messages_cz.yml b/src/main/resources/messages/messages_cz.yml
similarity index 100%
rename from src/main/resources/messages_cz.yml
rename to src/main/resources/messages/messages_cz.yml
diff --git a/src/main/resources/messages_de.yml b/src/main/resources/messages/messages_de.yml
similarity index 100%
rename from src/main/resources/messages_de.yml
rename to src/main/resources/messages/messages_de.yml
diff --git a/src/main/resources/messages_en.yml b/src/main/resources/messages/messages_en.yml
similarity index 100%
rename from src/main/resources/messages_en.yml
rename to src/main/resources/messages/messages_en.yml
diff --git a/src/main/resources/messages_es.yml b/src/main/resources/messages/messages_es.yml
similarity index 100%
rename from src/main/resources/messages_es.yml
rename to src/main/resources/messages/messages_es.yml
diff --git a/src/main/resources/messages_eu.yml b/src/main/resources/messages/messages_eu.yml
similarity index 100%
rename from src/main/resources/messages_eu.yml
rename to src/main/resources/messages/messages_eu.yml
diff --git a/src/main/resources/messages_fi.yml b/src/main/resources/messages/messages_fi.yml
similarity index 100%
rename from src/main/resources/messages_fi.yml
rename to src/main/resources/messages/messages_fi.yml
diff --git a/src/main/resources/messages_fr.yml b/src/main/resources/messages/messages_fr.yml
similarity index 100%
rename from src/main/resources/messages_fr.yml
rename to src/main/resources/messages/messages_fr.yml
diff --git a/src/main/resources/messages_gl.yml b/src/main/resources/messages/messages_gl.yml
similarity index 100%
rename from src/main/resources/messages_gl.yml
rename to src/main/resources/messages/messages_gl.yml
diff --git a/src/main/resources/messages_hu.yml b/src/main/resources/messages/messages_hu.yml
similarity index 100%
rename from src/main/resources/messages_hu.yml
rename to src/main/resources/messages/messages_hu.yml
diff --git a/src/main/resources/messages_it.yml b/src/main/resources/messages/messages_it.yml
similarity index 100%
rename from src/main/resources/messages_it.yml
rename to src/main/resources/messages/messages_it.yml
diff --git a/src/main/resources/messages_ko.yml b/src/main/resources/messages/messages_ko.yml
similarity index 100%
rename from src/main/resources/messages_ko.yml
rename to src/main/resources/messages/messages_ko.yml
diff --git a/src/main/resources/messages_lt.yml b/src/main/resources/messages/messages_lt.yml
similarity index 100%
rename from src/main/resources/messages_lt.yml
rename to src/main/resources/messages/messages_lt.yml
diff --git a/src/main/resources/messages_nl.yml b/src/main/resources/messages/messages_nl.yml
similarity index 100%
rename from src/main/resources/messages_nl.yml
rename to src/main/resources/messages/messages_nl.yml
diff --git a/src/main/resources/messages_pl.yml b/src/main/resources/messages/messages_pl.yml
similarity index 100%
rename from src/main/resources/messages_pl.yml
rename to src/main/resources/messages/messages_pl.yml
diff --git a/src/main/resources/messages_pt.yml b/src/main/resources/messages/messages_pt.yml
similarity index 100%
rename from src/main/resources/messages_pt.yml
rename to src/main/resources/messages/messages_pt.yml
diff --git a/src/main/resources/messages_ru.yml b/src/main/resources/messages/messages_ru.yml
similarity index 98%
rename from src/main/resources/messages_ru.yml
rename to src/main/resources/messages/messages_ru.yml
index 536dc479..4a6a2bf1 100644
--- a/src/main/resources/messages_ru.yml
+++ b/src/main/resources/messages/messages_ru.yml
@@ -1,58 +1,58 @@
-unknown_user: '&fПользователь не найден в Базе Данных'
-unsafe_spawn: '&eВаше расположение перед выходом было опасным - вы перенесены на спавн'
-not_logged_in: '&cВы еще не вошли!'
-reg_voluntarily: '&aЧтобы зарегистрироваться введите: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
-usage_log: '&eСинтаксис: &d/l ПАРОЛЬ &eили &d/login ПАРОЛЬ'
-wrong_pwd: '&4Неправильный пароль!'
-unregistered: '&6Вы успешно удалили свой аккаунт!'
-reg_disabled: '&4Регистрация отключена'
-valid_session: '&aСессия открыта'
-login: '&2Вы успешно вошли!'
-vb_nonActiv: '&6Ваш аккаунт еще не активирован! Проверьте вашу почту!'
-user_regged: '&4Такой игрок уже зарегистрирован'
-usage_reg: '&4Использование: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
-max_reg: '&4Вы превысили макс количество регистраций на ваш IP'
-no_perm: '&4Недостаточно прав'
-error: '&4Произошла ошибка. Свяжитесь с администратором'
-login_msg: '&4Авторизация: &5/l ПАРОЛЬ'
-reg_msg: '&4Регистрация: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
-password_error_nick: '&fВы не можете использовать ваш ник в роли пароля'
-password_error_unsafe: '&fВы не можете использовать небезопасный пароль'
-reg_email_msg: '&4Регистрация: &5/reg EMAIL ПОВТОР_EMAIL'
-usage_unreg: '&4Использование: &5/unregister ПАРОЛЬ'
-pwd_changed: '&2Пароль изменен!'
-user_unknown: '&4Такой игрок не зарегистрирован'
-password_error: '&4Пароль не совпадает'
-invalid_session: '&4Сессия некорректна. Дождитесь, пока она закончится'
-reg_only: '&4Только для зарегистрированных! Посетите http://сайт_сервера.com/register/ для регистрации'
-logged_in: '&4Вы уже авторизированы!'
-logout: '&2Вы успешно вышли'
-same_nick: '&4Такой игрок уже играет на сервере'
-registered: '&2Успешная регистрация!'
-pass_len: '&4Твой пароль либо слишком длинный, либо слишком короткий'
-reload: '&6Конфигурация и база данных перезагружены'
-timeout: '&4Время для авторизации истекло'
-usage_changepassword: '&4Использование: &5/changepassword СТАРЫЙ_ПАРОЛЬ НОВЫЙ_ПАРОЛЬ'
-name_len: '&4Ваш логин слишком длинный или слишком короткий'
-regex: '&4Ваш логин содержит запрещенные символы. Разрешенные символы: REG_EX'
-add_email: '&4Добавьте свой email: &5/email add ВАШ_EMAIL ВАШ_EMAIL'
-bad_database_email: '&4[AuthMe] Команда &5/email&4 доступна только при работе с MySQL или SQLite. Обратититесь к администрации сервера'
-recovery_email: '&4Забыли пароль? Используйте &5/email recovery ВАШ_EMAIL'
-usage_captcha: '&4Вы должны ввести код, используйте: &5/captcha '
-wrong_captcha: '&4Неверный код, используйте: &5/captcha THE_CAPTCHA'
-valid_captcha: '&2Вы успешно ввели код!'
-kick_forvip: '&6VIP игрок зашел на переполненный сервер!'
-kick_fullserver: '&4Сервер переполнен!'
-usage_email_add: '&4Использование: &5/email add ВАШ_EMAIL ПОВТОР_EMAIL'
-usage_email_change: '&4Использование: &5/email change СТАРЫЙ_EMAIL НОВЫЙ_EMAIL'
-usage_email_recovery: '&4Использование: /email recovery EMAIL'
-new_email_invalid: '[AuthMe] Недействительный новый email!'
-old_email_invalid: '[AuthMe] Недействительный старый email!'
-email_invalid: '[AuthMe] Недействительный email'
-email_added: '[AuthMe] Email добавлен!'
-email_confirm: '[AuthMe] Подтвердите ваш Email!'
-email_changed: '[AuthMe] Email изменен!'
-email_send: '[AuthMe] Письмо с инструкциями для восстановления было отправлено на ваш Email!'
-country_banned: 'Вход с IP-адресов вашей страны воспрещен на этом сервере'
-antibot_auto_enabled: '[AuthMe] AntiBot-режим автоматически включен из-за большого количества входов!'
-antibot_auto_disabled: '[AuthMe] AntiBot-режим автоматичски отключен после %m мин. Надеюсь атака закончилась'
+unknown_user: '&fПользователь не найден в Базе Данных'
+unsafe_spawn: '&eВаше расположение перед выходом было опасным - вы перенесены на спавн'
+not_logged_in: '&cВы еще не вошли!'
+reg_voluntarily: '&aЧтобы зарегистрироваться введите: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
+usage_log: '&eСинтаксис: &d/l ПАРОЛЬ &eили &d/login ПАРОЛЬ'
+wrong_pwd: '&4Неправильный пароль!'
+unregistered: '&6Вы успешно удалили свой аккаунт!'
+reg_disabled: '&4Регистрация отключена'
+valid_session: '&aСессия открыта'
+login: '&2Вы успешно вошли!'
+vb_nonActiv: '&6Ваш аккаунт еще не активирован! Проверьте вашу почту!'
+user_regged: '&4Такой игрок уже зарегистрирован'
+usage_reg: '&4Использование: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
+max_reg: '&4Вы превысили макс количество регистраций на ваш IP'
+no_perm: '&4Недостаточно прав'
+error: '&4Произошла ошибка. Свяжитесь с администратором'
+login_msg: '&4Авторизация: &5/l ПАРОЛЬ'
+reg_msg: '&4Регистрация: &5/reg ПАРОЛЬ ПОВТОР_ПАРОЛЯ'
+password_error_nick: '&fВы не можете использовать ваш ник в роли пароля'
+password_error_unsafe: '&fВы не можете использовать небезопасный пароль'
+reg_email_msg: '&4Регистрация: &5/reg EMAIL ПОВТОР_EMAIL'
+usage_unreg: '&4Использование: &5/unregister ПАРОЛЬ'
+pwd_changed: '&2Пароль изменен!'
+user_unknown: '&4Такой игрок не зарегистрирован'
+password_error: '&4Пароль не совпадает'
+invalid_session: '&4Сессия некорректна. Дождитесь, пока она закончится'
+reg_only: '&4Только для зарегистрированных! Посетите http://сайт_сервера.com/register/ для регистрации'
+logged_in: '&4Вы уже авторизированы!'
+logout: '&2Вы успешно вышли'
+same_nick: '&4Такой игрок уже играет на сервере'
+registered: '&2Успешная регистрация!'
+pass_len: '&4Твой пароль либо слишком длинный, либо слишком короткий'
+reload: '&6Конфигурация и база данных перезагружены'
+timeout: '&4Время для авторизации истекло'
+usage_changepassword: '&4Использование: &5/changepassword СТАРЫЙ_ПАРОЛЬ НОВЫЙ_ПАРОЛЬ'
+name_len: '&4Ваш логин слишком длинный или слишком короткий'
+regex: '&4Ваш логин содержит запрещенные символы. Разрешенные символы: REG_EX'
+add_email: '&4Добавьте свой email: &5/email add ВАШ_EMAIL ВАШ_EMAIL'
+bad_database_email: '&4[AuthMe] Команда &5/email&4 доступна только при работе с MySQL или SQLite. Обратититесь к администрации сервера'
+recovery_email: '&4Забыли пароль? Используйте &5/email recovery ВАШ_EMAIL'
+usage_captcha: '&4Вы должны ввести код, используйте: &5/captcha '
+wrong_captcha: '&4Неверный код, используйте: &5/captcha THE_CAPTCHA'
+valid_captcha: '&2Вы успешно ввели код!'
+kick_forvip: '&6VIP игрок зашел на переполненный сервер!'
+kick_fullserver: '&4Сервер переполнен!'
+usage_email_add: '&4Использование: &5/email add ВАШ_EMAIL ПОВТОР_EMAIL'
+usage_email_change: '&4Использование: &5/email change СТАРЫЙ_EMAIL НОВЫЙ_EMAIL'
+usage_email_recovery: '&4Использование: /email recovery EMAIL'
+new_email_invalid: '[AuthMe] Недействительный новый email!'
+old_email_invalid: '[AuthMe] Недействительный старый email!'
+email_invalid: '[AuthMe] Недействительный email'
+email_added: '[AuthMe] Email добавлен!'
+email_confirm: '[AuthMe] Подтвердите ваш Email!'
+email_changed: '[AuthMe] Email изменен!'
+email_send: '[AuthMe] Письмо с инструкциями для восстановления было отправлено на ваш Email!'
+country_banned: 'Вход с IP-адресов вашей страны воспрещен на этом сервере'
+antibot_auto_enabled: '[AuthMe] AntiBot-режим автоматически включен из-за большого количества входов!'
+antibot_auto_disabled: '[AuthMe] AntiBot-режим автоматичски отключен после %m мин. Надеюсь атака закончилась'
diff --git a/src/main/resources/messages_sk.yml b/src/main/resources/messages/messages_sk.yml
similarity index 100%
rename from src/main/resources/messages_sk.yml
rename to src/main/resources/messages/messages_sk.yml
diff --git a/src/main/resources/messages_tr.yml b/src/main/resources/messages/messages_tr.yml
similarity index 100%
rename from src/main/resources/messages_tr.yml
rename to src/main/resources/messages/messages_tr.yml
diff --git a/src/main/resources/messages_uk.yml b/src/main/resources/messages/messages_uk.yml
similarity index 100%
rename from src/main/resources/messages_uk.yml
rename to src/main/resources/messages/messages_uk.yml
diff --git a/src/main/resources/messages_vn.yml b/src/main/resources/messages/messages_vn.yml
similarity index 97%
rename from src/main/resources/messages_vn.yml
rename to src/main/resources/messages/messages_vn.yml
index 56efede9..1722385a 100644
--- a/src/main/resources/messages_vn.yml
+++ b/src/main/resources/messages/messages_vn.yml
@@ -1,59 +1,59 @@
-unknown_user: '&fNgười chơi không tồn tại trong cơ sở dữ liệu'
-unsafe_spawn: '&fNơi thoát server của bạn không an toàn, đang dịch chuyển bạn tới điểm spawn của server'
-not_logged_in: '&cChưa đăng nhập!'
-reg_voluntarily: '&fBạn có thể đăng kí tài khoản với lệnh
- "/register mật-khẩu nhập-lại-mật-khẩu"'
-usage_log: '&eSử dụng: /login password'
-wrong_pwd: '&cSai mật khẩu'
-unregistered: '&cHuỷ đăng kí thành công!'
-reg_disabled: '&cHệ thống đăng kí đã bị vô hiệu'
-valid_session: '&cPhiên đăng nhập còn tồn tại, bạn không cần nhập mật khẩu'
-login: '&cĐăng nhập thành công!'
-vb_nonActiv: '&fTài khoản của bạn chưa được kích hoạt, kiểm tra email!'
-user_regged: '&cTên đăng nhập này đã được đăng kí'
-usage_reg: '&eSử dụng: /register mật-khẩu nhập-lại-mật-khẩu'
-max_reg: '&fSố lượng tài khoản ở IP của bạn trong server này đã quá giới hạn cho phép'
-no_perm: '&cKhông có quyền'
-error: '&fCó lỗi xảy ra; Báo lại cho người điều hành server'
-login_msg: '&cĐăng nhập với lệnh "/login mật-khẩu"'
-reg_msg: '&cĐăng kí tài khoản với lệnh "/register mật-khẩu nhập-lại-mật-khẩu"'
-reg_email_msg: '&cĐăng kí email cho tài khoản với lệnh "/register "'
-usage_unreg: '&eSử dụng: /unregister mật-khẩu'
-pwd_changed: '&cĐã đổi mật khẩu!'
-user_unknown: '&cTài khoản này chưa được đăng kí'
-password_error: '&fMật khẩu không khớp'
-unvalid_session: '&fPhiên đăng nhập không hồi đáp, vui lòng chờ phiên đăng nhập kết thúc'
-reg_only: '&fChỉ cho phép người đã đăng kí! Hãy vào trang http://web-của.bạn/ để đăng kí'
-logged_in: '&cĐã đăng nhập!'
-logout: '&cThoát đăng nhập thành công'
-same_nick: '&fTài khoản đang được người khác sử dụng trong server'
-registered: '&cĐăng kí thành công!'
-pass_len: '&fMật khẩu của bạn quá ngắn hoặc quá dài'
-reload: '&fThiết lập và dữ liệu đã được nạp lại'
-timeout: '&fQuá thời gian đăng nhập'
-usage_changepassword: '&eSử dụng: /changepassword mật-khẩu-cũ mật-khẩu-mới'
-name_len: '&cTên đăng nhập của bạn quá ngắn hoặc quá dài'
-regex: '&cTên đăng nhập của bạn có chứa kí tự đặc biệt không được cho phép. Các kí tự hợp lệ: REG_EX'
-add_email: '&cVui lòng thêm địa chỉ email cho tài khoản với lệnh: /email add email-của-bạn nhập-lại-email-của-bạn'
-bad_database_email: '[AuthMe] Lệnh /email chỉ hoạt động với cơ sở dữ liệu MySQL và SQLite,
- hãy liên hệ điều hành viên của server'
-recovery_email: '&cQuên mật khẩu? Hãy dùng lệnh /email recovery '
-usage_captcha: '&cBạn cần nhập mã xác nhận: /captcha '
-wrong_captcha: '&cSai mã xác nhận, nhập lại: /captcha '
-valid_captcha: '&aMã xác nhận hợp lệ!'
-kick_forvip: '&cNgười chơi VIP đã vào server hiện đang full!'
-kick_fullserver: '&cXin lỗi, hiện tại server không còn trống slot để bạn có thể vào!'
-usage_email_add: '&eSử dụng: /email add '
-usage_email_change: '&eSử dụng: /email change '
-usage_email_recovery: '&eSử dụng: /email recovery '
-new_email_invalid: '[AuthMe] Địa chỉ email mới không hợp lệ!'
-old_email_invalid: '[AuthMe] Địa chỉ email cũ không hợp lệ!'
-email_invalid: '[AuthMe] Sai địa chỉ email'
-email_added: '[AuthMe] Đã thêm địa chỉ email !'
-email_confirm: '[AuthMe] Xác nhận email !'
-email_changed: '[AuthMe] Đã thay đổi email !'
-email_send: '[AuthMe] Đã gửi email khôi phục mật khẩu tới bạn !'
-country_banned: 'Rất tiếc, quốc gia của bạn không được phép gia nhập server'
-antibot_auto_enabled: '[AuthMe] AntiBot đã được kích hoạt vì lượng người chơi kết nối vượt quá giới hạn!'
-antibot_auto_disabled: '[AuthMe] AntiBot tự huỷ kích hoạt sau %m phút,
+unknown_user: '&fNgười chơi không tồn tại trong cơ sở dữ liệu'
+unsafe_spawn: '&fNơi thoát server của bạn không an toàn, đang dịch chuyển bạn tới điểm spawn của server'
+not_logged_in: '&cChưa đăng nhập!'
+reg_voluntarily: '&fBạn có thể đăng kí tài khoản với lệnh
+ "/register mật-khẩu nhập-lại-mật-khẩu"'
+usage_log: '&eSử dụng: /login password'
+wrong_pwd: '&cSai mật khẩu'
+unregistered: '&cHuỷ đăng kí thành công!'
+reg_disabled: '&cHệ thống đăng kí đã bị vô hiệu'
+valid_session: '&cPhiên đăng nhập còn tồn tại, bạn không cần nhập mật khẩu'
+login: '&cĐăng nhập thành công!'
+vb_nonActiv: '&fTài khoản của bạn chưa được kích hoạt, kiểm tra email!'
+user_regged: '&cTên đăng nhập này đã được đăng kí'
+usage_reg: '&eSử dụng: /register mật-khẩu nhập-lại-mật-khẩu'
+max_reg: '&fSố lượng tài khoản ở IP của bạn trong server này đã quá giới hạn cho phép'
+no_perm: '&cKhông có quyền'
+error: '&fCó lỗi xảy ra; Báo lại cho người điều hành server'
+login_msg: '&cĐăng nhập với lệnh "/login mật-khẩu"'
+reg_msg: '&cĐăng kí tài khoản với lệnh "/register mật-khẩu nhập-lại-mật-khẩu"'
+reg_email_msg: '&cĐăng kí email cho tài khoản với lệnh "/register "'
+usage_unreg: '&eSử dụng: /unregister mật-khẩu'
+pwd_changed: '&cĐã đổi mật khẩu!'
+user_unknown: '&cTài khoản này chưa được đăng kí'
+password_error: '&fMật khẩu không khớp'
+unvalid_session: '&fPhiên đăng nhập không hồi đáp, vui lòng chờ phiên đăng nhập kết thúc'
+reg_only: '&fChỉ cho phép người đã đăng kí! Hãy vào trang http://web-của.bạn/ để đăng kí'
+logged_in: '&cĐã đăng nhập!'
+logout: '&cThoát đăng nhập thành công'
+same_nick: '&fTài khoản đang được người khác sử dụng trong server'
+registered: '&cĐăng kí thành công!'
+pass_len: '&fMật khẩu của bạn quá ngắn hoặc quá dài'
+reload: '&fThiết lập và dữ liệu đã được nạp lại'
+timeout: '&fQuá thời gian đăng nhập'
+usage_changepassword: '&eSử dụng: /changepassword mật-khẩu-cũ mật-khẩu-mới'
+name_len: '&cTên đăng nhập của bạn quá ngắn hoặc quá dài'
+regex: '&cTên đăng nhập của bạn có chứa kí tự đặc biệt không được cho phép. Các kí tự hợp lệ: REG_EX'
+add_email: '&cVui lòng thêm địa chỉ email cho tài khoản với lệnh: /email add email-của-bạn nhập-lại-email-của-bạn'
+bad_database_email: '[AuthMe] Lệnh /email chỉ hoạt động với cơ sở dữ liệu MySQL và SQLite,
+ hãy liên hệ điều hành viên của server'
+recovery_email: '&cQuên mật khẩu? Hãy dùng lệnh /email recovery '
+usage_captcha: '&cBạn cần nhập mã xác nhận: /captcha '
+wrong_captcha: '&cSai mã xác nhận, nhập lại: /captcha '
+valid_captcha: '&aMã xác nhận hợp lệ!'
+kick_forvip: '&cNgười chơi VIP đã vào server hiện đang full!'
+kick_fullserver: '&cXin lỗi, hiện tại server không còn trống slot để bạn có thể vào!'
+usage_email_add: '&eSử dụng: /email add '
+usage_email_change: '&eSử dụng: /email change '
+usage_email_recovery: '&eSử dụng: /email recovery '
+new_email_invalid: '[AuthMe] Địa chỉ email mới không hợp lệ!'
+old_email_invalid: '[AuthMe] Địa chỉ email cũ không hợp lệ!'
+email_invalid: '[AuthMe] Sai địa chỉ email'
+email_added: '[AuthMe] Đã thêm địa chỉ email !'
+email_confirm: '[AuthMe] Xác nhận email !'
+email_changed: '[AuthMe] Đã thay đổi email !'
+email_send: '[AuthMe] Đã gửi email khôi phục mật khẩu tới bạn !'
+country_banned: 'Rất tiếc, quốc gia của bạn không được phép gia nhập server'
+antibot_auto_enabled: '[AuthMe] AntiBot đã được kích hoạt vì lượng người chơi kết nối vượt quá giới hạn!'
+antibot_auto_disabled: '[AuthMe] AntiBot tự huỷ kích hoạt sau %m phút,
hi vọng lượng kết nối sẽ giảm bớt'
\ No newline at end of file
diff --git a/src/main/resources/messages_zhcn.yml b/src/main/resources/messages/messages_zhcn.yml
similarity index 100%
rename from src/main/resources/messages_zhcn.yml
rename to src/main/resources/messages/messages_zhcn.yml
diff --git a/src/main/resources/messages_zhhk.yml b/src/main/resources/messages/messages_zhhk.yml
similarity index 98%
rename from src/main/resources/messages_zhhk.yml
rename to src/main/resources/messages/messages_zhhk.yml
index 173fb46c..d66f1003 100644
--- a/src/main/resources/messages_zhhk.yml
+++ b/src/main/resources/messages/messages_zhhk.yml
@@ -1,61 +1,61 @@
-# Translator: uSoc_lifehome (http://lifeho.me) #
-# Translator: WaterXCubic #
-# -------------------------------------------- #
-unknown_user: '&8[&6Τt&8] &fΤƨäsbƮwC'
-unsafe_spawn: '&8[&6Τt&8] &fAnXmwA{bNǰeA쭫IC'
-not_logged_in: '&8[&6Τt&8] &cA٨SnJ I'
-reg_voluntarily: '&8[&6Τt&8] &fAiHϥγoӪOӵUG m /register <бKX> n'
-usage_log: '&8[&6Τt&8] &cΪkG m /login n'
-wrong_pwd: '&8[&6Τt&8] &cAJF~KXC'
-unregistered: '&8[&6Τt&8] &cAw\|UOC'
-reg_disabled: '&8[&6Τt&8] &cAwsaUC'
-valid_session: '&8[&6Τt&8] &b I ڰOoAAw^ӡ'
-login: '&8[&6Τt&8] &cA\nJFC'
-password_error_nick: '&fAiHϥΧAWrKX!'
-password_error_unsafe: '&fAiHϥΤwKX'
-vb_nonActiv: '&8[&6Τt&8] &fAb٨SgLql I'
-user_regged: '&8[&6Τt&8] &cΤWwgULFC'
-usage_reg: '&8[&6Τt&8] &cΪkG m /register <бKX> n'
-max_reg: '&8[&6Τt&8] &fAIPa}wFUƤWC'
-no_perm: '&8[&6Τt&8] &bAiH CraftingHK aʬ줤dݻC'
-error: '&8[&6Τt&8] &foͿ~AлPzpC'
-login_msg: '&8[&6Τt&8] &cШϥγoӫOӵnJG m /login n'
-reg_msg: '&8[&6Τt&8] &cШϥγoӪOӵUG m /register <бKX> n'
-reg_email_msg: '&8[&6Τt&8] &cШϥγoӪOӵUG m /register <йql> n'
-usage_unreg: '&8[&6Τt&8] &cΪkG m /unregister n'
-pwd_changed: '&8[&6Τt&8] &cA\FAKX I'
-user_unknown: '&8[&6Τt&8] &cΤWSwnOơC'
-password_error: '&8[&6Τt&8] &fKXŦXC'
-invalid_session: '&8[&6Τt&8] &fnJqƤwlaAеݵnJqC'
-reg_only: '&8[&6Τt&8] &fwU|AХ https://www.example.com/ UC'
-logged_in: '&8[&6Τt&8] &cAwgnJLFC'
-logout: '&8[&6Τt&8] &bA\nXFC'
-same_nick: '&8[&6Τt&8] &fPWawbCC'
-registered: '&8[&6Τt&8] &bA\UFC'
-pass_len: '&8[&6Τt&8] &fAKXäŦXWwסC'
-reload: '&8[&6Τt&8] &bnJtγ]wθƮwsJC'
-timeout: '&8[&6Τt&8] &fnJOɡC'
-usage_changepassword: '&8[&6Τt&8] &fΪkG m /changepassword <±KX> n'
-name_len: '&8[&6Τt&8] &cAΤWŦXWwסC'
-regex: '&8[&6Τt&8] &cAΤWte\ršCHU\rG REG_EX'
-add_email: '&8[&6Τt&8] &bЬAbߧYK[qla}G m /email add <йqla}> n'
-bad_database_email: '&8[&6Τt&8] OuAΩϥMySQLSQLiteAC'
-recovery_email: '&8[&6Τt&8] &cѰOKX H ШϥγoӪOӧsKXG m /email recovery n'
-usage_captcha: '&8[&6Τt&8] &cΪkG m /captcha n'
-wrong_captcha: '&8[&6Τt&8] &cAJF~ҽXAШϥ m /captcha <ҽX> n AJC'
-valid_captcha: '&8[&6Τt&8] &cAҿJҽXOLĪ I'
-kick_forvip: '&c]VIPanJFAC'
-kick_fullserver: '&cpI ]AHFAҥHAثenJAC'
-usage_email_add: '&8[&6Τt&8] &fΪkG m /email add <йql> n'
-usage_email_change: '&8[&6Τt&8] &fΪkG m /email change <¹ql> n'
-usage_email_recovery: '&8[&6Τt&8] &fΪkG m /email recovery n'
-new_email_invalid: '&8[&6Τt&8] AҶgsqla}äTC'
-old_email_invalid: '&8[&6Τt&8] AҶg¹qla}äTC'
-email_invalid: '&8[&6Τt&8] AҶgqla}äTC'
-email_added: '&8[&6Τt&8] w[JAqla}OC'
-email_confirm: '&8[&6Τt&8] ЭпJAqla}C'
-email_changed: '&8[&6Τt&8] Aqla}OwC'
-email_send: '&8[&6Τt&8] ѰOKXHwHXAЬdC'
-country_banned: '&8[&6Τt&8] AwAaѹCAȡC'
-antibot_auto_enabled: '&8[&6Τt&8] H{Ǥw]{ɤjqM`suӱҥΡC'
-antibot_auto_disabled: '&8[&6Τt&8] H{ˬd줣`sƤw֡Aé %m ᰱB@C'
+# Translator: uSoc_lifehome (http://lifeho.me) #
+# Translator: WaterXCubic #
+# -------------------------------------------- #
+unknown_user: '&8[&6Τt&8] &fΤƨäsbƮwC'
+unsafe_spawn: '&8[&6Τt&8] &fAnXmwA{bNǰeA쭫IC'
+not_logged_in: '&8[&6Τt&8] &cA٨SnJ I'
+reg_voluntarily: '&8[&6Τt&8] &fAiHϥγoӪOӵUG m /register <бKX> n'
+usage_log: '&8[&6Τt&8] &cΪkG m /login n'
+wrong_pwd: '&8[&6Τt&8] &cAJF~KXC'
+unregistered: '&8[&6Τt&8] &cAw\|UOC'
+reg_disabled: '&8[&6Τt&8] &cAwsaUC'
+valid_session: '&8[&6Τt&8] &b I ڰOoAAw^ӡ'
+login: '&8[&6Τt&8] &cA\nJFC'
+password_error_nick: '&fAiHϥΧAWrKX!'
+password_error_unsafe: '&fAiHϥΤwKX'
+vb_nonActiv: '&8[&6Τt&8] &fAb٨SgLql I'
+user_regged: '&8[&6Τt&8] &cΤWwgULFC'
+usage_reg: '&8[&6Τt&8] &cΪkG m /register <бKX> n'
+max_reg: '&8[&6Τt&8] &fAIPa}wFUƤWC'
+no_perm: '&8[&6Τt&8] &bAiH CraftingHK aʬ줤dݻC'
+error: '&8[&6Τt&8] &foͿ~AлPzpC'
+login_msg: '&8[&6Τt&8] &cШϥγoӫOӵnJG m /login n'
+reg_msg: '&8[&6Τt&8] &cШϥγoӪOӵUG m /register <бKX> n'
+reg_email_msg: '&8[&6Τt&8] &cШϥγoӪOӵUG m /register <йql> n'
+usage_unreg: '&8[&6Τt&8] &cΪkG m /unregister n'
+pwd_changed: '&8[&6Τt&8] &cA\FAKX I'
+user_unknown: '&8[&6Τt&8] &cΤWSwnOơC'
+password_error: '&8[&6Τt&8] &fKXŦXC'
+invalid_session: '&8[&6Τt&8] &fnJqƤwlaAеݵnJqC'
+reg_only: '&8[&6Τt&8] &fwU|AХ https://www.example.com/ UC'
+logged_in: '&8[&6Τt&8] &cAwgnJLFC'
+logout: '&8[&6Τt&8] &bA\nXFC'
+same_nick: '&8[&6Τt&8] &fPWawbCC'
+registered: '&8[&6Τt&8] &bA\UFC'
+pass_len: '&8[&6Τt&8] &fAKXäŦXWwסC'
+reload: '&8[&6Τt&8] &bnJtγ]wθƮwsJC'
+timeout: '&8[&6Τt&8] &fnJOɡC'
+usage_changepassword: '&8[&6Τt&8] &fΪkG m /changepassword <±KX> n'
+name_len: '&8[&6Τt&8] &cAΤWŦXWwסC'
+regex: '&8[&6Τt&8] &cAΤWte\ršCHU\rG REG_EX'
+add_email: '&8[&6Τt&8] &bЬAbߧYK[qla}G m /email add <йqla}> n'
+bad_database_email: '&8[&6Τt&8] OuAΩϥMySQLSQLiteAC'
+recovery_email: '&8[&6Τt&8] &cѰOKX H ШϥγoӪOӧsKXG m /email recovery n'
+usage_captcha: '&8[&6Τt&8] &cΪkG m /captcha n'
+wrong_captcha: '&8[&6Τt&8] &cAJF~ҽXAШϥ m /captcha <ҽX> n AJC'
+valid_captcha: '&8[&6Τt&8] &cAҿJҽXOLĪ I'
+kick_forvip: '&c]VIPanJFAC'
+kick_fullserver: '&cpI ]AHFAҥHAثenJAC'
+usage_email_add: '&8[&6Τt&8] &fΪkG m /email add <йql> n'
+usage_email_change: '&8[&6Τt&8] &fΪkG m /email change <¹ql> n'
+usage_email_recovery: '&8[&6Τt&8] &fΪkG m /email recovery n'
+new_email_invalid: '&8[&6Τt&8] AҶgsqla}äTC'
+old_email_invalid: '&8[&6Τt&8] AҶg¹qla}äTC'
+email_invalid: '&8[&6Τt&8] AҶgqla}äTC'
+email_added: '&8[&6Τt&8] w[JAqla}OC'
+email_confirm: '&8[&6Τt&8] ЭпJAqla}C'
+email_changed: '&8[&6Τt&8] Aqla}OwC'
+email_send: '&8[&6Τt&8] ѰOKXHwHXAЬdC'
+country_banned: '&8[&6Τt&8] AwAaѹCAȡC'
+antibot_auto_enabled: '&8[&6Τt&8] H{Ǥw]{ɤjqM`suӱҥΡC'
+antibot_auto_disabled: '&8[&6Τt&8] H{ˬd줣`sƤw֡Aé %m ᰱB@C'
diff --git a/src/main/resources/messages_zhtw.yml b/src/main/resources/messages/messages_zhtw.yml
similarity index 98%
rename from src/main/resources/messages_zhtw.yml
rename to src/main/resources/messages/messages_zhtw.yml
index 6668976e..5091f841 100644
--- a/src/main/resources/messages_zhtw.yml
+++ b/src/main/resources/messages/messages_zhtw.yml
@@ -1,62 +1,62 @@
-# Translator: MineWolf50
-# Last Time Edit : 2015 / 7 / 14 , A.M.10:14
-# = = = = = = = = = = = = = = = = = = = = = = = #
-unknown_user: "&b【AuthMe】&6沒有在資料庫內找到該玩家。"
-unsafe_spawn: '&b【AuthMe】&6你登出的地點不安全,已傳送你到安全的地點。'
-not_logged_in: '&b【AuthMe】&6你還沒有登入!'
-reg_voluntarily: '&b【AuthMe】&6使用 &c"/register <密碼> <確認密碼>" &6來註冊你的暱稱'
-usage_log: '&b【AuthMe】&6用法: &c"/login <密碼>"'
-wrong_pwd: '&b【AuthMe】&6密碼錯誤!'
-unregistered: '&b【AuthMe】&6你已經成功取消註冊。'
-reg_disabled: '&b【AuthMe】&6已關閉註冊功能'
-password_error_nick: '&b【AuthMe】&6你不可以用你的 ID ( 名稱 ) 來當作密碼 !'
-password_error_unsafe: '&b【AuthMe】&6你不可以使用這個不安全的密碼'
-valid_session: '&b【AuthMe】&6你已經成功登入!'
-login: '&b【AuthMe】&6密碼正確,你已成功登入!'
-vb_nonActiv: '&b【AuthMe】&6你的帳號還沒有經過驗證! 檢查看看你的電子信箱 (Email) 吧!'
-user_regged: '&b【AuthMe】&6這個帳號已經被註冊過了!'
-usage_reg: '&b【AuthMe】&6用法: &c"/register <密碼> <確認密碼>"'
-max_reg: '&b【AuthMe】&6你的 IP 位置所註冊的帳號數量已經達到最大。'
-no_perm: '&b【AuthMe】&6你沒有使用該指令的權限。'
-error: '&b【AuthMe】&6發生錯誤,請聯繫管理員'
-login_msg: '&b【AuthMe】&6請使用 &c"/login <密碼>" &6來登入。'
-reg_msg: '&b【AuthMe】&6請使用 "&c/register <密碼> <確認密碼>" 來註冊。'
-reg_email_msg: '&b【AuthMe】&6請使用 &c"/register <重複Email>" 來註冊'
-usage_unreg: '&b【AuthMe】&6用法: &c"/unregister <密碼>"'
-pwd_changed: '&b【AuthMe】&6密碼變更成功!'
-user_unknown: '&b【AuthMe】&6這個帳號還沒有註冊過'
-password_error: '&b【AuthMe】&6兩次輸入的密碼不一致!'
-invalid_session: '&b【AuthMe】&6憑證日期不相符!'
-reg_only: '&b【AuthMe】&6請到下列網站 :「 http://example.com 」 進行註冊'
-logged_in: '&b【AuthMe】&6你已經登入了!'
-logout: '&b【AuthMe】&6你已成功登出'
-same_nick: '&b【AuthMe】&6有同樣帳號的玩家在線上!'
-registered: '&b【AuthMe】&6你已成功註冊'
-pass_len: '&b【AuthMe】&6你的密碼 超過最大字數 / 小於最小字數'
-reload: '&b【AuthMe】&6已重新讀取設定檔及資料庫'
-timeout: '&b【AuthMe】&6超過登入時間,請稍後再試一次'
-usage_changepassword: '&b【AuthMe】&6用法: &c"/changepassword <舊密碼> <新密碼>"'
-name_len: '&b【AuthMe】&6你的暱稱 太長 / 太短 了!'
-regex: '&b【AuthMe】&6暱稱裡包含不能使用的字符'
-add_email: '&b【AuthMe】&6請使用 &c"/email add <你的Email> <再次輸入你的Email>" &6來添加 Email'
-bad_database_email: '&b【AuthMe】&6此指令只適用於有使用MySQL和SQLite的伺服器。'
-recovery_email: '&b【AuthMe】&6忘記密碼了嗎? 使用 &c"/email recovery <你的Email>"'
-usage_captcha: '&b【AuthMe】&6請用 &c"/captcha " &6來輸入你的驗證碼'
-wrong_captcha: '&b【AuthMe】&6錯誤的驗證碼'
-valid_captcha: '&b【AuthMe】&6驗證碼無效!'
-kick_forvip: '&b【AuthMe】&6你已經被請出。&c原因 : 有 VIP 玩家登入伺服器'
-kick_fullserver: '&b【AuthMe】&6伺服器已經滿了,請等等再試一次'
-usage_email_add: '&b【AuthMe】&6用法: &c"/email add <你的Email> <重複Email>"'
-usage_email_change: '&b【AuthMe】&6用法: &c"/email change <舊的Email> <新的Email>"'
-usage_email_recovery: '&b【AuthMe】&6用法: &c"/email recovery <你的Email>"'
-new_email_invalid: '&b【AuthMe】&6新的Email無效!'
-old_email_invalid: '&b【AuthMe】&6舊的Email無效!'
-email_invalid: '&b【AuthMe】&6無效的Email!'
-email_added: '&b【AuthMe】&6已添加Email!'
-email_confirm: '&b【AuthMe】&6請驗證你的Email!'
-email_changed: '&b【AuthMe】&6Email已變更!'
-email_send: '&b【AuthMe】&6已經送出重設密碼要求至你的Email , 請查收。'
-email_exists: '&b【AuthMe】&6這個帳戶已經有設定電子郵件了'
-country_banned: '&b【AuthMe】&6你所在的地區無法進入此伺服器'
-antibot_auto_enabled: '&b【AuthMe】&6AntiBotMod已自動啟用!'
+# Translator: MineWolf50
+# Last Time Edit : 2015 / 7 / 14 , A.M.10:14
+# = = = = = = = = = = = = = = = = = = = = = = = #
+unknown_user: "&b【AuthMe】&6沒有在資料庫內找到該玩家。"
+unsafe_spawn: '&b【AuthMe】&6你登出的地點不安全,已傳送你到安全的地點。'
+not_logged_in: '&b【AuthMe】&6你還沒有登入!'
+reg_voluntarily: '&b【AuthMe】&6使用 &c"/register <密碼> <確認密碼>" &6來註冊你的暱稱'
+usage_log: '&b【AuthMe】&6用法: &c"/login <密碼>"'
+wrong_pwd: '&b【AuthMe】&6密碼錯誤!'
+unregistered: '&b【AuthMe】&6你已經成功取消註冊。'
+reg_disabled: '&b【AuthMe】&6已關閉註冊功能'
+password_error_nick: '&b【AuthMe】&6你不可以用你的 ID ( 名稱 ) 來當作密碼 !'
+password_error_unsafe: '&b【AuthMe】&6你不可以使用這個不安全的密碼'
+valid_session: '&b【AuthMe】&6你已經成功登入!'
+login: '&b【AuthMe】&6密碼正確,你已成功登入!'
+vb_nonActiv: '&b【AuthMe】&6你的帳號還沒有經過驗證! 檢查看看你的電子信箱 (Email) 吧!'
+user_regged: '&b【AuthMe】&6這個帳號已經被註冊過了!'
+usage_reg: '&b【AuthMe】&6用法: &c"/register <密碼> <確認密碼>"'
+max_reg: '&b【AuthMe】&6你的 IP 位置所註冊的帳號數量已經達到最大。'
+no_perm: '&b【AuthMe】&6你沒有使用該指令的權限。'
+error: '&b【AuthMe】&6發生錯誤,請聯繫管理員'
+login_msg: '&b【AuthMe】&6請使用 &c"/login <密碼>" &6來登入。'
+reg_msg: '&b【AuthMe】&6請使用 "&c/register <密碼> <確認密碼>" 來註冊。'
+reg_email_msg: '&b【AuthMe】&6請使用 &c"/register <重複Email>" 來註冊'
+usage_unreg: '&b【AuthMe】&6用法: &c"/unregister <密碼>"'
+pwd_changed: '&b【AuthMe】&6密碼變更成功!'
+user_unknown: '&b【AuthMe】&6這個帳號還沒有註冊過'
+password_error: '&b【AuthMe】&6兩次輸入的密碼不一致!'
+invalid_session: '&b【AuthMe】&6憑證日期不相符!'
+reg_only: '&b【AuthMe】&6請到下列網站 :「 http://example.com 」 進行註冊'
+logged_in: '&b【AuthMe】&6你已經登入了!'
+logout: '&b【AuthMe】&6你已成功登出'
+same_nick: '&b【AuthMe】&6有同樣帳號的玩家在線上!'
+registered: '&b【AuthMe】&6你已成功註冊'
+pass_len: '&b【AuthMe】&6你的密碼 超過最大字數 / 小於最小字數'
+reload: '&b【AuthMe】&6已重新讀取設定檔及資料庫'
+timeout: '&b【AuthMe】&6超過登入時間,請稍後再試一次'
+usage_changepassword: '&b【AuthMe】&6用法: &c"/changepassword <舊密碼> <新密碼>"'
+name_len: '&b【AuthMe】&6你的暱稱 太長 / 太短 了!'
+regex: '&b【AuthMe】&6暱稱裡包含不能使用的字符'
+add_email: '&b【AuthMe】&6請使用 &c"/email add <你的Email> <再次輸入你的Email>" &6來添加 Email'
+bad_database_email: '&b【AuthMe】&6此指令只適用於有使用MySQL和SQLite的伺服器。'
+recovery_email: '&b【AuthMe】&6忘記密碼了嗎? 使用 &c"/email recovery <你的Email>"'
+usage_captcha: '&b【AuthMe】&6請用 &c"/captcha " &6來輸入你的驗證碼'
+wrong_captcha: '&b【AuthMe】&6錯誤的驗證碼'
+valid_captcha: '&b【AuthMe】&6驗證碼無效!'
+kick_forvip: '&b【AuthMe】&6你已經被請出。&c原因 : 有 VIP 玩家登入伺服器'
+kick_fullserver: '&b【AuthMe】&6伺服器已經滿了,請等等再試一次'
+usage_email_add: '&b【AuthMe】&6用法: &c"/email add <你的Email> <重複Email>"'
+usage_email_change: '&b【AuthMe】&6用法: &c"/email change <舊的Email> <新的Email>"'
+usage_email_recovery: '&b【AuthMe】&6用法: &c"/email recovery <你的Email>"'
+new_email_invalid: '&b【AuthMe】&6新的Email無效!'
+old_email_invalid: '&b【AuthMe】&6舊的Email無效!'
+email_invalid: '&b【AuthMe】&6無效的Email!'
+email_added: '&b【AuthMe】&6已添加Email!'
+email_confirm: '&b【AuthMe】&6請驗證你的Email!'
+email_changed: '&b【AuthMe】&6Email已變更!'
+email_send: '&b【AuthMe】&6已經送出重設密碼要求至你的Email , 請查收。'
+email_exists: '&b【AuthMe】&6這個帳戶已經有設定電子郵件了'
+country_banned: '&b【AuthMe】&6你所在的地區無法進入此伺服器'
+antibot_auto_enabled: '&b【AuthMe】&6AntiBotMod已自動啟用!'
antibot_auto_disabled: '&b【AuthMe】&6AntiBotMod將會於 &c%m &6分鐘後自動關閉'
\ No newline at end of file