Django Anymail

Django email backends and webhooks for Amazon SES, MailerSend, Mailgun, Mailjet, Postmark, Postal, SendGrid, Sendinblue, SparkPost and more
Alternatives To Django Anymail
Project NameStarsDownloadsRepos Using ThisPackages Using ThisMost Recent CommitTotal ReleasesLatest ReleaseOpen IssuesLicenseLanguage
Django Anymail1,4161,07010a month ago48May 15, 20223otherPython
Django email backends and webhooks for Amazon SES, MailerSend, Mailgun, Mailjet, Postmark, Postal, SendGrid, Sendinblue, SparkPost and more
Stampie28565a year ago24September 08, 20211mitPHP
Library for using online Email providers
Go Mail162117 months ago17February 17, 20223mitGo
📧 A cross platform mail driver for GoLang. Featuring Mailgun, Postal, Postmark, SendGrid, SparkPost & SMTP.
Slmmail1061742 months ago40January 24, 20224otherPHP
Send mail from Laminas or Mezzio using external mail services.
Dns Zone Files39
a year agocc0-1.0
⛅️ DNS Zone Files ready to import on CloudFlare for easy configurations of common configs. Files are in BIND Format.
5 months ago9October 22, 2021mitPHP
A bundle to catch API webhook from different mail service
Courier24444 years ago13March 12, 20192otherPHP
A domain-driven library for sending transactional emails in PHP
a month ago53PHP
Send Affordable Bulk Email Campaign Through WordPress
Xe Advanced Mailer12
10 months ago1gpl-2.0PHP
XE 고급 메일 발송 모듈 (Advanced Mailer)
Parse Server Sparkpost Adapter3
5 years agoJavaScript
Simple sparkpost adapter for parse server
Alternatives To Django Anymail
Select To Compare

Alternative Project Comparisons

Anymail: Django email integration for transactional ESPs

Anymail lets you send and receive email in Django using your choice of transactional email service providers (ESPs). It extends the standard django.core.mail with many common ESP-added features, providing a consistent API that avoids locking your code to one specific ESP (and making it easier to change ESPs later if needed).

Anymail currently supports these ESPs:

  • Amazon SES
  • MailerSend
  • Mailgun
  • Mailjet
  • Mandrill (MailChimp transactional)
  • Postal (self-hosted ESP)
  • Postmark
  • SendGrid
  • SendinBlue
  • SparkPost

Anymail includes:

  • Integration of each ESP's sending APIs into Django's built-in email package, including support for HTML, attachments, extra headers, and other standard email features
  • Extensions to expose common ESP-added functionality, like tags, metadata, and tracking, with code that's portable between ESPs
  • Simplified inline images for HTML email
  • Normalized sent-message status and tracking notification, by connecting your ESP's webhooks to Django signals
  • "Batch transactional" sends using your ESP's merge and template features
  • Inbound message support, to receive email through your ESP's webhooks, with simplified, portable access to attachments and other inbound content

Anymail maintains compatibility with all Django versions that are in mainstream or extended support, plus (usually) a few older Django versions, and is extensively tested on all Python versions supported by Django. (Even-older Django versions may still be covered by an Anymail extended support release; consult the changelog for details.)

Anymail releases follow semantic versioning. The package is released under the BSD license.

test status in GitHub Actions integration test status in GitHub Actions documentation build status on ReadTheDocs


Anymail 1-2-3

Here's how to send a message. This example uses Mailgun, but you can substitute Mailjet or Postmark or SendGrid or SparkPost or any other supported ESP where you see "mailgun":

  1. Install Anymail from PyPI:

    $ pip install "django-anymail[mailgun]"

    (The [mailgun] part installs any additional packages needed for that ESP. Mailgun doesn't have any, but some other ESPs do.)

  2. Edit your project's

        # ...
        # ...
    ANYMAIL = {
        # (exact settings here depend on your ESP...)
        "MAILGUN_API_KEY": "<your Mailgun key>",
        "MAILGUN_SENDER_DOMAIN": '',  # your Mailgun domain, if needed
    EMAIL_BACKEND = "anymail.backends.mailgun.EmailBackend"  # or sendgrid.EmailBackend, or...
    DEFAULT_FROM_EMAIL = "[email protected]"  # if you don't already have this in settings
    SERVER_EMAIL = "[email protected]"  # ditto (default from-email for Django errors)
  3. Now the regular Django email functions will send through your chosen ESP:

    from django.core.mail import send_mail
    send_mail("It works!", "This will get sent through Mailgun",
              "Anymail Sender <[email protected]>", ["[email protected]"])

    You could send an HTML message, complete with an inline image, custom tags and metadata:

    from django.core.mail import EmailMultiAlternatives
    from anymail.message import attach_inline_image_file
    msg = EmailMultiAlternatives(
        subject="Please activate your account",
        body="Click to activate your account:",
        from_email="Example <[email protected]>",
        to=["New User <[email protected]>", "[email protected]"],
        reply_to=["Helpdesk <[email protected]>"])
    # Include an inline image in the html:
    logo_cid = attach_inline_image_file(msg, "/path/to/logo.jpg")
    html = """<img alt="Logo" src="cid:{logo_cid}">
              <p>Please <a href="">activate</a>
              your account</p>""".format(logo_cid=logo_cid)
    msg.attach_alternative(html, "text/html")
    # Optional Anymail extensions:
    msg.metadata = {"user_id": "8675309", "experiment_variation": 1}
    msg.tags = ["activation", "onboarding"]
    msg.track_clicks = True
    # Send it:

See the full documentation for more features and options, including receiving messages and tracking sent message status.

Popular Sparkpost Projects
Popular Sendgrid Projects
Popular Messaging Categories
Related Searches

Get A Weekly Email With Trending Projects For These Categories
No Spam. Unsubscribe easily at any time.