Skip to content

Commit

Permalink
Fix some issues with the new sql-storage implementations
Browse files Browse the repository at this point in the history
  • Loading branch information
TBlueF committed Apr 7, 2024
1 parent f18f7a9 commit 240ca6c
Show file tree
Hide file tree
Showing 4 changed files with 54 additions and 32 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@
@Getter
public class SQLConfig extends StorageConfig {

private static final Pattern URL_DIALECT_PATTERN = Pattern.compile("jdbc:([^:]*)://.*");
private static final Pattern URL_DIALECT_PATTERN = Pattern.compile("jdbc:([^:]*):.*");

private String connectionUrl = "jdbc:mysql://localhost/bluemap?permitMysqlScheme";
private Map<String, String> connectionProperties = new HashMap<>();
Expand Down Expand Up @@ -102,7 +102,12 @@ public Dialect getDialect() throws ConfigurationException {
// default from connection-url
if (key == null) {
Matcher matcher = URL_DIALECT_PATTERN.matcher(connectionUrl);
if (!matcher.find()) return Dialect.MYSQL;
if (!matcher.find()) {
throw new ConfigurationException("""
Failed to parse the provided connection-url!
Please check your 'connection-url' setting in your configuration and make sure it is in the correct format.
""".strip());
}
key = Key.bluemap(matcher.group(1)).getFormatted();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ public void delete(DoublePredicate onProgress) throws IOException {
deleted = sql.purgeMapTiles(mapId, 1000);
totalDeleted += deleted;

if (onProgress.test((double) totalDeleted / tileCount))
if (!onProgress.test((double) totalDeleted / tileCount))
return;

} while (deleted > 0 && totalDeleted < tileCount);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;

@SuppressWarnings("SqlSourceToSinkFlow")
@RequiredArgsConstructor
Expand All @@ -45,9 +44,9 @@ public abstract class AbstractCommandSet implements CommandSet {
private final Database db;

final LoadingCache<String, Integer> mapKeys = Caffeine.newBuilder()
.build(this::mapKey);
.build(this::findOrCreateMapKey);
final LoadingCache<Compression, Integer> compressionKeys = Caffeine.newBuilder()
.build(this::compressionKey);
.build(this::findOrCreateCompressionKey);

@Language("sql")
public abstract String createMapTableStatement();
Expand Down Expand Up @@ -83,8 +82,8 @@ public int writeMapTile(
String mapId, int lod, int x, int z, Compression compression,
byte[] bytes
) throws IOException {
int mapKey = Objects.requireNonNull(mapKeys.get(mapId));
int compressionKey = Objects.requireNonNull(compressionKeys.get(compression));
int mapKey = mapKey(mapId);
int compressionKey = compressionKey(compression);
return db.run(connection -> {
return executeUpdate(connection,
writeMapTileStatement(),
Expand Down Expand Up @@ -201,7 +200,7 @@ public TilePosition[] listMapTiles(String mapId, int lod, Compression compressio

@Override
public int writeMapMeta(String mapId, String itemName, byte[] bytes) throws IOException {
int mapKey = Objects.requireNonNull(mapKeys.get(mapId));
int mapKey = mapKey(mapId);
return db.run(connection -> {
return executeUpdate(connection,
writeMapMetaStatement(),
Expand Down Expand Up @@ -265,24 +264,28 @@ public boolean hasMapMeta(String mapId, String itemName) throws IOException {

@Override
public void purgeMap(String mapId) throws IOException {
db.run(connection -> {
synchronized (mapKeys) {
db.run(connection -> {

executeUpdate(connection,
purgeMapTileTableStatement(),
mapId
);
executeUpdate(connection,
purgeMapTileTableStatement(),
mapId
);

executeUpdate(connection,
purgeMapMetaTableStatement(),
mapId
);
executeUpdate(connection,
purgeMapMetaTableStatement(),
mapId
);

executeUpdate(connection,
deleteMapStatement(),
mapId
);
executeUpdate(connection,
deleteMapStatement(),
mapId
);

});
});

mapKeys.invalidate(mapId);
}
}

@Language("sql")
Expand Down Expand Up @@ -324,7 +327,14 @@ public String[] listMapIds(int start, int count) throws IOException {
@Language("sql")
public abstract String createMapKeyStatement();

public int mapKey(String mapId) throws IOException {
public int mapKey(String mapId) {
synchronized (mapKeys) {
//noinspection DataFlowIssue
return mapKeys.get(mapId);
}
}

public int findOrCreateMapKey(String mapId) throws IOException {
return db.run(connection -> {
ResultSet result = executeQuery(connection,
findMapKeyStatement(),
Expand Down Expand Up @@ -353,7 +363,14 @@ public int mapKey(String mapId) throws IOException {
@Language("sql")
public abstract String createCompressionKeyStatement();

public int compressionKey(Compression compression) throws IOException {
public int compressionKey(Compression compression) {
synchronized (compressionKeys) {
//noinspection DataFlowIssue
return compressionKeys.get(compression);
}
}

public int findOrCreateCompressionKey(Compression compression) throws IOException {
return db.run(connection -> {
ResultSet result = executeQuery(connection,
findCompressionKeyStatement(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ public SqliteCommandSet(Database db) {
public String createMapTableStatement() {
return """
CREATE TABLE IF NOT EXISTS `bluemap_map` (
`id` INTEGER UNSIGNED PRIMARY KEY AUTOINCREMENT,
`id` INTEGER PRIMARY KEY AUTOINCREMENT,
`map_id` TEXT UNIQUE NOT NULL
) STRICT
""";
Expand All @@ -49,7 +49,7 @@ public String createMapTableStatement() {
public String createCompressionTableStatement() {
return """
CREATE TABLE IF NOT EXISTS `bluemap_map_tile_compression` (
`id` INTEGER UNSIGNED PRIMARY KEY AUTOINCREMENT,
`id` INTEGER PRIMARY KEY AUTOINCREMENT,
`compression` TEXT UNIQUE NOT NULL
) STRICT
""";
Expand All @@ -60,7 +60,7 @@ public String createCompressionTableStatement() {
public String createMapMetaTableStatement() {
return """
CREATE TABLE IF NOT EXISTS `bluemap_map_meta` (
`map` INTEGER UNSIGNED NOT NULL,
`map` INTEGER NOT NULL,
`key` TEXT NOT NULL,
`value` BLOB NOT NULL,
PRIMARY KEY (`map`, `key`),
Expand All @@ -78,11 +78,11 @@ FOREIGN KEY (`map`)
public String createMapTileTableStatement() {
return """
CREATE TABLE IF NOT EXISTS `bluemap_map_tile` (
`map` INTEGER UNSIGNED NOT NULL,
`lod` INTEGER UNSIGNED NOT NULL,
`map` INTEGER NOT NULL,
`lod` INTEGER NOT NULL,
`x` INTEGER NOT NULL,
`z` INTEGER NOT NULL,
`compression` INTEGER UNSIGNED NOT NULL,
`compression` INTEGER NOT NULL,
`data` BLOB NOT NULL,
PRIMARY KEY (`map`, `lod`, `x`, `z`),
CONSTRAINT `fk_bluemap_map_tile_map`
Expand All @@ -104,7 +104,7 @@ FOREIGN KEY (`compression`)
public String fixLegacyCompressionIdsStatement() {
return """
UPDATE `bluemap_map_tile_compression`
SET `compression` = CONCAT('bluemap:', `compression`)
SET `compression` = 'bluemap:' || `compression`
WHERE NOT `compression` LIKE '%:%'
""";
}
Expand Down

0 comments on commit 240ca6c

Please sign in to comment.