stefano cattaneo
stefano cattaneo

Reputation: 123

Geofence transition PendingIntent blocked by the OS on Android Oreo

This only happens on Android Oreo. I'm using Play Services 11.4.2. I'm registering geofences using the GeofencingClient and the addGeofences method with a pendingIntent to an IntentService that is handling geofence transitions. It looks like the intent sent by the play services is blocked by the OS in certain conditions.

The system logs the following:

Background start not allowed: service Intent { cmp=my.app.id/my.package.struct.GeofenceTransIntentService (has extras) } to my.app.id/my.package.struct.GeofenceTransIntentService from pid=-1 uid=10154 pkg=my.app.id

as soon as I add a geofence in the following situations:

Upvotes: 2

Views: 3228

Answers (2)

Michael Krause
Michael Krause

Reputation: 4849

In addition to switching to a BroadcastReceiver as mentioned in the accepted answer, I'd like to point out that although you will still receive BOOT_COMPLETED, you will not be able to receive PROVIDERS_CHANGED any longer.

PROVIDERS_CHANGED is an implicit broadcast and is not in the list of broadcast exceptions.

BOOT_COMPLETED is in the list of broadcast exceptions which is why you'll still receive it.

If you want to learn about an alternative approach to get the hook when location services is toggled, please see my answer to a related question for more details.

Upvotes: 1

pincopallino
pincopallino

Reputation: 130

This is caused by the new Android Oreo background service limitations.

You have to change the PendingIntent from using a Service to using a BroadcastReceiver.

See this CodeLab for further information and example code.

Upvotes: 10

Related Questions