summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJesse Morgan <jesse@jesterpm.net>2013-09-16 21:48:34 -0700
committerJesse Morgan <jesse@jesterpm.net>2013-09-17 00:49:28 -0700
commitfeb118725012cb1929f245b446568fe1ecb6ce01 (patch)
tree827abcde4590f0933b771fe274946692dac0488c /src
parentb0e55924299341245fff5991b5666c1ef2853b42 (diff)
Adding logout functionv20130917a
Diffstat (limited to 'src')
-rw-r--r--src/com/p4square/grow/frontend/GrowFrontend.java1
-rw-r--r--src/com/p4square/grow/frontend/LogoutResource.java40
-rw-r--r--src/templates/templates/nav.ftl3
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>