Skip to main content

API for connecting to the smtprelay server.

Project description

This module provides an interface for the smtprelay server that allows it to be used as a logger or just to send emails.

smtprelay is designed to act as a message queue for sending e-mails so that rate limiting and authentication can be implemented in one place.

Configuration

Configuration is done via Zirconium, which allows for you to use your configuration language of choice. The example configuration below is given in TOML. Note that you must install the toml package for versions of Python where it is not built-in.

[smtp_relay]
end_point = "http://server:port/send"   # Mandatory, put in the path to your smtprelay server here.
bearer_token = "blahblah"               # Mandatory, put in your secret token here from the relay server.
default_send_group = ""                 # Optional, specify a send group to be applied to all messages unless one is specified in code.
default_send_from = ""                  # Optional, specify a sender e-mail here for all messages unless one is provided in code.
retry_file = ""                         # Optional, specify a path to a file that will be used to store messages when the relay server cannot be contacted.
show_errors = true                      # Change to false to hide the printed errors when connections to the relay server fail
request_timeout = 2.5                   # Change the timeout for the requests module here (default is 2.5)
cap_on_retry = 50                       # Change the maximum number of e-mails that will be send during a retry attempt.

Automatic Retries

This package allows for e-mails to be saved to a file if the smtprelay server is not available. To use this option, you must first set the retry_file to a file path in the configuration. You can then schedule the resend using either the entry point or by calling the module in cron.d or Windows task manager:

    # Make sure you're in the right venv and that you execute this from the proper
    # working directory for where you've located the configuration files.
    
    python -m smtprelayapi
    # OR
    smtprelayapi-resend

Usage

In this example, we simply queue up a message to be sent. The send_group parameter is a simple text string that is recorded on the server side so that the origin of messages can be tracked.

    from autoinject import injector
    from smtprelayapi import RelayClient
    
    @injector.inject
    def send_an_email(rc: RelayClient = None):
        rc.send_email(
            subject="Extended Warranty",
            plain_message="We've been trying to reach you about your car's extended warranty.",
            html_message="<p>We've been trying to reach you about your car's <strong>extended warranty</strong>.</p>",
            from_email="scammer@example.com",
            to_emails="adam.undergrove@example.com",
            bcc_emails="head.scammer@example.com",
            send_group="warranty-scams"
        )

An implementation of logging.Handler is also provided for simplicity to integrate with the logging module.

    from smtprelayapi import RelayHandler
    import logging
    
    handler = RelayHandler(
        subject="Application Log: myapplication: %{levelname}!",
        format_subject=True,
        toaddrs="admin@example.com",
        ccaddrs="manager@example.com",
        send_group="myapplication-errors",
        level=logging.WARNING
    )
    logging.getLogger().addHandler(handler)    

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

smtprelayapi-1.0.0.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

smtprelayapi-1.0.0-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file smtprelayapi-1.0.0.tar.gz.

File metadata

  • Download URL: smtprelayapi-1.0.0.tar.gz
  • Upload date:
  • Size: 8.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for smtprelayapi-1.0.0.tar.gz
Algorithm Hash digest
SHA256 3de5136f567e591c4ea925037b5691734aca90655ad757465c7d77d63c2c7afa
MD5 b88e2b944175e1a6f7716ffc40da0bf0
BLAKE2b-256 22e1b8ed953e7d6712acbe5e10026992c9928374b1287449595ee81e6ad8d095

See more details on using hashes here.

File details

Details for the file smtprelayapi-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for smtprelayapi-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0b8c942c67f769a028e61ea9f45f44f5860d0471aeafe43888f32dfa41287caf
MD5 c3ae8c2f93058534a956298273a7e480
BLAKE2b-256 dbf9dfaa3b602d3199a669bdd7cab2c4ecb0ca311a5af6d6c0e3d46590f01bfc

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