From bf1f941e507c11a4cca2562f8eff6fa9c2dc03c3 Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Sat, 1 Jul 2017 18:06:23 +0800 Subject: [PATCH] Adapt to Android O new broadcast limitations --- app/src/main/AndroidManifest.xml | 4 ++-- .../topjohnwu/magisk/SettingsActivity.java | 8 +++++++ .../magisk/receivers/PackageReceiver.java | 24 ++++++++++--------- 3 files changed, 23 insertions(+), 13 deletions(-) diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 989feed5a..7195b27f4 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -62,8 +62,8 @@ - - + + diff --git a/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java b/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java index b14ff70c6..c7ce9aef4 100644 --- a/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java +++ b/app/src/main/java/com/topjohnwu/magisk/SettingsActivity.java @@ -1,12 +1,14 @@ package com.topjohnwu.magisk; import android.content.SharedPreferences; +import android.os.Build; import android.os.Bundle; import android.preference.ListPreference; import android.preference.PreferenceCategory; import android.preference.PreferenceFragment; import android.preference.PreferenceManager; import android.preference.PreferenceScreen; +import android.preference.SwitchPreference; import android.support.v7.app.ActionBar; import android.support.v7.widget.Toolbar; import android.widget.Toast; @@ -81,6 +83,7 @@ public class SettingsActivity extends Activity { suNotification = (ListPreference) findPreference("su_notification"); multiuserMode = (ListPreference) findPreference("multiuser_mode"); namespaceMode = (ListPreference) findPreference("mnt_ns"); + SwitchPreference reauth = (SwitchPreference) findPreference("su_reauth"); setSummary(); @@ -90,6 +93,11 @@ public class SettingsActivity extends Activity { prefScreen.removePreference(suCategory); } + // Remove re-authentication option on Android O, it will not work + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + suCategory.removePreference(reauth); + } + findPreference("clear").setOnPreferenceClickListener((pref) -> { Utils.clearRepoCache(getActivity()); return true; diff --git a/app/src/main/java/com/topjohnwu/magisk/receivers/PackageReceiver.java b/app/src/main/java/com/topjohnwu/magisk/receivers/PackageReceiver.java index 3711b2730..b9501db43 100644 --- a/app/src/main/java/com/topjohnwu/magisk/receivers/PackageReceiver.java +++ b/app/src/main/java/com/topjohnwu/magisk/receivers/PackageReceiver.java @@ -20,20 +20,22 @@ public class PackageReceiver extends BroadcastReceiver { return; switch (intent.getAction()) { - case Intent.ACTION_PACKAGE_ADDED: - int uid = intent.getIntExtra(Intent.EXTRA_UID, -1); - // Update the UID if available - if (uid > 0) { - policy.uid = uid % 100000; - } - magiskManager.suDB.updatePolicy(policy); - return; - case Intent.ACTION_PACKAGE_REMOVED: - boolean isUpdate = intent.getBooleanExtra(Intent.EXTRA_REPLACING, false); - if (!isUpdate || magiskManager.suReauth) { + case Intent.ACTION_PACKAGE_REPLACED: + // This will only work pre-O + if (magiskManager.suReauth) { magiskManager.suDB.deletePolicy(policy); + } else { + int uid = intent.getIntExtra(Intent.EXTRA_UID, -1); + // Update the UID if available + if (uid > 0) { + policy.uid = uid % 100000; + } + magiskManager.suDB.updatePolicy(policy); } break; + case Intent.ACTION_PACKAGE_FULLY_REMOVED: + magiskManager.suDB.deletePolicy(policy); + break; } } }