Manage programatic *Push Notifications* from Django admin
Project description
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
celery
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).
# 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
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.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.