Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 4453c3cd authored by Tony Mak's avatar Tony Mak Committed by android-build-merger
Browse files

resolve merge conflicts of 56a2b529 to nyc-dev am: d7dcc3e2 am: 34377e03

am: 68cce397

Change-Id: Ieb10d27e72646260f0c75535485a6fe11efe2a32
parents 67f43835 68cce397
Loading
Loading
Loading
Loading
+15 −0
Original line number Diff line number Diff line
@@ -69,6 +69,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;
@@ -119,6 +120,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;
@@ -8554,6 +8556,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: {
@@ -8579,12 +8585,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 {