From 2a7d99688167104a3f31be814798a268a6b1bcb8 Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Sat, 27 May 2017 02:41:24 +0800 Subject: [PATCH] Add multiuser support --- .../com/topjohnwu/magisk/AboutActivity.java | 2 - .../com/topjohnwu/magisk/MagiskManager.java | 30 +++++--- .../topjohnwu/magisk/SettingsActivity.java | 73 +++++++++---------- .../magisk/services/BootupIntentService.java | 20 ++--- app/src/main/res/values/arrays.xml | 12 +++ app/src/main/res/values/strings.xml | 8 ++ app/src/main/res/xml/app_settings.xml | 13 ++-- 7 files changed, 84 insertions(+), 74 deletions(-) diff --git a/app/src/main/java/com/topjohnwu/magisk/AboutActivity.java b/app/src/main/java/com/topjohnwu/magisk/AboutActivity.java index 104628119..ee744f3ca 100644 --- a/app/src/main/java/com/topjohnwu/magisk/AboutActivity.java +++ b/app/src/main/java/com/topjohnwu/magisk/AboutActivity.java @@ -3,7 +3,6 @@ package com.topjohnwu.magisk; import android.content.Intent; import android.net.Uri; import android.os.Bundle; -import android.preference.PreferenceManager; import android.support.annotation.Nullable; import android.support.v7.app.ActionBar; import android.support.v7.app.AlertDialog; @@ -18,7 +17,6 @@ import android.widget.TextView; import com.topjohnwu.magisk.components.AboutCardRow; import com.topjohnwu.magisk.components.Activity; import com.topjohnwu.magisk.components.AlertDialogBuilder; -import com.topjohnwu.magisk.utils.Logger; import java.io.IOException; import java.io.InputStream; diff --git a/app/src/main/java/com/topjohnwu/magisk/MagiskManager.java b/app/src/main/java/com/topjohnwu/magisk/MagiskManager.java index 5726e0735..b5cf1a063 100644 --- a/app/src/main/java/com/topjohnwu/magisk/MagiskManager.java +++ b/app/src/main/java/com/topjohnwu/magisk/MagiskManager.java @@ -30,6 +30,10 @@ public class MagiskManager extends Application { public static final String UNINSTALLER = "magisk_uninstaller.sh"; public static final String INTENT_SECTION = "section"; public static final String BUSYBOX_VERSION = "1.26.2"; + public static final String ROOT_ACCESS_PROP = "persist.magisk.root"; + public static final String MULTIUSER_MODE_PROP = "persist.magisk.multiuser"; + public static final String MAGISKHIDE_PROP = "persist.magisk.hide"; + public static final String DISABLE_INDICATION_PROP = "ro.magisk.disable"; // Events public final CallbackEvent blockDetectionDone = new CallbackEvent<>(); @@ -53,7 +57,6 @@ public class MagiskManager extends Application { public boolean isSuClient = false; public String suVersion = null; public boolean disabled; - public boolean magiskHideStarted; // Data public ValueSortedMap repoMap; @@ -72,6 +75,7 @@ public class MagiskManager extends Application { public int suRequestTimeout; public int suLogTimeout = 14; public int suAccessState; + public int multiuserMode; public int suResponseType; public int suNotificationType; @@ -130,6 +134,7 @@ public class MagiskManager extends Application { .putString("su_auto_response", String.valueOf(suResponseType)) .putString("su_notification", String.valueOf(suNotificationType)) .putString("su_access", String.valueOf(suAccessState)) + .putString("multiuser_mode", String.valueOf(multiuserMode)) .putString("busybox_version", BUSYBOX_VERSION) .apply(); // Add busybox to PATH @@ -149,12 +154,17 @@ public class MagiskManager extends Application { isSuClient = suVersion.toUpperCase().contains("MAGISK"); } if (isSuClient) { - ret = Shell.sh("getprop persist.sys.root_access"); + ret = Shell.sh("getprop " + ROOT_ACCESS_PROP); if (Utils.isValidShellResponse(ret)) { suAccessState = Integer.parseInt(ret.get(0)); } else { - Shell.su(true, "setprop persist.sys.root_access 3"); - suAccessState = 3; + suAccessState = 0; + } + ret = Shell.sh("getprop " + MULTIUSER_MODE_PROP); + if (Utils.isValidShellResponse(ret)) { + multiuserMode = Integer.parseInt(ret.get(0)); + } else { + multiuserMode = 0; } } } @@ -177,21 +187,17 @@ public class MagiskManager extends Application { magiskVersionCode = Integer.parseInt(ret.get(0)); } catch (NumberFormatException ignored) {} } - ret = Shell.sh("getprop ro.magisk.disable"); + ret = Shell.sh("getprop " + DISABLE_INDICATION_PROP); try { disabled = Utils.isValidShellResponse(ret) && Integer.parseInt(ret.get(0)) != 0; } catch (NumberFormatException e) { disabled = false; } - ret = Shell.sh("getprop persist.magisk.hide"); + ret = Shell.sh("getprop " + MAGISKHIDE_PROP); try { - magiskHideStarted = Utils.isValidShellResponse(ret) && Integer.parseInt(ret.get(0)) != 0; + magiskHide = Utils.isValidShellResponse(ret) && Integer.parseInt(ret.get(0)) != 0; } catch (NumberFormatException e) { - magiskHideStarted = false; - } - - if (magiskHideStarted) { - magiskHide = true; + magiskHide = false; } } diff --git a/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java b/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java index 79581dced..36ac81c56 100644 --- a/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java +++ b/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java @@ -60,11 +60,8 @@ public class SettingsActivity extends Activity { private SharedPreferences prefs; private PreferenceScreen prefScreen; - private ListPreference suAccess, autoRes, suNotification, requestTimeout; - - private MagiskManager getApplication() { - return Utils.getMagiskManager(getActivity()); - } + private ListPreference suAccess, autoRes, suNotification, requestTimeout, multiuserMode; + private MagiskManager magiskManager; @Override public void onCreate(Bundle savedInstanceState) { @@ -72,6 +69,7 @@ public class SettingsActivity extends Activity { addPreferencesFromResource(R.xml.app_settings); prefs = PreferenceManager.getDefaultSharedPreferences(getActivity()); prefScreen = getPreferenceScreen(); + magiskManager = Utils.getMagiskManager(getActivity()); PreferenceCategory magiskCategory = (PreferenceCategory) findPreference("magisk"); PreferenceCategory suCategory = (PreferenceCategory) findPreference("superuser"); @@ -81,6 +79,7 @@ public class SettingsActivity extends Activity { autoRes = (ListPreference) findPreference("su_auto_response"); requestTimeout = (ListPreference) findPreference("su_request_timeout"); suNotification = (ListPreference) findPreference("su_notification"); + multiuserMode = (ListPreference) findPreference("multiuser_mode"); setSummary(); @@ -97,10 +96,10 @@ public class SettingsActivity extends Activity { prefScreen.removePreference(magiskCategory); prefScreen.removePreference(suCategory); } else { - if (!getApplication().isSuClient) { + if (!magiskManager.isSuClient) { prefScreen.removePreference(suCategory); } - if (getApplication().magiskVersionCode < 130) { + if (magiskManager.magiskVersionCode < 130) { prefScreen.removePreference(magiskCategory); } } @@ -126,9 +125,9 @@ public class SettingsActivity extends Activity { switch (key) { case "dark_theme": enabled = prefs.getBoolean("dark_theme", false); - if (getApplication().isDarkTheme != enabled) { - getApplication().isDarkTheme = enabled; - getApplication().reloadMainActivity.trigger(); + if (magiskManager.isDarkTheme != enabled) { + magiskManager.isDarkTheme = enabled; + magiskManager.reloadMainActivity.trigger(); getActivity().recreate(); } break; @@ -148,29 +147,10 @@ public class SettingsActivity extends Activity { }.exec(); Toast.makeText(getActivity(), R.string.settings_reboot_toast, Toast.LENGTH_LONG).show(); break; - case "busybox": - enabled = prefs.getBoolean("busybox", false); - new SerialTask() { - private boolean enable = enabled; - @Override - protected Void doInBackground(Void... voids) { - if (enable) { - Shell.su( - "setprop persist.magisk.busybox 1", - "sh /sbin/magic_mask.sh mount_busybox"); - } else { - Shell.su( - "setprop persist.magisk.busybox 0", - "umount /system/xbin"); - } - return null; - } - }.exec(); - break; case "magiskhide": enabled = prefs.getBoolean("magiskhide", false); if (enabled) { - if (!getApplication().isSuClient) { + if (!magiskManager.isSuClient) { new AlertDialogBuilder(getActivity()) .setTitle(R.string.no_magisksu_title) .setMessage(R.string.no_magisksu_msg) @@ -202,17 +182,32 @@ public class SettingsActivity extends Activity { }.exec(); break; case "su_access": - getApplication().suAccessState = Utils.getPrefsInt(prefs, "su_access", 0); - Shell.su("setprop persist.sys.root_access " + getApplication().suAccessState); + magiskManager.suAccessState = Utils.getPrefsInt(prefs, "su_access", 0); + new SerialTask(getActivity()) { + @Override + protected Void doInBackground(Void... params) { + Shell.su("setprop " + MagiskManager.ROOT_ACCESS_PROP + " " + magiskManager.suAccessState); + return null; + } + }.exec(); break; + case "multiuser_mode": + magiskManager.multiuserMode = Utils.getPrefsInt(prefs, "multiuser_mode", 0); + new SerialTask(getActivity()) { + @Override + protected Void doInBackground(Void... params) { + Shell.su("setprop " + MagiskManager.MULTIUSER_MODE_PROP + " " + magiskManager.multiuserMode); + return null; + } + }.exec(); case "su_request_timeout": - getApplication().suRequestTimeout = Utils.getPrefsInt(prefs, "su_request_timeout", 10); + magiskManager.suRequestTimeout = Utils.getPrefsInt(prefs, "su_request_timeout", 10); break; case "su_auto_response": - getApplication().suResponseType = Utils.getPrefsInt(prefs, "su_auto_response", 0); + magiskManager.suResponseType = Utils.getPrefsInt(prefs, "su_auto_response", 0); break; case "su_notification": - getApplication().suNotificationType = Utils.getPrefsInt(prefs, "su_notification", 1); + magiskManager.suNotificationType = Utils.getPrefsInt(prefs, "su_notification", 1); break; case "developer_logging": MagiskManager.devLogging = prefs.getBoolean("developer_logging", false); @@ -226,13 +221,15 @@ public class SettingsActivity extends Activity { private void setSummary() { suAccess.setSummary(getResources() - .getStringArray(R.array.su_access)[getApplication().suAccessState]); + .getStringArray(R.array.su_access)[magiskManager.suAccessState]); autoRes.setSummary(getResources() - .getStringArray(R.array.auto_response)[getApplication().suResponseType]); + .getStringArray(R.array.auto_response)[magiskManager.suResponseType]); suNotification.setSummary(getResources() - .getStringArray(R.array.su_notification)[getApplication().suNotificationType]); + .getStringArray(R.array.su_notification)[magiskManager.suNotificationType]); requestTimeout.setSummary( getString(R.string.request_timeout_summary, prefs.getString("su_request_timeout", "10"))); + multiuserMode.setSummary(getResources() + .getStringArray(R.array.multiuser_summary)[magiskManager.multiuserMode]); } } diff --git a/app/src/main/java/com/topjohnwu/magisk/services/BootupIntentService.java b/app/src/main/java/com/topjohnwu/magisk/services/BootupIntentService.java index de1f72c5b..06aa1c1a3 100644 --- a/app/src/main/java/com/topjohnwu/magisk/services/BootupIntentService.java +++ b/app/src/main/java/com/topjohnwu/magisk/services/BootupIntentService.java @@ -2,12 +2,6 @@ package com.topjohnwu.magisk.services; import android.app.IntentService; import android.content.Intent; -import android.widget.Toast; - -import com.topjohnwu.magisk.MagiskManager; -import com.topjohnwu.magisk.R; -import com.topjohnwu.magisk.utils.Shell; -import com.topjohnwu.magisk.utils.Utils; public class BootupIntentService extends IntentService { @@ -17,14 +11,10 @@ public class BootupIntentService extends IntentService { @Override protected void onHandleIntent(Intent intent) { - MagiskManager magiskManager = Utils.getMagiskManager(this); - magiskManager.initSuAccess(); - magiskManager.updateMagiskInfo(); - if (magiskManager.prefs.getBoolean("magiskhide", false) && - !magiskManager.disabled && !magiskManager.magiskHideStarted && magiskManager.magiskVersionCode >= 130) { - magiskManager.toast(R.string.start_magiskhide, Toast.LENGTH_LONG); - Shell.su(true, MagiskManager.MAGISK_HIDE_PATH + "enable", - "setprop persist.magisk.hide 1"); - } + /* Currently no bootup task to do + MagiskManager magiskManager = Utils.getMagiskManager(this); + magiskManager.initSuAccess(); + magiskManager.updateMagiskInfo(); + */ } } diff --git a/app/src/main/res/values/arrays.xml b/app/src/main/res/values/arrays.xml index 74bf942de..51092a10a 100644 --- a/app/src/main/res/values/arrays.xml +++ b/app/src/main/res/values/arrays.xml @@ -49,4 +49,16 @@ @string/toast + + @string/settings_owner_only + @string/settings_owner_manage + @string/settings_user_independent + + + + @string/owner_only_summary + @string/owner_manage_summary + @string/user_indepenent_summary + + \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 8d4e3349a..365bad46b 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -201,4 +201,12 @@ Target UID:\u0020 Command:\u0020 + Multiuser Mode + Device Owner Only + Device Owner Managed + User Independent + Only owner has root access + Only owner can manage root access and receive request prompts + Each user has its own separate root rules + diff --git a/app/src/main/res/xml/app_settings.xml b/app/src/main/res/xml/app_settings.xml index d5ffc6f54..bfc8e395c 100644 --- a/app/src/main/res/xml/app_settings.xml +++ b/app/src/main/res/xml/app_settings.xml @@ -31,13 +31,6 @@ android:title="@string/settings_core_only_title" android:summary="@string/settings_core_only_summary" /> - - - - - - - + +