mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			160 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			4.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.rule.ruletrigger;
 | 
						|
 | 
						|
import java.util.HashSet;
 | 
						|
import java.util.Set;
 | 
						|
 | 
						|
import org.alfresco.repo.policy.PolicyComponent;
 | 
						|
import org.alfresco.repo.security.authentication.AuthenticationComponent;
 | 
						|
import org.alfresco.service.cmr.dictionary.DictionaryService;
 | 
						|
import org.alfresco.service.cmr.repository.ContentService;
 | 
						|
import org.alfresco.service.cmr.repository.NodeRef;
 | 
						|
import org.alfresco.service.cmr.repository.NodeService;
 | 
						|
import org.alfresco.service.cmr.rule.RuleType;
 | 
						|
 | 
						|
/**
 | 
						|
 * Rule trigger abstract base 
 | 
						|
 * 
 | 
						|
 * @author Roy Wetherall
 | 
						|
 */
 | 
						|
public abstract class RuleTriggerAbstractBase implements RuleTrigger
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * A list of the rule types that are interested in this trigger
 | 
						|
     */
 | 
						|
    private Set<RuleType> ruleTypes = new HashSet<RuleType>();
 | 
						|
 | 
						|
    /**
 | 
						|
     * The policy component
 | 
						|
     */
 | 
						|
    protected PolicyComponent policyComponent;
 | 
						|
 | 
						|
    /**
 | 
						|
     * The node service
 | 
						|
     */
 | 
						|
    protected NodeService nodeService;
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * The content service
 | 
						|
     */
 | 
						|
    protected ContentService contentService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * The authentication Component
 | 
						|
     */
 | 
						|
    protected AuthenticationComponent authenticationComponent;
 | 
						|
 | 
						|
    /** The dictionary service */
 | 
						|
    protected DictionaryService dictionaryService;
 | 
						|
    
 | 
						|
    /** 
 | 
						|
     * Indicates whether the rule should be executed immediately or at the end of the transaction.
 | 
						|
     * By default this is false as all rules are executed at the end of the transaction.
 | 
						|
     */
 | 
						|
    protected boolean executeRuleImmediately = false;
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Set the policy component
 | 
						|
     * 
 | 
						|
     * @param policyComponent
 | 
						|
     *            the policy component
 | 
						|
     */
 | 
						|
    public void setPolicyComponent(PolicyComponent policyComponent)
 | 
						|
    {
 | 
						|
        this.policyComponent = policyComponent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Set the node service
 | 
						|
     * 
 | 
						|
     * @param nodeService
 | 
						|
     *            the node service
 | 
						|
     */
 | 
						|
    public void setNodeService(NodeService nodeService)
 | 
						|
    {
 | 
						|
        this.nodeService = nodeService;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Set the content service
 | 
						|
     * 
 | 
						|
     * @param contentService	the content service
 | 
						|
     */
 | 
						|
    public void setContentService(ContentService contentService) 
 | 
						|
    {
 | 
						|
		this.contentService = contentService;
 | 
						|
	}
 | 
						|
 | 
						|
    /**
 | 
						|
     * Set the authenticationComponent
 | 
						|
     */
 | 
						|
    public void setAuthenticationComponent(AuthenticationComponent authenticationComponent)
 | 
						|
    {
 | 
						|
        this.authenticationComponent = authenticationComponent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Set the dictionary service
 | 
						|
     * 
 | 
						|
     * @param dictionaryService     the dictionary service
 | 
						|
     */
 | 
						|
    public void setDictionaryService(DictionaryService dictionaryService)
 | 
						|
    {
 | 
						|
        this.dictionaryService = dictionaryService;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Sets the values that indicates whether the rule should be executed immediately
 | 
						|
     * or not.
 | 
						|
     * 
 | 
						|
     * @param executeRuleImmediately    true execute the rule immediaely, false otherwise
 | 
						|
     */
 | 
						|
    public void setExecuteRuleImmediately(boolean executeRuleImmediately)
 | 
						|
    {
 | 
						|
        this.executeRuleImmediately = executeRuleImmediately;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Registration of an interested rule type
 | 
						|
     * 
 | 
						|
     */
 | 
						|
    public void registerRuleType(RuleType ruleType)
 | 
						|
    {
 | 
						|
        this.ruleTypes.add(ruleType);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Trigger the rules that relate to any interested rule types for the node
 | 
						|
     * references passed. 
 | 
						|
     * 
 | 
						|
     * @param nodeRef
 | 
						|
     *            the node reference who rules are to be triggered
 | 
						|
     * @param actionedUponNodeRef
 | 
						|
     *            the node reference that will be actioned upon by the rules
 | 
						|
     */
 | 
						|
    protected void triggerRules(NodeRef nodeRef, NodeRef actionedUponNodeRef)
 | 
						|
    {
 | 
						|
        for (RuleType ruleType : this.ruleTypes)
 | 
						|
        {
 | 
						|
            ruleType.triggerRuleType(nodeRef, actionedUponNodeRef, this.executeRuleImmediately);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |