summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/tags/2.0.1-RC1/modules/sca-api/src/main/java/org/oasisopen/sca/annotation/Service.java
blob: 5c2600ff1262bc48311b84843e8842efdc29900c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/*
 * Copyright(C) OASIS(R) 2005,2010. All Rights Reserved.
 * OASIS trademark, IPR and other policies apply.
 */
package org.oasisopen.sca.annotation;

import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

/**
 * The @Service annotation is used on a component implementation
 * class to specify the SCA services offered by the implementation.
 *
 * The class need not be declared as implementing all of the
 * interfaces implied by the services, but all methods of the service
 * interfaces must be present.
 *
 * A class used as the implementation of a service is not required
 * to have a @Service annotation.  If a class has no @Service annotation,
 * then the rules determining which services are offered and what
 * interfaces those services have are determined by the specific
 * implementation type.
 */
@Target(TYPE)
@Retention(RUNTIME)
public @interface Service {

    /**
     * The value is an array of interface or class objects that should be
     * exposed as services by this component.
     *
     * @return the services of this component
     */
    Class<?>[] value();

    /**
     * The value is an array of strings which are used as the service names
     * for each of the interfaces declared in the value array.
     *
     * @return the service names
     */
    String[] names() default {};
}