From 135ea8b3263a0dd58cd5a83c33fad6f2f6c5b4f6 Mon Sep 17 00:00:00 2001 From: Julia Reynolds Date: Tue, 28 Jun 2016 15:16:21 -0400 Subject: Check caller's uid before allowing notification policy access. Bug: 29421441 Change-Id: I7460268595e932d54660b02007bcd68b95fe8aec --- .../com/android/server/notification/NotificationManagerService.java | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'services') diff --git a/services/core/java/com/android/server/notification/NotificationManagerService.java b/services/core/java/com/android/server/notification/NotificationManagerService.java index 4351798..b922d26 100644 --- a/services/core/java/com/android/server/notification/NotificationManagerService.java +++ b/services/core/java/com/android/server/notification/NotificationManagerService.java @@ -1642,6 +1642,7 @@ public class NotificationManagerService extends SystemService { } private void enforcePolicyAccess(String pkg, String method) { + checkCallerIsSameApp(pkg); if (!checkPolicyAccess(pkg)) { Slog.w(TAG, "Notification policy access denied calling " + method); throw new SecurityException("Notification policy access denied"); @@ -3130,6 +3131,10 @@ public class NotificationManagerService extends SystemService { if (isCallerSystem()) { return; } + checkCallerIsSameApp(pkg); + } + + private static void checkCallerIsSameApp(String pkg) { final int uid = Binder.getCallingUid(); try { ApplicationInfo ai = AppGlobals.getPackageManager().getApplicationInfo( -- cgit v1.1