View Javadoc
1   /*
2    * JBoss, Home of Professional Open Source
3    * Copyright 2014, Red Hat, Inc. and/or its affiliates, and individual
4    * contributors by the @authors tag. See the copyright.txt in the
5    * distribution for a full listing of individual contributors.
6    *
7    * Licensed under the Apache License, Version 2.0 (the "License");
8    * you may not use this file except in compliance with the License.
9    * You may obtain a copy of the License at
10   * http://www.apache.org/licenses/LICENSE-2.0
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  package org.jboss.as.quickstarts.cdi.interceptor;
18  
19  import static java.lang.annotation.ElementType.TYPE;
20  import static java.lang.annotation.RetentionPolicy.RUNTIME;
21  
22  import java.lang.annotation.Retention;
23  import java.lang.annotation.Target;
24  
25  import javax.enterprise.inject.Alternative;
26  import javax.enterprise.inject.Stereotype;
27  
28  /**
29   * A stereotype is an annotation, annotated @Stereotype, that packages several other annotations. It specify 2 interceptors
30   * bindings (@Logging and @Audit) to be inherited by all beans with that stereotype. This stereotype also indicate that all
31   * beans to which it is applied are @Alternatives. An alternative stereotype lets us classify beans by deployment scenario.
32   * 
33   * @author ievgen.shulga
34   */
35  @Stereotype
36  @Alternative
37  @Audit
38  @Logging
39  @Retention(RUNTIME)
40  @Target(TYPE)
41  public @interface ServiceStereotype {
42  
43  }