Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
permission_handler
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
songyanzhi
permission_handler
Commits
c655b4ab
Commit
c655b4ab
authored
Mar 22, 2021
by
Maurits van Beusekom
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Correctly handle some permissions on pre Android Q
parent
f8b6809c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
3 deletions
+16
-3
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionUtils.java
+16
-3
No files found.
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionUtils.java
View file @
c655b4ab
...
...
@@ -93,11 +93,14 @@ public class PermissionUtils {
break
;
case
PermissionConstants
.
PERMISSION_GROUP_LOCATION_ALWAYS
:
// Note that the LOCATION_ALWAYS will deliberately fallthrough to the LOCATION
// case on pre Android Q devices. The ACCESS_BACKGROUND_LOCATION permission was only
// introduced in Android Q, before it should be treated as the ACCESS_COARSE_LOCATION or
// ACCESS_FINE_LOCATION.
if
(
Build
.
VERSION
.
SDK_INT
>=
Build
.
VERSION_CODES
.
Q
)
{
if
(
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACCESS_BACKGROUND_LOCATION
))
permissionNames
.
add
(
Manifest
.
permission
.
ACCESS_BACKGROUND_LOCATION
);
}
case
PermissionConstants
.
PERMISSION_GROUP_LOCATION_WHEN_IN_USE
:
case
PermissionConstants
.
PERMISSION_GROUP_LOCATION
:
if
(
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACCESS_COARSE_LOCATION
))
...
...
@@ -184,12 +187,22 @@ public class PermissionUtils {
break
;
case
PermissionConstants
.
PERMISSION_GROUP_ACCESS_MEDIA_LOCATION
:
if
(
Build
.
VERSION
.
SDK_INT
>=
Build
.
VERSION_CODES
.
Q
&&
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACCESS_MEDIA_LOCATION
))
// The ACCESS_MEDIA_LOCATION permission is introduced in Android Q, meaning we should
// not handle permissions on pre Android Q devices.
if
(
Build
.
VERSION
.
SDK_INT
<
Build
.
VERSION_CODES
.
Q
)
return
null
;
if
(
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACCESS_MEDIA_LOCATION
))
permissionNames
.
add
(
Manifest
.
permission
.
ACCESS_MEDIA_LOCATION
);
break
;
case
PermissionConstants
.
PERMISSION_GROUP_ACTIVITY_RECOGNITION
:
if
(
Build
.
VERSION
.
SDK_INT
>=
Build
.
VERSION_CODES
.
Q
&&
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACTIVITY_RECOGNITION
))
// The ACCESS_MEDIA_LOCATION permission is introduced in Android Q, meaning we should
// not handle permissions on pre Android Q devices.
if
(
Build
.
VERSION
.
SDK_INT
<
Build
.
VERSION_CODES
.
Q
)
return
null
;
if
(
hasPermissionInManifest
(
context
,
permissionNames
,
Manifest
.
permission
.
ACTIVITY_RECOGNITION
))
permissionNames
.
add
(
Manifest
.
permission
.
ACTIVITY_RECOGNITION
);
break
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment