X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fdata%2FPost.java;h=bd3986f7b5c9462973fee107d3c71be4705070c6;hb=72407829d504a0444aadd09cc937bae10b6cb866;hp=5269fe46f15ee9dcd796639844090b80d507bc74;hpb=45803a1c678d6811f7bbf85d50c79844031be0f0;p=Sone.git
diff --git a/src/main/java/net/pterodactylus/sone/data/Post.java b/src/main/java/net/pterodactylus/sone/data/Post.java
index 5269fe4..bd3986f 100644
--- a/src/main/java/net/pterodactylus/sone/data/Post.java
+++ b/src/main/java/net/pterodactylus/sone/data/Post.java
@@ -17,8 +17,12 @@
package net.pterodactylus.sone.data;
+import java.util.Collections;
import java.util.Comparator;
+import java.util.List;
+import java.util.Set;
+import com.google.common.base.Function;
import com.google.common.base.Optional;
import com.google.common.base.Predicate;
@@ -28,7 +32,7 @@ import com.google.common.base.Predicate;
*
* @author David âBombeâ Roden
*/
-public interface Post {
+public interface Post extends Identified {
/** Comparator for posts, sorts descending by time. */
public static final Comparator TIME_COMPARATOR = new Comparator() {
@@ -45,11 +49,18 @@ public interface Post {
@Override
public boolean apply(Post post) {
- return post.getTime() <= System.currentTimeMillis();
+ return (post == null) ? false : post.getTime() <= System.currentTimeMillis();
}
};
+ public static final Function> TO_REPLIES = new Function>() {
+ @Override
+ public List apply(Post post) {
+ return (post == null) ? Collections.emptyList() : post.getReplies();
+ }
+ };
+
//
// ACCESSORS
//
@@ -69,14 +80,6 @@ public interface Post {
public Sone getSone();
/**
- * Returns whether this post has a recipient.
- *
- * @return {@code true} if this post has a recipient, {@code false}
- * otherwise
- */
- public boolean hasRecipient();
-
- /**
* Returns the ID of the recipient {@link Sone}, or
* {@link Optional#absent()} if this post does not have a recipient.
*
@@ -85,10 +88,7 @@ public interface Post {
public Optional getRecipientId();
/**
- * Returns the recipient of this post, if any. As this method can return
- * {@link Optional#absent()} if the post has a recipient which has not yet
- * been loaded, it is recommended to use {@link #hasRecipient()} to check
- * for the presence of a recipient.
+ * Returns the recipient of this post, if any.
*
* @return The recipient of this post, or {@link Optional#absent()} if there
* is no recipient
@@ -119,10 +119,16 @@ public interface Post {
/**
* Sets whether this post is known.
*
- * @param known
- * {@code true} if this post is known, {@code false} otherwise
* @return This post
*/
- public Post setKnown(boolean known);
+ public Post setKnown();
+
+ void like(Sone localSone);
+ void unlike(Sone localSone);
+
+ boolean isLiked(Sone sone);
+ Set getLikes();
+
+ List getReplies();
}