2023-06-12 22:55:44 +02:00
|
|
|
package de.bluecolored.bluemap.core.storage.sql.dialect;
|
|
|
|
|
2023-06-18 01:02:13 +02:00
|
|
|
import de.bluecolored.bluemap.core.storage.sql.*;
|
2023-06-12 22:55:44 +02:00
|
|
|
|
|
|
|
public enum DialectType {
|
|
|
|
|
|
|
|
MYSQL (MySQLStorage::new, "mysql"),
|
|
|
|
MARIADB (MySQLStorage::new, "mariadb"),
|
2023-06-18 01:02:13 +02:00
|
|
|
POSTGRESQL (PostgreSQLStorage::new, "postgresql"),
|
|
|
|
SQLITE (SQLiteStorage::new, "sqlite");
|
2023-06-12 22:55:44 +02:00
|
|
|
|
2023-06-12 23:07:00 +02:00
|
|
|
private static final DialectType FALLBACK = MYSQL;
|
|
|
|
|
2023-06-12 22:55:44 +02:00
|
|
|
private final SQLStorageFactory storageFactory;
|
|
|
|
private final String dialectName;
|
|
|
|
|
|
|
|
DialectType(SQLStorageFactory storageFactory, String dialectName) {
|
|
|
|
this.storageFactory = storageFactory;
|
|
|
|
this.dialectName = dialectName;
|
|
|
|
}
|
|
|
|
public String getDialectName() {
|
|
|
|
return dialectName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static SQLStorage getStorage(String dialectName, SQLStorageSettings settings) throws Exception {
|
|
|
|
for (DialectType dialect : values()) {
|
|
|
|
if (dialect.getDialectName().equals(dialectName)) {
|
|
|
|
return dialect.storageFactory.provide(settings);
|
|
|
|
}
|
|
|
|
}
|
2023-06-12 23:07:00 +02:00
|
|
|
|
|
|
|
// unknown dialect, use fallback
|
|
|
|
return FALLBACK.storageFactory.provide(settings);
|
2023-06-12 22:55:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@FunctionalInterface
|
|
|
|
public interface SQLStorageFactory {
|
|
|
|
SQLStorage provide(SQLStorageSettings config) throws Exception;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|