All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.openejb.test.SuperInterceptedBean Maven / Gradle / Ivy

There is a newer version: 4.7.5
Show newest version
/**
 *  Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  See the NOTICE file distributed with
 *  this work for additional information regarding copyright ownership.
 *  The ASF licenses this file to You under the Apache License, Version 2.0
 *  (the "License"); you may not use this file except in compliance with
 *  the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package org.apache.openejb.test;

import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.interceptor.AroundInvoke;
import javax.interceptor.InvocationContext;

import org.apache.openejb.test.interceptor.Interceptor;

/**
 * @author Prasad Kashyap
 *
 * @version $Rev: 607077 $ $Date: 2007-12-27 14:55:23 +0000 (Thu, 27 Dec 2007) $
 */
public class SuperInterceptedBean {

    /**
     * 
     */
    public SuperInterceptedBean() {
        super();
    }
    
    /**
     * The interceptor method. 
     * This should intercept all business methods in this bean class.
     * It cannot exclude even those annotated with @ExcludeClassInterceptors
     * 
     * @param ctx - InvocationContext
     * 
     * @return - the result of the next method invoked. If a method returns void, proceed returns null. 
     * For lifecycle callback interceptor methods, if there is no callback method defined on the bean class, 
     * the invocation of proceed in the last interceptor method in the chain is a no-op, and null is returned. 
     * If there is more than one such interceptor method, the invocation of proceed causes the container to execute those methods in order.
     * 
     * @throws runtime exceptions or application exceptions that are allowed in the throws clause of the business method.
     */
    @AroundInvoke
    public Object superBeanInterceptor(InvocationContext ctx) throws Exception {
        Interceptor.profile(ctx, "superBeanInterceptor");
        return ctx.proceed();
    }
    
    /**
     * The interceptor method. 
     * This should intercept postConstruct of the bean
     * 
     * @throws runtime exceptions.
     */    
    @PostConstruct
    public void superBeanInterceptorPostConstruct() throws Exception {
        Interceptor.profile(this, "superBeanInterceptorPostConstruct");
        return;
    }
    
      
    /**
     * The interceptor method. 
     * This should intercept preDestroy of the bean.
     * 
     * @throws runtime exceptions.
     */    
    @PreDestroy
    public void superBeanInterceptorPreDestroy() throws Exception {
        Interceptor.profile(this, "superBeanInterceptorPreDestroy");
        return;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy