X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fdatabase%2Fmemory%2FConfigurationLoader.java;h=268f1a203ae4b228e5944374e250dea27f94000d;hb=081a7b1344574efb641fe925088e4eb975e2e47e;hp=24505acf1f7319de93e5573ff6ada3ccf9187f14;hpb=36b8e20651c14970ca30a1b8ed43af219b367bc9;p=Sone.git
diff --git a/src/main/java/net/pterodactylus/sone/database/memory/ConfigurationLoader.java b/src/main/java/net/pterodactylus/sone/database/memory/ConfigurationLoader.java
index 24505ac..268f1a2 100644
--- a/src/main/java/net/pterodactylus/sone/database/memory/ConfigurationLoader.java
+++ b/src/main/java/net/pterodactylus/sone/database/memory/ConfigurationLoader.java
@@ -1,66 +1,131 @@
package net.pterodactylus.sone.database.memory;
+import static java.util.logging.Level.WARNING;
+
+import java.util.Collection;
+import java.util.HashMap;
import java.util.HashSet;
+import java.util.Map;
+import java.util.Map.Entry;
import java.util.Set;
+import java.util.logging.Logger;
+
+import javax.annotation.Nonnull;
+import javax.annotation.Nullable;
import net.pterodactylus.util.config.Configuration;
+import net.pterodactylus.util.config.ConfigurationException;
/**
* Helper class for interacting with a {@link Configuration}.
- *
- * @author David âBombeâ Roden
*/
public class ConfigurationLoader {
+ private static final Logger logger = Logger.getLogger(ConfigurationLoader.class.getName());
private final Configuration configuration;
public ConfigurationLoader(Configuration configuration) {
this.configuration = configuration;
}
+ public synchronized Set loadFriends(String localSoneId) {
+ return loadIds("Sone/" + localSoneId + "/Friends");
+ }
+
+ public void saveFriends(String soneId, Collection friends) {
+ saveIds("Sone/" + soneId + "/Friends", friends);
+ }
+
public synchronized Set loadKnownPosts() {
- Set knownPosts = new HashSet();
- int postCounter = 0;
+ return loadIds("KnownPosts");
+ }
+
+ public synchronized Set loadKnownPostReplies() {
+ return loadIds("KnownReplies");
+ }
+
+ public synchronized Set loadBookmarkedPosts() {
+ return loadIds("Bookmarks/Post");
+ }
+
+ @Nullable
+ public synchronized Long getSoneFollowingTime(@Nonnull String soneId) {
+ return loadSoneFollowingTimes().get(soneId);
+ }
+
+ public synchronized void removeSoneFollowingTime(@Nonnull String soneId) {
+ Map soneFollowingTimes = loadSoneFollowingTimes();
+ soneFollowingTimes.remove(soneId);
+ storeSoneFollowingTimes(soneFollowingTimes);
+ }
+
+ public synchronized void setSoneFollowingTime(@Nonnull String soneId, long time) {
+ Map soneFollowingTimes = loadSoneFollowingTimes();
+ soneFollowingTimes.put(soneId, time);
+ storeSoneFollowingTimes(soneFollowingTimes);
+ }
+
+ private synchronized Map loadSoneFollowingTimes() {
+ Map soneFollowingTimes = new HashMap<>();
+ int soneCounter = 0;
while (true) {
- String knownPostId = configuration
- .getStringValue("KnownPosts/" + postCounter++ + "/ID")
- .getValue(null);
- if (knownPostId == null) {
+ String soneId = configuration.getStringValue("SoneFollowingTimes/" + soneCounter + "/Sone").getValue(null);
+ if (soneId == null) {
break;
}
- knownPosts.add(knownPostId);
+ soneFollowingTimes.put(soneId, configuration.getLongValue("SoneFollowingTimes/" + soneCounter++ + "/Time").getValue(null));
}
- return knownPosts;
+ return soneFollowingTimes;
}
- public synchronized Set loadKnownPostReplies() {
- Set knownPostReplies = new HashSet();
- int replyCounter = 0;
- while (true) {
- String knownReplyId = configuration
- .getStringValue("KnownReplies/" + replyCounter++ + "/ID")
- .getValue(null);
- if (knownReplyId == null) {
- break;
+ private synchronized void storeSoneFollowingTimes(Map soneFollowingTimes) {
+ int soneCounter = 0;
+ try {
+ for (Entry soneFollowingTime : soneFollowingTimes.entrySet()) {
+ configuration.getStringValue("SoneFollowingTimes/" + soneCounter + "/Sone").setValue(soneFollowingTime.getKey());
+ configuration.getLongValue("SoneFollowingTimes/" + soneCounter + "/Time").setValue(soneFollowingTime.getValue());
+ ++soneCounter;
}
- knownPostReplies.add(knownReplyId);
+ configuration.getStringValue("SoneFollowingTimes/" + soneCounter + "/Sone").setValue(null);
+ } catch (ConfigurationException ce1) {
+ logger.log(WARNING, "Could not save Sone following times!", ce1);
}
- return knownPostReplies;
}
- public synchronized Set loadBookmarkedPosts() {
- Set bookmarkedPosts = new HashSet();
- int postCounter = 0;
+ private Set loadIds(String prefix) {
+ Set ids = new HashSet<>();
+ int idCounter = 0;
while (true) {
- String bookmarkedPostId = configuration
- .getStringValue("Bookmarks/Post/" + postCounter++ + "/ID")
+ String id = configuration
+ .getStringValue(prefix + "/" + idCounter++ + "/ID")
.getValue(null);
- if (bookmarkedPostId == null) {
+ if (id == null) {
break;
}
- bookmarkedPosts.add(bookmarkedPostId);
+ ids.add(id);
+ }
+ return ids;
+ }
+
+ public synchronized void saveBookmarkedPosts(
+ Set bookmarkedPosts) {
+ saveIds("Bookmarks/Post", bookmarkedPosts);
+ }
+
+ private void saveIds(String prefix, Collection ids) {
+ try {
+ int idCounter = 0;
+ for (String id : ids) {
+ configuration
+ .getStringValue(prefix + "/" + idCounter++ + "/ID")
+ .setValue(id);
+ }
+ configuration
+ .getStringValue(prefix + "/" + idCounter + "/ID")
+ .setValue(null);
+ } catch (ConfigurationException ce1) {
+ logger.log(WARNING, "Could not save bookmarked posts!", ce1);
}
- return bookmarkedPosts;
}
}