• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2021 Google LLC
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   https://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package com.google.android.enterprise.connectedapps.annotations;
17 
18 import java.lang.annotation.ElementType;
19 import java.lang.annotation.Retention;
20 import java.lang.annotation.RetentionPolicy;
21 import java.lang.annotation.Target;
22 
23 /**
24  * Specify configuration for cross-profile calls.
25  *
26  * <p>Typically you should have only one {@link CrossProfileConfiguration} annotated class in your
27  * build.
28  */
29 @Target(ElementType.TYPE)
30 @Retention(RetentionPolicy.CLASS)
31 public @interface CrossProfileConfiguration {
32   /** provider classes that should be accessible */
providers()33   Class<?>[] providers() default {};
34 
35   /**
36    * A {@code android.app.Service} subclass which should be used as the superclass of the generated
37    * service. By default this is {@code android.app.Service}.
38    */
serviceSuperclass()39   Class<?> serviceSuperclass() default CrossProfileConfiguration.class;
40   // android.app.Service isn't available to the annotations library, so we default to
41   // CrossProfileConfiguration and swap it to android.app.Service when compiling
42 
43   /**
44    * A {@code android.app.Service} subclass which should be used instead of the generated service.
45    *
46    * <p>If not specified, a service will be generated.
47    *
48    * <p>The class name must match the {@link CustomProfileConnector#serviceClassName()}.
49    */
serviceClass()50   Class<?> serviceClass() default CrossProfileConfiguration.class;
51 
52   /**
53    * The {@link CustomProfileConnector} used by this configuration.
54    *
55    * <p>Defaults to {@code com.google.android.enterprise.connectedapps.CrossProfileConnector}.
56    */
connector()57   Class<?> connector() default CrossProfileConfiguration.class;
58   // com.google.android.enterprise.connectedapps.CrossProfileConnector isn't available to the
59   // annotations library, so we default to CrossProfileConfiguration and swap it out when compiling.
60 }
61