/* * 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 <P> the policy interface */ public class AssociationPolicyDelegate<P extends AssociationPolicy> { private DictionaryService dictionary; private CachedPolicyFactory<ClassFeatureBehaviourBinding, P> 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<P> policyClass, BehaviourIndex<ClassFeatureBehaviourBinding> index) { // Get list of all pre-registered behaviours for the policy and // ensure they are valid. Collection<BehaviourDefinition> 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<ClassFeatureBehaviourBinding, P>(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<P> 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<P> getList(NodeRef nodeRef, QName classQName, QName assocTypeQName) { checkAssocType(assocTypeQName); return factory.createList(new ClassFeatureBehaviourBinding(dictionary, nodeRef, classQName, assocTypeQName)); } /** * Gets a <tt>Policy</tt> 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<QName> classQNames, QName assocTypeQName) { return get(null, classQNames, assocTypeQName); } /** * Gets a <tt>Policy</tt> 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<QName> classQNames, QName assocTypeQName) { checkAssocType(assocTypeQName); return factory.toPolicy(getList(nodeRef, classQNames, assocTypeQName)); } /** * Gets the <tt>Policy</tt> 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<P> getList(Set<QName> classQNames, QName assocTypeQName) { return getList(null, classQNames, assocTypeQName); } /** * Gets the <tt>Policy</tt> 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<P> getList(NodeRef nodeRef, Set<QName> classQNames, QName assocTypeQName) { checkAssocType(assocTypeQName); Collection<P> policies = new HashSet<P>(); for (QName classQName : classQNames) { P policy = factory.create(new ClassFeatureBehaviourBinding(dictionary, nodeRef, classQName, assocTypeQName)); if (policy instanceof PolicyList) { policies.addAll(((PolicyList<P>)policy).getPolicies()); } else { policies.add(policy); } } return policies; } }