diff options
| author | 2023-07-10 20:26:19 +0000 | |
|---|---|---|
| committer | 2023-07-10 20:26:19 +0000 | |
| commit | 6cc598239e7d901f59e98f98fe01a3eb1a3d02ad (patch) | |
| tree | 03568532381824fb8f0137043b727c3a4e9d62b0 | |
| parent | 51bf3fd50340507f4b34d222d0bda90d5d7e0bb5 (diff) | |
| parent | cf72d72cf7bfe49f5a35d6ea3c7bd14b0bbdd055 (diff) | |
Merge "Camera: Clear identity before access device policy manager" into main
| -rw-r--r-- | services/core/java/com/android/server/camera/CameraServiceProxy.java | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/services/core/java/com/android/server/camera/CameraServiceProxy.java b/services/core/java/com/android/server/camera/CameraServiceProxy.java index 5a3a3df180a6..2f354b386821 100644 --- a/services/core/java/com/android/server/camera/CameraServiceProxy.java +++ b/services/core/java/com/android/server/camera/CameraServiceProxy.java @@ -595,16 +595,26 @@ public class CameraServiceProxy extends SystemService @Override public boolean isCameraDisabled(int userId) { - DevicePolicyManager dpm = mContext.getSystemService(DevicePolicyManager.class); - if (dpm == null) { - Slog.e(TAG, "Failed to get the device policy manager service"); + if (Binder.getCallingUid() != Process.CAMERASERVER_UID) { + Slog.e(TAG, "Calling UID: " + Binder.getCallingUid() + + " doesn't match expected camera service UID!"); return false; } + final long ident = Binder.clearCallingIdentity(); try { - return dpm.getCameraDisabled(null, userId); - } catch (Exception e) { - e.printStackTrace(); - return false; + DevicePolicyManager dpm = mContext.getSystemService(DevicePolicyManager.class); + if (dpm == null) { + Slog.e(TAG, "Failed to get the device policy manager service"); + return false; + } + try { + return dpm.getCameraDisabled(null, userId); + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } finally { + Binder.restoreCallingIdentity(ident); } } }; |