Use traditional getter name.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / SoneTemplatePage.java
index ce84abd..065950e 100644 (file)
@@ -25,8 +25,8 @@ import net.pterodactylus.sone.data.Sone;
 import net.pterodactylus.sone.web.page.Page;
 import net.pterodactylus.sone.web.page.TemplatePage;
 import net.pterodactylus.util.template.Template;
-import freenet.clients.http.RedirectException;
 import freenet.clients.http.SessionManager.Session;
+import freenet.clients.http.ToadletContext;
 
 /**
  * Base page for the Freetalk web interface.
@@ -38,8 +38,12 @@ public class SoneTemplatePage extends TemplatePage {
        /** The Sone core. */
        protected final WebInterface webInterface;
 
+       /** Whether to require a login. */
+       private final boolean requireLogin;
+
        /**
-        * Creates a new template page for Freetalk.
+        * Creates a new template page for Freetalk that does not require the user
+        * to be logged in.
         *
         * @param path
         *            The path of the page
@@ -51,8 +55,27 @@ public class SoneTemplatePage extends TemplatePage {
         *            The Sone web interface
         */
        public SoneTemplatePage(String path, Template template, String pageTitleKey, WebInterface webInterface) {
-               super(path, template, webInterface.l10n(), pageTitleKey);
+               this(path, template, pageTitleKey, webInterface, false);
+       }
+
+       /**
+        * Creates a new template page for Freetalk.
+        *
+        * @param path
+        *            The path of the page
+        * @param template
+        *            The template to render
+        * @param pageTitleKey
+        *            The l10n key of the page title
+        * @param webInterface
+        *            The Sone web interface
+        * @param requireLogin
+        *            Whether this page requires a login
+        */
+       public SoneTemplatePage(String path, Template template, String pageTitleKey, WebInterface webInterface, boolean requireLogin) {
+               super(path, template, webInterface.getL10n(), pageTitleKey, "noPermission.html");
                this.webInterface = webInterface;
+               this.requireLogin = requireLogin;
                template.set("webInterface", webInterface);
        }
 
@@ -64,35 +87,35 @@ public class SoneTemplatePage extends TemplatePage {
         * Returns the current session, creating a new session if there is no
         * current session.
         *
-        * @param request
-        *            The request to extract the session information from
+        * @param toadletContenxt
+        *            The toadlet context
         * @return The current session, or {@code null} if there is no current
         *         session
         */
-       protected Session getCurrentSession(Request request) {
-               return getCurrentSession(request, true);
+       protected Session getCurrentSession(ToadletContext toadletContenxt) {
+               return getCurrentSession(toadletContenxt, true);
        }
 
        /**
         * Returns the current session, creating a new session if there is no
         * current session and {@code create} is {@code true}.
         *
-        * @param request
-        *            The request to extract the session information from
+        * @param toadletContenxt
+        *            The toadlet context
         * @param create
         *            {@code true} to create a new session if there is no current
         *            session, {@code false} otherwise
         * @return The current session, or {@code null} if there is no current
         *         session
         */
-       protected Session getCurrentSession(Request request, boolean create) {
+       protected Session getCurrentSession(ToadletContext toadletContenxt, boolean create) {
                try {
-                       Session session = webInterface.sessionManager().useSession(request.getToadletContext());
+                       Session session = webInterface.getSessionManager().useSession(toadletContenxt);
                        if (create && (session == null)) {
-                               session = webInterface.sessionManager().createSession(UUID.randomUUID().toString(), request.getToadletContext());
+                               session = webInterface.getSessionManager().createSession(UUID.randomUUID().toString(), toadletContenxt);
                        }
                        return session;
-               } catch (RedirectException re1) {
+               } catch (freenet.clients.http.RedirectException re1) {
                        return null;
                }
        }
@@ -100,17 +123,43 @@ public class SoneTemplatePage extends TemplatePage {
        /**
         * Returns the currently logged in Sone.
         *
-        * @param request
-        *            The request to extract the session information from
+        * @param toadletContext
+        *            The toadlet context
         * @return The currently logged in Sone, or {@code null} if no Sone is
         *         currently logged in
         */
-       protected Sone getCurrentSone(Request request) {
-               Session session = getCurrentSession(request);
+       protected Sone getCurrentSone(ToadletContext toadletContext) {
+               Session session = getCurrentSession(toadletContext);
                if (session == null) {
                        return null;
                }
-               return (Sone) session.getAttribute("Sone.CurrentSone");
+               String soneId = (String) session.getAttribute("Sone.CurrentSone");
+               if (soneId == null) {
+                       return null;
+               }
+               for (Sone sone : webInterface.getCore().getSones()) {
+                       if (sone.getId().equals(soneId)) {
+                               return sone;
+                       }
+               }
+               return null;
+       }
+
+       /**
+        * Sets the currently logged in Sone.
+        *
+        * @param toadletContext
+        *            The toadlet context
+        * @param sone
+        *            The Sone to set as currently logged in
+        */
+       protected void setCurrentSone(ToadletContext toadletContext, Sone sone) {
+               Session session = getCurrentSession(toadletContext);
+               if (sone == null) {
+                       session.removeAttribute("Sone.CurrentSone");
+               } else {
+                       session.setAttribute("Sone.CurrentSone", sone.getId());
+               }
        }
 
        //
@@ -126,13 +175,31 @@ public class SoneTemplatePage extends TemplatePage {
        }
 
        /**
+        * {@inheritDoc}
+        */
+       @Override
+       protected String getShortcutIcon() {
+               return "images/icon.png";
+       }
+
+       /**
         * Returns whether this page requires the user to log in.
         *
         * @return {@code true} if the user is required to be logged in to use this
         *         page, {@code false} otherwise
         */
        protected boolean requiresLogin() {
-               return false;
+               return requireLogin;
+       }
+
+       /**
+        * {@inheritDoc}
+        */
+       @Override
+       protected void processTemplate(Request request, Template template) throws RedirectException {
+               super.processTemplate(request, template);
+               template.set("currentSone", getCurrentSone(request.getToadletContext()));
+               template.set("request", request);
        }
 
        /**
@@ -140,10 +207,21 @@ public class SoneTemplatePage extends TemplatePage {
         */
        @Override
        protected String getRedirectTarget(Page.Request request) {
-               if (requiresLogin() && (getCurrentSone(request) == null)) {
+               if (requiresLogin() && (getCurrentSone(request.getToadletContext()) == null)) {
                        return "login.html";
                }
                return null;
        }
 
+       /**
+        * {@inheritDoc}
+        */
+       @Override
+       public boolean isEnabled(ToadletContext toadletContext) {
+               if (requiresLogin()) {
+                       return getCurrentSone(toadletContext) != null;
+               }
+               return true;
+       }
+
 }