mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2025-01-18 10:57:10 -05:00
132 lines
6.4 KiB
Diff
132 lines
6.4 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Collin Fijalkovich <cfijalkovich@google.com>
|
||
|
Date: Thu, 7 May 2020 16:54:24 -0700
|
||
|
Subject: [PATCH] Initialize developer options ContentObserver at app start
|
||
|
|
||
|
Previously we initialized the ContentObserver in Receiver on receipt of
|
||
|
the BOOT_COMPLETE signal, but the process that handles that signal now
|
||
|
dies during boot. This change initializes the ContentObserver at
|
||
|
application start to ensure we always have an observer in place.
|
||
|
|
||
|
Additionally, we add the ContentObserver when the quick settings tile
|
||
|
service starts. This ensures that even if we do not open Traceur before
|
||
|
disabling developer options, the tile will be removed.
|
||
|
|
||
|
Bug: 150612980
|
||
|
Test: Traceur QS tile disappears after disabling developer options
|
||
|
Change-Id: I8512d9d1854490290c90b646f4cab2e939aa61c6
|
||
|
---
|
||
|
.../google/android/traceur/MainFragment.java | 2 +
|
||
|
src/com/google/android/traceur/QsService.java | 1 +
|
||
|
src/com/google/android/traceur/Receiver.java | 70 ++++++++++---------
|
||
|
3 files changed, 39 insertions(+), 34 deletions(-)
|
||
|
|
||
|
diff --git a/src/com/google/android/traceur/MainFragment.java b/src/com/google/android/traceur/MainFragment.java
|
||
|
index e69b2b3..1d80576 100644
|
||
|
--- a/src/com/google/android/traceur/MainFragment.java
|
||
|
+++ b/src/com/google/android/traceur/MainFragment.java
|
||
|
@@ -83,6 +83,8 @@ public class MainFragment extends PreferenceFragment {
|
||
|
public void onCreate(@Nullable Bundle savedInstanceState) {
|
||
|
super.onCreate(savedInstanceState);
|
||
|
|
||
|
+ Receiver.updateDeveloperOptionsWatcher(getContext());
|
||
|
+
|
||
|
mPrefs = PreferenceManager.getDefaultSharedPreferences(
|
||
|
getActivity().getApplicationContext());
|
||
|
|
||
|
diff --git a/src/com/google/android/traceur/QsService.java b/src/com/google/android/traceur/QsService.java
|
||
|
index 0ddbf36..60e42e5 100644
|
||
|
--- a/src/com/google/android/traceur/QsService.java
|
||
|
+++ b/src/com/google/android/traceur/QsService.java
|
||
|
@@ -57,6 +57,7 @@ public class QsService extends TileService {
|
||
|
getQsTile().setState(tracingOn ? Tile.STATE_ACTIVE : Tile.STATE_INACTIVE);
|
||
|
getQsTile().setLabel(titleString);
|
||
|
getQsTile().updateTile();
|
||
|
+ Receiver.updateDeveloperOptionsWatcher(this);
|
||
|
}
|
||
|
|
||
|
/** When we click the tile, toggle tracing state.
|
||
|
diff --git a/src/com/google/android/traceur/Receiver.java b/src/com/google/android/traceur/Receiver.java
|
||
|
index b58dec6..4f3415d 100644
|
||
|
--- a/src/com/google/android/traceur/Receiver.java
|
||
|
+++ b/src/com/google/android/traceur/Receiver.java
|
||
|
@@ -180,42 +180,44 @@ public class Receiver extends BroadcastReceiver {
|
||
|
* preference to false to hide the tile. The user will need to re-enable the
|
||
|
* preference if they decide to turn Developer Options back on again.
|
||
|
*/
|
||
|
- private static void updateDeveloperOptionsWatcher(Context context) {
|
||
|
- Uri settingUri = Settings.Global.getUriFor(
|
||
|
- Settings.Global.DEVELOPMENT_SETTINGS_ENABLED);
|
||
|
-
|
||
|
- ContentObserver developerOptionsObserver =
|
||
|
- new ContentObserver(new Handler()) {
|
||
|
- @Override
|
||
|
- public void onChange(boolean selfChange) {
|
||
|
- super.onChange(selfChange);
|
||
|
-
|
||
|
- boolean developerOptionsEnabled = (1 ==
|
||
|
- Settings.Global.getInt(context.getContentResolver(),
|
||
|
- Settings.Global.DEVELOPMENT_SETTINGS_ENABLED , 0));
|
||
|
-
|
||
|
- ComponentName name = new ComponentName(context,
|
||
|
- StorageProvider.class);
|
||
|
- context.getPackageManager().setComponentEnabledSetting(name,
|
||
|
- developerOptionsEnabled
|
||
|
- ? PackageManager.COMPONENT_ENABLED_STATE_ENABLED
|
||
|
- : PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
||
|
- PackageManager.DONT_KILL_APP);
|
||
|
-
|
||
|
- if (!developerOptionsEnabled) {
|
||
|
- SharedPreferences prefs =
|
||
|
- PreferenceManager.getDefaultSharedPreferences(context);
|
||
|
- prefs.edit().putBoolean(
|
||
|
- context.getString(R.string.pref_key_quick_setting), false)
|
||
|
- .commit();
|
||
|
- updateQuickSettings(context);
|
||
|
+ static void updateDeveloperOptionsWatcher(Context context) {
|
||
|
+ if (mDeveloperOptionsObserver == null) {
|
||
|
+ Uri settingUri = Settings.Global.getUriFor(
|
||
|
+ Settings.Global.DEVELOPMENT_SETTINGS_ENABLED);
|
||
|
+
|
||
|
+ mDeveloperOptionsObserver =
|
||
|
+ new ContentObserver(new Handler()) {
|
||
|
+ @Override
|
||
|
+ public void onChange(boolean selfChange) {
|
||
|
+ super.onChange(selfChange);
|
||
|
+
|
||
|
+ boolean developerOptionsEnabled = (1 ==
|
||
|
+ Settings.Global.getInt(context.getContentResolver(),
|
||
|
+ Settings.Global.DEVELOPMENT_SETTINGS_ENABLED , 0));
|
||
|
+
|
||
|
+ ComponentName name = new ComponentName(context,
|
||
|
+ StorageProvider.class);
|
||
|
+ context.getPackageManager().setComponentEnabledSetting(name,
|
||
|
+ developerOptionsEnabled
|
||
|
+ ? PackageManager.COMPONENT_ENABLED_STATE_ENABLED
|
||
|
+ : PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
||
|
+ PackageManager.DONT_KILL_APP);
|
||
|
+
|
||
|
+ if (!developerOptionsEnabled) {
|
||
|
+ SharedPreferences prefs =
|
||
|
+ PreferenceManager.getDefaultSharedPreferences(context);
|
||
|
+ prefs.edit().putBoolean(
|
||
|
+ context.getString(R.string.pref_key_quick_setting), false)
|
||
|
+ .commit();
|
||
|
+ updateQuickSettings(context);
|
||
|
+ }
|
||
|
}
|
||
|
- }
|
||
|
- };
|
||
|
+ };
|
||
|
|
||
|
- context.getContentResolver().registerContentObserver(settingUri,
|
||
|
- false, developerOptionsObserver);
|
||
|
- developerOptionsObserver.onChange(true);
|
||
|
+ context.getContentResolver().registerContentObserver(settingUri,
|
||
|
+ false, mDeveloperOptionsObserver);
|
||
|
+ mDeveloperOptionsObserver.onChange(true);
|
||
|
+ }
|
||
|
}
|
||
|
|
||
|
private static void postCategoryNotification(Context context, SharedPreferences prefs) {
|