From db9f0ec6ff79771c185b1f00b862956629af44b0 Mon Sep 17 00:00:00 2001 From: Alex Ryltsov Date: Thu, 7 Mar 2024 15:21:11 +0200 Subject: [PATCH] bugfix: Camera plugin allows to access the photo gallery and pick the photo(s) even if the user has not granted the required permission For details please see https://github.com/ionic-team/capacitor/issues/7320 --- .../plugins/camera/CameraPlugin.java | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/camera/android/src/main/java/com/capacitorjs/plugins/camera/CameraPlugin.java b/camera/android/src/main/java/com/capacitorjs/plugins/camera/CameraPlugin.java index 754e76720..f358088ed 100644 --- a/camera/android/src/main/java/com/capacitorjs/plugins/camera/CameraPlugin.java +++ b/camera/android/src/main/java/com/capacitorjs/plugins/camera/CameraPlugin.java @@ -241,7 +241,24 @@ private boolean checkPhotosPermissions(PluginCall call) { @PermissionCallback private void cameraPermissionsCallback(PluginCall call) { if (call.getMethodName().equals("pickImages")) { - openPhotos(call, true, true); + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) { + if (getPermissionState(PHOTOS) != PermissionState.GRANTED) { + Logger.debug(getLogTag(), "User denied photos permission: " + getPermissionState(PHOTOS).toString()); + call.reject(PERMISSION_DENIED_ERROR_PHOTOS); + return; + } + } else if (Build.VERSION.SDK_INT < Build.VERSION_CODES.TIRAMISU) { + if (getPermissionState(READ_EXTERNAL_STORAGE) != PermissionState.GRANTED) { + Logger.debug(getLogTag(), "User denied photos permission: " + getPermissionState(READ_EXTERNAL_STORAGE).toString()); + call.reject(PERMISSION_DENIED_ERROR_PHOTOS); + return; + } + } else if (getPermissionState(MEDIA) != PermissionState.GRANTED) { + Logger.debug(getLogTag(), "User denied photos permission: " + getPermissionState(MEDIA).toString()); + call.reject(PERMISSION_DENIED_ERROR_PHOTOS); + return; + } + openPhotos(call, true, true); } else { if (settings.getSource() == CameraSource.CAMERA && getPermissionState(CAMERA) != PermissionState.GRANTED) { Logger.debug(getLogTag(), "User denied camera permission: " + getPermissionState(CAMERA).toString());