2023-02-10 17:17:22 -05:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Dmitry Muhomor <muhomor.dmitry@gmail.com>
Date: Fri, 10 Feb 2023 12:44:30 +0200
Subject: [PATCH] add a toggle for forcibly disabling SUPL
---
res/values/strings.xml | 3 ++
res/xml/location_settings.xml | 7 +++
2023-02-17 17:33:47 -05:00
.../ForceDisableSuplPrefController.java | 46 +++++++++++++++++++
3 files changed, 56 insertions(+)
2023-02-10 17:17:22 -05:00
create mode 100644 src/com/android/settings/location/ForceDisableSuplPrefController.java
diff --git a/res/values/strings.xml b/res/values/strings.xml
2023-06-09 16:19:07 -04:00
index 3d44ae6ca6..1be8ea0677 100644
2023-02-10 17:17:22 -05:00
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -13706,4 +13706,7 @@
<string name="connectivity_check_title">Internet connectivity check</string>
<string name="connectivity_check_summary">HTTP endpoints to use for performing internet connectivity checks.</string>
+
+ <string name="force_disable_supl_title">Force disable Secure User Plane Location (SUPL)</string>
2023-06-07 15:32:53 -04:00
+ <string name="force_disable_supl_summary">Always disable SUPL assisted location support regardless of carrier configuration or emergency call status (does not disable control plane A-GNSS and DivestOS does not send IMSI to the SUPL)</string>
2023-02-10 17:17:22 -05:00
</resources>
diff --git a/res/xml/location_settings.xml b/res/xml/location_settings.xml
index fe87efd73d..74502a7d58 100644
--- a/res/xml/location_settings.xml
+++ b/res/xml/location_settings.xml
@@ -66,6 +66,13 @@
android:title="@string/location_services_preference_title"
settings:controller="com.android.settings.location.LocationServicesPreferenceController"/>
+
+ <com.android.settingslib.RestrictedSwitchPreference
+ android:key="force_disable_supl"
+ android:title="@string/force_disable_supl_title"
+ android:summary="@string/force_disable_supl_summary"
+ settings:controller="com.android.settings.location.ForceDisableSuplPrefController"/>
+
</PreferenceCategory>
<com.android.settingslib.widget.FooterPreference
diff --git a/src/com/android/settings/location/ForceDisableSuplPrefController.java b/src/com/android/settings/location/ForceDisableSuplPrefController.java
new file mode 100644
2023-02-17 17:33:47 -05:00
index 0000000000..879174f3c8
2023-02-10 17:17:22 -05:00
--- /dev/null
+++ b/src/com/android/settings/location/ForceDisableSuplPrefController.java
2023-02-17 17:33:47 -05:00
@@ -0,0 +1,46 @@
2023-02-10 17:17:22 -05:00
+package com.android.settings.location;
+
2023-02-17 17:33:47 -05:00
+import android.content.ContentResolver;
2023-02-10 17:17:22 -05:00
+import android.content.Context;
+import android.os.Process;
+import android.provider.Settings;
+
+import com.android.settings.core.TogglePreferenceController;
+
+public class ForceDisableSuplPrefController extends TogglePreferenceController {
+
+ public ForceDisableSuplPrefController(Context ctx, String key) {
+ super(ctx, key);
+ }
+
+ @Override
+ public int getAvailabilityStatus() {
+ if (!Process.myUserHandle().isSystem()) {
+ return DISABLED_FOR_USER;
+ }
+
+ return AVAILABLE;
+ }
+
+ @Override
+ public boolean isChecked() {
2023-02-17 17:33:47 -05:00
+ ContentResolver cr = mContext.getContentResolver();
2023-02-10 17:17:22 -05:00
+ String key = Settings.Global.FORCE_DISABLE_SUPL;
+ int def = Settings.Global.FORCE_DISABLE_SUPL_DEFAULT;
+
+ return Settings.Global.getInt(cr, key, def) == 1;
+ }
+
+ @Override
+ public boolean setChecked(boolean isChecked) {
2023-02-17 17:33:47 -05:00
+ ContentResolver cr = mContext.getContentResolver();
2023-02-10 17:17:22 -05:00
+ String key = Settings.Global.FORCE_DISABLE_SUPL;
+
+ return Settings.Global.putInt(cr, key, isChecked ? 1 : 0);
+ }
+
+ @Override
+ public int getSliceHighlightMenuRes() {
+ return NO_RES;
+ }
+}