mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			210 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco 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 Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 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;
 | |
|     }
 | |
| 
 | |
| }
 |