Merge branch 'release-0.4'
[Sone.git] / src / main / java / net / pterodactylus / sone / web / ViewSonePage.java
index 8b88f2e..9746afd 100644 (file)
 
 package net.pterodactylus.sone.web;
 
+import java.util.List;
+
+import net.pterodactylus.sone.data.Post;
+import net.pterodactylus.sone.data.Reply;
 import net.pterodactylus.sone.data.Sone;
+import net.pterodactylus.util.template.DataProvider;
 import net.pterodactylus.util.template.Template;
 
 /**
@@ -47,11 +52,29 @@ public class ViewSonePage extends SoneTemplatePage {
         * {@inheritDoc}
         */
        @Override
-       protected void processTemplate(Request request, Template template) throws RedirectException {
-               super.processTemplate(request, template);
+       protected void processTemplate(Request request, DataProvider dataProvider) throws RedirectException {
+               super.processTemplate(request, dataProvider);
                String soneId = request.getHttpRequest().getParam("sone");
                Sone sone = webInterface.getCore().getSone(soneId, false);
-               template.set("sone", sone);
+               dataProvider.set("sone", sone);
+       }
+
+       /**
+        * {@inheritDoc}
+        */
+       @Override
+       protected void postProcess(Request request, DataProvider dataProvider) {
+               Sone sone = (Sone) dataProvider.get("sone");
+               if (sone == null) {
+                       return;
+               }
+               List<Post> posts = sone.getPosts();
+               for (Post post : posts) {
+                       webInterface.getCore().markPostKnown(post);
+                       for (Reply reply : webInterface.getCore().getReplies(post)) {
+                               webInterface.getCore().markReplyKnown(reply);
+                       }
+               }
        }
 
 }