Open
Description
On Android 11 and above, when the location permission is requested the user can allow the app to access the device location "Only this time". When this option is selected and the app is moved to the background, after a short time (around one minute) the one time session expires and the app is killed. This behavior also occurs when an in-app browser is launched from the main NativeScript activity, which is how I found this issue.
I tested on an Android 11 emulator. The manifest includes ACCESS_COARSE_LOCATION, ACCESS_FINE_LOCATION, ACCESS_BACKGROUND_LOCATION permissions.
These are the device logs:
05-30 17:52:29.386 524 524 I OneTimePermissionUserManager: One time session expired for org.nativescript.temp (10163).
05-30 17:52:29.428 4559 4580 V PermissionControllerServiceImpl: Permission grant result requestId=-2574434414935562278 callingUid=10163 callingPackage=org.nativescript.temp permission=android.permission.ACCESS_FINE_LOCATION isImplicit=false result=15
05-30 17:52:29.428 4559 4580 V PermissionControllerServiceImpl: Permission grant result requestId=-2574434414935562278 callingUid=10163 callingPackage=org.nativescript.temp permission=android.permission.ACCESS_COARSE_LOCATION isImplicit=false result=15
05-30 17:52:29.473 524 3731 W AppOps : setUidMode() called with a mode inconsistent with runtime permission state, this is discouraged and you should revoke the runtime permission instead: uid=10163, switchCode=0, mode=1, permission=android.permission.ACCESS_COARSE_LOCATION
05-30 17:52:29.473 524 574 I ActivityManager: Killing 9104:org.nativescript.temp/u0a163 (adj 700): one-time permission revoked
05-30 17:52:29.583 524 4992 I WindowManager: WIN DEATH: Window{49ce565 u0 org.nativescript.temp/com.tns.NativeScriptActivity}
05-30 17:52:29.583 524 4992 W InputDispatcher: Attempted to unregister already unregistered input channel '49ce565 org.nativescript.temp/com.tns.NativeScriptActivity (server)'
05-30 17:52:29.588 289 289 I Zygote : Process 9104 exited due to signal 9 (Killed)
05-30 17:52:29.590 524 550 W ActivityManager: setHasOverlayUi called on unknown pid: 9104
05-30 17:52:29.616 524 558 I libprocessgroup: Successfully killed process cgroup uid 10163 pid 9104 in 138ms
05-30 17:52:32.302 209 212 E android.system.suspend@1.0-service: Error opening kernel wakelock stats for: wakeup34: Permission denied
05-30 17:52:32.299 209 209 W Binder:209_2: type=1400 audit(0.0:80): avc: denied { read } for name="wakeup34" dev="sysfs" ino=19014 scontext=u:r:system_suspend:s0 tcontext=u:object_r:sysfs:s0 tclass=dir permissive=0
05-30 17:52:32.320 209 212 E android.system.suspend@1.0-service: Error opening kernel wakelock stats for: wakeup35: Permission denied
05-30 17:52:32.315 209 209 W Binder:209_2: type=1400 audit(0.0:81): avc: denied { read } for name="wakeup35" dev="sysfs" ino=19077 scontext=u:r:system_suspend:s0 tcontext=u:object_r:sysfs:s0 tclass=dir permissive=0
To reproduce:
- Create a new NS8 project (I was unable to run the demo app)
- Install and configure the plugin
- Call
enableLocationRequest
- Select "Only this time"
- Minimize the app
Is it a default Android behavior or is it possibile to fix this issue, for example extending the one-time session duration?
Metadata
Metadata
Assignees
Labels
No labels