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

Commit 995cf8e5 authored by Lifu Tang's avatar Lifu Tang Committed by Evelyn Torres
Browse files

Restrict WifiScanModeActivity when user restriction applies

Bug: 299633613
(cherry picked from https://googleplex-android-review.googlesource.com/q/commit:7a792e0b8f68bc4aeb939af703790fd76b51ccbd)
Cherrypick-From: https://googleplex-android-review.googlesource.com/q/commit:110eff4afb424e7aab22e2a16bd19405bd759f5e
Merged-In: If8cfb7047c0131da451a7af0d2b5108080876b85
Change-Id: If8cfb7047c0131da451a7af0d2b5108080876b85
parent fca77914
Loading
Loading
Loading
Loading
+35 −14
Original line number Diff line number Diff line
@@ -18,33 +18,39 @@ package com.android.settings.wifi;

import android.app.Dialog;
import android.app.settings.SettingsEnums;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.net.wifi.WifiManager;
import android.os.Bundle;
import android.os.UserManager;
import android.text.TextUtils;
import android.util.Log;
import android.view.WindowManager;

import androidx.appcompat.app.AlertDialog;
import androidx.fragment.app.DialogFragment;
import androidx.fragment.app.FragmentActivity;

import com.android.internal.annotations.VisibleForTesting;
import com.android.settings.R;
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;

/**
 * This activity requests users permission to allow scanning even when Wi-Fi is turned off
 */
/** This activity requests users permission to allow scanning even when Wi-Fi is turned off */
public class WifiScanModeActivity extends FragmentActivity {
    private static final String TAG = "WifiScanModeActivity";
    private DialogFragment mDialog;

    @VisibleForTesting
    private String mApp;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        getWindow().addSystemFlags(
        getWindow()
                .addSystemFlags(
                        WindowManager.LayoutParams.SYSTEM_FLAG_HIDE_NON_SYSTEM_OVERLAY_WINDOWS);
        Intent intent = getIntent();
        if (savedInstanceState == null) {
@@ -68,6 +74,12 @@ public class WifiScanModeActivity extends FragmentActivity {
    }

    private void createDialog() {
        if (!isWifiScanModeConfigAllowed(getApplicationContext())) {
            Log.e(TAG, "This user is not allowed to configure Wi-Fi Scan Mode!");
            finish();
            return;
        }

        if (mDialog == null) {
            mDialog = AlertDialogFragment.newInstance(mApp);
            mDialog.show(getSupportFragmentManager(), "dialog");
@@ -116,6 +128,7 @@ public class WifiScanModeActivity extends FragmentActivity {
        }

        private final String mApp;

        public AlertDialogFragment(String app) {
            super();
            mApp = app;
@@ -134,28 +147,36 @@ public class WifiScanModeActivity extends FragmentActivity {
        @Override
        public Dialog onCreateDialog(Bundle savedInstanceState) {
            return new AlertDialog.Builder(getActivity())
                    .setMessage(TextUtils.isEmpty(mApp) ?
                        getString(R.string.wifi_scan_always_turn_on_message_unknown) :
                        getString(R.string.wifi_scan_always_turnon_message, mApp))
                    .setPositiveButton(R.string.wifi_scan_always_confirm_allow,
                    .setMessage(
                            TextUtils.isEmpty(mApp)
                                    ? getString(R.string.wifi_scan_always_turn_on_message_unknown)
                                    : getString(R.string.wifi_scan_always_turnon_message, mApp))
                    .setPositiveButton(
                            R.string.wifi_scan_always_confirm_allow,
                            new DialogInterface.OnClickListener() {
                                public void onClick(DialogInterface dialog, int whichButton) {
                                    ((WifiScanModeActivity) getActivity()).doPositiveClick();
                                }
                            }
                    )
                    .setNegativeButton(R.string.wifi_scan_always_confirm_deny,
                            })
                    .setNegativeButton(
                            R.string.wifi_scan_always_confirm_deny,
                            new DialogInterface.OnClickListener() {
                                public void onClick(DialogInterface dialog, int whichButton) {
                                    ((WifiScanModeActivity) getActivity()).doNegativeClick();
                                }
                            }
                    )
                            })
                    .create();
        }

        @Override
        public void onCancel(DialogInterface dialog) {
            ((WifiScanModeActivity) getActivity()).doNegativeClick();
        }
    }

    private static boolean isWifiScanModeConfigAllowed(Context context) {
        final UserManager userManager = context.getSystemService(UserManager.class);
        if (userManager == null) return true;
        return !userManager.hasUserRestriction(UserManager.DISALLOW_CONFIG_LOCATION);
    }
}