resolve merge conflicts of 56a2b52937 to nyc-dev
Merged-In: If83d8edd0eea99145421e967ae47fdc264a5cf7c Merged-In: I129bfe850981cf0b3646b7c1cf19c8a3ec69f512 Change-Id: I81183e5b5bc702fb245a6a51afe6709c5b9dd3de
This commit is contained in:
@@ -68,6 +68,7 @@ import android.content.pm.PackageManager;
|
||||
import android.content.pm.PackageManager.NameNotFoundException;
|
||||
import android.content.pm.PackageManagerInternal;
|
||||
import android.content.pm.ParceledListSlice;
|
||||
import android.content.pm.PermissionInfo;
|
||||
import android.content.pm.ResolveInfo;
|
||||
import android.content.pm.ServiceInfo;
|
||||
import android.content.pm.UserInfo;
|
||||
@@ -118,6 +119,7 @@ import android.telephony.TelephonyManager;
|
||||
import android.text.TextUtils;
|
||||
import android.util.ArrayMap;
|
||||
import android.util.ArraySet;
|
||||
import android.util.EventLog;
|
||||
import android.util.Log;
|
||||
import android.util.Pair;
|
||||
import android.util.Slog;
|
||||
@@ -8361,6 +8363,10 @@ public class DevicePolicyManagerService extends IDevicePolicyManager.Stub {
|
||||
< android.os.Build.VERSION_CODES.M) {
|
||||
return false;
|
||||
}
|
||||
if (!isRuntimePermission(permission)) {
|
||||
EventLog.writeEvent(0x534e4554, "62623498", user.getIdentifier(), "");
|
||||
return false;
|
||||
}
|
||||
final PackageManager packageManager = mContext.getPackageManager();
|
||||
switch (grantState) {
|
||||
case DevicePolicyManager.PERMISSION_GRANT_STATE_GRANTED: {
|
||||
@@ -8386,12 +8392,21 @@ public class DevicePolicyManagerService extends IDevicePolicyManager.Stub {
|
||||
return true;
|
||||
} catch (SecurityException se) {
|
||||
return false;
|
||||
} catch (NameNotFoundException e) {
|
||||
return false;
|
||||
} finally {
|
||||
mInjector.binderRestoreCallingIdentity(ident);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public boolean isRuntimePermission(String permissionName) throws NameNotFoundException {
|
||||
final PackageManager packageManager = mContext.getPackageManager();
|
||||
PermissionInfo permissionInfo = packageManager.getPermissionInfo(permissionName, 0);
|
||||
return (permissionInfo.protectionLevel & PermissionInfo.PROTECTION_MASK_BASE)
|
||||
== PermissionInfo.PROTECTION_DANGEROUS;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getPermissionGrantState(ComponentName admin, String packageName,
|
||||
String permission) throws RemoteException {
|
||||
|
||||
Reference in New Issue
Block a user