H2 database support
This commit is contained in:
parent
e04608e499
commit
46f64d8048
11
pom.xml
11
pom.xml
@ -346,6 +346,11 @@
|
|||||||
<pattern>com.google.gson</pattern>
|
<pattern>com.google.gson</pattern>
|
||||||
<shadedPattern>fr.xephi.authme.libs.com.google.gson</shadedPattern>
|
<shadedPattern>fr.xephi.authme.libs.com.google.gson</shadedPattern>
|
||||||
</relocation>
|
</relocation>
|
||||||
|
<relocation>
|
||||||
|
<pattern>org.h2</pattern>
|
||||||
|
<shadedPattern>fr.xephi.authme.libs.org.h2</shadedPattern>
|
||||||
|
</relocation>
|
||||||
|
|
||||||
<!-- <relocation>-->
|
<!-- <relocation>-->
|
||||||
<!-- <pattern>com.cryptomorin.xseries</pattern>-->
|
<!-- <pattern>com.cryptomorin.xseries</pattern>-->
|
||||||
<!-- <shadedPattern>fr.xephi.authme.libs.com.cryptomorin.xseries</shadedPattern>-->
|
<!-- <shadedPattern>fr.xephi.authme.libs.com.cryptomorin.xseries</shadedPattern>-->
|
||||||
@ -519,6 +524,10 @@
|
|||||||
</build>
|
</build>
|
||||||
|
|
||||||
<repositories>
|
<repositories>
|
||||||
|
<repository>
|
||||||
|
<id>lss233-repo</id>
|
||||||
|
<url>https://crystal.app.lss233.com/repositories/minecraft/</url>
|
||||||
|
</repository>
|
||||||
<repository>
|
<repository>
|
||||||
<id>opencollab-snapshot-main</id>
|
<id>opencollab-snapshot-main</id>
|
||||||
<url>https://repo.opencollab.dev/main/</url>
|
<url>https://repo.opencollab.dev/main/</url>
|
||||||
@ -1125,7 +1134,7 @@
|
|||||||
<groupId>com.h2database</groupId>
|
<groupId>com.h2database</groupId>
|
||||||
<artifactId>h2</artifactId>
|
<artifactId>h2</artifactId>
|
||||||
<version>2.1.214</version>
|
<version>2.1.214</version>
|
||||||
<scope>test</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@ -4,7 +4,7 @@ package fr.xephi.authme.datasource;
|
|||||||
* DataSource type.
|
* DataSource type.
|
||||||
*/
|
*/
|
||||||
public enum DataSourceType {
|
public enum DataSourceType {
|
||||||
// H2,
|
H2,
|
||||||
|
|
||||||
MYSQL,
|
MYSQL,
|
||||||
|
|
||||||
|
|||||||
@ -1,408 +1,408 @@
|
|||||||
//package fr.xephi.authme.datasource;
|
package fr.xephi.authme.datasource;
|
||||||
//
|
|
||||||
//import com.google.common.annotations.VisibleForTesting;
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
//import fr.xephi.authme.ConsoleLogger;
|
import fr.xephi.authme.ConsoleLogger;
|
||||||
//import fr.xephi.authme.data.auth.PlayerAuth;
|
import fr.xephi.authme.data.auth.PlayerAuth;
|
||||||
//import fr.xephi.authme.datasource.columnshandler.AuthMeColumnsHandler;
|
import fr.xephi.authme.datasource.columnshandler.AuthMeColumnsHandler;
|
||||||
//import fr.xephi.authme.output.ConsoleLoggerFactory;
|
import fr.xephi.authme.output.ConsoleLoggerFactory;
|
||||||
//import fr.xephi.authme.settings.Settings;
|
import fr.xephi.authme.settings.Settings;
|
||||||
//import fr.xephi.authme.settings.properties.DatabaseSettings;
|
import fr.xephi.authme.settings.properties.DatabaseSettings;
|
||||||
//
|
|
||||||
//import java.io.File;
|
import java.io.File;
|
||||||
//import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
//import java.sql.DatabaseMetaData;
|
import java.sql.DatabaseMetaData;
|
||||||
//import java.sql.DriverManager;
|
import java.sql.DriverManager;
|
||||||
//import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
//import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
//import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
//import java.sql.Statement;
|
import java.sql.Statement;
|
||||||
//import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
//import java.util.Collection;
|
import java.util.Collection;
|
||||||
//import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
//import java.util.List;
|
import java.util.List;
|
||||||
//import java.util.Locale;
|
import java.util.Locale;
|
||||||
//import java.util.Set;
|
import java.util.Set;
|
||||||
//
|
|
||||||
//import static fr.xephi.authme.datasource.SqlDataSourceUtils.getNullableLong;
|
import static fr.xephi.authme.datasource.SqlDataSourceUtils.getNullableLong;
|
||||||
//import static fr.xephi.authme.datasource.SqlDataSourceUtils.logSqlException;
|
import static fr.xephi.authme.datasource.SqlDataSourceUtils.logSqlException;
|
||||||
//
|
|
||||||
///**
|
/**
|
||||||
// * H2 data source.
|
* H2 data source.
|
||||||
// */
|
*/
|
||||||
//@SuppressWarnings({"checkstyle:AbbreviationAsWordInName"}) // Justification: Class name cannot be changed anymore
|
@SuppressWarnings({"checkstyle:AbbreviationAsWordInName"}) // Justification: Class name cannot be changed anymore
|
||||||
//public class H2 extends AbstractSqlDataSource {
|
public class H2 extends AbstractSqlDataSource {
|
||||||
//
|
|
||||||
// private final ConsoleLogger logger = ConsoleLoggerFactory.get(H2.class);
|
private final ConsoleLogger logger = ConsoleLoggerFactory.get(H2.class);
|
||||||
// private final Settings settings;
|
private final Settings settings;
|
||||||
// private final File dataFolder;
|
private final File dataFolder;
|
||||||
// private final String database;
|
private final String database;
|
||||||
// private final String tableName;
|
private final String tableName;
|
||||||
// private final Columns col;
|
private final Columns col;
|
||||||
// private Connection con;
|
private Connection con;
|
||||||
//
|
|
||||||
// /**
|
/**
|
||||||
// * Constructor for H2.
|
* Constructor for H2.
|
||||||
// *
|
*
|
||||||
// * @param settings The settings instance
|
* @param settings The settings instance
|
||||||
// * @param dataFolder The data folder
|
* @param dataFolder The data folder
|
||||||
// * @throws SQLException when initialization of a SQL datasource failed
|
* @throws SQLException when initialization of a SQL datasource failed
|
||||||
// */
|
*/
|
||||||
// public H2(Settings settings, File dataFolder) throws SQLException {
|
public H2(Settings settings, File dataFolder) throws SQLException {
|
||||||
// this.settings = settings;
|
this.settings = settings;
|
||||||
// this.dataFolder = dataFolder;
|
this.dataFolder = dataFolder;
|
||||||
// this.database = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
this.database = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
||||||
// this.tableName = settings.getProperty(DatabaseSettings.MYSQL_TABLE);
|
this.tableName = settings.getProperty(DatabaseSettings.MYSQL_TABLE);
|
||||||
// this.col = new Columns(settings);
|
this.col = new Columns(settings);
|
||||||
//
|
|
||||||
// try {
|
try {
|
||||||
// this.connect();
|
this.connect();
|
||||||
// this.setup();
|
this.setup();
|
||||||
// } catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
// logger.logException("Error during H2 initialization:", ex);
|
logger.logException("Error during H2 initialization:", ex);
|
||||||
// throw ex;
|
throw ex;
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @VisibleForTesting
|
@VisibleForTesting
|
||||||
// H2(Settings settings, File dataFolder, Connection connection) {
|
H2(Settings settings, File dataFolder, Connection connection) {
|
||||||
// this.settings = settings;
|
this.settings = settings;
|
||||||
// this.dataFolder = dataFolder;
|
this.dataFolder = dataFolder;
|
||||||
// this.database = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
this.database = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
||||||
// this.tableName = settings.getProperty(DatabaseSettings.MYSQL_TABLE);
|
this.tableName = settings.getProperty(DatabaseSettings.MYSQL_TABLE);
|
||||||
// this.col = new Columns(settings);
|
this.col = new Columns(settings);
|
||||||
// this.con = connection;
|
this.con = connection;
|
||||||
// this.columnsHandler = AuthMeColumnsHandler.createForSqlite(con, settings);
|
this.columnsHandler = AuthMeColumnsHandler.createForSqlite(con, settings);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// /**
|
/**
|
||||||
// * Initializes the connection to the H2 database.
|
* Initializes the connection to the H2 database.
|
||||||
// *
|
*
|
||||||
// * @throws SQLException when an SQL error occurs while connecting
|
* @throws SQLException when an SQL error occurs while connecting
|
||||||
// */
|
*/
|
||||||
// protected void connect() throws SQLException {
|
protected void connect() throws SQLException {
|
||||||
// try {
|
try {
|
||||||
// Class.forName("org.h2.Driver");
|
Class.forName("fr.xephi.authme.libs.org.h2.Driver");
|
||||||
// } catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
// throw new IllegalStateException("Failed to load H2 JDBC class", e);
|
throw new IllegalStateException("Failed to load H2 JDBC class", e);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// logger.debug("H2 driver loaded");
|
logger.debug("H2 driver loaded");
|
||||||
// this.con = DriverManager.getConnection(this.getJdbcUrl(this.dataFolder.getAbsolutePath(), "", this.database));
|
this.con = DriverManager.getConnection(this.getJdbcUrl(this.dataFolder.getAbsolutePath(), "", this.database));
|
||||||
// this.columnsHandler = AuthMeColumnsHandler.createForSqlite(con, settings);
|
this.columnsHandler = AuthMeColumnsHandler.createForSqlite(con, settings);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// /**
|
/**
|
||||||
// * Creates the table if necessary, or adds any missing columns to the table.
|
* Creates the table if necessary, or adds any missing columns to the table.
|
||||||
// *
|
*
|
||||||
// * @throws SQLException when an SQL error occurs while initializing the database
|
* @throws SQLException when an SQL error occurs while initializing the database
|
||||||
// */
|
*/
|
||||||
// @VisibleForTesting
|
@VisibleForTesting
|
||||||
// @SuppressWarnings("checkstyle:CyclomaticComplexity")
|
@SuppressWarnings("checkstyle:CyclomaticComplexity")
|
||||||
// protected void setup() throws SQLException {
|
protected void setup() throws SQLException {
|
||||||
// try (Statement st = con.createStatement()) {
|
try (Statement st = con.createStatement()) {
|
||||||
// // Note: cannot add unique fields later on in SQLite, so we add it on initialization
|
// Note: cannot add unique fields later on in SQLite, so we add it on initialization
|
||||||
// st.executeUpdate("CREATE TABLE IF NOT EXISTS " + tableName + " ("
|
st.executeUpdate("CREATE TABLE IF NOT EXISTS " + tableName + " ("
|
||||||
// + col.ID + " INTEGER AUTO_INCREMENT, "
|
+ col.ID + " INTEGER AUTO_INCREMENT, "
|
||||||
// + col.NAME + " VARCHAR(255) NOT NULL UNIQUE, "
|
+ col.NAME + " VARCHAR(255) NOT NULL UNIQUE, "
|
||||||
// + "CONSTRAINT table_const_prim PRIMARY KEY (" + col.ID + "));");
|
+ "CONSTRAINT table_const_prim PRIMARY KEY (" + col.ID + "));");
|
||||||
//
|
|
||||||
// DatabaseMetaData md = con.getMetaData();
|
DatabaseMetaData md = con.getMetaData();
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.REAL_NAME)) {
|
if (isColumnMissing(md, col.REAL_NAME)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
||||||
// + col.REAL_NAME + " VARCHAR(255) NOT NULL DEFAULT 'Player';");
|
+ col.REAL_NAME + " VARCHAR(255) NOT NULL DEFAULT 'Player';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.PASSWORD)) {
|
if (isColumnMissing(md, col.PASSWORD)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.PASSWORD + " VARCHAR(255) NOT NULL DEFAULT '';");
|
+ " ADD COLUMN " + col.PASSWORD + " VARCHAR(255) NOT NULL DEFAULT '';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (!col.SALT.isEmpty() && isColumnMissing(md, col.SALT)) {
|
if (!col.SALT.isEmpty() && isColumnMissing(md, col.SALT)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.SALT + " VARCHAR(255);");
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.SALT + " VARCHAR(255);");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LAST_IP)) {
|
if (isColumnMissing(md, col.LAST_IP)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.LAST_IP + " VARCHAR(40);");
|
+ " ADD COLUMN " + col.LAST_IP + " VARCHAR(40);");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LAST_LOGIN)) {
|
if (isColumnMissing(md, col.LAST_LOGIN)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.LAST_LOGIN + " TIMESTAMP;");
|
+ " ADD COLUMN " + col.LAST_LOGIN + " BIGINT;");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.REGISTRATION_IP)) {
|
if (isColumnMissing(md, col.REGISTRATION_IP)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.REGISTRATION_IP + " VARCHAR(40);");
|
+ " ADD COLUMN " + col.REGISTRATION_IP + " VARCHAR(40);");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.REGISTRATION_DATE)) {
|
if (isColumnMissing(md, col.REGISTRATION_DATE)) {
|
||||||
// addRegistrationDateColumn(st);
|
addRegistrationDateColumn(st);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LASTLOC_X)) {
|
if (isColumnMissing(md, col.LASTLOC_X)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_X
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_X
|
||||||
// + " DOUBLE NOT NULL DEFAULT '0.0';");
|
+ " DOUBLE NOT NULL DEFAULT '0.0';");
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_Y
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_Y
|
||||||
// + " DOUBLE NOT NULL DEFAULT '0.0';");
|
+ " DOUBLE NOT NULL DEFAULT '0.0';");
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_Z
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN " + col.LASTLOC_Z
|
||||||
// + " DOUBLE NOT NULL DEFAULT '0.0';");
|
+ " DOUBLE NOT NULL DEFAULT '0.0';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LASTLOC_WORLD)) {
|
if (isColumnMissing(md, col.LASTLOC_WORLD)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.LASTLOC_WORLD + " VARCHAR(255) NOT NULL DEFAULT 'world';");
|
+ " ADD COLUMN " + col.LASTLOC_WORLD + " VARCHAR(255) NOT NULL DEFAULT 'world';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LASTLOC_YAW)) {
|
if (isColumnMissing(md, col.LASTLOC_YAW)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
||||||
// + col.LASTLOC_YAW + " FLOAT;");
|
+ col.LASTLOC_YAW + " FLOAT;");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.LASTLOC_PITCH)) {
|
if (isColumnMissing(md, col.LASTLOC_PITCH)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
st.executeUpdate("ALTER TABLE " + tableName + " ADD COLUMN "
|
||||||
// + col.LASTLOC_PITCH + " FLOAT;");
|
+ col.LASTLOC_PITCH + " FLOAT;");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.EMAIL)) {
|
if (isColumnMissing(md, col.EMAIL)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.EMAIL + " VARCHAR(255);");
|
+ " ADD COLUMN " + col.EMAIL + " VARCHAR(255);");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.IS_LOGGED)) {
|
if (isColumnMissing(md, col.IS_LOGGED)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.IS_LOGGED + " INT NOT NULL DEFAULT '0';");
|
+ " ADD COLUMN " + col.IS_LOGGED + " INT NOT NULL DEFAULT '0';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.HAS_SESSION)) {
|
if (isColumnMissing(md, col.HAS_SESSION)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.HAS_SESSION + " INT NOT NULL DEFAULT '0';");
|
+ " ADD COLUMN " + col.HAS_SESSION + " INT NOT NULL DEFAULT '0';");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (isColumnMissing(md, col.TOTP_KEY)) {
|
if (isColumnMissing(md, col.TOTP_KEY)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.TOTP_KEY + " VARCHAR(32);");
|
+ " ADD COLUMN " + col.TOTP_KEY + " VARCHAR(32);");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if (!col.PLAYER_UUID.isEmpty() && isColumnMissing(md, col.PLAYER_UUID)) {
|
if (!col.PLAYER_UUID.isEmpty() && isColumnMissing(md, col.PLAYER_UUID)) {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.PLAYER_UUID + " VARCHAR(36)");
|
+ " ADD COLUMN " + col.PLAYER_UUID + " VARCHAR(36)");
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// logger.info("H2 Setup finished");
|
logger.info("H2 Setup finished");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
//
|
|
||||||
// private boolean isColumnMissing(DatabaseMetaData metaData, String columnName) throws SQLException {
|
private boolean isColumnMissing(DatabaseMetaData metaData, String columnName) throws SQLException {
|
||||||
// try (ResultSet rs = metaData.getColumns(null, null, tableName, columnName)) {
|
try (ResultSet rs = metaData.getColumns(null, null, tableName, columnName)) {
|
||||||
// return !rs.next();
|
return !rs.next();
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public void reload() {
|
public void reload() {
|
||||||
// close(con);
|
close(con);
|
||||||
// try {
|
try {
|
||||||
// this.connect();
|
this.connect();
|
||||||
// this.setup();
|
this.setup();
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logger.logException("Error while reloading H2:", ex);
|
logger.logException("Error while reloading H2:", ex);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public PlayerAuth getAuth(String user) {
|
public PlayerAuth getAuth(String user) {
|
||||||
// String sql = "SELECT * FROM " + tableName + " WHERE LOWER(" + col.NAME + ")=LOWER(?);";
|
String sql = "SELECT * FROM " + tableName + " WHERE LOWER(" + col.NAME + ")=LOWER(?);";
|
||||||
// try (PreparedStatement pst = con.prepareStatement(sql)) {
|
try (PreparedStatement pst = con.prepareStatement(sql)) {
|
||||||
// pst.setString(1, user);
|
pst.setString(1, user);
|
||||||
// try (ResultSet rs = pst.executeQuery()) {
|
try (ResultSet rs = pst.executeQuery()) {
|
||||||
// if (rs.next()) {
|
if (rs.next()) {
|
||||||
// return buildAuthFromResultSet(rs);
|
return buildAuthFromResultSet(rs);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// return null;
|
return null;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public Set<String> getRecordsToPurge(long until) {
|
public Set<String> getRecordsToPurge(long until) {
|
||||||
// Set<String> list = new HashSet<>();
|
Set<String> list = new HashSet<>();
|
||||||
// String select = "SELECT " + col.NAME + " FROM " + tableName + " WHERE MAX("
|
String select = "SELECT " + col.NAME + " FROM " + tableName + " WHERE MAX("
|
||||||
// + " COALESCE(" + col.LAST_LOGIN + ", 0),"
|
+ " COALESCE(" + col.LAST_LOGIN + ", 0),"
|
||||||
// + " COALESCE(" + col.REGISTRATION_DATE + ", 0)"
|
+ " COALESCE(" + col.REGISTRATION_DATE + ", 0)"
|
||||||
// + ") < ?;";
|
+ ") < ?;";
|
||||||
// try (PreparedStatement selectPst = con.prepareStatement(select)) {
|
try (PreparedStatement selectPst = con.prepareStatement(select)) {
|
||||||
// selectPst.setLong(1, until);
|
selectPst.setLong(1, until);
|
||||||
// try (ResultSet rs = selectPst.executeQuery()) {
|
try (ResultSet rs = selectPst.executeQuery()) {
|
||||||
// while (rs.next()) {
|
while (rs.next()) {
|
||||||
// list.add(rs.getString(col.NAME));
|
list.add(rs.getString(col.NAME));
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// return list;
|
return list;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public void purgeRecords(Collection<String> toPurge) {
|
public void purgeRecords(Collection<String> toPurge) {
|
||||||
// String delete = "DELETE FROM " + tableName + " WHERE " + col.NAME + "=?;";
|
String delete = "DELETE FROM " + tableName + " WHERE " + col.NAME + "=?;";
|
||||||
// try (PreparedStatement deletePst = con.prepareStatement(delete)) {
|
try (PreparedStatement deletePst = con.prepareStatement(delete)) {
|
||||||
// for (String name : toPurge) {
|
for (String name : toPurge) {
|
||||||
// deletePst.setString(1, name.toLowerCase(Locale.ROOT));
|
deletePst.setString(1, name.toLowerCase(Locale.ROOT));
|
||||||
// deletePst.executeUpdate();
|
deletePst.executeUpdate();
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public boolean removeAuth(String user) {
|
public boolean removeAuth(String user) {
|
||||||
// String sql = "DELETE FROM " + tableName + " WHERE " + col.NAME + "=?;";
|
String sql = "DELETE FROM " + tableName + " WHERE " + col.NAME + "=?;";
|
||||||
// try (PreparedStatement pst = con.prepareStatement(sql)) {
|
try (PreparedStatement pst = con.prepareStatement(sql)) {
|
||||||
// pst.setString(1, user.toLowerCase(Locale.ROOT));
|
pst.setString(1, user.toLowerCase(Locale.ROOT));
|
||||||
// pst.executeUpdate();
|
pst.executeUpdate();
|
||||||
// return true;
|
return true;
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// return false;
|
return false;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public void closeConnection() {
|
public void closeConnection() {
|
||||||
// try {
|
try {
|
||||||
// if (con != null && !con.isClosed()) {
|
if (con != null && !con.isClosed()) {
|
||||||
// con.close();
|
con.close();
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public DataSourceType getType() {
|
public DataSourceType getType() {
|
||||||
// return DataSourceType.H2;
|
return DataSourceType.H2;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public List<PlayerAuth> getAllAuths() {
|
public List<PlayerAuth> getAllAuths() {
|
||||||
// List<PlayerAuth> auths = new ArrayList<>();
|
List<PlayerAuth> auths = new ArrayList<>();
|
||||||
// String sql = "SELECT * FROM " + tableName + ";";
|
String sql = "SELECT * FROM " + tableName + ";";
|
||||||
// try (PreparedStatement pst = con.prepareStatement(sql); ResultSet rs = pst.executeQuery()) {
|
try (PreparedStatement pst = con.prepareStatement(sql); ResultSet rs = pst.executeQuery()) {
|
||||||
// while (rs.next()) {
|
while (rs.next()) {
|
||||||
// PlayerAuth auth = buildAuthFromResultSet(rs);
|
PlayerAuth auth = buildAuthFromResultSet(rs);
|
||||||
// auths.add(auth);
|
auths.add(auth);
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// return auths;
|
return auths;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public List<String> getLoggedPlayersWithEmptyMail() {
|
public List<String> getLoggedPlayersWithEmptyMail() {
|
||||||
// List<String> players = new ArrayList<>();
|
List<String> players = new ArrayList<>();
|
||||||
// String sql = "SELECT " + col.REAL_NAME + " FROM " + tableName + " WHERE " + col.IS_LOGGED + " = 1"
|
String sql = "SELECT " + col.REAL_NAME + " FROM " + tableName + " WHERE " + col.IS_LOGGED + " = 1"
|
||||||
// + " AND (" + col.EMAIL + " = 'your@email.com' OR " + col.EMAIL + " IS NULL);";
|
+ " AND (" + col.EMAIL + " = 'your@email.com' OR " + col.EMAIL + " IS NULL);";
|
||||||
// try (Statement st = con.createStatement(); ResultSet rs = st.executeQuery(sql)) {
|
try (Statement st = con.createStatement(); ResultSet rs = st.executeQuery(sql)) {
|
||||||
// while (rs.next()) {
|
while (rs.next()) {
|
||||||
// players.add(rs.getString(1));
|
players.add(rs.getString(1));
|
||||||
// }
|
}
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// return players;
|
return players;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public List<PlayerAuth> getRecentlyLoggedInPlayers() {
|
public List<PlayerAuth> getRecentlyLoggedInPlayers() {
|
||||||
// List<PlayerAuth> players = new ArrayList<>();
|
List<PlayerAuth> players = new ArrayList<>();
|
||||||
// String sql = "SELECT * FROM " + tableName + " ORDER BY " + col.LAST_LOGIN + " DESC LIMIT 10;";
|
String sql = "SELECT * FROM " + tableName + " ORDER BY " + col.LAST_LOGIN + " DESC LIMIT 10;";
|
||||||
// try (Statement st = con.createStatement(); ResultSet rs = st.executeQuery(sql)) {
|
try (Statement st = con.createStatement(); ResultSet rs = st.executeQuery(sql)) {
|
||||||
// while (rs.next()) {
|
while (rs.next()) {
|
||||||
// players.add(buildAuthFromResultSet(rs));
|
players.add(buildAuthFromResultSet(rs));
|
||||||
// }
|
}
|
||||||
// } catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
// logSqlException(e);
|
logSqlException(e);
|
||||||
// }
|
}
|
||||||
// return players;
|
return players;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// public boolean setTotpKey(String user, String totpKey) {
|
public boolean setTotpKey(String user, String totpKey) {
|
||||||
// String sql = "UPDATE " + tableName + " SET " + col.TOTP_KEY + " = ? WHERE " + col.NAME + " = ?";
|
String sql = "UPDATE " + tableName + " SET " + col.TOTP_KEY + " = ? WHERE " + col.NAME + " = ?";
|
||||||
// try (PreparedStatement pst = con.prepareStatement(sql)) {
|
try (PreparedStatement pst = con.prepareStatement(sql)) {
|
||||||
// pst.setString(1, totpKey);
|
pst.setString(1, totpKey);
|
||||||
// pst.setString(2, user.toLowerCase(Locale.ROOT));
|
pst.setString(2, user.toLowerCase(Locale.ROOT));
|
||||||
// pst.executeUpdate();
|
pst.executeUpdate();
|
||||||
// return true;
|
return true;
|
||||||
// } catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
// logSqlException(e);
|
logSqlException(e);
|
||||||
// }
|
}
|
||||||
// return false;
|
return false;
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// private PlayerAuth buildAuthFromResultSet(ResultSet row) throws SQLException {
|
private PlayerAuth buildAuthFromResultSet(ResultSet row) throws SQLException {
|
||||||
// String salt = !col.SALT.isEmpty() ? row.getString(col.SALT) : null;
|
String salt = !col.SALT.isEmpty() ? row.getString(col.SALT) : null;
|
||||||
//
|
|
||||||
// return PlayerAuth.builder()
|
return PlayerAuth.builder()
|
||||||
// .name(row.getString(col.NAME))
|
.name(row.getString(col.NAME))
|
||||||
// .email(row.getString(col.EMAIL))
|
.email(row.getString(col.EMAIL))
|
||||||
// .realName(row.getString(col.REAL_NAME))
|
.realName(row.getString(col.REAL_NAME))
|
||||||
// .password(row.getString(col.PASSWORD), salt)
|
.password(row.getString(col.PASSWORD), salt)
|
||||||
// .totpKey(row.getString(col.TOTP_KEY))
|
.totpKey(row.getString(col.TOTP_KEY))
|
||||||
// .lastLogin(getNullableLong(row, col.LAST_LOGIN))
|
.lastLogin(getNullableLong(row, col.LAST_LOGIN))
|
||||||
// .lastIp(row.getString(col.LAST_IP))
|
.lastIp(row.getString(col.LAST_IP))
|
||||||
// .registrationDate(row.getLong(col.REGISTRATION_DATE))
|
.registrationDate(row.getLong(col.REGISTRATION_DATE))
|
||||||
// .registrationIp(row.getString(col.REGISTRATION_IP))
|
.registrationIp(row.getString(col.REGISTRATION_IP))
|
||||||
// .locX(row.getDouble(col.LASTLOC_X))
|
.locX(row.getDouble(col.LASTLOC_X))
|
||||||
// .locY(row.getDouble(col.LASTLOC_Y))
|
.locY(row.getDouble(col.LASTLOC_Y))
|
||||||
// .locZ(row.getDouble(col.LASTLOC_Z))
|
.locZ(row.getDouble(col.LASTLOC_Z))
|
||||||
// .locWorld(row.getString(col.LASTLOC_WORLD))
|
.locWorld(row.getString(col.LASTLOC_WORLD))
|
||||||
// .locYaw(row.getFloat(col.LASTLOC_YAW))
|
.locYaw(row.getFloat(col.LASTLOC_YAW))
|
||||||
// .locPitch(row.getFloat(col.LASTLOC_PITCH))
|
.locPitch(row.getFloat(col.LASTLOC_PITCH))
|
||||||
// .build();
|
.build();
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// /**
|
/**
|
||||||
// * Creates the column for registration date and sets all entries to the current timestamp.
|
* Creates the column for registration date and sets all entries to the current timestamp.
|
||||||
// * We do so in order to avoid issues with purging, where entries with 0 / NULL might get
|
* We do so in order to avoid issues with purging, where entries with 0 / NULL might get
|
||||||
// * purged immediately on startup otherwise.
|
* purged immediately on startup otherwise.
|
||||||
// *
|
*
|
||||||
// * @param st Statement object to the database
|
* @param st Statement object to the database
|
||||||
// */
|
*/
|
||||||
// private void addRegistrationDateColumn(Statement st) throws SQLException {
|
private void addRegistrationDateColumn(Statement st) throws SQLException {
|
||||||
// st.executeUpdate("ALTER TABLE " + tableName
|
st.executeUpdate("ALTER TABLE " + tableName
|
||||||
// + " ADD COLUMN " + col.REGISTRATION_DATE + " TIMESTAMP NOT NULL DEFAULT '0';");
|
+ " ADD COLUMN " + col.REGISTRATION_DATE + " BIGINT NOT NULL DEFAULT '0';");
|
||||||
//
|
|
||||||
// // Use the timestamp from Java to avoid timezone issues in case JVM and database are out of sync
|
// Use the timestamp from Java to avoid timezone issues in case JVM and database are out of sync
|
||||||
// long currentTimestamp = System.currentTimeMillis();
|
long currentTimestamp = System.currentTimeMillis();
|
||||||
// int updatedRows = st.executeUpdate(String.format("UPDATE %s SET %s = %d;",
|
int updatedRows = st.executeUpdate(String.format("UPDATE %s SET %s = %d;",
|
||||||
// tableName, col.REGISTRATION_DATE, currentTimestamp));
|
tableName, col.REGISTRATION_DATE, currentTimestamp));
|
||||||
// logger.info("Created column '" + col.REGISTRATION_DATE + "' and set the current timestamp, "
|
logger.info("Created column '" + col.REGISTRATION_DATE + "' and set the current timestamp, "
|
||||||
// + currentTimestamp + ", to all " + updatedRows + " rows");
|
+ currentTimestamp + ", to all " + updatedRows + " rows");
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// @Override
|
@Override
|
||||||
// String getJdbcUrl(String dataPath, String ignored, String database) {
|
String getJdbcUrl(String dataPath, String ignored, String database) {
|
||||||
// return "jdbc:h2:" + dataPath + File.separator + database + ".db";
|
return "jdbc:h2:" + dataPath + File.separator + database + ".db";
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// private static void close(Connection con) {
|
private static void close(Connection con) {
|
||||||
// if (con != null) {
|
if (con != null) {
|
||||||
// try {
|
try {
|
||||||
// con.close();
|
con.close();
|
||||||
// } catch (SQLException ex) {
|
} catch (SQLException ex) {
|
||||||
// logSqlException(ex);
|
logSqlException(ex);
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//}
|
}
|
||||||
//
|
|
||||||
|
|||||||
@ -5,6 +5,7 @@ import fr.xephi.authme.data.auth.PlayerCache;
|
|||||||
import fr.xephi.authme.datasource.CacheDataSource;
|
import fr.xephi.authme.datasource.CacheDataSource;
|
||||||
import fr.xephi.authme.datasource.DataSource;
|
import fr.xephi.authme.datasource.DataSource;
|
||||||
import fr.xephi.authme.datasource.DataSourceType;
|
import fr.xephi.authme.datasource.DataSourceType;
|
||||||
|
import fr.xephi.authme.datasource.H2;
|
||||||
import fr.xephi.authme.datasource.MariaDB;
|
import fr.xephi.authme.datasource.MariaDB;
|
||||||
import fr.xephi.authme.datasource.MySQL;
|
import fr.xephi.authme.datasource.MySQL;
|
||||||
import fr.xephi.authme.datasource.PostgreSqlDataSource;
|
import fr.xephi.authme.datasource.PostgreSqlDataSource;
|
||||||
@ -76,9 +77,9 @@ public class DataSourceProvider implements Provider<DataSource> {
|
|||||||
case SQLITE:
|
case SQLITE:
|
||||||
dataSource = new SQLite(settings, dataFolder);
|
dataSource = new SQLite(settings, dataFolder);
|
||||||
break;
|
break;
|
||||||
// case H2:
|
case H2:
|
||||||
// dataSource = new H2(settings, dataFolder);
|
dataSource = new H2(settings, dataFolder);
|
||||||
// break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new UnsupportedOperationException("Unknown data source type '" + dataSourceType + "'");
|
throw new UnsupportedOperationException("Unknown data source type '" + dataSourceType + "'");
|
||||||
}
|
}
|
||||||
|
|||||||
@ -92,6 +92,7 @@ public class BackupService {
|
|||||||
case MYSQL:
|
case MYSQL:
|
||||||
return performMySqlBackup();
|
return performMySqlBackup();
|
||||||
case SQLITE:
|
case SQLITE:
|
||||||
|
case H2:
|
||||||
String dbName = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
String dbName = settings.getProperty(DatabaseSettings.MYSQL_DATABASE);
|
||||||
return performFileBackup(dbName + ".db");
|
return performFileBackup(dbName + ".db");
|
||||||
default:
|
default:
|
||||||
|
|||||||
@ -10,7 +10,7 @@ import static ch.jalu.configme.properties.PropertyInitializer.newProperty;
|
|||||||
public final class DatabaseSettings implements SettingsHolder {
|
public final class DatabaseSettings implements SettingsHolder {
|
||||||
|
|
||||||
@Comment({"What type of database do you want to use?",
|
@Comment({"What type of database do you want to use?",
|
||||||
"Valid values: SQLITE, MARIADB, MYSQL, POSTGRESQL"})
|
"Valid values: H2, SQLITE, MARIADB, MYSQL, POSTGRESQL"})
|
||||||
public static final Property<DataSourceType> BACKEND =
|
public static final Property<DataSourceType> BACKEND =
|
||||||
newProperty(DataSourceType.class, "DataSource.backend", DataSourceType.SQLITE);
|
newProperty(DataSourceType.class, "DataSource.backend", DataSourceType.SQLITE);
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user