diff options
| author | 2023-07-10 21:44:01 +0000 | |
|---|---|---|
| committer | 2023-07-10 21:44:01 +0000 | |
| commit | fbad94fbdef37e08c8146213370de376bd692ae1 (patch) | |
| tree | 3a4620b59c9f2cb1a4a21b194228270c456390be | |
| parent | 5abd13f53dce7a72d79f84ea21141916704da3c7 (diff) | |
| parent | 63827abeb6efcf457652cf94e89fff23b3831b73 (diff) | |
Merge "Camera: Clear identity before access device policy manager" into main am: 6cc598239e am: 63827abeb6
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/2652179
Change-Id: I4b398800a92462b0d3b192208296d1c77762ac5f
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
| -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); } } }; |