Merge branch 'next' into edit-wot-trust
[Sone.git] / src / main / java / net / pterodactylus / sone / template / PostAccessor.java
index 9284f0d..d5dd406 100644 (file)
 
 package net.pterodactylus.sone.template;
 
+import java.io.IOException;
+import java.io.StringReader;
+
 import net.pterodactylus.sone.core.Core;
 import net.pterodactylus.sone.data.Post;
+import net.pterodactylus.sone.data.Sone;
+import net.pterodactylus.sone.text.FreenetLinkParser;
 import net.pterodactylus.util.template.DataProvider;
 import net.pterodactylus.util.template.ReflectionAccessor;
+import net.pterodactylus.util.template.TemplateFactory;
 
 /**
  * Accessor for {@link Post} objects that adds additional properties:
@@ -33,6 +39,9 @@ import net.pterodactylus.util.template.ReflectionAccessor;
  */
 public class PostAccessor extends ReflectionAccessor {
 
+       /** Parser for Freenet links. */
+       private final FreenetLinkParser linkParser;
+
        /** The core to get the replies from. */
        private final Core core;
 
@@ -41,9 +50,12 @@ public class PostAccessor extends ReflectionAccessor {
         *
         * @param core
         *            The core to get the replies from
+        * @param templateFactory
+        *            The template factory for the text parser
         */
-       public PostAccessor(Core core) {
+       public PostAccessor(Core core, TemplateFactory templateFactory) {
                this.core = core;
+               linkParser = new FreenetLinkParser(templateFactory);
        }
 
        /**
@@ -51,8 +63,29 @@ public class PostAccessor extends ReflectionAccessor {
         */
        @Override
        public Object get(DataProvider dataProvider, Object object, String member) {
+               Post post = (Post) object;
                if ("replies".equals(member)) {
-                       return core.getReplies((Post) object);
+                       return core.getReplies(post);
+               } else if (member.equals("likes")) {
+                       return core.getLikes(post);
+               } else if (member.equals("liked")) {
+                       Sone currentSone = (Sone) dataProvider.getData("currentSone");
+                       return (currentSone != null) && (currentSone.isLikedPostId(post.getId()));
+               } else if (member.equals("new")) {
+                       return core.isNewPost(post.getId(), false);
+               } else if (member.equals("text")) {
+                       String text = post.getText();
+                       if (text == null) {
+                               return null;
+                       }
+                       try {
+                               synchronized (linkParser) {
+                                       linkParser.setPostingSone(post.getSone());
+                                       return linkParser.parse(new StringReader(text));
+                               }
+                       } catch (IOException ioe1) {
+                               /* ignore. */
+                       }
                }
                return super.get(dataProvider, object, member);
        }