Skip to main content

Django app for sending notifications.

Project description

django-ilmoitin

Latest PyPI version Python versions

A templated Django messaging library

Installation

  1. pip install django-ilmoitin

  2. Add django_ilmoitin to INSTALLED_APPS.

  3. Run migrations

    python manage.py migrate ilmoitin
    

Use version 0.7.0 for a project based on Django >= 3.2 and Python >= 3.8

For older Python versions, use version 0.6.0.

Use version 0.5.x for a project based on Django 2.x.

If you need to make changes to django-ilmoitin and your project uses Django 2.x, add your changes to the branch stable/0.5.x and then make a new 0.5.x release from it.

Usage

  1. django-ilmoitin uses django-mailer to send emails, so you need to configure the MAILER_EMAIL_BACKEND setting to let django-mailer know, how to actually send the mail:

    MAILER_EMAIL_BACKEND = "your.actual.EmailBackend"
    
  2. Define default from address in settings

    DEFAULT_FROM_EMAIL = "Ilmoitin <ilmoitin@example.com>"
    

    In case you need translated from addresses, those can be defined like

    ILMOITIN_TRANSLATED_FROM_EMAIL: {
       "fi": "Yrjö <ilmoitin@example.com>",
       "en": "George <ilmoitin@example.com>",
    }
    

    The value from DEFAULT_FROM_EMAIL will be used for languages not defined in that dict.

  3. Create a notifications.py file in django app and register your notification types:

    from django_ilmoitin.registry import notifications
    
    notifications.register("event_created", "Event created")
    notifications.register("event_deleted", "Event deleted")
    
  4. Create a dummy_context.py file in django app and add dummy context data. Either use the codes of notifications that you registered in the previous step, or use the const COMMON_CONTEXT to make some variables available for all templates:

    from django_ilmoitin.dummy_context import COMMON_CONTEXT, dummy_context
    
    from .models import MyModel
    
    my_object = MyModel(foo="bar")
    
    dummy_context.update({
        COMMON_CONTEXT: {"my_object": my_object},
        "event_created": {
            "foo": "bar"
        },
        "event_deleted": {
            "fizz": "buzz"
        }
    })
    
  5. Import notifications and dummy context in your apps.py:

    from django.apps import AppConfig
    
    
    class ExampleConfig(AppConfig):
        name = "example"
    
        def ready(self):
            import example.notifications
            import example.dummy_context
    
  6. Go to django admin and add notification templates to your notifications

  7. Send notifications. List of attachment files can be passed as last optional argument:

    from django_ilmoitin.utils import send_notification
    
    context = {
        "foo": "bar",
    }
    attachment = "test.txt", "foo bar", "text/plain"
    
    send_notification("foo@bar.com", "event_created", context, [attachment])
    
  8. By default, notifications will be sent immediately, if you only want to add notification to the message queue and send it later, configure ILMOITIN_QUEUE_NOTIFICATIONS:

    ILMOITIN_QUEUE_NOTIFICATIONS = True
    

Using the GraphQL API

The package provides an optional GraphQL API that requires a working graphene API to work, and it needs additional dependencies.

  1. To install them, run: pip install django-ilmoitin[graphql_api]

  2. Add the Query to the entrypoint where you build your schema:

# my_app/schema.py
import django_ilmoitin.api.schema as django_ilmoitin_schema

class Query(
    # other extended classes
    django_ilmoitin_schema.Query,
    graphene.ObjectType,
):
    pass

Adding authentication to the queries

All the queries are public by default. The way to protect them is to override the resolvers on your app and call the "parent" query on the new resolver.

An example of how to protect a query would be as follows:

class Query(
    # other extended classes
    django_ilmoitin_schema.Query,
    graphene.ObjectType,
):

  @staticmethod
  @login_required
  def resolve_notification_templates(parent, info, **kwargs):
      return django_ilmoitin_schema.Query.resolve_notification_templates(
          parent, info, **kwargs
      )

If you need more specific permission checking, you can also do

class Query(
    # other extended classes
    django_ilmoitin_schema.Query,
    graphene.ObjectType,
):

  @staticmethod
  def resolve_notification_templates(parent, info, **kwargs):
      user = info.context.user
      if user.has_perms(["very_specific_permission"]):
          return django_ilmoitin_schema.Query.resolve_notification_templates(
              parent, info, **kwargs
          )
      raise PermissionError("User not authorised")

Code format

This project uses black for Python code formatting. We follow the basic config, without any modifications. Basic black commands:

  • To let black do its magic: black .
  • To see which files black would change: black --check .

Troubleshooting guide

  1. Cannot receive email even though it was sent successfully
  • Some strict spam filter might mark email as spam if its Message-ID header has suspicious domain name (e.g 158431519447.10.15335486611387428798@qa-staging-i09m9b-staging-77bd999444-p2497)

  • This is because Python tries to generate messsage id base on the FQDN of the local machine before sending email . Fortunately most of Email Sending services (Mailgun, MailChimp, Sendgrid,..) have a way to generate a reliable message-id that will likely pass spam filter, so we better let them do it.

  • If you are using django-anymail as the email backend, there is an easy way to remove the auto-generated Message ID using pre_send signal

  • Example:

    from anymail.signals import pre_send
    @receiver(pre_send)
    def remove_message_id(sender, message, **kwargs):
        message.extra_headers.pop("Message-ID", None)

Note that it only works if you are using django-anymail as your email backend

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_ilmoitin-0.7.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

django_ilmoitin-0.7.0-py3-none-any.whl (16.5 kB view details)

Uploaded Python 3

File details

Details for the file django_ilmoitin-0.7.0.tar.gz.

File metadata

  • Download URL: django_ilmoitin-0.7.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for django_ilmoitin-0.7.0.tar.gz
Algorithm Hash digest
SHA256 fc3672772ea70eca9cac47560cc72cff8edf243bdb21b03dde277983c63bf2d0
MD5 d5aebe846ae8712b5e1c227e322ae1d5
BLAKE2b-256 a91f066b99b52cc1e0a11e6c4c169ad05e98b230e30aa74b7d651fcb8cbebf37

See more details on using hashes here.

File details

Details for the file django_ilmoitin-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_ilmoitin-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 01b1f82c52af7fa40b85529bad772c7976d472a439634140201f902747618e79
MD5 4aa098b062cb2226607c96f7dde9b8f7
BLAKE2b-256 47a95f5ebf7633e137137975c2f9c47e98570b46128d035f43b7364d07feb1f3

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