diff options
Diffstat (limited to 'src/com')
| -rw-r--r-- | src/com/p4square/grow/frontend/GrowFrontend.java | 1 | ||||
| -rw-r--r-- | src/com/p4square/grow/frontend/LogoutResource.java | 40 | 
2 files changed, 41 insertions, 0 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); +    } +} | 
