Class ChildApplicationContextFactory

java.lang.Object
org.alfresco.repo.management.subsystems.AbstractPropertyBackedBean
org.alfresco.repo.management.subsystems.ChildApplicationContextFactory
All Implemented Interfaces:
EventListener, ApplicationContextFactory, PropertyBackedBean, PropertyBackedBeanState, PropertyBackedBeanWithMonitor, org.springframework.beans.factory.Aware, org.springframework.beans.factory.BeanNameAware, org.springframework.beans.factory.DisposableBean, org.springframework.beans.factory.InitializingBean, org.springframework.context.ApplicationContextAware, org.springframework.context.ApplicationListener<org.springframework.context.ApplicationEvent>
Direct Known Subclasses:
EncryptedContentStoreChildApplicationContextFactory, LuceneChildApplicationContextFactory, NoIndexChildApplicationContextFactory, SolrChildApplicationContextFactory

public class ChildApplicationContextFactory extends AbstractPropertyBackedBean implements ApplicationContextFactory, PropertyBackedBeanWithMonitor
A factory allowing initialization of an entire 'subsystem' in a child application context. As with other PropertyBackedBeans, can be stopped, reconfigured, started and tested. Each instance possesses a typeName property, that determines where the factory will look for default configuration for the application context. In addition, its id property will determine where the factory will look for override configuration in the extension classpath.

