/**
* Licensed to Apereo under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright ownership. Apereo
* licenses this file to you 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 the
* following location:
*
* <p>http://www.apache.org/licenses/LICENSE-2.0
*
* <p>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.apereo.portal.groups;
import java.util.Set;
import javax.naming.Name;
/**
* An <code>IEntityGroup</code> is a composite, or non-leaf <code>IGroupMember</code>. It contains
* <code>IEntities</code> and other <code>IEntityGroups</code>.
*
* <p>The api defines methods for adding a member to, and removing it from, a group, though not vice
* versa. (Although there is nothing to prevent a given <code>IGroupMember</code> implementation
* from storing references to its containing groups.) These methods only change the group structure
* in memory.
*
* <p><code>addChild(IGroupMember gm)</code><br>
* <code>removeChild(IGroupMember gm)</code><br>
*
* <p>The following methods commit changes in the group structure to the persistent store:
*
* <p><code>delete()</code> - delete the group and its memberships<br>
* <code>update()</code> - insert or update the group, as appropriate<br>
* <code>updateMembers()</code> - insert/update/delete group memberships as appropriate<br>
*
* <p>The following methods were added to permit an <code>IEntityGroup</code> to function within a
* composite group service:
*
* <p><code>getLocalKey()</code> - returns the key within the service of origin.<br>
* <code>getServiceName()</code> - returns the Name of the group service of origin.<br>
* <code>setLocalGroupService()</code> - sets the group service of origin.<br>
*
* <p>
*
*/
public interface IEntityGroup extends IGroupMember {
/**
* Answers if this <code>IGroupMember</code> has any members.
*
* @return boolean
*/
boolean hasMembers() throws GroupsException;
/** Answers if <code>IGroupMember</code> gm is a member of <code>this</code>. */
boolean contains(IGroupMember gm) throws GroupsException;
/**
* Answers if <code>IGroupMember</code> gm is a recursive member of <code>this</code>.
*
* @return boolean
* @param gm org.apereo.portal.groups.IGroupMember
*/
boolean deepContains(IGroupMember gm) throws GroupsException;
/** Returns a collection of this <code>IGroupMember's</code> children. */
Set<IGroupMember> getChildren() throws GroupsException;
/**
* Returns a collection of this <code>IGroupMember's</code> recursively-retrieved <code>
* IGroupMembers</code>.
*/
Set<IGroupMember> getDescendants() throws GroupsException;
/**
* Adds <code>IGroupMember</code> gm to this group, but does not commit it to the data store.
* Use <code>updateMembers()</code> to commit memberships to the data store.
*
* @param gm org.apereo.portal.groups.IGroupMember
* @exception GroupsException is thrown if the member is a group and this group already has a
* group with the same name or if the addition of the group creates a circular reference.
*/
void addChild(IGroupMember gm) throws GroupsException;
/**
* Deletes the <code>IEntityGroup</code> from the data store.
*
* @exception GroupsException if the delete cannot be performed.
*/
void delete() throws GroupsException;
/**
* Returns the name of the group creator. May be null.
*
* @return String
*/
String getCreatorID();
/**
* Returns the group description, which may be null.
*
* @return String
*/
String getDescription();
/**
* Returns the key from the group service of origin.
*
* @return String
*/
String getLocalKey();
/**
* Returns the group name.
*
* @return String
*/
String getName();
/**
* Returns the Name of the group service of origin.
*
* @return String
*/
Name getServiceName();
/**
* Answers if this <code>IEntityGroup</code> can be changed or deleted.
*
* @return boolean
* @exception GroupsException
*/
boolean isEditable() throws GroupsException;
/**
* Removes the <code>IGroupMember</code> from this group, but does not remove the membership
* from the data store.
*
* @param gm org.apereo.portal.groups.IGroupMember
*/
void removeChild(IGroupMember gm) throws GroupsException;
/** @param userID String (required) */
void setCreatorID(String userID);
/** @param name String (may be null) */
void setDescription(String name);
/**
* Sets the group name which must be unique within any of its containing groups.
*
* @param name String
* @exception GroupsException
*/
void setName(String name) throws GroupsException;
/**
* Commit the <code>IEntityGroup</code> AND ITS MEMBERSHIPS to the data store.
*
* @exception GroupsException if the update cannot be performed.
*/
void update() throws GroupsException;
/**
* Commit this <code>IEntityGroup's</code> memberships to the data store.
*
* @exception GroupsException if the update cannot be performed.
*/
void updateMembers() throws GroupsException;
/** Sets the group service of origin. */
void setLocalGroupService(IIndividualGroupService groupService) throws GroupsException;
}