Skip to main content

A simple mailer for web forms

Project description

Simple Mailer

Build Status PyPi version t

A simple Python mailer program that can be run in the WSGI environment of a shared hosting provider.

This program provides a web resource that can be used by an HTML web form to send a plain text email to a specific email address. HTML mail are not supported.

Features:

  • Can be triggered by a WSGI call or run standalone as a daemon
  • Configurable using environment variables
  • Captcha support (Recaptcha v3 for now)
  • Customizable email template
  • Easy to setup

Installation

Generic Shared Hosting

  1. Install the package, e.g. using pip install simple-mailer
  2. Copy over the wsgi/passenger_wsgi.py to the appropriate folder and rename accordingly
  3. Configure the environment variables, listed below, as needed

More information, including hosting provider specific instructions, can be found on the Wiki.

Namecheap

See this blog post.

Configuration

All configuration is done using environment variables.

SMTP_HOST

The hostname of the SMTP server that will send the email.

Example: smtp.example.com

Default: localhost

SMTP_PORT

The port number of the SMTP server at SMTP_HOST.

Default: 465

USE_TLS

Secure the connection to the SMTP server using TLS. Highly recommended.

Default: true

SMTP_USERID

The id of the SMTP user account on the SMTP server at SMTP_HOST.

Example: mailer@example.com

Default: An empty string.

SMTP_PASSWORD

The password of the SMTP user account on the SMTP server at SMTP_HOST.

Example: rosebud20

SMTP_TIMEOUT

The maximum number of seconds allowed for a SMTP connection to be established.

Default: 5

TO_ADDRESS

The recipient email address that will receive the email.

Example: orders@example.net

FROM_ADDRESS

The email address of the sender that will appear in the email that will be sent.

Example: mailer@example.com

REPLY_TO_FIELD

The form field that will be used to populate the Reply-to field of the email.

Default: An empty string

Example: email

MAIL_SUBJECT

The subject of every sent email.

You can use Jinja2 template tags here, just like the email body. The variables in the template context are:

  • data, containing all the fields that were sent (and passed the filters)
  • metadata, containing fields for: client_ip (the originating IP address), origin (the origin of the request, e.g. the page with the form), mailer_url (the URL of the mailer endpoint that processed the request)

Example: An order for {{data.goods} was sent from IP {{metadata.client_ip}}

Default: An empty string.

MAIL_TEMPLATE_PATH

The filesystem path to the email template file that will be used for the outgoing email.

You can use Jinja2 template tags in the email template. The variables that will be made available in the template context are:

  • data, containing all the fields that were sent (and passed the filters)
  • metadata, containing fields for: client_ip (the originating IP address), origin (the origin of the request, e.g. the page with the form), mailer_url (the URL of the mailer endpoint that processed the request)

Example: /home/myuser/templates/mail.txt

Default: The default template will be used.

MAILER_PATH

The path of the URL where the mailer resource will be available.

Default: mail

If the root path of this application has been made available at https://api.example.com/simple-mailer, email will need to be POSTed to https://api.example.com/simple-mailer/mail

CAPTCHA_TYPE

The captcha protocol to use. Possible values are: recaptchav3

Example: recaptchav3

Default: An empty string (no captcha system will be used - not recommended)

Note: the relevant captcha field in the POST, e.g. g-captcha-response, will be removed from the data that will be sent by email.

CAPTCHA_SECRET

The secret used to validate the request using a given secret.

Example: d0n0tsh4r3m3

Default: An empty string.

CAPTCHA_VERIFY_URL

The URL where challenge responses regarding the captcha can be verified, if required.

Example: https://www.google.com/recaptcha/api/siteverify

Default: An empty string.

REDIRECT_URL

If set, redirect the client to the given URL. If not, set a 200 OK response will be returned. The following template tags can be used: {{ REFERER }}, to use the value of the Referer (sic) field of the request, and {{ ORIGIN }}, to use the value of the Origin field of the request.

Example: https://www.example.org/thank-you

Example: {{ REFERER }}

Default: An empty string

FIELDS_EXCLUDED

A list of fields in the POST request to exclude from the email. Fields are comma separated. These fields take precedence over FIELDS_INCLUDED, i.e. if a field is mentioned here it will be excluded even if it is listed in FIELDS_INCLUDED.

Example: secret_field1,secret_field2

Default: An empty string (no fields are excluded)

FIELDS_INCLUDED

A list of fields in the POST request to include in the email. Fields are comma separated. All other fields will be ignored, but only if they are not also mentioned in FIELDS_EXCLUDED

Example: secret_field1,secret_field2

Default: An empty string (no fields are excluded)

Note: captcha keys are automatically included.

ENABLE_DEBUG

Enable the debug resource. This provides various diagnostic information.

The resource will be made available at DEBUG_PATH

Default: false

Note: Only enable it when you're trying to debug a problem, since it will expose your configuration variables and is expensive to render.

DEBUG_PATH

The path where the debug resource will be made available.

Default: /debug

LOG_LEVEL

The log level, from a choice of: DEBUG, INFO WARN, ERROR, and CRITICAL.

Default: WARN

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

simple-mailer-1.1.0.tar.gz (17.6 kB view details)

Uploaded Source

Built Distribution

simple_mailer-1.1.0-py3-none-any.whl (20.8 kB view details)

Uploaded Python 3

File details

Details for the file simple-mailer-1.1.0.tar.gz.

File metadata

  • Download URL: simple-mailer-1.1.0.tar.gz
  • Upload date:
  • Size: 17.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.46.1 CPython/3.7.5

File hashes

Hashes for simple-mailer-1.1.0.tar.gz
Algorithm Hash digest
SHA256 72f6ba5d8ae0b0f4b01e49c92e02589f3bd768adbc8c152b517d6172cc4f6027
MD5 3a849d922f8a32fabee15c10e453068a
BLAKE2b-256 4df4baef2e5540869c77c7008837e6c2ad031d3b4a961cec3aac414e2f96d1ed

See more details on using hashes here.

File details

Details for the file simple_mailer-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: simple_mailer-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 20.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.46.1 CPython/3.7.5

File hashes

Hashes for simple_mailer-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3024fa3c0cf7e68f4f73f4a3909590b4baafec8ae4a9430f324b5ac2dcb377f0
MD5 690f436983408334829844aae81f2c0a
BLAKE2b-256 60e2e409759795a9aeb809b589105c9ce0e3c6254b511220d6343d14e05f844b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page