mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-10 12:59:40 +01:00
Ported: Fix directory access when the running app has the All files access permission
- m4gr3d
e2c7d3e6c0
This commit is contained in:
parent
464b0b5e08
commit
76f9237411
@ -66,7 +66,7 @@ internal enum class StorageScope {
|
|||||||
/**
|
/**
|
||||||
* Determines which [StorageScope] the given path falls under.
|
* Determines which [StorageScope] the given path falls under.
|
||||||
*/
|
*/
|
||||||
fun identifyStorageScope(path: String?): StorageScope {
|
fun identifyStorageScope(path: String?): StorageScope {
|
||||||
if (path == null) {
|
if (path == null) {
|
||||||
return UNKNOWN
|
return UNKNOWN
|
||||||
}
|
}
|
||||||
@ -76,31 +76,42 @@ internal enum class StorageScope {
|
|||||||
return UNKNOWN
|
return UNKNOWN
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If we have 'All Files Access' permission, we can access all directories without
|
||||||
|
// restriction.
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R && Environment.isExternalStorageManager()) {
|
||||||
|
return APP
|
||||||
|
}
|
||||||
|
|
||||||
val canonicalPathFile = pathFile.canonicalPath
|
val canonicalPathFile = pathFile.canonicalPath
|
||||||
|
|
||||||
if (internalAppDir != null && canonicalPathFile.startsWith(internalAppDir)) {
|
if (internalAppDir != null && canonicalPathFile.startsWith(internalAppDir)) {
|
||||||
return APP
|
return APP
|
||||||
}
|
}
|
||||||
|
|
||||||
if (internalCacheDir != null && canonicalPathFile.startsWith(internalCacheDir)) {
|
if (internalCacheDir != null && canonicalPathFile.startsWith(internalCacheDir)) {
|
||||||
return APP
|
return APP
|
||||||
}
|
}
|
||||||
|
|
||||||
if (externalAppDir != null && canonicalPathFile.startsWith(externalAppDir)) {
|
if (externalAppDir != null && canonicalPathFile.startsWith(externalAppDir)) {
|
||||||
return APP
|
return APP
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sharedDir != null && canonicalPathFile.startsWith(sharedDir)) {
|
val rootDir: String? = System.getenv("ANDROID_ROOT")
|
||||||
|
if (rootDir != null && canonicalPathFile.startsWith(rootDir)) {
|
||||||
|
return APP
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sharedDir != null && canonicalPathFile.startsWith(sharedDir)) {
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
|
||||||
// Before R, apps had access to shared storage so long as they have the right
|
// Before R, apps had access to shared storage so long as they have the right
|
||||||
// permissions (and flag on Q).
|
// permissions (and flag on Q).
|
||||||
return APP
|
return APP
|
||||||
}
|
}
|
||||||
|
|
||||||
// Post R, access is limited based on the target destination
|
// Post R, access is limited based on the target destination
|
||||||
// 'Downloads' and 'Documents' are still accessible
|
// 'Downloads' and 'Documents' are still accessible
|
||||||
if ((downloadsSharedDir != null && canonicalPathFile.startsWith(downloadsSharedDir))
|
if ((downloadsSharedDir != null && canonicalPathFile.startsWith(downloadsSharedDir))
|
||||||
|| (documentsSharedDir != null && canonicalPathFile.startsWith(documentsSharedDir))) {
|
|| (documentsSharedDir != null && canonicalPathFile.startsWith(documentsSharedDir))) {
|
||||||
return APP
|
return APP
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user