Files
alfresco-community-repo/source/java/org/alfresco/repo/policy/ClassPolicyDelegate.java
Raluca Munteanu 8674e2bfc8 Merged 5.1.N (5.1.2) to 5.2.N (5.2.1)
125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2)
      125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125781 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2016-04-26 12:48:49 +00:00

174 lines
5.5 KiB
Java

package org.alfresco.repo.policy;
import java.util.Collection;
import java.util.HashSet;
import java.util.Set;
import org.alfresco.api.AlfrescoPublicApi;
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 <P> the policy interface
*/
@AlfrescoPublicApi
public class ClassPolicyDelegate<P extends ClassPolicy>
{
private DictionaryService dictionary;
private CachedPolicyFactory<ClassBehaviourBinding, 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*/ ClassPolicyDelegate(DictionaryService dictionary, Class<P> policyClass, BehaviourIndex<ClassBehaviourBinding> index, long tryLockTimeout)
{
// 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<ClassBehaviourBinding, P>(policyClass, index);
this.factory.setTryLockTimeout(tryLockTimeout);
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<P> 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<P> 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 <tt>Policy</tt>
* will be a wrapper of multiple appropriate policies.
*
* @param classQNames the class qualified names
* @return Returns the policy
*/
public P get(Set<QName> classQNames)
{
return get(null, classQNames);
}
/**
* Gets the policy implementation for the given classes. The single <tt>Policy</tt>
* 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<QName> classQNames)
{
return factory.toPolicy(getList(nodeRef, classQNames));
}
/**
* Gets the collection of <tt>Policy</tt> implementations for the given classes
*
* @param classQNames the class qualified names
* @return Returns the collection of policies
*/
public Collection<P> getList(Set<QName> classQNames)
{
return getList(null, classQNames);
}
/**
* Gets the collection of <tt>Policy</tt> implementations for the given classes
*
* @param classQNames the class qualified names
* @return Returns the collection of policies
*/
public Collection<P> getList(NodeRef nodeRef, Set<QName> classQNames)
{
Collection<P> policies = new HashSet<P>();
for (QName classQName : classQNames)
{
P policy = factory.create(new ClassBehaviourBinding(dictionary, nodeRef, classQName));
if (policy instanceof PolicyList)
{
policies.addAll(((PolicyList<P>)policy).getPolicies());
}
else
{
policies.add(policy);
}
}
return policies;
}
}