/* * Copyright (C) 2018 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.app.admin; import static android.app.admin.DevicePolicyManager.CONTENT_PROTECTION_DISABLED; import static android.app.admin.DevicePolicyManager.ContentProtectionPolicy; import android.annotation.UserIdInt; import com.android.server.LocalServices; import java.util.Collections; import java.util.Map; /** * Stores a copy of the set of device policies maintained by {@link DevicePolicyManager} that * can be accessed from any place without risking dead locks. * * @hide */ public abstract class DevicePolicyCache { protected DevicePolicyCache() { } /** * @return the instance. */ public static DevicePolicyCache getInstance() { final DevicePolicyManagerInternal dpmi = LocalServices.getService(DevicePolicyManagerInternal.class); return (dpmi != null) ? dpmi.getDevicePolicyCache() : EmptyDevicePolicyCache.INSTANCE; } /** * See {@link DevicePolicyManager#getScreenCaptureDisabled} */ public abstract boolean isScreenCaptureAllowed(@UserIdInt int userHandle); /** * Caches {@link DevicePolicyManager#getPasswordQuality(android.content.ComponentName)} of the * given user with {@code null} passed in as argument. */ public abstract int getPasswordQuality(@UserIdInt int userHandle); /** * Caches {@link DevicePolicyManager#getPermissionPolicy(android.content.ComponentName)} of * the given user. */ public abstract int getPermissionPolicy(@UserIdInt int userHandle); /** * Caches {@link DevicePolicyManager#getContentProtectionPolicy(android.content.ComponentName)} * of the given user. */ public abstract @ContentProtectionPolicy int getContentProtectionPolicy(@UserIdInt int userId); /** * True if there is an admin on the device who can grant sensor permissions. */ public abstract boolean canAdminGrantSensorsPermissions(); /** * Returns a map of package names to package names, for which all launcher shortcuts which * match a key package name should be modified to launch the corresponding value package * name in the managed profile. The overridden shortcut should be badged accordingly. */ public abstract Map getLauncherShortcutOverrides(); /** * Empty implementation. */ private static class EmptyDevicePolicyCache extends DevicePolicyCache { private static final EmptyDevicePolicyCache INSTANCE = new EmptyDevicePolicyCache(); @Override public boolean isScreenCaptureAllowed(int userHandle) { return true; } @Override public int getPasswordQuality(int userHandle) { return DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED; } @Override public int getPermissionPolicy(int userHandle) { return DevicePolicyManager.PERMISSION_POLICY_PROMPT; } @Override public @ContentProtectionPolicy int getContentProtectionPolicy(@UserIdInt int userId) { return CONTENT_PROTECTION_DISABLED; } @Override public boolean canAdminGrantSensorsPermissions() { return false; } @Override public Map getLauncherShortcutOverrides() { return Collections.EMPTY_MAP; } } }