/* * JBoss, Home of Professional Open Source. * Copyright 2008, Red Hat Middleware LLC, and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This 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 software 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 software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.web.tomcat.service.session; import java.util.HashMap; import java.util.Map; import org.jboss.web.tomcat.service.session.distributedcache.spi.DistributableSessionMetadata; import org.jboss.web.tomcat.service.session.distributedcache.spi.OutgoingSessionGranularitySessionData; /** * Implementation of a ClusteredSession where the replication granularity level * is session based; that is, we replicate the entire attribute map whenever a * request makes any attribute dirty. * <p/> * Note that the isolation level of the cache dictates the * concurrency behavior.</p> * * @author Ben Wang * @author Brian Stansberry * * @version $Revision: 92504 $ */ class SessionBasedClusteredSession extends ClusteredSession<OutgoingSessionGranularitySessionData> { static final long serialVersionUID = 3200976125245487256L; /** * Descriptive information describing this Session implementation. */ protected static final String info = "SessionBasedClusteredSession/1.0"; // ----------------------------------------------------------- Constructors public SessionBasedClusteredSession(ClusteredManager<OutgoingSessionGranularitySessionData> manager) { super(manager); } // ---------------------------------------------- Overridden Public Methods @Override public String getInfo() { return (info); } @Override protected OutgoingSessionGranularitySessionData getOutgoingSessionData() { boolean needFull = isFullReplicationNeeded(); Map<String, Object> attrs = (needFull || isSessionAttributeMapDirty()) ? getSessionAttributeMap() : null; DistributableSessionMetadata metadata = (needFull || isSessionMetadataDirty()) ? getSessionMetadata() : null; Long timestamp = attrs != null || metadata != null || getMustReplicateTimestamp() ? Long.valueOf(getSessionTimestamp()) : null; return new OutgoingData(getRealId(), getVersion(), timestamp, metadata, attrs); } @Override protected Object removeAttributeInternal(String name, boolean localCall, boolean localOnly) { if (localCall) sessionAttributesDirty(); return getAttributesInternal().remove(name); } @Override protected Object setAttributeInternal(String name, Object value) { sessionAttributesDirty(); return getAttributesInternal().put(name, value); } // ----------------------------------------------------------------- Private private Map<String, Object> getSessionAttributeMap() { Map<String, Object> attrs = new HashMap<String, Object>(getAttributesInternal()); removeExcludedAttributes(attrs); return attrs; } // ----------------------------------------------------------------- Classes private static class OutgoingData extends OutgoingDistributableSessionDataImpl implements OutgoingSessionGranularitySessionData { private final Map<String, Object> attributes; public OutgoingData(String realId, int version, Long timestamp, DistributableSessionMetadata metadata, Map<String, Object> attributes) { super(realId, version, timestamp, metadata); this.attributes = attributes; } public Map<String, Object> getSessionAttributes() { return attributes; } } }