/********************************************************************************** * $URL: https://source.sakaiproject.org/svn/rwiki/trunk/rwiki-tool/tool/src/java/uk/ac/cam/caret/sakai/rwiki/tool/bean/helper/RecentlyVisitedHelperBean.java $ * $Id: RecentlyVisitedHelperBean.java 20354 2007-01-17 10:30:57Z ian@caret.cam.ac.uk $ *********************************************************************************** * * Copyright (c) 2003, 2004, 2005, 2006 The Sakai Foundation. * * Licensed under the Educational Community License, Version 1.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.opensource.org/licenses/ecl1.php * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * **********************************************************************************/ package uk.ac.cam.caret.sakai.rwiki.tool.bean.helper; import javax.servlet.ServletRequest; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import uk.ac.cam.caret.sakai.rwiki.tool.bean.RecentlyVisitedBean; /** * Helper bean to get a RecentlyVistedBean from a request. * * @author andrew */ public class RecentlyVisitedHelperBean { private static Log log = LogFactory.getLog(RecentlyVisitedHelperBean.class); /** * Session attribute to save the recentlyVisitedBean */ public static final String RECENT_VISIT_ATTR = "recentlyVisitedBean"; private ServletRequest request; private RecentlyVisitedBean recentBean; private String defaultSpace; /** * Sets the recently visited bean using the set request and logger and * default space. */ public void init() { recentBean = RecentlyVisitedHelperBean.getRecentlyVisitedBean( (HttpServletRequest) request, defaultSpace); } /** * Set the current request * * @param servletRequest */ public void setServletRequest(ServletRequest servletRequest) { this.request = servletRequest; } /** * Set the default space * * @param defaultSpace */ public void setDefaultSpace(String defaultSpace) { this.defaultSpace = defaultSpace; } /** * Retrieve the current <code>RecentlyVisitedBean</code> from the passed * in <code>ServletRequest</code> or create one in the default space. * * @param request * current servlet request * @param log * current logger * @param defaultSpace * defaultSpace to for the RecentlyVisitedBean * @return RecentlyVisitedBean */ public static RecentlyVisitedBean getRecentlyVisitedBean( HttpServletRequest request, String defaultSpace) { HttpSession session = request.getSession(); RecentlyVisitedBean bean = null; try { bean = (RecentlyVisitedBean) session .getAttribute(RECENT_VISIT_ATTR); } catch (ClassCastException e) { log.warn("Session contains object at " + RECENT_VISIT_ATTR + " which is not a valid breadcrumb bean\n" + "Object is: " + session.getAttribute(RECENT_VISIT_ATTR).toString()); } if (bean == null) { bean = new RecentlyVisitedBean(defaultSpace); session.setAttribute(RECENT_VISIT_ATTR, bean); } return bean; } /** * Get the retrieved recently visited bean * * @return recentlyVisitedBean */ public RecentlyVisitedBean getRecentlyVisitedBean() { return recentBean; } }