Fix sponge subject storage

This commit is contained in:
Luck 2018-04-25 17:30:02 +01:00
parent ba51f803ba
commit cbb562b603
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B
2 changed files with 7 additions and 17 deletions

View File

@ -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

View File

@ -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;