001    // Copyright 2004, 2005 The Apache Software Foundation
002    //
003    // Licensed under the Apache License, Version 2.0 (the "License");
004    // you may not use this file except in compliance with the License.
005    // You may obtain a copy of the License at
006    //
007    //     http://www.apache.org/licenses/LICENSE-2.0
008    //
009    // Unless required by applicable law or agreed to in writing, software
010    // distributed under the License is distributed on an "AS IS" BASIS,
011    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012    // See the License for the specific language governing permissions and
013    // limitations under the License.
014    
015    package org.apache.examples.impl;
016    
017    import java.lang.reflect.InvocationHandler;
018    import java.lang.reflect.Proxy;
019    
020    import org.apache.commons.logging.Log;
021    import org.apache.hivemind.InterceptorStack;
022    import org.apache.hivemind.ServiceInterceptorFactory;
023    import org.apache.hivemind.internal.Module;
024    
025    /**
026     * Creates a simple, proxy-based interceptor that mimics most (but not all) of the behavior
027     * of {@link org.apache.hivemind.service.impl.LoggingInterceptorClassFactory}.
028     *
029     * @author Howard Lewis Ship
030     */
031    public class ProxyLoggingInterceptorFactory implements ServiceInterceptorFactory
032    {
033    
034        public void createInterceptor(InterceptorStack stack, Module invokingModule, Object parameters)
035        {
036            Log log = stack.getServiceLog();
037    
038            InvocationHandler handler = new ProxyLoggingInvocationHandler(log, stack.peek());
039    
040            Object interceptor =
041                Proxy.newProxyInstance(
042                    invokingModule.getClassResolver().getClassLoader(),
043                    new Class[] { stack.getServiceInterface()},
044                    handler);
045    
046            stack.push(interceptor);
047        }
048    }