/* * Copyright (C) 2005 Alfresco, Inc. * * Licensed under the Mozilla Public License version 1.1 * with a permitted attribution clause. You may obtain a * copy of the License at * * http://www.alfresco.org/legal/license.txt * * 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.alfresco.repo.policy; import java.util.Collection; import java.util.HashSet; import java.util.Set; import org.alfresco.service.cmr.dictionary.AssociationDefinition; import org.alfresco.service.cmr.dictionary.DictionaryService; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.namespace.QName; /** * Delegate for a Class Feature-level (Property and Association) Policies. Provides * access to Policy Interface implementations which invoke the appropriate bound behaviours. * * @author David Caruana * * @param

the policy interface */ public class AssociationPolicyDelegate

{ 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*/ AssociationPolicyDelegate(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; } /** * Ensures the validity of the given assoc type * * @param assocTypeQName * @throws IllegalArgumentException */ private void checkAssocType(QName assocTypeQName) throws IllegalArgumentException { AssociationDefinition assocDef = dictionary.getAssociation(assocTypeQName); if (assocDef == null) { throw new IllegalArgumentException("Association " + assocTypeQName + " has not been defined in the data dictionary"); } } /** * Gets the Policy implementation for the specified Class and Association * * When multiple behaviours are bound to the policy for the class feature, an * aggregate policy implementation is returned which invokes each policy * in turn. * * @param classQName the class qualified name * @param assocTypeQName the association type qualified name * @return the policy */ public P get(QName classQName, QName assocTypeQName) { return get(null, classQName, assocTypeQName); } /** * Gets the Policy implementation for the specified Class and Association * * When multiple behaviours are bound to the policy for the class feature, an * aggregate policy implementation is returned which invokes each policy * in turn. * * @param nodeRef the node reference * @param classQName the class qualified name * @param assocTypeQName the association type qualified name * @return the policy */ public P get(NodeRef nodeRef, QName classQName, QName assocTypeQName) { checkAssocType(assocTypeQName); return factory.create(new ClassFeatureBehaviourBinding(dictionary, nodeRef, classQName, assocTypeQName)); } /** * Gets the collection of Policy implementations for the specified Class and Association * * @param classQName the class qualified name * @param assocTypeQName the association type qualified name * @return the collection of policies */ public Collection

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

getList(NodeRef nodeRef, QName classQName, QName assocTypeQName) { checkAssocType(assocTypeQName); return factory.createList(new ClassFeatureBehaviourBinding(dictionary, nodeRef, classQName, assocTypeQName)); } /** * Gets a Policy for all the given Class and Association * * @param classQNames the class qualified names * @param assocTypeQName the association type qualified name * @return Return the policy */ public P get(Set classQNames, QName assocTypeQName) { return get(null, classQNames, assocTypeQName); } /** * Gets a Policy for all the given Class and Association * * @param nodeRef the node reference * @param classQNames the class qualified names * @param assocTypeQName the association type qualified name * @return Return the policy */ public P get(NodeRef nodeRef, Set classQNames, QName assocTypeQName) { checkAssocType(assocTypeQName); return factory.toPolicy(getList(nodeRef, classQNames, assocTypeQName)); } /** * Gets the Policy instances for all the given Classes and Associations * * @param classQNames the class qualified names * @param assocTypeQName the association type qualified name * @return Return the policies */ public Collection

getList(Set classQNames, QName assocTypeQName) { return getList(null, classQNames, assocTypeQName); } /** * Gets the Policy instances for all the given Classes and Associations * * @param nodeRef the node reference * @param classQNames the class qualified names * @param assocTypeQName the association type qualified name * @return Return the policies */ public Collection

getList(NodeRef nodeRef, Set classQNames, QName assocTypeQName) { checkAssocType(assocTypeQName); Collection

policies = new HashSet

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

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