Skip to main content

Fake SMTP server

Project description

nullsmtp
========

.. image:: https://travis-ci.org/MasterOdin/nullsmtp.svg?branch=master
:target: https://travis-ci.org/MasterOdin/nullsmtp
:alt: Build Status

nullsmtp is a fake SMTP server (written in python) which can be used for development. The server catches incoming mail,
writes them to a file, and doesn't actually send it out to the intended recipients. All emails are saved to a directory
(defaults to ``/var/log/nullsmtp``, but can be changed via flag) where each email address sent to gets its own folder
and then emails are stored in that folder named ``{sender}.{time}.msg``. This is useful for debugging applications
where you don't want a GUI (as you're running a headless VM say), but still actually need to see the messages that
were sent in the system, without having to worry about things getting bounced or whatever.

Generally, you'd probably want to install this instead of something like sendmail or some other package that would
handle sending mail from your server.

Requirements
============
nullsmtp relies on Python 3.3+ and just its standard library. Recommended to also have ``pip`` for installation.

Installation
============
Recommended Installation is through PyPi::

pip install nullsmtp

Or if you've cloned the repository::

python3 setup.py install


Usage
=====
::

usage: nullsmtp [-h] [--no-fork] [-H HOST] [-P PORT] [--mail-dir MAIL_DIR]
[-v]

optional arguments:
-h, --help show this help message and exit
--no-fork Don't fork and run nullsmtp as a daemon. Additionally,
this willprint all log messages to stdout/stderr and
all emails to stdout.
-H HOST, --host HOST Host to listen on
-P PORT, --port PORT Port to listen on
--mail-dir MAIL_DIR Location to write logs and emails (defaults to
~/.nullsmtp)
-v, --version show program's version number and exit
By default, you will need to use sudo as the server wants to bind itself to localhost and port 22.
However, if you use a different port, then it will not require using sudo. However, note, that if the current running
user of the script does not have access to create a directory/file within ``/var/log`` or ``/var/log/nullsmtp``, then
no emails will be written to file, but just through the console.

If the mail directory is writeable to, then you should have the following directory structure::

nullsmtp.log
person1@example.com/
1492024232.person2@example.com.msg
1492024462.person2@example.com.msg
1493678462.person1@example.com.msg
person2@example.com/
person1@example.com.1232421423.msg

where ``nullsmtp.log`` a log file for the system, and then each folder represents a person's "inbox" and inside
are messages from someone at a given timestamp (seconds from epoch).

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

nullsmtp-0.3.1.tar.gz (5.4 kB view details)

Uploaded Source

File details

Details for the file nullsmtp-0.3.1.tar.gz.

File metadata

  • Download URL: nullsmtp-0.3.1.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for nullsmtp-0.3.1.tar.gz
Algorithm Hash digest
SHA256 d618e9f5027ae91a8c202621dd241ca45f47c230551ceacc4155c570e70c59aa
MD5 00eee4a96b28f7ad29bb19197937129a
BLAKE2b-256 2b8d0ee0137c465144ed517e427279730725e3f57a18279a00392e0d55e4bfe0

See more details on using hashes here.

Provenance

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