]> source.dussan.org Git - archiva.git/blob
6a648bfd9e72326d7b9484a80bace390a0f41036
[archiva.git] /
1 package org.apache.maven.archiva.common.spring;
2
3 /*
4  * Licensed to the Apache Software Foundation (ASF) under one
5  * or more contributor license agreements.  See the NOTICE file
6  * distributed with this work for additional information
7  * regarding copyright ownership.  The ASF licenses this file
8  * to you under the Apache License, Version 2.0 (the
9  * "License"); you may not use this file except in compliance
10  * with the License.  You may obtain a copy of the License at
11  *
12  *  http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing,
15  * software distributed under the License is distributed on an
16  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17  * KIND, either express or implied.  See the License for the
18  * specific language governing permissions and limitations
19  * under the License.
20  */
21
22 import org.codehaus.plexus.logging.LogEnabled;
23 import org.codehaus.plexus.logging.Logger;
24 import org.codehaus.plexus.logging.LoggerManager;
25 import org.codehaus.plexus.logging.console.ConsoleLogger;
26 import org.codehaus.plexus.logging.slf4j.Slf4jLogger;
27 import org.codehaus.plexus.logging.slf4j.Slf4jLoggerManager;
28 import org.codehaus.plexus.personality.plexus.lifecycle.phase.Initializable;
29 import org.springframework.beans.BeansException;
30 import org.springframework.beans.factory.InitializingBean;
31 import org.springframework.beans.factory.config.BeanPostProcessor;
32
33 /**
34  * A Spring bean postPorcessor to apply Plexu LogEnabled lifecycle interface
35  *
36  * @author <a href="mailto:nicolas@apache.org">Nicolas De Loof</a>
37  * @since 1.1
38  */
39 public class PlexusLogEnabledBeanPostProcessor
40     implements BeanPostProcessor, InitializingBean
41 {
42     private LoggerManager loggerManager = new Slf4jLoggerManager();
43
44     /**
45      * {@inheritDoc}
46      * @see org.springframework.beans.factory.InitializingBean#afterPropertiesSet()
47      */
48     public void afterPropertiesSet()
49         throws Exception
50     {
51         if ( loggerManager instanceof Initializable )
52         {
53             ( (Initializable) loggerManager ).initialize();
54         }
55     }
56
57     /**
58      * {@inheritDoc}
59      * @see org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization(java.lang.Object, java.lang.String)
60      */
61     public Object postProcessAfterInitialization( Object bean, String beanName )
62         throws BeansException
63     {
64         return bean;
65     }
66
67     /**
68      * {@inheritDoc}
69      * @see org.springframework.beans.factory.config.BeanPostProcessor#postProcessBeforeInitialization(java.lang.Object, java.lang.String)
70      */
71     public Object postProcessBeforeInitialization( Object bean, String beanName )
72         throws BeansException
73     {
74         if ( bean instanceof LogEnabled )
75         {
76             ( (LogEnabled) bean ).enableLogging( loggerManager.getLoggerForComponent( beanName ) );
77         }
78         return bean;
79     }
80
81     protected void setLoggerManager( LoggerManager loggerManager )
82     {
83         this.loggerManager = loggerManager;
84     }
85
86 }