X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Ffcp%2FSubscribeUSK.java;h=1a94af219c10ba24f184b305f23334af87c5af6e;hb=60b7b05425f9ac14f05ce243a1d09aa105a48a21;hp=b0c5e7e6f797fa52b5b0a37d92d97a12ff402fe8;hpb=cd753d3f782e0024fd3edaa97b40f8e86bc3a8b3;p=jFCPlib.git
diff --git a/src/main/java/net/pterodactylus/fcp/SubscribeUSK.java b/src/main/java/net/pterodactylus/fcp/SubscribeUSK.java
index b0c5e7e..1a94af2 100644
--- a/src/main/java/net/pterodactylus/fcp/SubscribeUSK.java
+++ b/src/main/java/net/pterodactylus/fcp/SubscribeUSK.java
@@ -18,13 +18,15 @@
package net.pterodactylus.fcp;
+import java.util.Optional;
+
/**
* With a âSubscribeUSKâ a client requests to be notified if the edition number
* of a USK changes.
*
* @author David âBombeâ Roden <bombe@freenetproject.org>
*/
-public class SubscribeUSK extends FcpMessage {
+public class SubscribeUSK extends FcpMessage implements Identifiable {
public SubscribeUSK(String identifier) {
super("SubscribeUSK");
@@ -36,20 +38,73 @@ public class SubscribeUSK extends FcpMessage {
setField("URI", uri);
}
+ @Override
+ public String getIdentifier() {
+ return getField("Identifier");
+ }
+
+ public String getUri() {
+ return getField("URI");
+ }
+
public void setUri(String uri) {
setField("URI", uri);
}
+ public boolean isActive() {
+ return !Boolean.parseBoolean(getField("DontPoll"));
+ }
+
/**
* Sets whether updates for the USK are actively searched.
*
* @param active
- * true
to actively search for newer editions,
- * false
to only watch for newer editions that are
- * found from other requests
+ * true
to actively search for newer editions,
+ * false
to only watch for newer editions that are
+ * found from other requests
*/
public void setActive(boolean active) {
setField("DontPoll", String.valueOf(!active));
}
+ public boolean isSparse() {
+ return Boolean.valueOf(getField("SparsePoll"));
+ }
+
+ public void setSparse(boolean sparse) {
+ setField("SparsePoll", String.valueOf(sparse));
+ }
+
+ public Priority getPriority() {
+ return Optional.ofNullable(getField("PriorityClass")).map(Priority::valueOf).orElse(Priority.bulkSplitfile);
+ }
+
+ public void setPriority(Priority priority) {
+ setField("PriorityClass", priority.toString());
+ }
+
+ public Priority getActivePriority() {
+ return Optional.ofNullable(getField("PriorityClassProgress")).map(Priority::valueOf).orElse(Priority.update);
+ }
+
+ public void setActivePriority(Priority activePriority) {
+ setField("PriorityClassProgress", activePriority.toString());
+ }
+
+ public boolean isRealTime() {
+ return Boolean.valueOf(getField("RealTimeFlag"));
+ }
+
+ public void setRealTime(boolean realTime) {
+ setField("RealTimeFlag", String.valueOf(realTime));
+ }
+
+ public boolean isIgnoreDateHints() {
+ return Boolean.valueOf(getField("IgnoreUSKDatehints"));
+ }
+
+ public void setIgnoreDateHints(boolean ignoreDateHints) {
+ setField("IgnoreUSKDatehints", String.valueOf(ignoreDateHints));
+ }
+
}