2022-08-18 11:41:37 +02:00
# Mailpit - email testing for developers
2022-07-29 13:23:08 +02:00
2022-08-07 00:57:45 +02:00
![Tests ](https://github.com/axllent/mailpit/actions/workflows/tests.yml/badge.svg )
![Build status ](https://github.com/axllent/mailpit/actions/workflows/release-build.yml/badge.svg )
![Docker builds ](https://github.com/axllent/mailpit/actions/workflows/build-docker.yml/badge.svg )
![CodeQL ](https://github.com/axllent/mailpit/actions/workflows/codeql-analysis.yml/badge.svg )
2022-08-07 12:38:23 +02:00
[![Go Report Card ](https://goreportcard.com/badge/github.com/axllent/mailpit )](https://goreportcard.com/report/github.com/axllent/mailpit)
2022-08-07 00:57:45 +02:00
2023-03-29 05:36:00 +02:00
Mailpit is a multi-platform email testing tool & API for developers.
2022-07-29 13:23:08 +02:00
It acts as both an SMTP server, and provides a web interface to view all captured emails.
Mailpit is inspired by [MailHog ](#why-rewrite-mailhog ), but much, much faster.
2022-10-07 13:26:46 +02:00
![Mailpit ](https://raw.githubusercontent.com/axllent/mailpit/develop/docs/screenshot.png )
2022-07-29 13:23:08 +02:00
2022-08-05 14:09:20 +02:00
2022-07-29 13:23:08 +02:00
## Features
2022-08-18 11:41:37 +02:00
- Runs entirely from a single binary, no installation required
2022-07-29 14:17:56 +02:00
- SMTP server (default `0.0.0.0:1025` )
2023-04-01 06:02:49 +02:00
- Web UI to view emails (formatted HTML, highlighted HTML source, text, headers, raw source and MIME attachments including image thumbnails)
2023-04-03 08:53:11 +02:00
- Mobile and tablet HTML preview toggle in desktop mode
2022-09-16 13:15:40 +02:00
- Advanced mail search ([see wiki](https://github.com/axllent/mailpit/wiki/Mail-search))
2022-11-13 06:20:54 +02:00
- Message tagging ([see wiki](https://github.com/axllent/mailpit/wiki/Tagging))
2022-07-30 09:57:44 +02:00
- Real-time web UI updates using web sockets for new mail
2022-08-06 15:07:04 +02:00
- Optional browser notifications for new mail (HTTPS only)
2022-07-29 13:23:08 +02:00
- Configurable automatic email pruning (default keeps the most recent 500 emails)
2022-08-30 12:42:43 +02:00
- Email storage either in a temporary or persistent database ([see wiki](https://github.com/axllent/mailpit/wiki/Email-storage))
2022-09-02 14:35:02 +02:00
- Fast SMTP processing & storing - approximately 70-100 emails per second depending on CPU, network speed & email size
2023-03-12 04:06:26 +02:00
- Can handle tens of thousands of emails
- Optional SMTP with STARTTLS & SMTP authentication, including an "accept anything" mode ([see wiki](https://github.com/axllent/mailpit/wiki/SMTP-with-STARTTLS-and-authentication))
2022-08-06 10:00:05 +02:00
- Optional HTTPS for web UI ([see wiki](https://github.com/axllent/mailpit/wiki/HTTPS))
- Optional basic authentication for web UI ([see wiki](https://github.com/axllent/mailpit/wiki/Basic-authentication))
2022-11-01 09:24:28 +02:00
- A simple REST API ([see docs](docs/apiv1/README.md))
2022-08-06 10:00:05 +02:00
- Multi-architecture [Docker images ](https://github.com/axllent/mailpit/wiki/Docker-images )
2022-07-29 13:23:08 +02:00
## Installation
2023-02-06 04:27:08 +02:00
The Mailpit web UI listens by default on `http://0.0.0.0:8025` , and the SMTP port on `0.0.0.0:1025` .
2023-02-06 04:24:36 +02:00
Mailpit runs as a single binary and can be installed in different ways:
2023-04-01 06:02:49 +02:00
2023-02-06 04:24:36 +02:00
### Install via Brew (Mac)
Add the repository to your taps with `brew tap axllent/apps` , and then install Mailpit with `brew install mailpit` .
2023-04-01 06:02:49 +02:00
2023-02-06 04:24:36 +02:00
### Install via bash script (Linux & Mac)
2022-09-14 02:11:52 +02:00
Linux & Mac users can install it directly to `/usr/local/bin/mailpit` with:
```bash
sudo bash < < (curl -sL https://raw.githubusercontent.com/axllent/mailpit/develop/install.sh)
```
2023-04-01 06:02:49 +02:00
2023-02-06 04:24:36 +02:00
### Download static binary (Windows, Linux and Mac)
2022-07-29 13:23:08 +02:00
2023-02-06 04:24:36 +02:00
Static binaries can always be found on the [releases ](https://github.com/axllent/mailpit/releases/latest ). The `mailpit` binary can extracted and copied to your `$PATH` , or simply run as `./mailpit` .
2023-04-01 06:02:49 +02:00
2023-02-06 04:24:36 +02:00
### Docker
See [Docker instructions ](https://github.com/axllent/mailpit/wiki/Docker-images ).
2022-07-29 13:23:08 +02:00
2023-04-01 06:02:49 +02:00
2023-02-06 04:24:36 +02:00
### Compile from source
To build Mailpit from source see [building from source ](https://github.com/axllent/mailpit/wiki/Building-from-source ).
2022-09-14 07:25:56 +02:00
2022-07-29 13:23:08 +02:00
### Configuring sendmail
There are several different options available:
You can use `mailpit sendmail` as your sendmail configuration in `php.ini` :
```
sendmail_path = /usr/local/bin/mailpit sendmail
```
2022-08-05 05:40:32 +02:00
If Mailpit is found on the same host as sendmail, you can symlink the Mailpit binary to sendmail, eg: `ln -s /usr/local/bin/mailpit /usr/sbin/sendmail` (only if Mailpit is running on default 1025 port).
2022-07-29 13:23:08 +02:00
You can use your default system `sendmail` binary to route directly to port `1025` (configurable) by calling `/usr/sbin/sendmail -S localhost:1025` .
2022-08-06 10:00:05 +02:00
You can build a Mailpit-specific sendmail binary from source (see [building from source ](https://github.com/axllent/mailpit/wiki/Building-from-source )).
2022-07-29 13:23:08 +02:00
## Why rewrite MailHog?
2022-07-29 13:38:09 +02:00
I had been using MailHog for a few years to intercept and test emails generated from several projects. MailHog has a number of severe performance issues, many of the modules are horribly out of date, and other than a few accepted MRs, it is not actively developed.
2022-07-29 13:23:08 +02:00
2022-09-15 07:40:39 +02:00
Initially I started trying to upgrade a fork of MailHog (both the UI as well as the HTTP server & API), but soon discovered that it is (with all due respect) very poorly designed. It is over-engineered (split over 9 separate projects) and has too many unnecessary features for my purpose. It performs exceptionally poorly when dealing with large amounts of emails or processing any email with an attachment (a single email with a 3MB attachment can take over a minute to ingest). The API also transmits a lot of duplicate and unnecessary data on every message request for all web calls, and there is no HTTP compression.
2022-07-29 13:23:08 +02:00
In order to improve it I felt it needed to be completely rewritten, and so Mailpit was born.