Skip to main content

A Python Mail Server

Project description

Build Status Coverage Status Documentation Status

Salmon - A Python Mail Server

Salmon is a pure Python mail server designed to create robust and complex mail applications in the style of modern web frameworks. Salmon is designed to sit behind a traditional mail server in the same way a web application sits behind Apache or Nginx. It has all the features of a web application stack (templates, routing, handlers, state machine) and plays well with other libraries, such as Django and SQLAlchemy.

Salmon has been released under the GNU GPLv3, as published by the FSF.

Features

Salmon supports running in many contexts for processing mail using the best technology currently available. Since Salmon is aiming to be a modern mail server and Mail processing framework, it has some features you don’t find in any other Mail server.

  • Written in portable Python that should run on almost any Unix server.

  • Handles mail in almost any encoding and format, including attachments, and canonicalizes them for easier processing.

  • Sends nearly pristine clean mail that is easier to process by other receiving servers.

  • Properly decodes internationalized mail into Python unicode, and translates Python unicode back into nice clean ascii and/or UTF-8 mail.

  • Supports working with Maildir queues to defer work and distribute it to multiple machines.

  • Can run as an non-root user on privileged ports to reduce the risk of intrusion.

  • Salmon can also run in a completely separate virtualenv for easy deployment.

  • A flexible and easy to use routing system lets you write stateful or stateless handlers of your email.

  • Ability to use Jinja2 or Mako templates to craft emails including the headers.

  • Easily configurable to use alternative sending and receiving systems, database libraries, or any other systems you need to talk to.

  • Yet, you don’t have to configure everything to get stated. A simple salmon gen command lets you get an application up and running quick.

  • Finally, many helpful commands for general mail server debugging and cleaning.

Installing

pip install salmon-mail

Project Information

Project documentation can be found here

Fork

Salmon is a fork of Lamson. In the summer of 2012 (2012-07-13 to be exact), Lamson was relicensed under a BSD variant that was revokable. The two clauses that were of most concern:

4. Contributors agree that any contributions are owned by the copyright holder
and that contributors have absolutely no rights to their contributions.

5. The copyright holder reserves the right to revoke this license on anyone who
uses this copyrighted work at any time for any reason.

I read that to mean that I could make a contribution but then have said work denied to me because the original author didn’t like the colour of my socks. So I went and found the latest version that was available under the GNU GPL version 3.

Salmon is an anagram of Lamson, if you hadn’t worked it out already.

Source

You can find the source on GitHub:

https://github.com/moggers87/salmon

Status

Salmon has just had some major changes to modernise the code-base. The main APIs should be compatible with releases prior to 3.0.0, but there’s no guarantee that older applications won’t need changes.

Python versions supported are: 3.8, 3.9, 3.10, 3.11, and 3.12.

See the CHANGELOG for more details on what’s changed since Salmon version 2.

License

Salmon is released under the GNU GPLv3 license, which can be found here

Contributing

Pull requests and issues are most welcome. Please read our code of conduct before contributing!

I will not accept code that has been submitted for inclusion in the original project due to the terms of its new licence.

Code Of Conduct

The Salmon project has adopted the Contributor Covenant Code version 1.4. By contributing to this project, you agree to abide by its terms.

The full text of the code of conduct can be found here

Testing

The Salmon project needs unit tests, code reviews, coverage information, source analysis, and security reviews to maintain quality. If you find a bug, please take the time to write a test case that fails or provide a piece of mail that causes the failure.

If you contribute new code then your code should have as much coverage as possible, with a minimal amount of mocking.

Tests can be run via:

$ python setup.py test

Alternatively, if you have multiple versions of Python installed locally:

$ pip install tox
$ tox -e py36,py37

Refer to the tox documentation for more information.

Development

Salmon is written entirely in Python and runs on Python 3. It should hopefully run on any platform that supports Python and has Unix semantics.

If you find yourself lost in source code, just yell.

PEP-8 should be followed where possible, but feel free to ignore the 80 character limit it imposes (120 is a good marker IMO).

Funding

If you have found Salmon to be useful and would like to see its continued development, please consider buying me a coffee.

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

salmon_mail-3.3.0.tar.gz (204.4 kB view details)

Uploaded Source

Built Distribution

salmon_mail-3.3.0-py3-none-any.whl (87.3 kB view details)

Uploaded Python 3

File details

Details for the file salmon_mail-3.3.0.tar.gz.

File metadata

  • Download URL: salmon_mail-3.3.0.tar.gz
  • Upload date:
  • Size: 204.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.4

File hashes

Hashes for salmon_mail-3.3.0.tar.gz
Algorithm Hash digest
SHA256 550d2db25dec887209947431e48dbfd83a79fa981f1f86a6521de74a27718bfe
MD5 7bc412fb59b9b12ea3ec3bc1fde99f9b
BLAKE2b-256 1c50d63e7ad2ac225704a65642a601ae65dcb5c5fe0dc396b0987b0dc194e0d6

See more details on using hashes here.

File details

Details for the file salmon_mail-3.3.0-py3-none-any.whl.

File metadata

  • Download URL: salmon_mail-3.3.0-py3-none-any.whl
  • Upload date:
  • Size: 87.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.4

File hashes

Hashes for salmon_mail-3.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 73a0c8af19f28a8cb674a95853265bf02928ed4d8d9484adb1c294698e2ed079
MD5 b027a83981bb4eb0545ce41a38928b49
BLAKE2b-256 ea400004dfd4f6b4e98eefae369a47c22a8d7ce3107fa768395c8dbe57383293

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