Merge branch 'release-0.4'
[Sone.git] / src / main / java / net / pterodactylus / sone / web / ViewSonePage.java
index 4a12ed9..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;
 
 /**
@@ -36,7 +41,7 @@ public class ViewSonePage extends SoneTemplatePage {
         *            The Sone web interface
         */
        public ViewSonePage(Template template, WebInterface webInterface) {
-               super("viewSone.html", template, "Page.ViewSone.Title", webInterface);
+               super("viewSone.html", template, "Page.ViewSone.Title", webInterface, false);
        }
 
        //
@@ -47,23 +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.core().getSone(soneId);
-               template.set("sone", sone);
+               Sone sone = webInterface.getCore().getSone(soneId, false);
+               dataProvider.set("sone", sone);
        }
 
-       //
-       // SONETEMPLATEPAGE METHODS
-       //
-
        /**
         * {@inheritDoc}
         */
        @Override
-       protected boolean requiresLogin() {
-               return true;
+       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);
+                       }
+               }
        }
 
 }