X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2FSoneTemplatePage.java;h=6afc3b7bd3d12271d3b7cf6996dc2befac7fd314;hb=fcd011a16b119966906b3137513e9432ab86c3a8;hp=2b697ce7783f3b7f68fd81b3e4a08a664b329cac;hpb=18c431e8997e88425d596ee72a01da4244a9a3e9;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/web/SoneTemplatePage.java b/src/main/java/net/pterodactylus/sone/web/SoneTemplatePage.java index 2b697ce..6afc3b7 100644 --- a/src/main/java/net/pterodactylus/sone/web/SoneTemplatePage.java +++ b/src/main/java/net/pterodactylus/sone/web/SoneTemplatePage.java @@ -19,13 +19,14 @@ package net.pterodactylus.sone.web; import java.util.Arrays; import java.util.Collection; +import java.util.UUID; 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. @@ -60,24 +61,79 @@ public class SoneTemplatePage extends TemplatePage { // /** + * Returns the current session, creating a new session if there is no + * current session. + * + * @param toadletContenxt + * The toadlet context + * @return The current session, or {@code null} if there is no current + * session + */ + 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 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(ToadletContext toadletContenxt, boolean create) { + try { + Session session = webInterface.sessionManager().useSession(toadletContenxt); + if (create && (session == null)) { + session = webInterface.sessionManager().createSession(UUID.randomUUID().toString(), toadletContenxt); + } + return session; + } catch (freenet.clients.http.RedirectException re1) { + return null; + } + } + + /** * Returns the currently logged in Sone. * - * @param request - * The request to extract the session information from + * @param toadletContenxt + * The toadlet context * @return The currently logged in Sone, or {@code null} if no Sone is * currently logged in */ - protected Sone getCurrentSone(Request request) { - try { - Session session = webInterface.sessionManager().useSession(request.getToadletContext()); - if (session == null) { - return null; - } - return (Sone) session.getAttribute("Sone.CurrentSone"); - } catch (RedirectException re1) { - /* okay, no current session, return null. */ + protected Sone getCurrentSone(ToadletContext toadletContenxt) { + Session session = getCurrentSession(toadletContenxt); + if (session == null) { return null; } + String soneId = (String) session.getAttribute("Sone.CurrentSone"); + for (Sone sone : webInterface.core().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()); + } } // @@ -106,11 +162,31 @@ public class SoneTemplatePage extends TemplatePage { * {@inheritDoc} */ @Override + protected void processTemplate(Request request, Template template) throws RedirectException { + super.processTemplate(request, template); + template.set("currentSone", getCurrentSone(request.getToadletContext())); + } + + /** + * {@inheritDoc} + */ + @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; + } + }