Skip to main content

A GOV.UK Notify flavoured Django email backend

Project description

django-gov-notify, a GOV.UK Notify flavoured Django email backend

GitHub workflow

django-gov-notify provides Django integration with the GOV.UK Notify service for sending emails and SMS messages. Python Client Documentation.

This is implemented as a custom Django email backend. It presents a similar internal API to standard Django email backends, but with some restrictions:

  • GOV.UK Notify emails are sent to one recipient each. CC: and BCC: fields are not supported.
  • A single email 'message' with multiple recipients will result in multiple individual API calls to GOV.UK Notify, each message being sent to a single recipient. The backend will still report back 1, as per Django's default behaviour.
  • Attachments are not (at the moment) supported.
  • Custom headers are not supported.
  • To configure a 'reply-to' address, you must first configure such an address in the GOV.UK Notify admin interface.
  • The 'from' address field is not supported. This must be configured within the GOV.UK Notify admin interface.
  • Preformatted emails are expected to be configured in the service admin dashboard as Markdown templates with placeholders.
  • The email body is interpreted as very limited Markdown. On testing, it seems that variables are not interpreted as markdown, or maybe mangled, e.g. _test_ was emailed as *test*.

Compatibility

django-gov-notify supports:

  • Python 3.9, 3.10, 3.11 and 3.12
  • Django 4.2, 5.0 and 5.1

Installation

Using pip:

$ pip install django-gov-notify

Using Poetry

$ poetry add django-gov-notify

Configuration

In your Django project's settings:

EMAIL_BACKEND = "django_gov_notify.backends.NotifyEmailBackend"

You will need at least one email template ID, with a plain template:

Subject: ((subject))
Body: ((body))

Set the Django settings:

  • GOVUK_NOTIFY_API_KEY (NB not GOV_UK…)
  • GOVUK_NOTIFY_PLAIN_EMAIL_TEMPLATE_ID

This plain template ID setting, and template IDs passed to the NotifyEmailMessage class, use string representations of the UUID keys.

Usage

Sending an email using a template

Configure the template in the GOV.UK Notify dashboard:

Subject: Message about ((topic))
Body: Hello ((first name)), your reference is ((ref number))

Create an email message, supplying the template ID and a personalisation dictionary (this should also include any variables defined in the template subject):

from django_gov_notify.message import NotifyEmailMessage

message = NotifyEmailMessage(
    to=["recipient@example.com"],
    template_id="43573f75-80e7-402f-b308-e5f1066fbd6f",
    personalisation={
        "topic": "The Prisoner",
        "first name": "Patrick",
        "ref number": "6",
    },
)
message.send()

Note that in this case a subject and body are not required, nor permitted, because the personalisation dict won't know how to do anything with them.

Sending an email using the default (blank) template

This assumes you have configured a blank template with the parameters

Subject: ((subject))
Body: ((body))

from django_gov_notify.message import NotifyEmailMessage

message = NotifyEmailMessage(
    subject="Test subject", body="Test message content", to=["recipient@example.com"]
)
message.send()

Note that in this case a subject and body are required, and you must not pass the template_id or personalisation kwargs.

Sending an email using the send_mail shortcut function

Use it in the normal fashion, including a 'from' address that will be discarded:

from django.utils.mail import send_mail

send_mail("Subject", "Message content", "from@example.com", ["recipient@example.com"])

This will use the blank template ID configured as settings.GOVUK_NOTIFY_PLAIN_EMAIL_TEMPLATE_ID. Attachments, custom headers, and BCC recipients are not supported.

Contributing

To work on this repository locally:

  • install: poetry install
  • run tests: poetry run python runtests.py

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_gov_notify-0.6.0.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

django_gov_notify-0.6.0-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file django_gov_notify-0.6.0.tar.gz.

File metadata

  • Download URL: django_gov_notify-0.6.0.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.2 Linux/6.8.0-45-generic

File hashes

Hashes for django_gov_notify-0.6.0.tar.gz
Algorithm Hash digest
SHA256 989368bc13eb1db59ed39354525a039bd6078312ec6510cfa6d2d123de68c2eb
MD5 14c9df7ad6e3095a56efc4d4271b5564
BLAKE2b-256 628f72d44b7a48617ca2d11a4b68a6f091a997e7dd3ad97b2bd5336e316d8b65

See more details on using hashes here.

File details

Details for the file django_gov_notify-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: django_gov_notify-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.2 Linux/6.8.0-45-generic

File hashes

Hashes for django_gov_notify-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eba507a740d709ed8cffcd2d7599b40bca08b9078dc9a53cf4029a8f95bc6789
MD5 f0418ce92899c01cdfa72acf78057d69
BLAKE2b-256 2c4cb160e87337261952666f83b724be7df1829bcf6d85e6fb828df4b70d6066

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