/* Name: - UserRequestContext Description: - Requires: - Provides: - Part of: ProcessPuzzle Framework, Domain and Business Model Ready Architecture. Provides content, workflow and social networking functionality. http://www.processpuzzle.com ProcessPuzzle - Content and Workflow Management Integration Business Platform Author(s): - Zsolt Zsuffa Copyright: (C) 2011 This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.processpuzzle.user_session.domain; import java.io.Serializable; import com.processpuzzle.application.domain.Application; /** * Implemented by classes that provide an application wide request context. * Each request context has its own ID, which is unique per request. The ID can hence * be used for tracking specific user requests by correlating it with user name. * The request context references a SecurityContext, which holds information about * the current user if logged on, null otherwise. * * Note: As request contexts can be serialized it is imperative that any referenced * objects are also serializable and that the overall size is kept at a minimum. * * @author kkj, jsb * @since 20-7-2004 * @version $revision: $ */ public interface UserRequestContext extends Serializable { /** * Get the current request id * @return Request ID */ public String getId(); /** * Get the complete stack of request ids, reflecting the call chain * through which this context has passed. * @return The current list of request contexts */ public String[] getIds(); /** * @return The current application session if one exists, otherwise a new one. */ public UserSession getUserSession(); /** * Set the current application session * @param applicationSession The session to set */ public void setUserSession( UserSession applicationSession ); public Application getApplication(); }