/* Wotonomy: OpenStep design patterns for pure Java applications. Copyright (C) 2003 Intersect Software Corp. This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, see http://www.gnu.org */ package net.wotonomy.web; /** * An abstract class defining the requirements for persisting session state * across user transactions. Used by WOApplication to persist sessions between * requests. * * @author michael@mpowers.net * @author $Author: cgruber $ * @version $Revision: 893 $ */ public abstract class WOSessionStore { private static WOSessionStore serverSessionStore = null; /** * Returns the default session store used by WOApplication. */ public static WOSessionStore serverSessionStore() { if (serverSessionStore == null) { serverSessionStore = new WOServletSessionStore(); } return serverSessionStore; } /** * Called by WOApplication after the request-response cycle has ended. The * context's session will again be available for subsequent requests. */ public final void checkInSessionForContext(WOContext aContext) { saveSessionForContext(aContext); } /** * Returns the session with the specified id for the specified request, or null * if none exist. Subsequent calls for the same id will return null until the * session is checked in again. Called by WOApplication before the * request-response cycle starts. */ public final WOSession checkOutSessionWithID(String sessionID, WORequest aRequest) { return restoreSessionWithID(sessionID, aRequest); } /** * Removes the WOSession for the specified ID from the store and returns it. */ public abstract WOSession removeSessionWithID(String sessionID); /** * Returns the WOSession for the specified ID from the store. */ public abstract WOSession restoreSessionWithID(String sessionID, WORequest aRequest); /** * Places the context's session into the store. */ public abstract void saveSessionForContext(WOContext context); } /* * $Log$ Revision 1.1 2006/02/16 13:22:22 cgruber Check in all sources in * eclipse-friendly maven-enabled packages. * * Revision 1.1 2003/01/07 20:48:29 mpowers Implemented WOSessionStore and * WOServletSessionStore. * * */