mirror of
				https://github.com/topjohnwu/Magisk.git
				synced 2025-10-25 11:38:51 +00:00 
			
		
		
		
	Optimize logging in Magisk Manager
This commit is contained in:
		| @@ -19,6 +19,7 @@ public class SuLogEntry { | ||||
|         fromUid = policy.uid; | ||||
|         packageName = policy.packageName; | ||||
|         appName = policy.appName; | ||||
|         action = policy.policy == Policy.ALLOW; | ||||
|     } | ||||
|  | ||||
|     public SuLogEntry(ContentValues values) { | ||||
|   | ||||
| @@ -14,8 +14,13 @@ public class BootReceiver extends BroadcastReceiver { | ||||
|  | ||||
|     @Override | ||||
|     public void onReceive(Context context, Intent intent) { | ||||
|         if (intent == null) | ||||
|             return; | ||||
|         if (TextUtils.equals(intent.getAction(), Intent.ACTION_BOOT_COMPLETED)) { | ||||
|             switch (intent.getExtras().getString("action", "boot")) { | ||||
|             String action = intent.getStringExtra("action"); | ||||
|             if (action == null) | ||||
|                 action = "boot"; | ||||
|             switch (action) { | ||||
|                 case "request": | ||||
|                     Intent i = new Intent(context, Data.classMap.get(SuRequestActivity.class)) | ||||
|                             .putExtra("socket", intent.getStringExtra("socket")) | ||||
| @@ -26,6 +31,9 @@ public class BootReceiver extends BroadcastReceiver { | ||||
|                 case "log": | ||||
|                     SuConnector.handleLogs(intent, 2); | ||||
|                     break; | ||||
|                 case "notify": | ||||
|                     SuConnector.handleNotify(intent); | ||||
|                     break; | ||||
|                 case "boot": | ||||
|                     OnBootService.enqueueWork(context); | ||||
|                     break; | ||||
|   | ||||
| @@ -10,6 +10,7 @@ public class SuReceiver extends BroadcastReceiver { | ||||
|  | ||||
|     @Override | ||||
|     public void onReceive(Context context, Intent intent) { | ||||
|         SuConnector.handleLogs(intent, 1); | ||||
|         if (intent != null) | ||||
|             SuConnector.handleLogs(intent, 1); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -50,69 +50,87 @@ public abstract class SuConnector { | ||||
|     public abstract void response(); | ||||
|  | ||||
|     public static void handleLogs(Intent intent, int version) { | ||||
|         MagiskManager mm = Data.MM(); | ||||
|  | ||||
|         if (intent == null) return; | ||||
|  | ||||
|         int fromUid = intent.getIntExtra("from.uid", -1); | ||||
|         if (fromUid < 0) return; | ||||
|         if (fromUid == Process.myUid()) return; | ||||
|  | ||||
|         Policy policy = mm.mDB.getPolicy(fromUid); | ||||
|         if (policy == null) { | ||||
|         MagiskManager mm = Data.MM(); | ||||
|         PackageManager pm = mm.getPackageManager(); | ||||
|         Policy policy; | ||||
|  | ||||
|         boolean notify; | ||||
|         Bundle data = intent.getExtras(); | ||||
|         if (data.containsKey("notify")) { | ||||
|             notify = data.getBoolean("notify"); | ||||
|             try { | ||||
|                 policy = new Policy(fromUid, mm.getPackageManager()); | ||||
|                 policy = new Policy(fromUid, pm); | ||||
|             } catch (PackageManager.NameNotFoundException e) { | ||||
|                 e.printStackTrace(); | ||||
|                 return; | ||||
|             } | ||||
|         } else { | ||||
|             // Doesn't report whether notify or not, check database ourselves | ||||
|             policy = mm.mDB.getPolicy(fromUid); | ||||
|             if (policy == null) | ||||
|                 return; | ||||
|             notify = policy.notification; | ||||
|         } | ||||
|  | ||||
|         SuLogEntry log = new SuLogEntry(policy); | ||||
|         if (version == 1) { | ||||
|             String action = intent.getStringExtra("action"); | ||||
|             if (action == null) return; | ||||
|             switch (action) { | ||||
|                 case "allow": | ||||
|                     log.action = true; | ||||
|                     policy.policy = Policy.ALLOW; | ||||
|                     break; | ||||
|                 case "deny": | ||||
|                     log.action = false; | ||||
|                     policy.policy = Policy.DENY; | ||||
|                     break; | ||||
|                 default: | ||||
|                     return; | ||||
|             } | ||||
|         } else { | ||||
|             switch (intent.getIntExtra("policy", -1)) { | ||||
|                 case Policy.ALLOW: | ||||
|                     log.action = true; | ||||
|                     break; | ||||
|                 case Policy.DENY: | ||||
|                     log.action = false; | ||||
|                     break; | ||||
|                 default: | ||||
|                     return; | ||||
|             } | ||||
|             policy.policy = data.getInt("policy", -1); | ||||
|             if (policy.policy < 0) | ||||
|                 return; | ||||
|         } | ||||
|  | ||||
|         String message = mm.getString(log.action ? | ||||
|                 R.string.su_allow_toast : R.string.su_deny_toast, policy.appName); | ||||
|         if (notify) | ||||
|             handleNotify(policy); | ||||
|  | ||||
|         SuLogEntry log = new SuLogEntry(policy); | ||||
|  | ||||
|         int toUid = intent.getIntExtra("to.uid", -1); | ||||
|         if (toUid < 0) return; | ||||
|         int pid = intent.getIntExtra("pid", -1); | ||||
|         if (pid < 0) return; | ||||
|         String command = intent.getStringExtra("command"); | ||||
|         if (command == null) return; | ||||
|         log.toUid = toUid; | ||||
|         log.fromPid = pid; | ||||
|         log.command = command; | ||||
|         log.date = new Date(); | ||||
|         mm.mDB.addLog(log); | ||||
|     } | ||||
|  | ||||
|     private static void handleNotify(Policy policy) { | ||||
|         MagiskManager mm = Data.MM(); | ||||
|         String message = mm.getString(policy.policy == Policy.ALLOW ? | ||||
|                 R.string.su_allow_toast : R.string.su_deny_toast, policy.appName); | ||||
|         if (policy.notification && Data.suNotificationType == Const.Value.NOTIFICATION_TOAST) | ||||
|             Utils.toast(message, Toast.LENGTH_SHORT); | ||||
|     } | ||||
|  | ||||
|         if (policy.logging) { | ||||
|             int toUid = intent.getIntExtra("to.uid", -1); | ||||
|             if (toUid < 0) return; | ||||
|             int pid = intent.getIntExtra("pid", -1); | ||||
|             if (pid < 0) return; | ||||
|             String command = intent.getStringExtra("command"); | ||||
|             if (command == null) return; | ||||
|             log.toUid = toUid; | ||||
|             log.fromPid = pid; | ||||
|             log.command = command; | ||||
|             log.date = new Date(); | ||||
|             mm.mDB.addLog(log); | ||||
|         } | ||||
|     public static void handleNotify(Intent intent) { | ||||
|         MagiskManager mm = Data.MM(); | ||||
|         int fromUid = intent.getIntExtra("from.uid", -1); | ||||
|         if (fromUid < 0) return; | ||||
|         if (fromUid == Process.myUid()) return; | ||||
|         try { | ||||
|             Policy policy = new Policy(fromUid, mm.getPackageManager()); | ||||
|             policy.policy = intent.getIntExtra("policy", -1); | ||||
|             if (policy.policy >= 0) | ||||
|                 handleNotify(policy); | ||||
|         } catch (PackageManager.NameNotFoundException ignored) {} | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 topjohnwu
					topjohnwu