Move login requirement to SoneTemplatePage.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / CreatePostPage.java
index b6b291e..869acd8 100644 (file)
@@ -18,6 +18,8 @@
 package net.pterodactylus.sone.web;
 
 import net.pterodactylus.sone.data.Post;
+import net.pterodactylus.sone.data.Sone;
+import net.pterodactylus.sone.web.page.Page.Request.Method;
 import net.pterodactylus.util.template.Template;
 
 /**
@@ -36,7 +38,7 @@ public class CreatePostPage extends SoneTemplatePage {
         *            The Sone web interface
         */
        public CreatePostPage(Template template, WebInterface webInterface) {
-               super("createPost.html", template, "Page.CreatePost.Title", webInterface);
+               super("createPost.html", template, "Page.CreatePost.Title", webInterface, true);
        }
 
        //
@@ -49,25 +51,17 @@ public class CreatePostPage extends SoneTemplatePage {
        @Override
        protected void processTemplate(Request request, Template template) throws RedirectException {
                super.processTemplate(request, template);
-               String text = request.getHttpRequest().getPartAsStringFailsafe("text", 65536).trim();
-               if (text.length() != 0) {
-                       Post post = new Post(System.currentTimeMillis(), text);
-                       getCurrentSone(request.getToadletContext()).addPost(post);
-                       throw new RedirectException("index.html");
+               String returnPage = request.getHttpRequest().getPartAsStringFailsafe("returnPage", 64);
+               if (request.getMethod() == Method.POST) {
+                       String text = request.getHttpRequest().getPartAsStringFailsafe("text", 65536).trim();
+                       if (text.length() != 0) {
+                               Sone currentSone = getCurrentSone(request.getToadletContext());
+                               webInterface.core().createPost(currentSone, System.currentTimeMillis(), text);
+                               throw new RedirectException(returnPage);
+                       }
+                       template.set("errorTextEmpty", true);
                }
-               template.set("errorTextEmpty", true);
-       }
-
-       //
-       // SONETEMPLATEPAGE METHODS
-       //
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       protected boolean requiresLogin() {
-               return true;
+               template.set("returnPage", returnPage);
        }
 
 }