mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	- PerformRenditionActionExecuter class and perform-rendition bean have been deprecated. These constituted a containing action which the RenditionService wrapped around every rendition definition. Their internals have been pushed down into AbstractRenderingEngine which should allow rendition definitions (which are actions) to be used as first-class action beans. What remains should be backwards compatible, but is now unnecessary. - Temporarily switched off some Mockito-based unit tests which need updating. Will chat to Nick tomorrow. - New action param: is-component-rendition : used to identify components renditions within a composite. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@20945 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			141 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			5.7 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.rendition;
 | |
| 
 | |
| import java.io.Serializable;
 | |
| import java.util.List;
 | |
| 
 | |
| import org.alfresco.repo.action.ParameterDefinitionImpl;
 | |
| import org.alfresco.repo.action.executer.ActionExecuter;
 | |
| import org.alfresco.repo.action.executer.ActionExecuterAbstractBase;
 | |
| import org.alfresco.service.cmr.action.Action;
 | |
| import org.alfresco.service.cmr.action.ActionService;
 | |
| import org.alfresco.service.cmr.action.ParameterDefinition;
 | |
| import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
 | |
| import org.alfresco.service.cmr.rendition.RenditionDefinition;
 | |
| import org.alfresco.service.cmr.repository.ChildAssociationRef;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.apache.commons.logging.Log;
 | |
| import org.apache.commons.logging.LogFactory;
 | |
| import org.springframework.extensions.surf.util.ParameterCheck;
 | |
| 
 | |
| /*
 | |
|  * In Alfresco 3.3, this class was a required 'containing action' for all renditions.
 | |
|  * It added handling for asynchronous renditions as well as some common business logic.
 | |
|  * It should no longer be used.
 | |
|  * 
 | |
|  * @author Neil McErlean
 | |
|  * @since 3.3
 | |
|  * @deprecated Starting with Alfresco 3.4 the perform-rendition action is no longer
 | |
|  *             necessary. All the work previously done by this class has been moved
 | |
|  *             into the rendition action executers themselves. This class now delegates
 | |
|  *             straight to those actions and therefore is no longer needed.
 | |
|  */
 | |
| @Deprecated
 | |
| public class PerformRenditionActionExecuter extends ActionExecuterAbstractBase
 | |
| {
 | |
|     private static final Log log = LogFactory.getLog(PerformRenditionActionExecuter.class);
 | |
| 
 | |
|     /** Action name and parameters */
 | |
|     public static final String NAME = "perform-rendition";
 | |
|     public static final String PARAM_RENDITION_DEFINITION = "renditionDefinition";
 | |
| 
 | |
|     /*
 | |
|      * Injected beans
 | |
|      */
 | |
|     private ActionService actionService;
 | |
| 
 | |
|     /**
 | |
|      * Injects the actionService bean.
 | |
|      * 
 | |
|      * @param actionService
 | |
|      *            the actionService.
 | |
|      */
 | |
|     public void setActionService(ActionService actionService)
 | |
|     {
 | |
|         this.actionService = actionService;
 | |
|     }
 | |
| 
 | |
|     @Override
 | |
|     protected void executeImpl(final Action containingAction, final NodeRef actionedUponNodeRef)
 | |
|     {
 | |
|         final RenditionDefinition renditionDefinition = getRenditionDefinition(containingAction);
 | |
|         if (log.isDebugEnabled())
 | |
|         {
 | |
|             StringBuilder msg = new StringBuilder();
 | |
|             msg.append("Rendering node ").append(actionedUponNodeRef).append(" with rendition definition ").append(
 | |
|                         renditionDefinition.getRenditionName());
 | |
|             msg.append("\n").append("  parameters:").append("\n");
 | |
|             if (renditionDefinition.getParameterValues().isEmpty() == false)
 | |
|             {
 | |
|             	for (String paramKey : renditionDefinition.getParameterValues().keySet())
 | |
|             	{
 | |
|             		msg.append("    ").append(paramKey).append("=").append(renditionDefinition.getParameterValue(paramKey)).append("\n");
 | |
|             	}
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|             	msg.append("    [None]");
 | |
|             }
 | |
|             log.debug(msg.toString());
 | |
|         }
 | |
| 
 | |
|         ChildAssociationRef result = executeRendition(actionedUponNodeRef, renditionDefinition);
 | |
|         containingAction.setParameterValue(PARAM_RESULT, result);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * This method gets the (mandatory) rendition definition parameter from the containing action.
 | |
|      * @param containingAction the containing action.
 | |
|      * @return the rendition definition.
 | |
|      * @throws IllegalArgumentException if the rendition definition is missing.
 | |
|      */
 | |
|     private RenditionDefinition getRenditionDefinition(final Action containingAction)
 | |
|     {
 | |
|         Serializable rendDefObj = containingAction.getParameterValue(PARAM_RENDITION_DEFINITION);
 | |
|         ParameterCheck.mandatory(PARAM_RENDITION_DEFINITION, rendDefObj);
 | |
|         return (RenditionDefinition) rendDefObj;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * This method delegates to the action service for the execution of the rendition.
 | |
|      * @param sourceNode
 | |
|      * @param definition
 | |
|      * @return the ChildAssociationRef result.
 | |
|      */
 | |
|     private ChildAssociationRef executeRendition(NodeRef sourceNode, RenditionDefinition definition)
 | |
|     {
 | |
|         actionService.executeAction(definition, sourceNode);
 | |
|         // Extract the result from the action
 | |
|         Serializable serializableResult = definition.getParameterValue(ActionExecuter.PARAM_RESULT);
 | |
|         return (ChildAssociationRef) serializableResult;
 | |
|     }
 | |
| 
 | |
|     @Override
 | |
|     protected void addParameterDefinitions(List<ParameterDefinition> paramList)
 | |
|     {
 | |
|         paramList.add(new ParameterDefinitionImpl(PARAM_RENDITION_DEFINITION, DataTypeDefinition.ANY, true,
 | |
|                     getParamDisplayLabel(PARAM_RENDITION_DEFINITION)));
 | |
| 
 | |
|         paramList.add(new ParameterDefinitionImpl(PARAM_RESULT, DataTypeDefinition.CHILD_ASSOC_REF, false,
 | |
|                     getParamDisplayLabel(PARAM_RESULT)));
 | |
|     }
 | |
| }
 |