Skip to main content

IMAP and SMTP in memory test server

Project description

License: MIT PyPI - Python Version Code style: black

mail-devel

This tool combines an in-memory SMTP mail-sink with an IMAP server. All mails coming over SMTP are stored in the IMAP inbox. This can be used to test outgoing and incoming mail configurations. Built on top of aiosmtpd and pymap.

The frontend is minimally handling the content of the mailbox. Please connect a proper mail client like Thunderbird for more advanced usage.

DO NOT USE FOR PRODUCTION.

Features

  • Receive, send mails, and reply to mails
  • Generate randomized mails using the HTTP frontend
  • Manage IMAP flags and automated flagging
  • Minimal HTTP frontend to support the basic testing
  • SMTP auto respond feature for automatic testing (see --smtp-responder)
  • Single or multi mail account mode (see configuration)
  • Mail aliases if in multi account mode

Usage

Docker

docker run -p 4080:4080 -p 4025:4025 -p 4143:4143 --rm fkantelberg/mail-devel --password abc

Docker Compose

The following example assumes that the tool is run in a docker compose network as one of the services and only need to publish the HTTP port.

  • Minimally define password in .env with MAILSINK_PASSWORD
  • Additionally define port in .env with MAILSINK_HTTP

Following the section from the docker-compose.yaml:

services:
  mailsink:
    image: fkantelberg/mail-devel:${MAILSINK_TAG:-latest}
    environment:
      MAIL_USER: ${MAILSINK_USER:-test@example.org}
    command: [--password, $MAILSINK_PASSWORD, --smtp-flagged-seen]
    ports:
      - ${MAILSINK_HTTP:-127.0.0.1:4080}:4080
      # If you want to connect a normal mail client via SMTP and IMAP
      # - ${MAILSINK_SMTP:-127.0.0.1:4025}:4025
      # - ${MAILSINK_IMAP:-127.0.0.1:4143}:4143

Python

$ pip install mail-devel
$ mail_devel --password secret

Configuration

Please use --help for a more complete overview of the configurations.

  • --password: The password for SMTP and IMAP

  • --auth-required: Disables SMTP without authentication

  • --flagged-seen: If set incoming mails are automatically flagged as seen/read. If you only want to flag mails coming via SMTP as seen use --smtp-flagged-seen

  • --multi-user: Switches from single user to multi user mode

    • Single User Mode: All mails are collected in a single mailbox which belongs to the defined user.

    • Multi User Mode: The mails are collected in the specific mailboxes for each receiver of the messages using the to, cc, and bcc mail headers. Allows the usage of mail aliases

  • --alias: Can be specified multiple times to map mail addresses using UNIX shell-style wildcards. Aliases can also be specified via a comma-separated list in the environment variable MAIL_ALIAS

  • --smtp-responder: Automatically respond to the mails coming in via SMTP

    • --smtp-responder reply_once: Reply once per mail thread
    • --smtp-responder reply_always: Always reply to incoming mails
    • --smtp-responder path/to/script.py: Custom auto responder. See the examples

Supported protocols for mails

  • SMTP (optionally with STARTTLS)
  • SMTPS
  • IMAP (optionally with STARTTLS)

References

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mail_devel-0.16.0-py3-none-any.whl (29.7 kB view details)

Uploaded Python 3

File details

Details for the file mail_devel-0.16.0-py3-none-any.whl.

File metadata

  • Download URL: mail_devel-0.16.0-py3-none-any.whl
  • Upload date:
  • Size: 29.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for mail_devel-0.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 47c23fd6f966a0841401aadfaaae91d1ff61ab2a8bf91836b589fa5e8ad2788a
MD5 d64306fda0dc96730a0881fd59e280bf
BLAKE2b-256 2712d730d6d7eeaccebbd7774d0c2eb1fd514ac5291844a0e3f9d5275bd52ce8

See more details on using hashes here.

Supported by

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