Metadata-Version: 2.1
Name: django3-stored-messages
Version: 2.0.0
Summary: Django contrib.messages on steroids
Home-page: https://github.com/evonove/django-stored-messages
Author: evonove
Author-email: info@evonove.it
License: BSD
Keywords: django-stored-messages
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Framework :: Django
Classifier: Framework :: Django :: 1.8
Classifier: Framework :: Django :: 1.9
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Requires-Dist: Django (>=2)

Django Stored Messages
======================

.. image:: https://travis-ci.org/evonove/django-stored-messages.png?branch=master
        :target: https://travis-ci.org/evonove/django-stored-messages

.. image:: https://coveralls.io/repos/evonove/django-stored-messages/badge.png
        :target: https://coveralls.io/r/evonove/django-stored-messages

.. image:: http://readthedocs.org/projects/django-stored-messages/badge/?version=latest
    :target: http://django-stored-messages.readthedocs.org/en/latest/?badge=latest
    :alt: Documentation Status

.. image:: https://badge.fury.io/py/django-stored-messages.png
    :target: http://badge.fury.io/py/django-stored-messages

Django contrib.messages on steroids

The app integrates smoothly with Django's `messages framework <http://docs.djangoproject.com/en/dev/ref/contrib/messages/>`_
(``django.contrib.messages``), but users can decide which messages have to be stored on the database
backend and kept available over sessions.

Features
--------

* Seamless integration with ``django.contrib.messages``
* All the features are in a mixin you can attach to your existing storage
* Stored messages are archived in the database or in a Redis instance
* Users can configure which message levels have to be persisted
* REST api to retrieve and mark messages as read (needs ``djangorestframework``)
* Signalling api to perform actions in response to messages activity

Compatibility table
-------------------

* Python 2.7, 3.4, 3.5
* Django 1.8, 1.9
* Django Rest Framework >= 3.3 (only if you want to use REST endpoints)

Do you use an earlier version of Django or Django Rest Framework? An `old version of stored_messages`_ is available even
if it's **not supported anymore**. Anyway, plan a migration to a newer version.

.. _old version of stored_messages: https://github.com/evonove/django-stored-messages/tree/1.3.1

Documentation
-------------

The full documentation is at http://django-stored-messages.rtfd.org. It includes `migration instructions`_ if you're
migrating from an earlier version of ``stored_messages``.

.. _migration instructions: http://django-stored-messages.readthedocs.org/en/latest/migrations.html

Quickstart
----------

Follow instruction for firing up `django.contrib.messages <http://docs.djangoproject.com/en/dev/ref/contrib/messages/>`_,
then install the app::

    $ pip install django-stored-messages

Add it to the installed apps:

.. code-block:: python

    INSTALLED_APPS = (
        # ...
        'stored_messages',
    )

In the settings, tell Django which is the message storage:

.. code-block:: python

    MESSAGE_STORAGE = 'stored_messages.storage.PersistentStorage'

As last step, don't forget to run Django migrations::

    $ python manage.py migrate

Then use it in a project through the django.contrib.messages api. The app provides for convenience
some message levels which are persisted by default:

.. code-block:: python

    import stored_messages

    from django.contrib import messages

    # standard message
    messages.add_message(request, messages.INFO, 'Hello world.')
    # this will be persisted and marked as 'unread'
    messages.add_message(request, stored_messages.STORED_INFO, 'Hello world, to the database!')

stored_messages expose the same api as well, so one can do:

.. code-block:: python

    import stored_messages
    stored_messages.add_message(request, stored_messages.INFO, 'Hello!')

If you want to use standard message levels but persist the messages, just add something like this
to the settings:

.. code-block:: python

    from django.contrib import messages

    STORED_MESSAGES = {
        # persist standard infos and standard errors
        'STORE_LEVELS': (messages.INFO, messages.ERROR,),
    }

Iterating the messages will automatically mark them as read (but still persisted):

.. code-block:: python

    storage = messages.get_messages(request)
    for unread_message in storage:
        # unread_message could be a stored message or a "standard" Django message
        do_something_with(unread_message)

...unless you mark the storage as not used:

.. code-block:: python

   storage.used = False

You can mark a stored message as read at any time:

.. code-block:: python

    stored_messages.mark_read(request.user, message)

Want to store your messages on Redis instead of your database? Here you go:

.. code-block:: python

    STORED_MESSAGES = {
        'STORAGE_BACKEND': 'stored_messages.backends.RedisBackend',
        'REDIS_URL': 'redis://localhost:6379/0',
    }

Examples
--------

`GitHub-like notifications with Stored Messages and AngularJS <http://dev.pippi.im/2013/10/22/build-github-like-notifications-with-django-messages-and-angular-js/>`_




History
-------

1.0.1 (2014-04-17)
++++++++++++++++++
* Major bug fixed on `inbox_get()` backend api
* Fixed InboxSerializer for redis backend messages
* Enhanced testsuite
* Added MessageDoesNotExist descriptions and return 404

1.0.0 (2014-04-01)
++++++++++++++++++
* New backend architecture with Redis support
* Support for broadcast messages

0.2.1 (2013-12-23)
++++++++++++++++++
* Added `stored_messages_count` template tag and tests

0.2.0 (2013-10-22)
++++++++++++++++++

* Added `stored_messages_archive` template tag
* Extended REST api

0.1.2 (2013-10-13)
++++++++++++++++++

* Added specific template tags for stored messages

0.1.1 (2013-10-10)
++++++++++++++++++

* Fixed setup.py

0.1.0 (2013-10-08)
++++++++++++++++++

* First release on PyPI.

