mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@119697 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			178 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /* 
 | |
|  * Copyright (C) 2005-2015 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.traitextender;
 | |
| 
 | |
| import java.util.Collections;
 | |
| import java.util.List;
 | |
| 
 | |
| import org.apache.commons.logging.Log;
 | |
| import org.apache.commons.logging.LogFactory;
 | |
| import org.springframework.beans.factory.InitializingBean;
 | |
| 
 | |
| /**
 | |
|  * A {@link SpringBeanExtension}s collection that get registered on the
 | |
|  * {@link Extender}'s registry on {@link #afterPropertiesSet()}.<br>
 | |
|  * Works in conjunction with {@link SpringBeanExtension}s and
 | |
|  * {@link SpringExtensionPoint}s to define and start spring based
 | |
|  * {@link ExtensionBundle}s of {@link SingletonExtension}s.<br>
 | |
|  * The spring-context XML sample bellow shows the definition of spring-bundled
 | |
|  * trait-extensions:
 | |
|  * 
 | |
|  * <pre>
 | |
|  * {@code
 | |
|  * 
 | |
|  *  <bean id="ep1" class="org.alfresco.traitextender.SpringExtensionPoint">
 | |
|  *     <property name="extension" value="org.alfresco.sample.Extension1" />
 | |
|  *     <property name="trait" value="org.alfresco.sample.Trait1" />
 | |
|  *  </bean>
 | |
|  *  
 | |
|  *  <bean id="ep2" class="org.alfresco.traitextender.SpringExtensionPoint">
 | |
|  *     <property name="extension" value="org.alfresco.sample.Extension2" />
 | |
|  *     <property name="trait" value="org.alfresco.sample.Trait2" />
 | |
|  *  </bean>
 | |
|  * 
 | |
|  *   <bean id="extension1" class="org.alfresco.sample.Extension1">
 | |
|  *    <property name="extensionPoint" ref="ep1" />
 | |
|  *  </bean>
 | |
|  * 
 | |
|  *  <bean id="extension2" class="org.alfresco.sample.Extension2">
 | |
|  *     <property name="extensionPoint" ref="ep2" />
 | |
|  *  </bean>
 | |
|  * 
 | |
|  *  <bean id="aBundle" class="org.alfresco.traitextender.SpringExtensionBundle">
 | |
|  *    <property name="id" value="org.alfresco.sample.aBundle" />
 | |
|  *    <property name="enabled" value="true" />
 | |
|  *    <property name="extensions">
 | |
|  *       <list>
 | |
|  *          <ref bean="extension1" />
 | |
|  *          <ref bean="extension2" />
 | |
|  *       </list >
 | |
|  *    </property>
 | |
|  *  </bean>
 | |
|  * }
 | |
|  * </pre>
 | |
|  * 
 | |
|  * @author Bogdan Horje
 | |
|  */
 | |
| public class SpringExtensionBundle implements InitializingBean
 | |
| {
 | |
|     private static Log logger = LogFactory.getLog(SpringExtensionBundle.class);
 | |
| 
 | |
|     private List<SpringBeanExtension<?, ?>> extensions = Collections.emptyList();
 | |
| 
 | |
|     private String id;
 | |
| 
 | |
|     private boolean enabled = true;
 | |
| 
 | |
|     private RegistryExtensionBundle extensionBundle;
 | |
| 
 | |
|     /**
 | |
|      * @param enabled <code>true</code> if the current bundle should be
 | |
|      *            registered.<br>
 | |
|      *            <code>false</code> if the current bundle should skip extension
 | |
|      *            registration
 | |
|      */
 | |
|     public void setEnabled(boolean enabled)
 | |
|     {
 | |
|         this.enabled = enabled;
 | |
|     }
 | |
| 
 | |
|     public void setExtensions(List<SpringBeanExtension<?, ?>> extensions)
 | |
|     {
 | |
|         this.extensions = extensions;
 | |
|     }
 | |
| 
 | |
|     public void setId(String id)
 | |
|     {
 | |
|         this.id = id;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a {@link RegistryExtensionBundle} and registers all contained
 | |
|      * {@link SpringBeanExtension}s with it.<br>
 | |
|      * When all extension have successfully registered it starts the
 | |
|      * {@link RegistryExtensionBundle}.<br>
 | |
|      * The previously created {@link RegistryExtensionBundle} is stored for
 | |
|      * later start or {@link #stop()} operations.
 | |
|      * 
 | |
|      * @see Extender#start(ExtensionBundle)
 | |
|      * @see Extender#stop(ExtensionBundle)
 | |
|      */
 | |
|     public synchronized void start()
 | |
|     {
 | |
| 
 | |
|         if (extensionBundle == null)
 | |
|         {
 | |
|             logger.info("Registering extension bundle " + id);
 | |
|             extensionBundle = new RegistryExtensionBundle(id);
 | |
| 
 | |
|             for (SpringBeanExtension<?, ?> springExtension : extensions)
 | |
|             {
 | |
|                 try
 | |
|                 {
 | |
|                     springExtension.register(extensionBundle);
 | |
|                 }
 | |
|                 catch (Exception error)
 | |
|                 {
 | |
|                     throw new InvalidExtension("Could not register extension " + springExtension + " with "
 | |
|                                                            + extensionBundle,
 | |
|                                                error);
 | |
|                 }
 | |
| 
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         logger.info("Starting extension bundle " + id);
 | |
|         Extender.getInstance().start(extensionBundle);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Stops a previously {@link #start()} created
 | |
|      * {@link RegistryExtensionBundle}.
 | |
|      * 
 | |
|      * @see Extender#start(ExtensionBundle)
 | |
|      * @see Extender#stop(ExtensionBundle)
 | |
|      */
 | |
|     public synchronized void stop()
 | |
|     {
 | |
|         if (extensionBundle == null)
 | |
|         {
 | |
|             logger.info("Stop request for unregistered extension bundle " + id);
 | |
|         }
 | |
|         logger.info("Stopping extension bundle " + id);
 | |
|         Extender.getInstance().stop(extensionBundle);
 | |
|     }
 | |
| 
 | |
|     @Override
 | |
|     public void afterPropertiesSet() throws Exception
 | |
|     {
 | |
|         if (this.enabled)
 | |
|         {
 | |
|             logger.info("The extension bundle " + id + " is spring-enabled. Starting ... ");
 | |
|             start();
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             logger.info("Extension bundle " + id + " is spring-disabled.");
 | |
|         }
 | |
|     }
 | |
| 
 | |
| }
 |