mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-03 23:17:48 +01:00
Annotations for the storage api
This commit is contained in:
parent
b511c12129
commit
fa0f9c8fa2
@ -5,6 +5,8 @@ import net.minestom.server.data.*;
|
|||||||
import net.minestom.server.utils.binary.BinaryReader;
|
import net.minestom.server.utils.binary.BinaryReader;
|
||||||
import net.minestom.server.utils.binary.BinaryWriter;
|
import net.minestom.server.utils.binary.BinaryWriter;
|
||||||
import net.minestom.server.utils.validate.Check;
|
import net.minestom.server.utils.validate.Check;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -37,10 +39,11 @@ public class StorageLocation {
|
|||||||
* Gets the data associated with a key using {@link StorageSystem#get(String)}.
|
* Gets the data associated with a key using {@link StorageSystem#get(String)}.
|
||||||
*
|
*
|
||||||
* @param key the key
|
* @param key the key
|
||||||
* @return the data associated to {@code key}
|
* @return the data associated to {@code key}, null if not any
|
||||||
* @see StorageSystem#get(String)
|
* @see StorageSystem#get(String)
|
||||||
*/
|
*/
|
||||||
public byte[] get(String key) {
|
@Nullable
|
||||||
|
public byte[] get(@NotNull String key) {
|
||||||
return storageSystem.get(key);
|
return storageSystem.get(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,7 +54,7 @@ public class StorageLocation {
|
|||||||
* @param data the data
|
* @param data the data
|
||||||
* @see StorageSystem#set(String, byte[])
|
* @see StorageSystem#set(String, byte[])
|
||||||
*/
|
*/
|
||||||
public void set(String key, byte[] data) {
|
public void set(@NotNull String key, byte[] data) {
|
||||||
this.storageSystem.set(key, data);
|
this.storageSystem.set(key, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,7 +64,7 @@ public class StorageLocation {
|
|||||||
* @param key the key
|
* @param key the key
|
||||||
* @see StorageSystem#delete(String)
|
* @see StorageSystem#delete(String)
|
||||||
*/
|
*/
|
||||||
public void delete(String key) {
|
public void delete(@NotNull String key) {
|
||||||
this.storageSystem.delete(key);
|
this.storageSystem.delete(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,7 +88,7 @@ public class StorageLocation {
|
|||||||
* @param type the class of the data
|
* @param type the class of the data
|
||||||
* @param <T> the type of the data
|
* @param <T> the type of the data
|
||||||
*/
|
*/
|
||||||
public <T> void set(String key, T object, Class<T> type) {
|
public <T> void set(@NotNull String key, @NotNull T object, @NotNull Class<T> type) {
|
||||||
final DataType<T> dataType = DATA_MANAGER.getDataType(type);
|
final DataType<T> dataType = DATA_MANAGER.getDataType(type);
|
||||||
Check.notNull(dataType, "You can only save registered DataType type!");
|
Check.notNull(dataType, "You can only save registered DataType type!");
|
||||||
|
|
||||||
@ -109,7 +112,7 @@ public class StorageLocation {
|
|||||||
* @param <T> the type of the data
|
* @param <T> the type of the data
|
||||||
* @return the object associated to the key
|
* @return the object associated to the key
|
||||||
*/
|
*/
|
||||||
public <T> T get(String key, Class<T> type) {
|
public <T> T get(@NotNull String key, @NotNull Class<T> type) {
|
||||||
final DataType<T> dataType = DATA_MANAGER.getDataType(type);
|
final DataType<T> dataType = DATA_MANAGER.getDataType(type);
|
||||||
Check.notNull(dataType, "You can only get registered DataType type!");
|
Check.notNull(dataType, "You can only get registered DataType type!");
|
||||||
|
|
||||||
@ -123,7 +126,7 @@ public class StorageLocation {
|
|||||||
return dataType.decode(binaryReader);
|
return dataType.decode(binaryReader);
|
||||||
}
|
}
|
||||||
|
|
||||||
public <T> T getOrDefault(String key, Class<T> type, T defaultValue) {
|
public <T> T getOrDefault(@NotNull String key, @NotNull Class<T> type, @Nullable T defaultValue) {
|
||||||
T value;
|
T value;
|
||||||
return (value = get(key, type)) != null ? value : defaultValue;
|
return (value = get(key, type)) != null ? value : defaultValue;
|
||||||
}
|
}
|
||||||
@ -135,7 +138,7 @@ public class StorageLocation {
|
|||||||
* @param key the key of the data
|
* @param key the key of the data
|
||||||
* @param dataContainer the {@link DataContainer} which will contain the new data
|
* @param dataContainer the {@link DataContainer} which will contain the new data
|
||||||
*/
|
*/
|
||||||
public void getAndCloneData(String key, DataContainer dataContainer) {
|
public void getAndCloneData(@NotNull String key, @NotNull DataContainer dataContainer) {
|
||||||
synchronized (cachedData) {
|
synchronized (cachedData) {
|
||||||
// Copy data from the cachedMap
|
// Copy data from the cachedMap
|
||||||
if (cachedData.containsKey(key)) {
|
if (cachedData.containsKey(key)) {
|
||||||
@ -161,7 +164,7 @@ public class StorageLocation {
|
|||||||
* @param key the key of the data
|
* @param key the key of the data
|
||||||
* @param dataContainer the {@link DataContainer} which will contain the new data
|
* @param dataContainer the {@link DataContainer} which will contain the new data
|
||||||
*/
|
*/
|
||||||
public void getAndCacheData(String key, DataContainer dataContainer) {
|
public void getAndCacheData(@NotNull String key, @NotNull DataContainer dataContainer) {
|
||||||
synchronized (cachedData) {
|
synchronized (cachedData) {
|
||||||
// Give the cached SerializableData if already loaded
|
// Give the cached SerializableData if already loaded
|
||||||
if (cachedData.containsKey(key)) {
|
if (cachedData.containsKey(key)) {
|
||||||
@ -184,7 +187,7 @@ public class StorageLocation {
|
|||||||
*
|
*
|
||||||
* @param key the specified cached data key
|
* @param key the specified cached data key
|
||||||
*/
|
*/
|
||||||
public void saveAndRemoveCachedData(String key) {
|
public void saveAndRemoveCachedData(@NotNull String key) {
|
||||||
synchronized (cachedData) {
|
synchronized (cachedData) {
|
||||||
final SerializableData serializableData = cachedData.get(key);
|
final SerializableData serializableData = cachedData.get(key);
|
||||||
if (serializableData == null)
|
if (serializableData == null)
|
||||||
@ -212,7 +215,7 @@ public class StorageLocation {
|
|||||||
*
|
*
|
||||||
* @param key the data key
|
* @param key the data key
|
||||||
*/
|
*/
|
||||||
public void saveCachedData(String key) {
|
public void saveCachedData(@NotNull String key) {
|
||||||
synchronized (cachedData) {
|
synchronized (cachedData) {
|
||||||
final SerializableData data = cachedData.get(key);
|
final SerializableData data = cachedData.get(key);
|
||||||
set(key, data.getIndexedSerializedData());
|
set(key, data.getIndexedSerializedData());
|
||||||
@ -226,6 +229,7 @@ public class StorageLocation {
|
|||||||
*
|
*
|
||||||
* @return the location
|
* @return the location
|
||||||
*/
|
*/
|
||||||
|
@NotNull
|
||||||
public String getLocation() {
|
public String getLocation() {
|
||||||
return location;
|
return location;
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package net.minestom.server.storage;
|
package net.minestom.server.storage;
|
||||||
|
|
||||||
import net.minestom.server.utils.validate.Check;
|
import net.minestom.server.utils.validate.Check;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
@ -33,7 +35,7 @@ public final class StorageManager {
|
|||||||
* @param storageSystem the {@link StorageSystem} used in the specified location
|
* @param storageSystem the {@link StorageSystem} used in the specified location
|
||||||
* @return the specified {@link StorageLocation}
|
* @return the specified {@link StorageLocation}
|
||||||
*/
|
*/
|
||||||
public StorageLocation getLocation(String location, StorageOptions storageOptions, StorageSystem storageSystem) {
|
public StorageLocation getLocation(@NotNull String location, @NotNull StorageOptions storageOptions, @NotNull StorageSystem storageSystem) {
|
||||||
Check.notNull(storageOptions, "The storage option cannot be null");
|
Check.notNull(storageOptions, "The storage option cannot be null");
|
||||||
return locationMap.computeIfAbsent(location,
|
return locationMap.computeIfAbsent(location,
|
||||||
s -> new StorageLocation(storageSystem, location, storageOptions));
|
s -> new StorageLocation(storageSystem, location, storageOptions));
|
||||||
@ -48,7 +50,7 @@ public final class StorageManager {
|
|||||||
* @return the {@link StorageLocation} at {@code location} with the default {@link StorageSystem}
|
* @return the {@link StorageLocation} at {@code location} with the default {@link StorageSystem}
|
||||||
* @throws NullPointerException if no default {@link StorageSystem} is defined with {@link #defineDefaultStorageSystem(Supplier)}
|
* @throws NullPointerException if no default {@link StorageSystem} is defined with {@link #defineDefaultStorageSystem(Supplier)}
|
||||||
*/
|
*/
|
||||||
public StorageLocation getLocation(String location, StorageOptions storageOptions) {
|
public StorageLocation getLocation(@NotNull String location, @NotNull StorageOptions storageOptions) {
|
||||||
Check.notNull(defaultStorageSystemSupplier,
|
Check.notNull(defaultStorageSystemSupplier,
|
||||||
"You need to either define a default storage system or specify your storage system for this specific location");
|
"You need to either define a default storage system or specify your storage system for this specific location");
|
||||||
final StorageSystem storageSystem = defaultStorageSystemSupplier.get();
|
final StorageSystem storageSystem = defaultStorageSystemSupplier.get();
|
||||||
@ -63,7 +65,8 @@ public final class StorageManager {
|
|||||||
* @return the {@link StorageLocation} at {@code location} with the default {@link StorageSystem}
|
* @return the {@link StorageLocation} at {@code location} with the default {@link StorageSystem}
|
||||||
* @throws NullPointerException if no default StorageSystem is defined {@link #defineDefaultStorageSystem(Supplier)}
|
* @throws NullPointerException if no default StorageSystem is defined {@link #defineDefaultStorageSystem(Supplier)}
|
||||||
*/
|
*/
|
||||||
public StorageLocation getLocation(String location) {
|
@Nullable
|
||||||
|
public StorageLocation getLocation(@NotNull String location) {
|
||||||
return getLocation(location, new StorageOptions());
|
return getLocation(location, new StorageOptions());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,7 +77,7 @@ public final class StorageManager {
|
|||||||
* @param storageSystem the {@link StorageSystem} to use
|
* @param storageSystem the {@link StorageSystem} to use
|
||||||
* @return true if the location exists, false otherwise
|
* @return true if the location exists, false otherwise
|
||||||
*/
|
*/
|
||||||
public boolean locationExists(String location, StorageSystem storageSystem) {
|
public boolean locationExists(@NotNull String location, @NotNull StorageSystem storageSystem) {
|
||||||
return storageSystem.exists(location);
|
return storageSystem.exists(location);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -84,7 +87,7 @@ public final class StorageManager {
|
|||||||
* @param location the location
|
* @param location the location
|
||||||
* @return true if the location exists
|
* @return true if the location exists
|
||||||
*/
|
*/
|
||||||
public boolean locationExists(String location) {
|
public boolean locationExists(@NotNull String location) {
|
||||||
return locationExists(location, defaultStorageSystemSupplier.get());
|
return locationExists(location, defaultStorageSystemSupplier.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,6 +97,7 @@ public final class StorageManager {
|
|||||||
*
|
*
|
||||||
* @return an unmodifiable list of all the loaded {@link StorageLocation}
|
* @return an unmodifiable list of all the loaded {@link StorageLocation}
|
||||||
*/
|
*/
|
||||||
|
@NotNull
|
||||||
public Collection<StorageLocation> getLoadedLocations() {
|
public Collection<StorageLocation> getLoadedLocations() {
|
||||||
return Collections.unmodifiableCollection(locationMap.values());
|
return Collections.unmodifiableCollection(locationMap.values());
|
||||||
}
|
}
|
||||||
@ -103,7 +107,7 @@ public final class StorageManager {
|
|||||||
*
|
*
|
||||||
* @param storageSystemSupplier the supplier called to get the default {@link StorageSystem}
|
* @param storageSystemSupplier the supplier called to get the default {@link StorageSystem}
|
||||||
*/
|
*/
|
||||||
public void defineDefaultStorageSystem(Supplier<StorageSystem> storageSystemSupplier) {
|
public void defineDefaultStorageSystem(@NotNull Supplier<StorageSystem> storageSystemSupplier) {
|
||||||
if (this.defaultStorageSystemSupplier != null) {
|
if (this.defaultStorageSystemSupplier != null) {
|
||||||
LOGGER.warn("The default storage-system has been changed. This could lead to issues!");
|
LOGGER.warn("The default storage-system has been changed. This could lead to issues!");
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
package net.minestom.server.storage;
|
package net.minestom.server.storage;
|
||||||
|
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a way of storing data by key/value.
|
* Represents a way of storing data by key/value.
|
||||||
* The location does not have to be a file or folder path. It is the 'identifier' of the data location.
|
* The location does not have to be a file or folder path. It is the 'identifier' of the data location.
|
||||||
@ -12,7 +15,7 @@ public interface StorageSystem {
|
|||||||
* @param location the location
|
* @param location the location
|
||||||
* @return true if the location exists
|
* @return true if the location exists
|
||||||
*/
|
*/
|
||||||
boolean exists(String location);
|
boolean exists(@NotNull String location);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called when a {@link StorageLocation} is opened with this {@link StorageSystem}.
|
* Called when a {@link StorageLocation} is opened with this {@link StorageSystem}.
|
||||||
@ -20,15 +23,16 @@ public interface StorageSystem {
|
|||||||
* @param location the location name
|
* @param location the location name
|
||||||
* @param storageOptions the {@link StorageOptions}
|
* @param storageOptions the {@link StorageOptions}
|
||||||
*/
|
*/
|
||||||
void open(String location, StorageOptions storageOptions);
|
void open(@NotNull String location, @NotNull StorageOptions storageOptions);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the data associated to a key.
|
* Gets the data associated to a key.
|
||||||
*
|
*
|
||||||
* @param key the key to retrieve
|
* @param key the key to retrieve
|
||||||
* @return the retrieved data
|
* @return the retrieved data, null if the data doesn't exist
|
||||||
*/
|
*/
|
||||||
byte[] get(String key);
|
@Nullable
|
||||||
|
byte[] get(@NotNull String key);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the specified data to the defined key.
|
* Sets the specified data to the defined key.
|
||||||
@ -36,14 +40,14 @@ public interface StorageSystem {
|
|||||||
* @param key the key of the data
|
* @param key the key of the data
|
||||||
* @param data the data
|
* @param data the data
|
||||||
*/
|
*/
|
||||||
void set(String key, byte[] data);
|
void set(@NotNull String key, byte[] data);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes the specified key from the database.
|
* Deletes the specified key from the database.
|
||||||
*
|
*
|
||||||
* @param key the key to delete
|
* @param key the key to delete
|
||||||
*/
|
*/
|
||||||
void delete(String key);
|
void delete(@NotNull String key);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called when the location is closed, generally during server shutdown.
|
* Called when the location is closed, generally during server shutdown.
|
||||||
|
@ -2,6 +2,7 @@ package net.minestom.server.storage.systems;
|
|||||||
|
|
||||||
import net.minestom.server.storage.StorageOptions;
|
import net.minestom.server.storage.StorageOptions;
|
||||||
import net.minestom.server.storage.StorageSystem;
|
import net.minestom.server.storage.StorageSystem;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.rocksdb.*;
|
import org.rocksdb.*;
|
||||||
|
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
@ -24,12 +25,12 @@ public class FileStorageSystem implements StorageSystem {
|
|||||||
private RocksDB rocksDB;
|
private RocksDB rocksDB;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean exists(String location) {
|
public boolean exists(@NotNull String location) {
|
||||||
return Files.isDirectory(Paths.get(location));
|
return Files.isDirectory(Paths.get(location));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void open(String location, StorageOptions storageOptions) {
|
public void open(@NotNull String location, @NotNull StorageOptions storageOptions) {
|
||||||
Options options = new Options().setCreateIfMissing(true);
|
Options options = new Options().setCreateIfMissing(true);
|
||||||
|
|
||||||
if (storageOptions.hasCompression()) {
|
if (storageOptions.hasCompression()) {
|
||||||
@ -45,7 +46,7 @@ public class FileStorageSystem implements StorageSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public byte[] get(String key) {
|
public byte[] get(@NotNull String key) {
|
||||||
try {
|
try {
|
||||||
return rocksDB.get(getKey(key));
|
return rocksDB.get(getKey(key));
|
||||||
} catch (RocksDBException e) {
|
} catch (RocksDBException e) {
|
||||||
@ -55,7 +56,7 @@ public class FileStorageSystem implements StorageSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void set(String key, byte[] data) {
|
public void set(@NotNull String key, byte[] data) {
|
||||||
try {
|
try {
|
||||||
this.rocksDB.put(getKey(key), data);
|
this.rocksDB.put(getKey(key), data);
|
||||||
} catch (RocksDBException e) {
|
} catch (RocksDBException e) {
|
||||||
@ -64,7 +65,7 @@ public class FileStorageSystem implements StorageSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void delete(String key) {
|
public void delete(@NotNull String key) {
|
||||||
try {
|
try {
|
||||||
this.rocksDB.delete(getKey(key));
|
this.rocksDB.delete(getKey(key));
|
||||||
} catch (RocksDBException e) {
|
} catch (RocksDBException e) {
|
||||||
|
Loading…
Reference in New Issue
Block a user