Skip to content
This repository has been archived by the owner on Jan 8, 2024. It is now read-only.

Latest commit

 

History

History
80 lines (55 loc) · 1.84 KB

README.rst

File metadata and controls

80 lines (55 loc) · 1.84 KB

Djpush

Manage programatic Push Notifications from Django admin.

Features

  • Define notifications via the admin
  • Categorize notifications
  • Schedule notifications by category
  • Choose your provider(APNS/apns2, GCM/gcm, OneSignal/yaosac). Actually you must install one.
  • Same notification in time range are canceled
  • (optional) Multiple language support via django-modelstranslation

Important Dependencies

  • django-timezone-field
  • pytz

Usage

In your settings.py define:

DJPUSH_NOTIFICATIONS_CHOICES
A list of slugs representing the notifications you want to send.
DJPUSH_DEFAULT_PROVIDER
The provider you want to use to send notifications(values can be found in pypn).

optional settings DJPUSH_NOTIFICATION_EXPIRES

The number of seconds after task will be considered expired
# Get a notification, you define them in the admin
notification = models.Notification.objects.get(slug='a-slug', enabled=True)

# Create a notification instance
notification_instance = models.NotificationInstance.objects.create(notification=notification, tokens=tokens, data=data)

# Send the notification
notification_instance.send()

Development

Update migrations

DJANGO_SETTINGS_MODULE=migration_settings django-admin makemigrations

Run tests

./runtests.py

Build/Publish

rm -rf dist
python setup.py sdist bdist_wheel
twine upload dist/*

Translations

To enable translations you have to install django-modeltranslation and add MIGRATION_MODULES = {'djpush': 'djangoproject.migrations'} to your settings.

Notifications will be sent including the available tranlations.