From 817cdf711380bb80981524ae99605bdb23ebec3b Mon Sep 17 00:00:00 2001 From: vvb2060 Date: Tue, 29 Jan 2019 04:41:51 +0800 Subject: [PATCH] fix multiuser owner_managed mode --- .../com/topjohnwu/magisk/model/entity/MagiskPolicy.kt | 6 +++--- native/jni/su/connect.cpp | 8 ++------ 2 files changed, 5 insertions(+), 9 deletions(-) diff --git a/app/src/main/java/com/topjohnwu/magisk/model/entity/MagiskPolicy.kt b/app/src/main/java/com/topjohnwu/magisk/model/entity/MagiskPolicy.kt index cf803c7b7..01bdfcb11 100644 --- a/app/src/main/java/com/topjohnwu/magisk/model/entity/MagiskPolicy.kt +++ b/app/src/main/java/com/topjohnwu/magisk/model/entity/MagiskPolicy.kt @@ -38,7 +38,7 @@ fun MagiskPolicy.toMap() = mapOf( fun Map.toPolicy(pm: PackageManager): MagiskPolicy { val uid = get("uid")?.toIntOrNull() ?: -1 val packageName = get("package_name").orEmpty() - val info = pm.getApplicationInfo(packageName, 0) + val info = pm.getApplicationInfo(packageName, PackageManager.GET_UNINSTALLED_PACKAGES) if (info.uid != uid) throw PackageManager.NameNotFoundException() @@ -59,9 +59,9 @@ fun Map.toPolicy(pm: PackageManager): MagiskPolicy { fun Int.toPolicy(pm: PackageManager, policy: Int = INTERACTIVE): MagiskPolicy { val pkg = pm.getPackagesForUid(this)?.firstOrNull() ?: throw PackageManager.NameNotFoundException() - val info = pm.getApplicationInfo(pkg, 0) + val info = pm.getApplicationInfo(pkg, PackageManager.GET_UNINSTALLED_PACKAGES) return MagiskPolicy( - uid = this, + uid = info.uid, packageName = pkg, policy = policy, applicationInfo = info, diff --git a/native/jni/su/connect.cpp b/native/jni/su/connect.cpp index f2f91b564..6b0ca720e 100644 --- a/native/jni/su/connect.cpp +++ b/native/jni/su/connect.cpp @@ -34,10 +34,6 @@ enum { (info->cfg[SU_MULTIUSER_MODE] == MULTIUSER_MODE_USER \ ? info->uid / 100000 : 0) -#define get_uid(info) \ -(info->cfg[SU_MULTIUSER_MODE] == MULTIUSER_MODE_OWNER_MANAGED \ -? info->uid % 100000 : info->uid) - #define get_cmd(to) \ (to.command[0] ? to.command : to.shell[0] ? to.shell : DEFAULT_SHELL) @@ -165,7 +161,7 @@ void app_log(const su_context &ctx) { if (fork_dont_care() == 0) { vector extras; extras.reserve(6); - extras.emplace_back("from.uid", get_uid(ctx.info)); + extras.emplace_back("from.uid", ctx.info->uid); extras.emplace_back("to.uid", ctx.req.uid); extras.emplace_back("pid", ctx.pid); extras.emplace_back("policy", ctx.info->access.policy); @@ -181,7 +177,7 @@ void app_notify(const su_context &ctx) { if (fork_dont_care() == 0) { vector extras; extras.reserve(2); - extras.emplace_back("from.uid", get_uid(ctx.info)); + extras.emplace_back("from.uid", ctx.info->uid); extras.emplace_back("policy", ctx.info->access.policy); exec_cmd("notify", extras, ctx.info);