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

Commit 731b5208 authored by Joel Galenson's avatar Joel Galenson
Browse files

Show dialog when trying to change location provider permission.

GMS Core is the location provider on the device and so the permission
cannot be disabled.  Instead of having clicks on it go to a disabled
tri-state screen, restore the P behavior of popping up a dialog that
can redirect users to the Location setting.

Fixes: 123902223
Test: Click on GMS Core location on four different screens and get
this dialog.
Test: Click on other permissions and get the normal tri-state.

Change-Id: Ic4ec22dea46405d4800010dec437822965f351ec
parent 391094fa
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -133,6 +133,10 @@
                android:excludeFromRecents="true"
                android:theme="@android:style/Theme.DeviceDefault.Light.Dialog.NoActionBar" />

        <activity android:name="com.android.packageinstaller.permission.ui.LocationProviderInterceptDialog"
                  android:excludeFromRecents="true"
                  android:theme="@android:style/Theme.DeviceDefault.Light.Dialog.NoActionBar" />

        <activity android:name="com.android.packageinstaller.permission.ui.ReviewAccessibilityServicesActivity"
                  android:excludeFromRecents="true"
                  android:theme="@android:style/Theme.DeviceDefault.Light.Dialog.NoActionBar" >
+9 −0
Original line number Diff line number Diff line
@@ -64,6 +64,15 @@ public final class AppPermissionActivity extends FragmentActivity {
            return;
        }

        if (LocationUtils.isLocationGroupAndProvider(this, permissionName,
                packageName)) {
            Intent intent = new Intent(this, LocationProviderInterceptDialog.class);
            intent.putExtra(Intent.EXTRA_PACKAGE_NAME, packageName);
            startActivity(intent);
            finish();
            return;
        }

        if (LocationUtils.isLocationGroupAndControllerExtraPackage(
                this, permissionName, packageName)) {
            // Redirect to location controller extra package settings.
+72 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2019 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 com.android.packageinstaller.permission.ui;

import android.app.AlertDialog;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.provider.Settings;
import android.util.Log;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.FragmentActivity;

import com.android.packageinstaller.permission.utils.Utils;
import com.android.permissioncontroller.R;

/**
 * A dialog saying that you cannot change the location provider's location permission.
 */
public final class LocationProviderInterceptDialog extends FragmentActivity {
    private static final String LOG_TAG = LocationProviderInterceptDialog.class.getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        String packageName = getIntent().getStringExtra(Intent.EXTRA_PACKAGE_NAME);
        if (packageName == null) {
            Log.i(LOG_TAG, "Missing mandatory argument EXTRA_PACKAGE_NAME");
            finish();
            return;
        }

        new AlertDialog.Builder(this)
                .setIcon(R.drawable.ic_dialog_alert_material)
                .setTitle(android.R.string.dialog_alert_title)
                .setMessage(getString(R.string.location_warning,
                        Utils.getAppLabel(getPackageInfo(packageName).applicationInfo, this)))
                .setNegativeButton(R.string.ok, null)
                .setPositiveButton(R.string.location_settings, (dialog, which) ->
                        startActivity(new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS)))
                .setOnDismissListener((dialog) -> finish())
                .show();
    }

    private @Nullable PackageInfo getPackageInfo(@NonNull String packageName) {
        try {
            return getPackageManager().getPackageInfo(packageName, PackageManager.GET_PERMISSIONS);
        } catch (PackageManager.NameNotFoundException e) {
            Log.i(LOG_TAG, "No package: " + packageName, e);
            finish();
            return null;
        }
    }
}