KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > sun > enterprise > deployment > annotation > handlers > PostActivateHandler


1 /*
2  * The contents of this file are subject to the terms
3  * of the Common Development and Distribution License
4  * (the License). You may not use this file except in
5  * compliance with the License.
6  *
7  * You can obtain a copy of the license at
8  * https://glassfish.dev.java.net/public/CDDLv1.0.html or
9  * glassfish/bootstrap/legal/CDDLv1.0.txt.
10  * See the License for the specific language governing
11  * permissions and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL
14  * Header Notice in each file and include the License file
15  * at glassfish/bootstrap/legal/CDDLv1.0.txt.
16  * If applicable, add the following below the CDDL Header,
17  * with the fields enclosed by brackets [] replaced by
18  * you own identifying information:
19  * "Portions Copyrighted [year] [name of copyright owner]"
20  *
21  * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
22  */

23 package com.sun.enterprise.deployment.annotation.handlers;
24
25 import java.lang.annotation.Annotation JavaDoc;
26 import java.lang.annotation.ElementType JavaDoc;
27 import java.lang.reflect.AnnotatedElement JavaDoc;
28 import java.lang.reflect.Method JavaDoc;
29
30 import javax.ejb.PostActivate JavaDoc;
31
32 import com.sun.enterprise.deployment.EjbDescriptor;
33 import com.sun.enterprise.deployment.EjbInterceptor;
34 import com.sun.enterprise.deployment.EjbSessionDescriptor;
35 import com.sun.enterprise.deployment.LifecycleCallbackDescriptor;
36
37 import com.sun.enterprise.deployment.annotation.AnnotationInfo;
38 import com.sun.enterprise.deployment.annotation.AnnotationProcessorException;
39 import com.sun.enterprise.deployment.annotation.HandlerProcessingResult;
40 import com.sun.enterprise.deployment.annotation.context.EjbContext;
41 import com.sun.enterprise.deployment.annotation.context.EjbInterceptorContext;
42
43 /**
44  * This handler is responsible for handling javax.ejb.PostActivate
45  *
46  */

47 public class PostActivateHandler extends AbstractAttributeHandler {
48     
49     public PostActivateHandler() {
50     }
51     
52     /**
53      * @return the annoation type this annotation handler is handling
54      */

55     public Class JavaDoc<? extends Annotation JavaDoc> getAnnotationType() {
56         return PostActivate JavaDoc.class;
57     }
58         
59     protected HandlerProcessingResult processAnnotation(AnnotationInfo ainfo,
60             EjbContext[] ejbContexts) throws AnnotationProcessorException {
61
62         for(EjbContext next : ejbContexts) {
63             
64             EjbSessionDescriptor ejbSessionDescriptor =
65                 (EjbSessionDescriptor) next.getDescriptor();
66
67             ejbSessionDescriptor.addPostActivateDescriptor(
68                 getPostActivateDescriptor(ainfo));
69             
70         }
71
72         return getDefaultProcessedResult();
73     }
74
75     protected HandlerProcessingResult processAnnotation(AnnotationInfo ainfo,
76             EjbInterceptorContext ejbInterceptorContext)
77             throws AnnotationProcessorException {
78
79         EjbInterceptor ejbInterceptor = ejbInterceptorContext.getDescriptor();
80         ejbInterceptor.addPostActivateDescriptor(
81             getPostActivateDescriptor(ainfo));
82         return getDefaultProcessedResult();
83     }
84
85     private LifecycleCallbackDescriptor getPostActivateDescriptor(
86             AnnotationInfo ainfo) {
87         Method JavaDoc annotatedMethod = (Method JavaDoc) ainfo.getAnnotatedElement();
88         LifecycleCallbackDescriptor postActivate =
89                 new LifecycleCallbackDescriptor();
90         postActivate.setLifecycleCallbackClass(annotatedMethod.getDeclaringClass().getName());
91         postActivate.setLifecycleCallbackMethod(annotatedMethod.getName());
92         return postActivate;
93     }
94
95     /**
96      * @return an array of annotation types this annotation handler would
97      * require to be processed (if present) before it processes it's own
98      * annotation type.
99      */

100     public Class JavaDoc<? extends Annotation JavaDoc>[] getTypeDependencies() {
101         return getEjbAnnotationTypes();
102     }
103
104     protected boolean isDelegatee() {
105         return true;
106     }
107 }
108
Popular Tags