aiosmtpd

A reimplementation of the Python stdlib smtpd.py based on asyncio.

Github stars Tracking Chart

=========================================
aiosmtpd - An asyncio based SMTP server

The Python standard library includes a basic
SMTP <http://www.faqs.org/rfcs/rfc5321.html>__ server in the
smtpd <https://docs.python.org/3/library/smtpd.html>__ module, based on the
old asynchronous libraries
asyncore <https://docs.python.org/3/library/asyncore.html>__ and
asynchat <https://docs.python.org/3/library/asynchat.html>__. These modules
are quite old and are definitely showing their age. asyncore and asynchat are
difficult APIs to work with, understand, extend, and fix.

With the introduction of the
asyncio <https://docs.python.org/3/library/asyncio.html>__ module in Python
3.4, a much better way of doing asynchronous I/O is now available. It seems
obvious that an asyncio-based version of the SMTP and related protocols are
needed for Python 3. This project brings together several highly experienced
Python developers collaborating on this reimplementation.

This package provides such an implementation of both the SMTP and LMTP
protocols.

Requirements

You need at least Python 3.5 to use this library. Both Windows and *nix are
supported.

License

aiosmtpd is released under the Apache License version 2.0.

Project details

As of 2016-07-14, aiosmtpd has been put under the aio-libs <https://github.com/aio-libs>__ umbrella project and moved to GitHub.

The best way to contact the developers is through the GitHub links above.
You can also request help by submitting a question on StackOverflow.

Building

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

$ python3 -m venv /path/to/venv
$ source /path/to/venv/bin/activate
$ python setup.py install

This will give you a command line script called smtpd which implements the
SMTP server. Use smtpd --help for details.

You will also have access to the aiosmtpd library, which you can use as a
testing environment for your SMTP clients. See the documentation links above
for details.

Developing

You'll need the tox <https://pypi.python.org/pypi/tox>__ tool to run the
test suite for Python 3. Once you've got that, run::

$ tox

Individual tests can be run like this::

$ tox -e py35-nocov -- -P <pattern>

where is a Python regular expression matching a test name.

You can also add the -E option to boost debugging output, e.g.::

$ tox -e py35-nocov -- -E

and these options can be combined::

$ tox -e py35-nocov -- -P test_connection_reset_during_DATA -E

Contents

.. toctree::
:maxdepth: 2

aiosmtpd/docs/intro
aiosmtpd/docs/concepts
aiosmtpd/docs/cli
aiosmtpd/docs/controller
aiosmtpd/docs/smtp
aiosmtpd/docs/lmtp
aiosmtpd/docs/handlers
aiosmtpd/docs/migrating
aiosmtpd/docs/manpage
aiosmtpd/docs/NEWS

Indices and tables

  • :ref:genindex
  • :ref:modindex
  • :ref:search

Main metrics

Overview
Name With Owneraio-libs/aiosmtpd
Primary LanguagePython
Program languagePython (Language Count: 2)
Platform
License:Apache License 2.0
所有者活动
Created At2016-07-14 13:51:17
Pushed At2025-04-11 07:49:23
Last Commit At2025-04-11 10:48:08
Release Count31
Last Release Namev1.4.6 (Posted on 2024-05-18 12:17:51)
First Release Name1.0a1 (Posted on 2015-10-19 21:51:18)
用户参与
Stargazers Count337
Watchers Count12
Fork Count96
Commits Count850
Has Issues Enabled
Issues Count181
Issue Open Count67
Pull Requests Count256
Pull Requests Open Count28
Pull Requests Close Count72
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private