/* * Copyright 2003-2005 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0 * * 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 org.apache.wsrp4j.commons.consumer.interfaces.session; import java.util.Iterator; /** * Interface for a consumer based group session.A group session * is used to hold portlet session objects of portlet instances * which belong to the same group of the same producer according to their * portlet description. * * @version $Id: GroupSession.java 374672 2006-02-03 14:10:58Z cziegeler $ */ public interface GroupSession { /** * Get the ID of the group this group session belongs to. * * @return The group ID **/ String getGroupID(); /** * Get the portlet session object which is identified with * the givven instanceKey from the group session. If no portlet session * with that instanceKey exists it depends of the implementation wether * null or a newly created portlet session object is returned. * * @param instanceKey The key which identifies the portlet session object * * @return The portlet session with the given key **/ PortletSession getPortletSession(String instanceKey); /** * Get all portlet session objects currently stored in the group session. * * @return Iterator with all portlet session objects in the group session. **/ Iterator getAllPortletSessions(); /** * Check if the group session holds a portlet session with the given key. * * @return True if the group session holds a protlet session with the * given key; false otherwise **/ boolean existsPortletSession(String instanceKey); /** * Set the ID of the group this group session belongs to. * * @param groupID ID of the group **/ void setGroupID(String groupID); /** * Add a portlet session to this group session. * * @param portletSession The portlet session which should be * added to this group session. **/ void addPortletSession(PortletSession portletSession); /** * Remove the portlet session object with the given key from the * group session. Subsequent calls of getPortletSession with the same * key should either return null or a newly created object. * * @param instanceKey Key which identifies the portlet session object to * be removed. **/ void removePortletSession(String instanceKey); /** * Removes all portlet session objects from the group session. Consequently * this methods can be used to clear the group session. **/ void removeAllPortletSessions(); }