- /**
- * Creates a new post.
- *
- * @param sone
- * The Sone that creates the post
- * @param time
- * The time of the post
- * @param text
- * The text of the post
- * @return The created post
- */
- public Post createPost(Sone sone, long time, String text) {
- return createPost(sone, null, time, text);
- }
-
- /**
- * Creates a new post.
- *
- * @param sone
- * The Sone that creates the post
- * @param recipient
- * The recipient Sone, or {@code null} if this post does not have
- * a recipient
- * @param text
- * The text of the post
- * @return The created post
- */
- public Post createPost(Sone sone, Sone recipient, String text) {
- return createPost(sone, recipient, System.currentTimeMillis(), text);
- }
-
- /**
- * Creates a new post.
- *
- * @param sone
- * The Sone that creates the post
- * @param recipient
- * The recipient Sone, or {@code null} if this post does not have
- * a recipient
- * @param time
- * The time of the post
- * @param text
- * The text of the post
- * @return The created post
- */
- public Post createPost(Sone sone, Sone recipient, long time, String text) {
- if (!isLocalSone(sone)) {
- logger.log(Level.FINE, "Tried to create post for non-local Sone: %s", sone);
- return null;
- }
- Post post = new Post(sone, time, text);
- if (recipient != null) {
- post.setRecipient(recipient);
- }
- synchronized (posts) {
- posts.put(post.getId(), post);
- }
- synchronized (newPosts) {
- knownPosts.add(post.getId());
- }
- sone.addPost(post);
- saveSone(sone);
- return post;
- }
-
- /**
- * Deletes the given post.
- *
- * @param post
- * The post to delete
- */
- public void deletePost(Post post) {
- if (!isLocalSone(post.getSone())) {
- logger.log(Level.WARNING, "Tried to delete post of non-local Sone: %s", post.getSone());
- return;
- }
- post.getSone().removePost(post);
- synchronized (posts) {
- posts.remove(post.getId());
- }
- saveSone(post.getSone());
- }
-
- /**
- * Marks the given post as known, if it is currently a new post (according
- * to {@link #isNewPost(String)}).
- *
- * @param post
- * The post to mark as known
- */
- public void markPostKnown(Post post) {
- synchronized (newPosts) {
- if (newPosts.remove(post.getId())) {
- knownPosts.add(post.getId());
- coreListenerManager.fireMarkPostKnown(post);
- saveConfiguration();
- }
- }
- }
-
- /**
- * Bookmarks the given post.
- *
- * @param post
- * The post to bookmark
- */
- public void bookmark(Post post) {
- bookmarkPost(post.getId());
- }
-
- /**
- * Bookmarks the post with the given ID.
- *
- * @param id
- * The ID of the post to bookmark
- */
- public void bookmarkPost(String id) {
- synchronized (bookmarkedPosts) {
- bookmarkedPosts.add(id);
- }
- }
-
- /**
- * Removes the given post from the bookmarks.
- *
- * @param post
- * The post to unbookmark
- */
- public void unbookmark(Post post) {
- unbookmarkPost(post.getId());
- }
-
- /**
- * Removes the post with the given ID from the bookmarks.
- *
- * @param id
- * The ID of the post to unbookmark
- */
- public void unbookmarkPost(String id) {
- synchronized (bookmarkedPosts) {
- bookmarkedPosts.remove(id);
- }
- }
-
- /**
- * Creates a new reply.
- *
- * @param sone
- * The Sone that creates the reply
- * @param post
- * The post that this reply refers to
- * @param text
- * The text of the reply
- * @return The created reply
- */
- public Reply createReply(Sone sone, Post post, String text) {
- return createReply(sone, post, System.currentTimeMillis(), text);
- }
-
- /**
- * Creates a new reply.
- *
- * @param sone
- * The Sone that creates the reply
- * @param post
- * The post that this reply refers to
- * @param time
- * The time of the reply
- * @param text
- * The text of the reply
- * @return The created reply
- */
- public Reply createReply(Sone sone, Post post, long time, String text) {
- if (!isLocalSone(sone)) {
- logger.log(Level.FINE, "Tried to create reply for non-local Sone: %s", sone);
- return null;
- }
- Reply reply = new Reply(sone, post, System.currentTimeMillis(), text);
- synchronized (replies) {
- replies.put(reply.getId(), reply);
- }
- synchronized (newReplies) {
- knownReplies.add(reply.getId());
- }
- sone.addReply(reply);
- saveSone(sone);
- return reply;
- }
-
- /**
- * Deletes the given reply.
- *
- * @param reply
- * The reply to delete
- */
- public void deleteReply(Reply reply) {
- Sone sone = reply.getSone();
- if (!isLocalSone(sone)) {
- logger.log(Level.FINE, "Tried to delete non-local reply: %s", reply);
- return;
- }
- synchronized (replies) {
- replies.remove(reply.getId());
- }
- sone.removeReply(reply);
- saveSone(sone);
- }
-
- /**
- * Marks the given reply as known, if it is currently a new reply (according
- * to {@link #isNewReply(String)}).
- *
- * @param reply
- * The reply to mark as known
- */
- public void markReplyKnown(Reply reply) {
- synchronized (newReplies) {
- if (newReplies.remove(reply.getId())) {
- knownReplies.add(reply.getId());
- coreListenerManager.fireMarkReplyKnown(reply);
- saveConfiguration();
- }
- }
- }
-
- /**
- * Creates a new top-level album for the given Sone.
- *
- * @param sone
- * The Sone to create the album for
- * @return The new album
- */
- public Album createAlbum(Sone sone) {
- return createAlbum(sone, null);
- }
-
- /**
- * Creates a new album for the given Sone.
- *
- * @param sone
- * The Sone to create the album for
- * @param parent
- * The parent of the album (may be {@code null} to create a
- * top-level album)
- * @return The new album
- */
- public Album createAlbum(Sone sone, Album parent) {
- Album album = new Album();
- synchronized (albums) {
- albums.put(album.getId(), album);
- }
- album.setSone(sone);
- if (parent != null) {
- parent.addAlbum(album);
- } else {
- sone.addAlbum(album);
- }
- return album;
- }
-
- /**
- * Starts the core.
- */
- public void start() {
- loadConfiguration();
- updateChecker.addUpdateListener(this);
- updateChecker.start();
- }
-
- /**
- * Stops the core.
- */
- public void stop() {
- synchronized (localSones) {
- for (SoneInserter soneInserter : soneInserters.values()) {
- soneInserter.stop();
- }