/* * Copyright (C) 2005 Alfresco, Inc. * * 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 2 * 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, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * As a special exception to the terms and conditions of version 2.0 of * the GPL, you may redistribute this Program in connection with Free/Libre * and Open Source Software ("FLOSS") applications as described in Alfresco's * FLOSS exception. You should have recieved a copy of the text describing * the FLOSS exception, and it is also available here: * http://www.alfresco.com/legal/licensing" */ package org.alfresco.repo.policy; import java.util.Collection; import java.util.HashSet; import java.util.Set; import org.alfresco.service.cmr.dictionary.ClassDefinition; import org.alfresco.service.cmr.dictionary.DictionaryService; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.namespace.QName; /** * Delegate for a Class-level Policy. Provides access to Policy Interface * implementations which invoke the appropriate bound behaviours. * * @author David Caruana * * @param

the policy interface */ public class ClassPolicyDelegate

{ private DictionaryService dictionary; private CachedPolicyFactory factory; /** * Construct. * * @param dictionary the dictionary service * @param policyClass the policy interface class * @param index the behaviour index to query against */ @SuppressWarnings("unchecked") /*package*/ ClassPolicyDelegate(DictionaryService dictionary, Class

policyClass, BehaviourIndex index) { // Get list of all pre-registered behaviours for the policy and // ensure they are valid. Collection definitions = index.getAll(); for (BehaviourDefinition definition : definitions) { definition.getBehaviour().getInterface(policyClass); } // Rely on cached implementation of policy factory // Note: Could also use PolicyFactory (without caching) this.factory = new CachedPolicyFactory(policyClass, index); this.dictionary = dictionary; } /** * Gets the Policy implementation for the specified Class * * When multiple behaviours are bound to the policy for the class, an * aggregate policy implementation is returned which invokes each policy * in turn. * * @param classQName the class qualified name * @return the policy */ public P get(QName classQName) { return get(null, classQName); } /** * Gets the Policy implementation for the specified Class * * @param nodeRef the node reference * @param classQName the class name * @return the policy */ public P get(NodeRef nodeRef, QName classQName) { ClassDefinition classDefinition = dictionary.getClass(classQName); if (classDefinition == null) { throw new IllegalArgumentException("Class " + classQName + " has not been defined in the data dictionary"); } return factory.create(new ClassBehaviourBinding(dictionary, nodeRef, classQName)); } /** * Gets the collection of Policy implementations for the specified Class * * @param classQName the class qualified name * @return the collection of policies */ public Collection

getList(QName classQName) { return getList(null, classQName); } /** * Gets the collection of Policy implementations for the specified Class * * @param nodeRef the node reference * @param classQName the class qualified name * @return the collection of policies */ public Collection

getList(NodeRef nodeRef, QName classQName) { ClassDefinition classDefinition = dictionary.getClass(classQName); if (classDefinition == null) { throw new IllegalArgumentException("Class " + classQName + " has not been defined in the data dictionary"); } return factory.createList(new ClassBehaviourBinding(dictionary, nodeRef, classQName)); } /** * Gets the policy implementation for the given classes. The single Policy * will be a wrapper of multiple appropriate policies. * * @param classQNames the class qualified names * @return Returns the policy */ public P get(Set classQNames) { return get(null, classQNames); } /** * Gets the policy implementation for the given classes. The single Policy * will be a wrapper of multiple appropriate policies. * * @param nodeRef the node reference * @param classQNames the class qualified names * @return Returns the policy */ public P get(NodeRef nodeRef, Set classQNames) { return factory.toPolicy(getList(nodeRef, classQNames)); } /** * Gets the collection of Policy implementations for the given classes * * @param classQNames the class qualified names * @return Returns the collection of policies */ public Collection

getList(Set classQNames) { return getList(null, classQNames); } /** * Gets the collection of Policy implementations for the given classes * * @param classQNames the class qualified names * @return Returns the collection of policies */ public Collection

getList(NodeRef nodeRef, Set classQNames) { Collection

policies = new HashSet

(); for (QName classQName : classQNames) { P policy = factory.create(new ClassBehaviourBinding(dictionary, nodeRef, classQName)); if (policy instanceof PolicyList) { policies.addAll(((PolicyList

)policy).getPolicies()); } else { policies.add(policy); } } return policies; } }