Skip to main content

Send asynchronous messages to users (eg from offline scripts). Useful for integration with Celery

Project description

Simple asynchronous messages for django.

Questions

What problem does this solve?

Suppose a user instigates an expensive task that you are processing offline (eg using Celery). This library provides a simple mechanism for notifying the user when the task is finished, utilising Django’s messaging framework.

What’s an example?

You might use Celery to generate a large report and then employ this library to notify the user that their report is ready to be downloaded. The user will see the message you’ve sent them when they make their next request after the message is submitted.

How does it work?

A cache is used to persist the messages, and middleware is used to pick these up and submit them to Django’s messaging framework. All very simple.

Aren’t there other libraries that do this?

Yes, there are - but they solve the problem in different ways:

What’s good about this implementation?

  • It’s simple, fast and easy to use.

  • It works cohesively with existing Django cache and messages framework. It will work no matter what cache backend your are using, and whatever storage backend is used for messages.

What’s bad?

  • A user may miss the message if they navigating quickly between pages. But this is a general problem of the Django messages framework.

Install

From PyPI (stable):

pip install django-async-messages

From Github (unstable):

pip install git+git://github.com/codeinthehole/django-async-messages#egg=djang-async-messages

Add 'async_messages.middleware.AsyncMiddleware' to your MIDDLEWARE_CLASSES. Ensure it comes after 'django.contrib.messages.middleware.MessageMiddleware'.

You need to have CACHES configured in you settings for this to work. As usual, memcache is the best choice.

Use

Send a message to a single user:

>>> from async_messages import message_user
>>> from django.contrib.auth.models import User
>>> barry = User.objects.get(username='barry')
>>> message_user(barry, "Barry, your report is ready")

Send a message to lots of users:

>>> from async_messages import message_users
>>> staff = User.objects.filter(is_staff=True)
>>> message_users(staff, "All budgets must be spent by the end of the day")

Specify message level:

>>> from django.contrib.messages import constants
>>> message_users(staff, "Boom!", constants.WARNING)

Send multiple messages to a single user:

>>> from async_messages import message_user
>>> from django.contrib.auth.models import User
>>> barry = User.objects.get(username='barry')
>>> message_user(barry, "Barry, your report is queued up for processing")
>>> # do more awesome stuff
>>> message_user(barry, "Barry, your report is ready")

Contributing

Fork, clone and create a virtualenv. Then run:

make install

Run tests with:

./runtests.py

Please submit pull requests using ‘develop’ as the target branch.

Changelog

0.2

  • Added possibility to queue multiple messages

0.1.2

  • Altered dependency on Django to be only 1.2+

0.1.1

  • Altered middleware to use process_response.

  • Better docstrings

0.1

  • Minimum viable product

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-async-messages-0.2.tar.gz (3.5 kB view details)

Uploaded Source

File details

Details for the file django-async-messages-0.2.tar.gz.

File metadata

File hashes

Hashes for django-async-messages-0.2.tar.gz
Algorithm Hash digest
SHA256 9a6a83da39539a8c47983a6cabe800ef87d1e60b4bbd5cd2affcaf5f406d5388
MD5 89f0b709aca2c9d6f16cca00d259b7f0
BLAKE2b-256 962d192f7fcf42d68d492fffb253b8785f7e731b58313e072422a74d9174b022

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page