Question

I'm writing a system app for a device that has
no Google Play Services nor Google Play Store installed.

I want to implement push notifications.

The device is running Android 4.2.2 and official Google GCM docs say:

A Google account is not a requirement on devices running Android 4.0.4 or higher.

But these docs are related to the new version of GCM which uses Google Play Services (not an option for me)

So I tried using the old, deprecated GCM helper library.
I installed GoogleServicesFramework4.0.x on the device (I can install GSF. but not Google Play Services)

I am now getting the AUTHENTICATION_FAILED error and registrationId is null.
I am guessing this is because no Google account is set up on the device.
Does the deprecated GCM library require Google account?
(My SENDER_ID is correct, I already checked that)


Basically, my question is:
Is it possible to make GCM work without Google account,
using the old, deprecated GCM helper library?

NOTE: I mustn't create Google account on the device (this is a requirement)

If this is not possible, then please suggest another way of implementing push notifications.
(Note that most of the push notifications providers actually use GCM "under the hood" (Urban Airpush, for example), so don't suggest those)

I would like to avoid having to poll server for notifications ("pull notifications") if possible,
thank you.

Was it helpful?

Solution

Just prior to the quote you posted (about Google account not being required), you have this :

It requires devices running Android 2.2 or higher that also have the Google Play Store application installed, or or an emulator running Android 2.2 with Google APIs. However, you are not limited to deploying your Android applications through Google Play Store.

Therefore it seems Google Play Store is a must for GCM to work.

I can't help you with an alternative to GCM.

OTHER TIPS

As an alternative to GCM, you could use MQTT as an open source and popular push notification alternative when Google account and Google Play services are absent on the device. Facebook has used aspects of MQTT in Facebook Messenger.

MQTT implementation requires:

1) an MQTT broker which runs on the server side. This could be something like the mosquitto broker which is Open Source.

2) an MQTT client library which you include in your Android app, enabling your app to connect, subscribe, and publish messages. There are a number of Java options listed at http://mqtt.org/software

3) to come up with a way of uniquely identifying users or devices, and then use that as a topic so that you can individually publish a message to one device. Dale Lane has written a nice guide on this (http://dalelane.co.uk/blog/?p=1599) and there is also a good set of resources about MQTT (https://github.com/mqtt/mqtt.github.io/wiki)

Also the blog post Github sample below provides a practical example to implement MQTT push notification for Android:

http://tokudu.com/post/50024574938/how-to-implement-push-notifications-for-android

https://github.com/tokudu/AndroidPushNotificationsDemo

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top