Djrill is an email backend and new message class for Django users that want to take advantage of the Mandrill transactional email service from MailChimp.
An optional Django admin interface is included. The admin interface allows you to:
- Check the status of your Mandrill API connection.
- Add/disable email senders.
- See stats on email tags and urls.
pip install djrill
The only dependency other than Django is the requests library from Kenneth Reitz. If you do not install through PyPI you will need to do
pip install requests
In settings.py
:
Add
djrill
to yourINSTALLED_APPS
.INSTALLED_APPS = ( ... "djrill" )
Add the following two lines, substituting your own
MANDRILL_API_KEY
:MANDRILL_API_KEY = "brack3t-is-awesome" MANDRILL_API_URL = "http://mandrillapp.com/api/1.0"
Override your existing email backend with the following line:
EMAIL_BACKEND = "djrill.mail.backends.djrill.DjrillBackend"
(optional) If you want to be able to add senders through Django's admin or view stats about your messages, do the following in your base
urls.py
... from django.contrib import admin from djrill import DjrillAdminSite admin.site = DjrillAdminSite() admin.autodiscover() ... urlpatterns = patterns('', ... url(r'^admin/', include(admin.site.urls)), )
Since you are replacing the global EMAIL_BACKEND
, all emails are sent through Mandrill's service.
If you just want to use Mandrill for sending emails through Django's built-in send_mail
and send_mass_mail
methods, all
you need to do is follow steps 1 through 3 of the above Configuration.
If, however, you want more control over the messages, to include an HTML version, or to attach tags or tracked URLs to an email,
usage of our DjrillMessage
class, which is a thin wrapper around Django's EmailMultiAlternatives
is required.
Example, in a view:
from django.views.generic import View from djrill.mail import DjrillMessage class SendEmailView(View): def get(self, request): subject = "Djrill Message" from_email = "djrill@example.com" # this has to be one of your approved senders from_name = "Djrill" # optional to = ["Djrill Receiver <djrill.receiver@example.com>", "djrill.two@example.com"] text_content = "This is the text version of your email" html_content = "<p>This is the HTML version of your email</p>" # optional, requires the ``attach_alternative`` line below tags = ["one tag", "two tag", "red tag", "blue tag"] # optional, can't be over 50 chars or start with an underscore msg = DjrillMessage(subject, text_content, from_email, to, tags=tags, from_name=from_name) msg.attach_alternative(html_content, "text/html") msg.send() ... # you'll want to return some sort of HttpResponse
Any tags over 50 characters in length are silently ignored since Mandrill doesn't support them. Any tags starting with an underscore will raise an ImproperlyConfigured
exception. Tags with an underscore are reserved by Mandrill.
If you attach more than one alternative type, an ImproperlyConfigured
exception will be raised. Mandrill does not support attaching
files to an email, so attachments will be silently ignored.
Not shown above, but settable, are the two options, track_clicks
and track_opens
. They are both set to True
by default, but can be set to False
and passed in when you instantiate your DjrillMessage
object.
Just like Django's EmailMessage
and EmailMultiAlternatives
, DjrillMessage
accepts extra headers through the
headers
argument. Currently it only accepts Reply-To
and X-*
headers since that is all that Mandrill accepts. Any
extra headers are silently discarded.
Thanks to the MailChimp team for asking us to build this nifty little app. Also thanks to James Socol on Github for his
django-adminplus library that got us off on the right foot for the custom admin views. Oh, and, of course, Kenneth Reitz for
the awesome requests
library.