mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	- undeleted and reinstated use of org.alfresco.util.Pair - undeleted org.alfresco.util.PropertyCheck which is used in the deployment code. - undeleted other org.alfresco.util.* classes which probably should never have been moved to spring surf. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@19312 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			142 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			5.4 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.avm.wf;
 | 
						|
 | 
						|
import org.alfresco.model.WCMAppModel;
 | 
						|
import org.alfresco.repo.avm.AVMNodeConverter;
 | 
						|
import org.alfresco.repo.workflow.jbpm.JBPMNode;
 | 
						|
import org.alfresco.repo.workflow.jbpm.JBPMSpringActionHandler;
 | 
						|
import org.alfresco.service.cmr.repository.NodeRef;
 | 
						|
import org.alfresco.service.cmr.repository.NodeService;
 | 
						|
import org.alfresco.service.cmr.search.ResultSet;
 | 
						|
import org.alfresco.service.cmr.search.SearchService;
 | 
						|
import org.alfresco.service.namespace.NamespaceService;
 | 
						|
import org.alfresco.util.Pair;
 | 
						|
import org.apache.commons.logging.Log;
 | 
						|
import org.apache.commons.logging.LogFactory;
 | 
						|
import org.jbpm.graph.exe.ExecutionContext;
 | 
						|
import org.springframework.beans.factory.BeanFactory;
 | 
						|
 | 
						|
/**
 | 
						|
 * Releases the test deploy server used by the workflow (if any).
 | 
						|
 * 
 | 
						|
 * @author Gavin Cornwell
 | 
						|
 */
 | 
						|
public class AVMReleaseTestServerHandler extends JBPMSpringActionHandler 
 | 
						|
{
 | 
						|
    private SearchService searchService;
 | 
						|
    private NodeService unprotectedNodeService;
 | 
						|
    
 | 
						|
    private static final String BEAN_NODE_SERVICE = "nodeService";
 | 
						|
    private static final String BEAN_SEARCH_SERVICE = "searchService";
 | 
						|
    
 | 
						|
    private static final long serialVersionUID = -202652488887586866L;
 | 
						|
    private static final Log logger = LogFactory.getLog(AVMReleaseTestServerHandler.class);
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Initialize service references.
 | 
						|
     * @param factory The BeanFactory to get references from.
 | 
						|
     */
 | 
						|
    @Override
 | 
						|
    protected void initialiseHandler(BeanFactory factory) 
 | 
						|
    {
 | 
						|
        this.searchService = (SearchService)factory.getBean(BEAN_SEARCH_SERVICE);
 | 
						|
        this.unprotectedNodeService = (NodeService)factory.getBean(BEAN_NODE_SERVICE);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Do the actual work.
 | 
						|
     * @param executionContext The context to get stuff from.
 | 
						|
     */
 | 
						|
    public void execute(ExecutionContext executionContext) throws Exception 
 | 
						|
    {
 | 
						|
        // get the store name
 | 
						|
        NodeRef pkg = ((JBPMNode)executionContext.getContextInstance().getVariable("bpm_package")).getNodeRef();
 | 
						|
        Pair<Integer, String> pkgPath = AVMNodeConverter.ToAVMVersionPath(pkg);
 | 
						|
        String [] workflowStorePath = pkgPath.getSecond().split(":");
 | 
						|
        String workflowStoreName = workflowStorePath[0];
 | 
						|
        
 | 
						|
        // get the web project node for the submission
 | 
						|
        JBPMNode webProjNode = (JBPMNode)executionContext.getContextInstance().getVariable("wcmwf_webproject");
 | 
						|
        NodeRef webProjectRef = webProjNode.getNodeRef();
 | 
						|
        
 | 
						|
        if (logger.isDebugEnabled())
 | 
						|
            logger.debug("Looking for test server to release for store: " + workflowStoreName);
 | 
						|
            
 | 
						|
        // query for the allocated test server (if one)
 | 
						|
        NodeRef testServer = findAllocatedServer(webProjectRef, workflowStoreName);
 | 
						|
        
 | 
						|
        if (testServer != null)
 | 
						|
        {
 | 
						|
           // reset the allocatedto property on the test server node
 | 
						|
           this.unprotectedNodeService.setProperty(testServer, WCMAppModel.PROP_DEPLOYSERVERALLOCATEDTO, null);
 | 
						|
               
 | 
						|
           if (logger.isDebugEnabled())
 | 
						|
               logger.debug("Released test server '" + testServer + "' from store: " + workflowStoreName);
 | 
						|
        }
 | 
						|
        else if (logger.isDebugEnabled())
 | 
						|
        {
 | 
						|
           logger.debug("Store '" + workflowStoreName + "' didn't have an allocated test server to release");
 | 
						|
        }
 | 
						|
    }
 | 
						|
    
 | 
						|
    private NodeRef findAllocatedServer(NodeRef webProjectRef, String store)
 | 
						|
    {        
 | 
						|
        StringBuilder query = new StringBuilder("@");
 | 
						|
        query.append(NamespaceService.WCMAPP_MODEL_PREFIX);
 | 
						|
        query.append("\\:");
 | 
						|
        query.append(WCMAppModel.PROP_DEPLOYSERVERALLOCATEDTO.getLocalName());
 | 
						|
        query.append(":\"");
 | 
						|
        query.append(store);
 | 
						|
        query.append("\"");
 | 
						|
      
 | 
						|
        ResultSet results = null;
 | 
						|
        NodeRef testServer = null;
 | 
						|
        try
 | 
						|
        {
 | 
						|
            // execute the query
 | 
						|
            results = this.searchService.query(webProjectRef.getStoreRef(), 
 | 
						|
                     SearchService.LANGUAGE_LUCENE, query.toString());
 | 
						|
         
 | 
						|
            if (results.length() == 1)
 | 
						|
            {
 | 
						|
                testServer = results.getNodeRef(0);
 | 
						|
            }
 | 
						|
            else if (results.length() > 1)
 | 
						|
            {
 | 
						|
               // get the first one and warn that we found many!
 | 
						|
               testServer = results.getNodeRef(0);
 | 
						|
               
 | 
						|
               if (logger.isWarnEnabled())
 | 
						|
               logger.warn("More than one allocated test server for store '" +
 | 
						|
                     store + "' was found, should only be one, first one found returned!");
 | 
						|
            }
 | 
						|
        }
 | 
						|
        finally
 | 
						|
        {
 | 
						|
            if (results != null)
 | 
						|
            {
 | 
						|
                results.close();
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return testServer;
 | 
						|
    }
 | 
						|
}
 |