script-astra/Android/Sdk/sources/android-35/android/app/admin/DevicePolicyCache.java
localadmin 4380f00a78 init
2025-01-20 18:15:20 +03:00

118 lines
3.9 KiB
Java

/*
* 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<String, String> 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<String, String> getLauncherShortcutOverrides() {
return Collections.EMPTY_MAP;
}
}
}