mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2024-10-01 01:35:54 -04:00
197 lines
7.6 KiB
Diff
197 lines
7.6 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: pratyush <codelab@pratyush.dev>
|
||
|
Date: Mon, 7 Jun 2021 22:15:59 +0100
|
||
|
Subject: [PATCH] add auto-reboot setting
|
||
|
|
||
|
---
|
||
|
res/values/arrays.xml | 31 +++++++
|
||
|
res/values/strings.xml | 3 +
|
||
|
res/xml/security_dashboard_settings.xml | 10 ++-
|
||
|
.../AutoRebootPreferenceController.java | 82 +++++++++++++++++++
|
||
|
.../settings/security/SecuritySettings.java | 1 +
|
||
|
5 files changed, 126 insertions(+), 1 deletion(-)
|
||
|
create mode 100644 src/com/android/settings/security/AutoRebootPreferenceController.java
|
||
|
|
||
|
diff --git a/res/values/arrays.xml b/res/values/arrays.xml
|
||
|
index f84afec09fc..954e3047f57 100644
|
||
|
--- a/res/values/arrays.xml
|
||
|
+++ b/res/values/arrays.xml
|
||
|
@@ -105,6 +105,37 @@
|
||
|
<item>1800000</item>
|
||
|
</string-array>
|
||
|
|
||
|
+ <!-- Auto reboot settings -->
|
||
|
+ <string-array name="auto_reboot_entries">
|
||
|
+ <item>Off</item>
|
||
|
+ <item>10 minutes</item>
|
||
|
+ <item>30 minutes</item>
|
||
|
+ <item>1 hour</item>
|
||
|
+ <item>2 hours</item>
|
||
|
+ <item>4 hours</item>
|
||
|
+ <item>8 hours</item>
|
||
|
+ <item>12 hours</item>
|
||
|
+ <item>24 hours</item>
|
||
|
+ <item>36 hours</item>
|
||
|
+ <item>48 hours</item>
|
||
|
+ <item>72 hours</item>
|
||
|
+ </string-array>
|
||
|
+
|
||
|
+ <string-array name="auto_reboot_values" translatable="false">
|
||
|
+ <item>0</item> <!-- Disabled -->
|
||
|
+ <item>600000</item>
|
||
|
+ <item>1800000</item>
|
||
|
+ <item>3600000</item>
|
||
|
+ <item>7200000</item>
|
||
|
+ <item>14400000</item>
|
||
|
+ <item>28800000</item>
|
||
|
+ <item>43200000</item>
|
||
|
+ <item>86400000</item>
|
||
|
+ <item>129600000</item>
|
||
|
+ <item>172800000</item>
|
||
|
+ <item>259200000</item>
|
||
|
+ </string-array>
|
||
|
+
|
||
|
<!-- Wi-Fi settings -->
|
||
|
|
||
|
<!-- Match this with the order of NetworkInfo.DetailedState. --> <skip />
|
||
|
diff --git a/res/values/strings.xml b/res/values/strings.xml
|
||
|
index 8fcbcbf6b49..9713adcc767 100644
|
||
|
--- a/res/values/strings.xml
|
||
|
+++ b/res/values/strings.xml
|
||
|
@@ -627,6 +627,9 @@
|
||
|
<!-- Text shown for title of owner info setting [CHAR LIMIT=30]-->
|
||
|
<string name="owner_info_settings_title">Add text on lock screen</string>
|
||
|
|
||
|
+ <string name="auto_reboot_title">Auto reboot</string>
|
||
|
+ <string name="auto_reboot_summary">Automatically reboot the device, if the phone hasn\'t been unlocked within the selected number of hours.</string>
|
||
|
+
|
||
|
<!-- Text shown for summary of owner info setting (if none set) [CHAR LIMIT=40]-->
|
||
|
<string name="owner_info_settings_summary">None</string>
|
||
|
<!-- Hint text shown in owner info edit text [CHAR LIMIT=50] -->
|
||
|
diff --git a/res/xml/security_dashboard_settings.xml b/res/xml/security_dashboard_settings.xml
|
||
|
index 0550441d3f2..d0aeb27fe53 100644
|
||
|
--- a/res/xml/security_dashboard_settings.xml
|
||
|
+++ b/res/xml/security_dashboard_settings.xml
|
||
|
@@ -60,6 +60,14 @@
|
||
|
android:title="@string/security_settings_biometric_preference_title"
|
||
|
android:summary="@string/summary_placeholder"
|
||
|
settings:keywords="@string/keywords_biometric_settings" />
|
||
|
+
|
||
|
+ <ListPreference
|
||
|
+ android:key="auto_reboot"
|
||
|
+ android:title="@string/auto_reboot_title"
|
||
|
+ android:summary="@string/auto_reboot_summary"
|
||
|
+ android:persistent="false"
|
||
|
+ android:entries="@array/auto_reboot_entries"
|
||
|
+ android:entryValues="@array/auto_reboot_values" />
|
||
|
</PreferenceCategory>
|
||
|
|
||
|
<Preference
|
||
|
@@ -71,4 +79,4 @@
|
||
|
settings:controller="com.android.settings.security.SecurityAdvancedSettingsController"
|
||
|
settings:keywords="@string/security_advanced_settings_keywords" />
|
||
|
|
||
|
-</PreferenceScreen>
|
||
|
\ No newline at end of file
|
||
|
+</PreferenceScreen>
|
||
|
diff --git a/src/com/android/settings/security/AutoRebootPreferenceController.java b/src/com/android/settings/security/AutoRebootPreferenceController.java
|
||
|
new file mode 100644
|
||
|
index 00000000000..c7a75219a5e
|
||
|
--- /dev/null
|
||
|
+++ b/src/com/android/settings/security/AutoRebootPreferenceController.java
|
||
|
@@ -0,0 +1,82 @@
|
||
|
+package com.android.settings.security;
|
||
|
+
|
||
|
+import android.content.Context;
|
||
|
+import android.os.UserManager;
|
||
|
+import android.provider.Settings;
|
||
|
+import android.util.Log;
|
||
|
+
|
||
|
+import androidx.preference.ListPreference;
|
||
|
+import androidx.preference.Preference;
|
||
|
+import androidx.preference.PreferenceCategory;
|
||
|
+import androidx.preference.PreferenceScreen;
|
||
|
+
|
||
|
+import com.android.settings.core.PreferenceControllerMixin;
|
||
|
+import com.android.settingslib.core.AbstractPreferenceController;
|
||
|
+import com.android.settingslib.core.lifecycle.events.OnResume;
|
||
|
+
|
||
|
+public class AutoRebootPreferenceController extends AbstractPreferenceController
|
||
|
+ implements PreferenceControllerMixin, OnResume,
|
||
|
+ Preference.OnPreferenceChangeListener {
|
||
|
+
|
||
|
+ private static final String KEY_AUTO_REBOOT = "auto_reboot";
|
||
|
+ private static final String PREF_KEY_SECURITY_CATEGORY = "security_category";
|
||
|
+
|
||
|
+ private PreferenceCategory mSecurityCategory;
|
||
|
+ private boolean mIsAdmin;
|
||
|
+ private final UserManager mUm;
|
||
|
+
|
||
|
+ public AutoRebootPreferenceController(Context context) {
|
||
|
+ super(context);
|
||
|
+ mUm = UserManager.get(context);
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public void displayPreference(PreferenceScreen screen) {
|
||
|
+ super.displayPreference(screen);
|
||
|
+ mSecurityCategory = screen.findPreference(PREF_KEY_SECURITY_CATEGORY);
|
||
|
+ updatePreferenceState();
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public boolean isAvailable() {
|
||
|
+ mIsAdmin = mUm.isAdminUser();
|
||
|
+ return mIsAdmin;
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public String getPreferenceKey() {
|
||
|
+ return KEY_AUTO_REBOOT;
|
||
|
+ }
|
||
|
+
|
||
|
+ // TODO: should we use onCreatePreferences() instead?
|
||
|
+ private void updatePreferenceState() {
|
||
|
+ if (mSecurityCategory == null) {
|
||
|
+ return;
|
||
|
+ }
|
||
|
+
|
||
|
+ if (mIsAdmin) {
|
||
|
+ ListPreference autoReboot =
|
||
|
+ (ListPreference) mSecurityCategory.findPreference(KEY_AUTO_REBOOT);
|
||
|
+ autoReboot.setValue(Long.toString(Settings.Global.getLong(
|
||
|
+ mContext.getContentResolver(), Settings.Global.SETTINGS_REBOOT_AFTER_TIMEOUT, 0)));
|
||
|
+ } else {
|
||
|
+ mSecurityCategory.removePreference(
|
||
|
+ mSecurityCategory.findPreference(KEY_AUTO_REBOOT));
|
||
|
+ }
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public void onResume() {
|
||
|
+ updatePreferenceState();
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public boolean onPreferenceChange(Preference preference, Object value) {
|
||
|
+ final String key = preference.getKey();
|
||
|
+ if (KEY_AUTO_REBOOT.equals(key) && mIsAdmin) {
|
||
|
+ long timeout = Long.parseLong((String) value);
|
||
|
+ Settings.Global.putLong(mContext.getContentResolver(), Settings.Global.SETTINGS_REBOOT_AFTER_TIMEOUT, timeout);
|
||
|
+ }
|
||
|
+ return true;
|
||
|
+ }
|
||
|
+}
|
||
|
diff --git a/src/com/android/settings/security/SecuritySettings.java b/src/com/android/settings/security/SecuritySettings.java
|
||
|
index 6d987f34c1f..7aaa1b1e58f 100644
|
||
|
--- a/src/com/android/settings/security/SecuritySettings.java
|
||
|
+++ b/src/com/android/settings/security/SecuritySettings.java
|
||
|
@@ -105,6 +105,7 @@ public class SecuritySettings extends DashboardFragment {
|
||
|
securityPreferenceControllers.add(new CombinedBiometricStatusPreferenceController(
|
||
|
context, lifecycle));
|
||
|
securityPreferenceControllers.add(new ChangeScreenLockPreferenceController(context, host));
|
||
|
+ securityPreferenceControllers.add(new AutoRebootPreferenceController(context));
|
||
|
controllers.add(new PreferenceCategoryController(context, SECURITY_CATEGORY)
|
||
|
.setChildren(securityPreferenceControllers));
|
||
|
controllers.addAll(securityPreferenceControllers);
|