Skip to main content

An asynchronous, highly configurable SMTP relay

Project description

Modern Relay

Welcome to Modern Relay’s documentation! The intention for this project is to build a mail relay that works seamlessly in the new IT landscape of cloud providers, API access, and the security measures that come with them. I’ve found that federating Microsoft 365 tenants and requiring MFA for all accounts is a great leap forward in securing organizations, but it introduces new strains on IT to integrate legacy devices/applications that an organization may not want to replace.

Modern Relay solves this problem by being a drop in replacement for the IIS-based SMTP relays that an organization likely already has in place. There are configurable “delivery agents” that Modern Relay uses to convert mail coming in from SMTP to different delivery schemes like an HTTP request to an API (e.g. Microsoft Graph). By leveraging APIs to different mail providers, you can skip licensing hassles, 2FA/app password woes, custom Exchange Online connectors, and adding another SPF address to your record.

Features

  • Fully asynchronous

  • Uses customizable delivery actions based on the origin IP address

  • Queues mail in the event of delivery failure for later resending

  • Access control to allow certain origin addresses/subnets or certain destination domains

  • Supports anonymous and plain login schemes

  • Supports STARTTLS if you provide the certs

  • Supports Microsoft Graph API mail delivery

Requirements

You need at least Python 3.6 to use this library

Supported Platforms

ModernRelay is tested on CPython and PyPy3.7 for the following platforms:

  • Windows 10

  • Ubuntu 20.04

  • Ubuntu 18.04

Installation

For Linux or Windows environments where you’re managing your own python installation, install with pip:

pip install modernrelay

You will need to set the appropriate environment variables for your chosen delivery agents. See individual agent documentation for more details.

If an installer is more your speed, go download a Windows msi installer from the releases section and run it.

Building

You can install this package in a virtual environment like so:

$ python3 -m venv /path/to/venv
$ source /path/to/venv/bin/activate
$ git clone https://github.com/blbuford/ModernRelay.git
$ cd ModernRelay
$ pip install -e .[dev]

License

ModernRelay is released under the MIT License.

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

ModernRelay-0.0.3.tar.gz (37.2 kB view details)

Uploaded Source

Built Distribution

ModernRelay-0.0.3-py3-none-any.whl (34.2 kB view details)

Uploaded Python 3

File details

Details for the file ModernRelay-0.0.3.tar.gz.

File metadata

  • Download URL: ModernRelay-0.0.3.tar.gz
  • Upload date:
  • Size: 37.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.25.1

File hashes

Hashes for ModernRelay-0.0.3.tar.gz
Algorithm Hash digest
SHA256 00f37477b952eec17b97afad3a1328f9c035377be1ef7c6d7d19490b85f67e48
MD5 a636a61a18368d533ca5efc225a77d37
BLAKE2b-256 7fa1895a7e946358ef2bee2480a5f7a0ecd0929a9b443b0c7176bdf62f28956a

See more details on using hashes here.

File details

Details for the file ModernRelay-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: ModernRelay-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 34.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.25.1

File hashes

Hashes for ModernRelay-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f23eeaa082d654b00896f7ae12f6c45d4d5379a76c7233cf6262c929df1b94a6
MD5 84e0a8a424a40f45a3e8dfd167e6b9c4
BLAKE2b-256 d7a99932c0560b870e017efbca781c459326d7e6cbb60cac41b2ca301ef839ba

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