import freenet.keys.FreenetURI;
/**
- * A Sone defines everything about a user: the {@link User} itself, her profile,
- * her status updates.
+ * A Sone defines everything about a user: her profile, her status updates, her
+ * replies, her likes and dislikes, etc.
* <p>
* Operations that modify the Sone need to synchronize on the Sone in question.
*
/** All posts. */
private final List<Post> posts = new ArrayList<Post>();
+ /** All replies. */
+ private final Set<Reply> replies = new HashSet<Reply>();
+
/** Modification count. */
private volatile long modificationCounter = 0;
}
/**
- * Adds a post with the given text to this Sone.
+ * Adds the given post to this Sone. The post will not be added if its
+ * {@link Post#getSone() Sone} is not this Sone.
*
- * @param text
- * The text to post
+ * @param post
+ * The post to add
*/
- public synchronized void addPost(String text) {
- Post post = new Post(this, System.currentTimeMillis(), text);
- if (posts.add(post)) {
+ public synchronized void addPost(Post post) {
+ if (post.getSone().equals(this) && posts.add(post)) {
modificationCounter++;
}
}
* The post to remove
*/
public synchronized void removePost(Post post) {
- if (posts.remove(post)) {
+ if (post.getSone().equals(this) && posts.remove(post)) {
+ modificationCounter++;
+ }
+ }
+
+ /**
+ * Returns all replies this Sone made.
+ *
+ * @return All replies this Sone made
+ */
+ public Set<Reply> getReplies() {
+ return Collections.unmodifiableSet(replies);
+ }
+
+ /**
+ * Adds a reply to this Sone. If the given reply was not made by this Sone,
+ * nothing is added to this Sone.
+ *
+ * @param reply
+ * The reply to add
+ */
+ public synchronized void addReply(Reply reply) {
+ if (reply.getSone().equals(this) && replies.add(reply)) {
+ modificationCounter++;
+ }
+ }
+
+ /**
+ * Removes a reply from this Sone.
+ *
+ * @param reply
+ * The reply to remove
+ */
+ public synchronized void removeReply(Reply reply) {
+ if (reply.getSone().equals(this) && replies.remove(reply)) {
modificationCounter++;
}
}