01: /**
02: * EasyBeans
03: * Copyright (C) 2006 Bull S.A.S.
04: * Contact: easybeans@ow2.org
05: *
06: * This library is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU Lesser General Public
08: * License as published by the Free Software Foundation; either
09: * version 2.1 of the License, or any later version.
10: *
11: * This library is distributed in the hope that it will be useful,
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14: * Lesser General Public License for more details.
15: *
16: * You should have received a copy of the GNU Lesser General Public
17: * License along with this library; if not, write to the Free Software
18: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19: * USA
20: *
21: * --------------------------------------------------------------------------
22: * $Id: JavaxAnnotationSecurityPermitAllVisitor.java 2059 2007-11-22 17:22:33Z benoitf $
23: * --------------------------------------------------------------------------
24: */package org.ow2.easybeans.deployment.annotations.analyzer;
25:
26: import org.ow2.easybeans.deployment.annotations.metadata.interfaces.IAnnotationSecurityPermitAll;
27:
28: /**
29: * This class manages the handling of @{@link javax.annotation.security.PermitAll}
30: * annotation.
31: * @param <T> Class implementing IAnnotationSecurityPermitAll interface.
32: * @author Florent Benoit
33: */
34: public class JavaxAnnotationSecurityPermitAllVisitor<T extends IAnnotationSecurityPermitAll>
35: extends AbsAnnotationVisitor<T> implements AnnotationType {
36:
37: /**
38: * Type of annotation.
39: */
40: public static final String TYPE = "Ljavax/annotation/security/PermitAll;";
41:
42: /**
43: * Constructor.
44: * @param annotationMetadata linked to a class/method metadata
45: */
46: public JavaxAnnotationSecurityPermitAllVisitor(
47: final T annotationMetadata) {
48: super (annotationMetadata);
49: }
50:
51: /**
52: * Visits the end of the annotation.<br>
53: * Creates the object and store it.
54: */
55: @Override
56: public void visitEnd() {
57: getAnnotationMetadata().setPermitAll(true);
58: }
59:
60: /**
61: * @return type of the annotation (its description).
62: */
63: public String getType() {
64: return TYPE;
65: }
66:
67: }
|