The factory will search for a Spring application context in the classpath using the following patterns in order:

  • alfresco/subsystems/<category>/<typeName>/*-context.xml
  • alfresco/extension/subsystems/<category>/<typeName>/<id>/*-context.xml
The child application context may use ${} placeholders, and will be configured with a PropertyPlaceholderConfigurer initialized with properties files found in classpath matching the following patterns in order:
  • alfresco/subsystems/<category>/<typeName>/*.properties
  • alfresco/extension/subsystems/<category>/<typeName>/<id>/*.properties
This means that the extension classpath can be used to provide instance-specific overrides to product default settings. Of course, if you are using the Enterprise edition, you might want to use a JMX client such as JConsole to edit the settings instead!

For advanced purposes, the class also allows management of 'composite' properties, that is properties that can be populated with a sequence of zero or more objects, themselves registered as property-backed beans. Using the compositePropertyTypes property you can register a Map of property names to Java Bean classes. Each property named in this map will then be materialized as a 'composite' property.

Composite property settings are best controlled either through a JMX console (Enterprise edition only) or /alfresco-global.properties in the classpath (the replacement to /alfresco/extension/custom-repository.properties). For example, suppose "imap.server.mountPoints" was registered as a composite property of type RepositoryPathConfigBean. You can then use the property to configure a list of RepositoryPathConfigBeans. First you specify in the property's value a list of zero or more 'instance names'. Each name must be unique within the property.

imap.server.mountPoints=Repository_virtual,Repository_archive

Then, by magic you have two separate instances of RepositoryPathConfigBean whose properties you can address through an extended set of properties prefixed by "imap.server.mountPoints".

To set a property on one of the instances, you append ".value.<instance name>.<bean property name>" to the parent property name. For example:

imap.server.mountPoints.value.Repository_virtual.store=${spaces.store}
imap.server.mountPoints.value.Repository_virtual.path=/${spaces.company_home.childname}

To specify a default value for a property on all instances of the bean, you append ".default.<bean property name>" to the parent property name. For example:

imap.server.mountPoints.default.store=${spaces.store}
imap.server.mountPoints.default.path=/${spaces.company_home.childname}

Note that it's perfectly valid to use placeholders in property values that will be resolved from other global properties.

In order to actually utilize this configurable list of beans in your child application context, you simply need to declare a ListFactoryBean whose ID is the same name as the property. For example:

 <bean id="imap.server.mountPoints" class="org.springframework.beans.factory.config.ListFactoryBean">
 <property name="sourceList">
 <!-- Whatever you declare in here will get replaced by the property value list -->
 <!-- This property is not actually required at all -->
 </property>
 </bean>
 
Then, when the application context is started and before that bean is initialized, it will be given the current configured list of values for the composite property. Magic! This all sounds like a complex, yet primitive replacement for Spring, but it means you can do powerful things to reconfigure the system through an admin UI rather than editing XML.
Author:
dward
  • Constructor Details

    • ChildApplicationContextFactory

      public ChildApplicationContextFactory()
      Default constructor for container construction.
    • ChildApplicationContextFactory

      public ChildApplicationContextFactory(org.springframework.context.ApplicationContext parent, PropertyBackedBeanRegistry registry, Properties propertyDefaults, Properties encryptedPropertyDefaults, String category, String typeName, List<String> instancePath) throws IOException
      Constructor for dynamically created instances, e.g. through DefaultChildApplicationContextManager.
      Parameters:
      parent - the parent application context
      registry - the registry of property backed beans
      propertyDefaults - property defaults provided by the installer or System properties
      encryptedPropertyDefaults - encrypted property defaults provided by the installer or System properties
      category - the category
      typeName - the type name
      instancePath - the instance path within the category
      Throws:
      IOException - Signals that an I/O exception has occurred.
  • Method Details

    • setTypeName

      public void setTypeName(String typeName)
      Sets the type name.
      Parameters:
      typeName - the typeName to set
    • getTypeName

      public String getTypeName()
      Gets the type name.
      Returns:
      the type name
    • setCompositePropertyTypes

      public void setCompositePropertyTypes(Map<String,Class<?>> compositePropertyTypes)
      Registers a set of composite propertes and their types.
      Parameters:
      compositePropertyTypes - a map of property names to Java classes. The classes should follow standard Java Bean conventions. If the class implements BeanNameAware the instance name will be propagated to the beanName property automatically.
    • getPersister

      public org.springframework.util.PropertiesPersister getPersister()
      Returns:
      the persister
    • setPersister

      public void setPersister(org.springframework.util.PropertiesPersister persister)
      Parameters:
      persister - the persister to set
    • afterPropertiesSet

      public void afterPropertiesSet() throws Exception
      Description copied from class: AbstractPropertyBackedBean
      Specified by:
      afterPropertiesSet in interface org.springframework.beans.factory.InitializingBean
      Overrides:
      afterPropertiesSet in class AbstractPropertyBackedBean
      Throws:
      Exception
    • createInitialState

      protected PropertyBackedBeanState createInitialState() throws IOException
      Description copied from class: AbstractPropertyBackedBean
      Creates the initial state.
      Specified by:
      createInitialState in class AbstractPropertyBackedBean
      Returns:
      the property backed bean state
      Throws:
      IOException - Signals that an I/O exception has occurred.
    • applyDefaultOverrides

      protected void applyDefaultOverrides(PropertyBackedBeanState state) throws IOException
      Description copied from class: AbstractPropertyBackedBean
      Applies default overrides to the initial state.
      Overrides:
      applyDefaultOverrides in class AbstractPropertyBackedBean
      Parameters:
      state - the state
      Throws:
      IOException - Signals that an I/O exception has occurred.
    • isUpdateable

      public boolean isUpdateable(String name)
      Description copied from class: AbstractPropertyBackedBean
      Checks if a property is updateable.
      Specified by:
      isUpdateable in interface PropertyBackedBean
      Overrides:
      isUpdateable in class AbstractPropertyBackedBean
      Parameters:
      name - the property name
      Returns:
      true if the property is updateable
    • getDescription

      public String getDescription(String name)
      Description copied from class: AbstractPropertyBackedBean
      Gets a Human readable description of the property, e.g. to provide via JMX.
      Specified by:
      getDescription in interface PropertyBackedBean
      Overrides:
      getDescription in class AbstractPropertyBackedBean
      Parameters:
      name - the name
      Returns:
      the description
    • destroy

      protected void destroy(boolean permanent)
      Description copied from class: AbstractPropertyBackedBean
      Releases any resources held by this component.
      Overrides:
      destroy in class AbstractPropertyBackedBean
      Parameters:
      permanent - is the component being destroyed forever, i.e. should persisted values be removed? On server shutdown, this value would be false, whereas on the removal of a dynamically created instance, this value would be true.
    • getReadOnlyApplicationContext

      public org.springframework.context.ApplicationContext getReadOnlyApplicationContext()
      Gets the application context. Will not start a subsystem.
      Returns:
      the application context or null
    • getApplicationContext

      public org.springframework.context.ApplicationContext getApplicationContext()
      Description copied from interface: ApplicationContextFactory
      Gets the application context, configured according to the properties of the factory.
      Specified by:
      getApplicationContext in interface ApplicationContextFactory
      Returns:
      the application context
    • getMonitorObject

      public Object getMonitorObject()
      Description copied from interface: PropertyBackedBeanWithMonitor
      Get the monitor object.
      Specified by:
      getMonitorObject in interface PropertyBackedBeanWithMonitor
      Returns:
      the monitor object or null if there is no monitor