/*
* 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;
}
}