Skip to content

Python-based Google Cloud Messaging backend for App Engine.

License

Notifications You must be signed in to change notification settings

pulse-eng/gae-python-gcm

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

About

gae-python-gcm is a simple implementation of Google Cloud Messaging for Google App Engine in Python.

This module is designed to take care of everything you have to think about when working with Android GCM messages on the server:

  • Takes advantage of App Engine's task queues to make retries asyncronous
  • Uses App Engine's memcache to collect error statistics
  • Provides two hook functions, delete_bad_token and update_token, which can be overridden or configured from a settings files to implement these actions in your environent.
  • Example django settings and testing / debug handlers.

Implementation with / without django

gae-python-gcm can be used with or without Django. The provided example was taken from a django-nonrel enviroment and is based on the way we use it at Pulse. If you want to use it with App Engine's built-in Django or without Django at all, it should be relatively simple to take the core functionality in /gae-python-gcm/gcm.py and leave the rest. Feel free to contact me if you have any quesitons (@gregbayer).

Why not use Google's GCM Server referance implmentation

We prefer to keep everything in Python instead of using the GCM server referance implmentation in Java.

Example

from gae_python_gcm.gcm import GCMMessage, GCMConnection

gcm_message = GCMMessage(push_token, android_payload)
gcm_conn = GCMConnection()
gcm_conn.notify_device(gcm_message)

Getting started

To add gae-python-gcm to your AppEngine project without Django:

  1. git clone git://github.com/gregbayer/gae-python-gcm.git
  2. Add entries to your app.yaml and queue.yaml based on included files.
  3. Copy the gae-python-gcm directory into your appengine project
  4. Make sure you set YOUR-GCM-API-KEY in /gae_python_gcm/gcm.py or in the settings module.

To add gae-python-gcm to your AppEngine project with Django:

  1. git clone git://github.com/gregbayer/gae-python-gcm.git
  2. Add entries to your app.yaml and queue.yaml based on included files.
  3. Copy the gae-python-gcm directory into your appengine project
  4. Configure your project as appropriate. You may find the urls.py and settings.py examples in the example_django_files directories useful.
  5. Make sure you set YOUR-GCM-API-KEY in /gae_python_gcm/gcm.py or in the settings module.

About

Python-based Google Cloud Messaging backend for App Engine.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%