diff --git a/config/alfresco/core-services-context.xml b/config/alfresco/core-services-context.xml index d52b3116f1..826e02a593 100644 --- a/config/alfresco/core-services-context.xml +++ b/config/alfresco/core-services-context.xml @@ -82,7 +82,8 @@ - + + @@ -119,6 +120,13 @@ + + + + + + + diff --git a/source/java/org/alfresco/repo/admin/Log4JHierarchyInit.java b/source/java/org/alfresco/repo/admin/Log4JHierarchyInit.java new file mode 100644 index 0000000000..42d54ccd0b --- /dev/null +++ b/source/java/org/alfresco/repo/admin/Log4JHierarchyInit.java @@ -0,0 +1,65 @@ +/* + * Copyright (C) 2005-2007 Alfresco Software Limited. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + + * This program 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 General Public License for more details. + + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + + * As a special exception to the terms and conditions of version 2.0 of + * the GPL, you may redistribute this Program in connection with Free/Libre + * and Open Source Software ("FLOSS") applications as described in Alfresco's + * FLOSS exception. You should have recieved a copy of the text describing + * the FLOSS exception, and it is also available here: + * http://www.alfresco.com/legal/licensing" + */ +package org.alfresco.repo.admin; + +import java.util.Enumeration; + +import org.apache.log4j.LogManager; +import org.apache.log4j.Logger; +import org.apache.log4j.jmx.HierarchyDynamicMBean; +import org.apache.log4j.spi.LoggerRepository; + +/** + * Initialises Log4j's HierarchyDynamicMBean (refer to core-services-context.xml) + * + */ +public class Log4JHierarchyInit +{ + private HierarchyDynamicMBean log4jHierarchy; + + public void setLog4jHierarchy(HierarchyDynamicMBean log4jHierarchy) + { + this.log4jHierarchy = log4jHierarchy; + } + + @SuppressWarnings("unchecked") + public void init() + { + // Add each logger (that has a level set) from the Log4J Repository to the Hierarchy MBean + LoggerRepository r = LogManager.getLoggerRepository(); + + Enumeration loggers = r.getCurrentLoggers(); + Logger logger = null; + + while (loggers.hasMoreElements()) + { + logger = (Logger)loggers.nextElement(); + if (logger.getLevel() != null) + { + log4jHierarchy.addLoggerMBean(logger.getName()); + } + } + } +}