diff options
author | Jesse Morgan <jesse@jesterpm.net> | 2013-09-16 21:48:34 -0700 |
---|---|---|
committer | Jesse Morgan <jesse@jesterpm.net> | 2013-09-17 00:49:28 -0700 |
commit | feb118725012cb1929f245b446568fe1ecb6ce01 (patch) | |
tree | 827abcde4590f0933b771fe274946692dac0488c /src | |
parent | b0e55924299341245fff5991b5666c1ef2853b42 (diff) |
Adding logout functionv20130917a
Diffstat (limited to 'src')
-rw-r--r-- | src/com/p4square/grow/frontend/GrowFrontend.java | 1 | ||||
-rw-r--r-- | src/com/p4square/grow/frontend/LogoutResource.java | 40 | ||||
-rw-r--r-- | src/templates/templates/nav.ftl | 3 |
3 files changed, 43 insertions, 1 deletions
diff --git a/src/com/p4square/grow/frontend/GrowFrontend.java b/src/com/p4square/grow/frontend/GrowFrontend.java index 76d4bf7..305622d 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..5c83f40 --- /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 net.jesterpm.session.Sessions; + +import com.p4square.grow.config.Config; + +/** + * This Resource removes a user's session and session cookies. + * + * @author Jesse Morgan <jesse@jesterpm.net> + */ +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> <@navLink href="${dynamicRoot}/contact.html">Contact</@navLink> <#if user??> - <@navLink href="${dynamicRoot}/account">Take Assessment</@navLink> + <@navLink href="${dynamicRoot}/account">Keep Growing</@navLink> + <@navLink href="${dynamicRoot}/account/logout">Logout</@navLink> <#else> <@navLink href="${dynamicRoot}/login.html">Login / Sign Up</@navLink> </#if> |