From 45202b50ece500430d9e560208b08a8283f76b96 Mon Sep 17 00:00:00 2001 From: Jesse Morgan Date: Mon, 16 Sep 2013 21:48:34 -0700 Subject: Adding logout function --- src/com/p4square/grow/frontend/GrowFrontend.java | 1 + src/com/p4square/grow/frontend/LogoutResource.java | 40 ++++++++++++++++++++++ src/templates/templates/nav.ftl | 3 +- 3 files changed, 43 insertions(+), 1 deletion(-) create mode 100644 src/com/p4square/grow/frontend/LogoutResource.java (limited to 'src') diff --git a/src/com/p4square/grow/frontend/GrowFrontend.java b/src/com/p4square/grow/frontend/GrowFrontend.java index 7014b31..07abd16 100644 --- a/src/com/p4square/grow/frontend/GrowFrontend.java +++ b/src/com/p4square/grow/frontend/GrowFrontend.java @@ -110,6 +110,7 @@ public class GrowFrontend extends FMFacade { final Router accountRouter = new Router(getContext()); accountRouter.attach("/authenticate", AuthenticatedResource.class); + accountRouter.attach("/logout", LogoutResource.class); accountRouter.attach("", AccountRedirectResource.class); accountRouter.attach("/assessment/question/{questionId}", SurveyPageResource.class); diff --git a/src/com/p4square/grow/frontend/LogoutResource.java b/src/com/p4square/grow/frontend/LogoutResource.java new file mode 100644 index 0000000..e26dcb7 --- /dev/null +++ b/src/com/p4square/grow/frontend/LogoutResource.java @@ -0,0 +1,40 @@ +/* + * Copyright 2013 Jesse Morgan + */ + +package com.p4square.grow.frontend; + +import org.restlet.representation.Representation; +import org.restlet.representation.StringRepresentation; +import org.restlet.resource.ServerResource; + +import com.p4square.session.Sessions; + +import com.p4square.grow.config.Config; + +/** + * This Resource removes a user's session and session cookies. + * + * @author Jesse Morgan + */ +public class LogoutResource extends ServerResource { + private Config mConfig; + + @Override + protected void doInit() { + super.doInit(); + + GrowFrontend growFrontend = (GrowFrontend) getApplication(); + mConfig = growFrontend.getConfig(); + } + + @Override + protected Representation get() { + Sessions.getInstance().delete(getRequest(), getResponse()); + + String nextPage = mConfig.getString("dynamicRoot", ""); + nextPage += "/index.html"; + getResponse().redirectSeeOther(nextPage); + return new StringRepresentation("Redirecting to " + nextPage); + } +} diff --git a/src/templates/templates/nav.ftl b/src/templates/templates/nav.ftl index cbbe3bd..6816568 100644 --- a/src/templates/templates/nav.ftl +++ b/src/templates/templates/nav.ftl @@ -21,7 +21,8 @@ <@navLink href="${dynamicRoot}/learnmore.html">Learn More <@navLink href="${dynamicRoot}/contact.html">Contact <#if user??> - <@navLink href="${dynamicRoot}/account">Take Assessment + <@navLink href="${dynamicRoot}/account">Keep Growing + <@navLink href="${dynamicRoot}/account/logout">Logout <#else> <@navLink href="${dynamicRoot}/login.html">Login / Sign Up -- cgit v1.2.3