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
c2d73c74
Unverified
Commit
c2d73c74
authored
Jun 25, 2020
by
Maurits van Beusekom
Committed by
GitHub
Jun 25, 2020
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #330 from ened/permissions-check-in-bg
Relands bug fix for permission check in background
parents
2457c78d
46904bfc
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
17 additions
and
17 deletions
+17
-17
permission_handler/CHANGELOG.md
+5
-0
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionConstants.java
+2
-2
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionManager.java
+5
-13
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionUtils.java
+1
-2
permission_handler/lib/permission_handler.dart
+4
-0
No files found.
permission_handler/CHANGELOG.md
View file @
c2d73c74
# next
*
Fixes Typo
*
Issue #233 - on 5.0: Solved a bug that prevented Android applications running in the background to check the permission status.
# 5.0.1
*
Update
`permission_handler_platform_interface 2.0.1`
...
...
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionConstants.java
View file @
c2d73c74
...
...
@@ -63,7 +63,7 @@ final class PermissionConstants {
static
final
int
PERMISSION_STATUS_GRANTED
=
1
;
static
final
int
PERMISSION_STATUS_RESTRICTED
=
2
;
static
final
int
PERMISSION_STATUS_NOT_DETERMINED
=
3
;
static
final
int
PERMISSION_STATUS_NE
W
ER_ASK_AGAIN
=
4
;
static
final
int
PERMISSION_STATUS_NE
V
ER_ASK_AGAIN
=
4
;
@Retention
(
RetentionPolicy
.
SOURCE
)
@IntDef
({
...
...
@@ -71,7 +71,7 @@ final class PermissionConstants {
PERMISSION_STATUS_GRANTED
,
PERMISSION_STATUS_RESTRICTED
,
PERMISSION_STATUS_NOT_DETERMINED
,
PERMISSION_STATUS_NEW
ER_ASK_AGAIN
,
PERMISSION_STATUS_NEV
ER_ASK_AGAIN
,
})
@interface
PermissionStatus
{
}
...
...
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionManager.java
View file @
c2d73c74
...
...
@@ -10,6 +10,7 @@ import android.os.PowerManager;
import
android.provider.Settings
;
import
android.util.Log
;
import
androidx.annotation.Nullable
;
import
androidx.annotation.VisibleForTesting
;
import
androidx.core.app.ActivityCompat
;
import
androidx.core.app.NotificationManagerCompat
;
...
...
@@ -57,14 +58,6 @@ final class PermissionManager {
CheckPermissionsSuccessCallback
successCallback
,
ErrorCallback
errorCallback
)
{
if
(
activity
==
null
)
{
Log
.
d
(
PermissionConstants
.
LOG_TAG
,
"Activity cannot be null."
);
errorCallback
.
onError
(
"PermissionHandler.PermissionManager"
,
"Android activity is required to check for permissions and cannot be null."
);
return
;
}
successCallback
.
onSuccess
(
determinePermissionStatus
(
permission
,
context
,
...
...
@@ -78,7 +71,7 @@ final class PermissionManager {
PermissionRegistry
permissionRegistry
,
RequestPermissionsSuccessCallback
successCallback
,
ErrorCallback
errorCallback
)
{
if
(
ongoing
)
{
if
(
ongoing
)
{
errorCallback
.
onError
(
"PermissionHandler.PermissionManager"
,
"A request for permissions is already running, please wait for it to finish before doing another request (note that you can request multiple permissions at the same time)."
);
...
...
@@ -162,7 +155,7 @@ final class PermissionManager {
private
int
determinePermissionStatus
(
@PermissionConstants
.
PermissionGroup
int
permission
,
Context
context
,
Activity
activity
)
{
@Nullable
Activity
activity
)
{
if
(
permission
==
PermissionConstants
.
PERMISSION_GROUP_NOTIFICATION
)
{
return
checkNotificationPermissionStatus
(
context
);
...
...
@@ -203,12 +196,11 @@ final class PermissionManager {
}
final
int
permissionStatus
=
ContextCompat
.
checkSelfPermission
(
context
,
name
);
if
(
permissionStatus
==
PackageManager
.
PERMISSION_DENIED
)
{
if
(!
PermissionUtils
.
getRequestedPermissionBefore
(
context
,
name
))
{
if
(!
PermissionUtils
.
getRequestedPermissionBefore
(
context
,
name
))
{
return
PermissionConstants
.
PERMISSION_STATUS_NOT_DETERMINED
;
}
else
if
(
Build
.
VERSION
.
SDK_INT
>=
Build
.
VERSION_CODES
.
M
&&
PermissionUtils
.
isNeverAskAgainSelected
(
activity
,
name
))
{
return
PermissionConstants
.
PERMISSION_STATUS_NE
W
ER_ASK_AGAIN
;
return
PermissionConstants
.
PERMISSION_STATUS_NE
V
ER_ASK_AGAIN
;
}
else
{
return
PermissionConstants
.
PERMISSION_STATUS_DENIED
;
}
...
...
permission_handler/android/src/main/java/com/baseflow/permissionhandler/PermissionUtils.java
View file @
c2d73c74
...
...
@@ -11,7 +11,6 @@ import android.util.Log;
import
androidx.annotation.RequiresApi
;
import
androidx.core.app.ActivityCompat
;
import
androidx.core.content.ContextCompat
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
...
...
@@ -241,7 +240,7 @@ public class PermissionUtils {
static
int
toPermissionStatus
(
final
Activity
activity
,
final
String
permissionName
,
int
grantResult
)
{
if
(
grantResult
==
PackageManager
.
PERMISSION_DENIED
)
{
return
Build
.
VERSION
.
SDK_INT
>=
Build
.
VERSION_CODES
.
M
&&
PermissionUtils
.
isNeverAskAgainSelected
(
activity
,
permissionName
)
?
PermissionConstants
.
PERMISSION_STATUS_NE
W
ER_ASK_AGAIN
?
PermissionConstants
.
PERMISSION_STATUS_NE
V
ER_ASK_AGAIN
:
PermissionConstants
.
PERMISSION_STATUS_DENIED
;
}
...
...
permission_handler/lib/permission_handler.dart
View file @
c2d73c74
...
...
@@ -23,6 +23,10 @@ Future<bool> openAppSettings() => _handler.openAppSettings();
/// Actions that can be executed on a permission.
extension
PermissionActions
on
Permission
{
/// The current status of this permission.
///
/// The Android-only [PermissionStatus.permanentlyDenied] status will only be
/// calculated if the active context is an Activity. If it isn't,
/// [PermissionStatus.denied] will be returned.
Future
<
PermissionStatus
>
get
status
=>
_handler
.
checkPermissionStatus
(
this
);
/// If you should show a rationale for requesting permission.
...
...
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