/* * 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 . */ package org.alfresco.repo.rule.ruletrigger; import java.util.HashSet; import java.util.Set; import org.alfresco.model.ContentModel; import org.alfresco.repo.action.ActionModel; import org.alfresco.repo.policy.PolicyComponent; import org.alfresco.repo.rule.RuleModel; 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.RuleService; import org.alfresco.service.cmr.rule.RuleType; import org.alfresco.service.namespace.QName; /** * Rule trigger abstract base * * @author Roy Wetherall */ public abstract class RuleTriggerAbstractBase implements RuleTrigger { /** the types (hardcoded) to ignore generally */ private static final Set IGNORE_TYPES; /** the aspects (hardcoded) to ignore generally */ private static final Set IGNORE_ASPECTS; static { IGNORE_TYPES = new HashSet(13); IGNORE_TYPES.add(RuleModel.TYPE_RULE); IGNORE_TYPES.add(ActionModel.TYPE_ACTION); IGNORE_TYPES.add(ContentModel.TYPE_THUMBNAIL); // Workaround to prevent rules running on cm:rating nodes (which happened for 'liked' folders ALF-8308 & ALF-8382) IGNORE_TYPES.add(ContentModel.TYPE_RATING); IGNORE_ASPECTS = new HashSet(13); IGNORE_ASPECTS.add(ContentModel.ASPECT_TEMPORARY); } /** * A list of the rule types that are interested in this trigger */ private Set ruleTypes = new HashSet(); protected PolicyComponent policyComponent; protected NodeService nodeService; protected ContentService contentService; protected AuthenticationComponent authenticationComponent; protected DictionaryService dictionaryService; protected RuleService ruleService; /** * 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 */ public void setPolicyComponent(PolicyComponent policyComponent) { this.policyComponent = policyComponent; } /** * Set the node service */ public void setNodeService(NodeService nodeService) { this.nodeService = nodeService; } /** * Set 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 */ public void setDictionaryService(DictionaryService dictionaryService) { this.dictionaryService = dictionaryService; } /** * Set the RuleService to assist with enabled/disabled check */ public void setRuleService(RuleService ruleService) { this.ruleService = ruleService; } /** * 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) { // Break out early if rules are off if (!areRulesEnabled()) { return; } // Do not trigger rules for rule and action type nodes if (ignoreTrigger(actionedUponNodeRef) == false) { for (RuleType ruleType : this.ruleTypes) { ruleType.triggerRuleType(nodeRef, actionedUponNodeRef, this.executeRuleImmediately); } } } /** * Helper method to allow triggers to check if rules are enabled or disabled * (ALF-10839: Eliminate rule discovery overhead on property update when rules have been disabled) * @return true if rules are enabled */ protected boolean areRulesEnabled() { return ruleService.isEnabled(); } /** * Indicate whether the trigger should be ignored or not * @param actionedUponNodeRef actioned upon node reference * @return boolean true if the trigger should be ignored, false otherwise */ private boolean ignoreTrigger(NodeRef actionedUponNodeRef) { boolean result = false; QName typeQName = nodeService.getType(actionedUponNodeRef); if (IGNORE_TYPES.contains(typeQName)) { result = true; } for (QName aspectToIgnore : IGNORE_ASPECTS) { if (nodeService.hasAspect(actionedUponNodeRef, aspectToIgnore)) { return true; } } return result; } }