An open API service indexing awesome lists of open source software.

https://github.com/skulltech/drymail

Makes sending emails easy and DRY — For Python 3.
https://github.com/skulltech/drymail

email email-sender python python3 smtp smtp-client

Last synced: 23 days ago
JSON representation

Makes sending emails easy and DRY — For Python 3.

Awesome Lists containing this project

README

        

# drymail
Makes sending emails easy and [DRY](https://en.wikipedia.org/wiki/Don%27t_repeat_yourself) — For Python 3.

[![PyPI version](https://badge.fury.io/py/drymail.svg)](https://badge.fury.io/py/drymail)

__Drymail__ is a minimalist wrapper over Python’s existing [smtplib](https://docs.python.org/3/library/smtplib.html) and [email](https://docs.python.org/3/library/email.html) libraries, designed to be friendly but unrestrictive. Here’s how you might send a simple email with an attachment using _drymail_.

```python
from drymail import SMTPMailer, Message

client = SMTPMailer(host='smtp.email.com', user='johndoe', password='password', tls=True)
message = Message(subject='Congrats on the new job!', sender=('John Doe', '[email protected]'),
receivers=[('Jane Doe', '[email protected]'), '[email protected]'], text='When is the party? ;)')
message.attach(filename='/path/to/congrats.pdf', mimetype='application/pdf')

client.send(message)
```

## Features

- Supports creating email with HTML content, plaintext content, or both!
- Supports mentioning contacts in the `“John Doe" ` format.
- Support standard headers like `CC`, `BCC`, `Reply-To` and `Authors`.
- Supports injecting custom headers.
- Supports adding attachments.
- And most importantly — the library being minimalist, it doesn’t restrict you in any way like some of the most fancier email frameworks do.

## Installation

Install `drymail` by running —

```console
$ pip3 install drymail
```

## Documentation

Documentation is available at https://drymail.readthedocs.io/

## Agenda

- Test suite.
- Restructure the `Message` class to handle dynamic `prepare`.

## Contribute

All kinds of contribution are welcome.

- Issue Tracker — https://github.com/drymail/issues
- Source Code — https://github.com/drymail

## License

This project is licensed under the MIT license.