package org.alfresco.repo.admin; import java.lang.reflect.Method; import java.net.URL; import java.util.ArrayList; import java.util.List; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.springframework.beans.BeansException; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; import org.springframework.core.io.Resource; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.core.io.support.ResourcePatternResolver; /** * Initialises Log4j's HierarchyDynamicMBean (refer to core-services-context.xml) and any overriding log4.properties files. * The actual implementation uses introspection to avoid any hard-coded references to Log4J classes. If Log4J is * not present, this class will do nothing. *
* Alfresco modules can provide their own log4j.properties file, which augments/overrides the global log4j.properties * within the Alfresco webapp. Within the module's source tree, suppose you create: *
* config/alfresco/module/{module.id}/log4j.properties ** At deployment time, this log4j.properties file will be placed in: *
* WEB-INF/classes/alfresco/module/{module.id}/log4j.properties ** Where {module.id} is whatever value is set within the AMP's module.properties file. For details, see: Developing an Alfresco Module *
* For example, if {module.id} is "org.alfresco.module.someModule", then within your source code you'll have: * *
* config / alfresco / module / org.alfresco.module.someModule / log4j.properties ** * This would be deployed to: *
* WEB - INF / classes / alfresco / module / org.alfresco.module.someModule / log4j.properties **/ public class Log4JHierarchyInit implements ApplicationContextAware { private static Log logger = LogFactory.getLog(Log4JHierarchyInit.class); private List
* This function supports Spring's syntax for retrieving multiple class path resources with the same name,
* via the "classpath*:" prefix. For details, see: {@link PathMatchingResourcePatternResolver}.
*/
public void setExtraLog4jUrls(List