/* * Copyright (C) 2022 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.annotation; import static java.lang.annotation.ElementType.METHOD; import static java.lang.annotation.RetentionPolicy.CLASS; import java.lang.annotation.Retention; import java.lang.annotation.Target; /** * Documents that the subject method's job is to look * up whether the provided or calling uid/pid has the requested permission. * *
Methods should either return `void`, but potentially throw {@link SecurityException}, * or return {@link android.content.pm.PackageManager.PermissionResult} `int`. * * @hide */ @Retention(CLASS) @Target({METHOD}) public @interface PermissionMethod { /** * Hard-coded list of permissions checked by this method */ @PermissionName String[] value() default {}; /** * If true, the check passes if the caller * has any ONE of the supplied permissions */ boolean anyOf() default false; /** * Signifies that the permission check passes if * the calling process OR the current process has * the permission */ boolean orSelf() default false; }