Skip to main content

Reusable application for Django introducing a message delivery framework

Project description


Reusable application for Django introducing a message delivery framework.


  • Message Types - message classes exposing message composition logic (plain text, html, etc.).

  • Messengers - clients for various protocols (smtp, jabber, twitter, telegram, facebook, vkontakte, etc.);

  • Support for user defined message types.

  • Support for user defined messenger types.

  • Message prioritization.

  • Message subscription/unsubscription system.

  • Message grouping to prevent flooding.

  • Message ‘read’ indication.

  • Means for background message delivery and cleanup.

  • Means to debug integration: test requisites, delivery log.

  • Django Admin integration.

  1. Configure messengers for your project (create in one of your apps):

from sitemessage.toolbox import register_messenger_objects, register_message_types
from sitemessage.messengers.smtp import SMTPMessenger

    # Here we register one messenger to deliver emails.
    # By default it uses mailing related settings from Django settings file.
  1. Schedule messages for delivery when and where needed (e.g. in a view):

from sitemessage.shortcuts import schedule_email

def send_mail_view(request):

    # Suppose `user_model` is a recipient Django User model instance.
    user1_model = ...

    # We pass `request.user` into `sender` to keep track of senders.
    schedule_email('Message from sitemessage.', [user1_model, ''], sender=request.user)

  1. Periodically run Django management command from wherever you like (cli, cron, Celery, uWSGI, etc.):

    ./ sitemessage_send_scheduled

And that’s only the tip of sitemessage iceberg, read the docs %)


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-sitemessage-1.4.0.tar.gz (53.7 kB view hashes)

Uploaded Source

Built Distribution

django_sitemessage-1.4.0-py3-none-any.whl (52.8 kB view hashes)

Uploaded Python 3

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