mirror of
https://github.com/LuckPerms/LuckPerms.git
synced 2025-01-07 17:07:36 +01:00
Fix sponge subject storage
This commit is contained in:
parent
ba51f803ba
commit
cbb562b603
@ -240,13 +240,13 @@ public class LPSpongeBootstrap implements LuckPermsBootstrap {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Path getDataDirectory() {
|
public Path getDataDirectory() {
|
||||||
Path dataDirectory = this.game.getGameDirectory().resolve("luckperms");
|
Path dataDirectory = this.game.getGameDirectory().toAbsolutePath().resolve("luckperms");
|
||||||
try {
|
try {
|
||||||
Files.createDirectories(dataDirectory);
|
Files.createDirectories(dataDirectory);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
return dataDirectory.toAbsolutePath();
|
return dataDirectory;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -30,6 +30,7 @@ import com.google.gson.Gson;
|
|||||||
import com.google.gson.GsonBuilder;
|
import com.google.gson.GsonBuilder;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.common.utils.ImmutableCollectors;
|
||||||
import me.lucko.luckperms.sponge.service.model.LPPermissionService;
|
import me.lucko.luckperms.sponge.service.model.LPPermissionService;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
@ -42,7 +43,6 @@ import java.util.Collections;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -69,15 +69,6 @@ public class SubjectStorage {
|
|||||||
this.service = service;
|
this.service = service;
|
||||||
this.gson = new GsonBuilder().setPrettyPrinting().create();
|
this.gson = new GsonBuilder().setPrettyPrinting().create();
|
||||||
this.container = container;
|
this.container = container;
|
||||||
checkContainer();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkContainer() {
|
|
||||||
try {
|
|
||||||
Files.createDirectories(this.container.getParent());
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -86,12 +77,14 @@ public class SubjectStorage {
|
|||||||
* @return the identifiers of all known collections
|
* @return the identifiers of all known collections
|
||||||
*/
|
*/
|
||||||
public Set<String> getSavedCollections() {
|
public Set<String> getSavedCollections() {
|
||||||
checkContainer();
|
if (!Files.exists(this.container)) {
|
||||||
|
return ImmutableSet.of();
|
||||||
|
}
|
||||||
|
|
||||||
try (Stream<Path> s = Files.list(this.container)) {
|
try (Stream<Path> s = Files.list(this.container)) {
|
||||||
return s.filter(p -> Files.isDirectory(p))
|
return s.filter(p -> Files.isDirectory(p))
|
||||||
.map(p -> p.getFileName().toString())
|
.map(p -> p.getFileName().toString())
|
||||||
.collect(Collectors.toSet());
|
.collect(ImmutableCollectors.toSet());
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return ImmutableSet.of();
|
return ImmutableSet.of();
|
||||||
@ -106,7 +99,6 @@ public class SubjectStorage {
|
|||||||
* @return a file
|
* @return a file
|
||||||
*/
|
*/
|
||||||
private Path resolveFile(String collectionIdentifier, String subjectIdentifier) {
|
private Path resolveFile(String collectionIdentifier, String subjectIdentifier) {
|
||||||
checkContainer();
|
|
||||||
Path collection = this.container.resolve(collectionIdentifier);
|
Path collection = this.container.resolve(collectionIdentifier);
|
||||||
try {
|
try {
|
||||||
Files.createDirectories(collection);
|
Files.createDirectories(collection);
|
||||||
@ -150,7 +142,6 @@ public class SubjectStorage {
|
|||||||
* @return a map of found subjects
|
* @return a map of found subjects
|
||||||
*/
|
*/
|
||||||
public Map<String, SubjectDataContainer> loadAllFromFile(String collectionIdentifier) {
|
public Map<String, SubjectDataContainer> loadAllFromFile(String collectionIdentifier) {
|
||||||
checkContainer();
|
|
||||||
Path collection = this.container.resolve(collectionIdentifier);
|
Path collection = this.container.resolve(collectionIdentifier);
|
||||||
if (!Files.exists(collection)) {
|
if (!Files.exists(collection)) {
|
||||||
return Collections.emptyMap();
|
return Collections.emptyMap();
|
||||||
@ -184,7 +175,6 @@ public class SubjectStorage {
|
|||||||
* @throws IOException if the read fails
|
* @throws IOException if the read fails
|
||||||
*/
|
*/
|
||||||
public LoadedSubject loadFromFile(String collectionIdentifier, String subjectIdentifier) throws IOException {
|
public LoadedSubject loadFromFile(String collectionIdentifier, String subjectIdentifier) throws IOException {
|
||||||
checkContainer();
|
|
||||||
Path collection = this.container.resolve(collectionIdentifier);
|
Path collection = this.container.resolve(collectionIdentifier);
|
||||||
if (!Files.exists(collection)) {
|
if (!Files.exists(collection)) {
|
||||||
return null;
|
return null;
|
||||||
|
Loading…
Reference in New Issue
Block a user