A GOV.UK Notify flavoured Django email backend
Project description
django-gov-notify, a GOV.UK Notify flavoured Django email backend
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
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 989368bc13eb1db59ed39354525a039bd6078312ec6510cfa6d2d123de68c2eb |
|
MD5 | 14c9df7ad6e3095a56efc4d4271b5564 |
|
BLAKE2b-256 | 628f72d44b7a48617ca2d11a4b68a6f091a997e7dd3ad97b2bd5336e316d8b65 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | eba507a740d709ed8cffcd2d7599b40bca08b9078dc9a53cf4029a8f95bc6789 |
|
MD5 | f0418ce92899c01cdfa72acf78057d69 |
|
BLAKE2b-256 | 2c4cb160e87337261952666f83b724be7df1829bcf6d85e6fb828df4b70d6066 |