1
0
mirror of https://github.com/axllent/mailpit.git synced 2025-01-10 00:43:53 +02:00
An email and SMTP testing tool with API for developers
Go to file
2023-04-25 08:57:16 +12:00
.chglog Update git-chglog format 2023-03-10 14:52:35 +13:00
.github Bump version of booxmedialtd/ws-action-parse-semver 2023-04-04 17:02:31 +12:00
cmd API: Enable cross-origin resource sharing (CORS) configuration 2023-04-21 12:49:49 +12:00
config API: Message relay / release 2023-04-21 12:10:13 +12:00
docs API: Include Reply-To in message summary (including Web UI) 2023-04-01 17:05:18 +13:00
sendmail Correctly parse -f argument for sendmail 2023-04-21 12:13:05 +12:00
server Feature: Add Access-Control-Allow-Methods methods when CORS origin is set 2023-04-25 08:57:16 +12:00
storage Move logging variable level to logger module 2023-04-21 11:59:26 +12:00
utils API: Message relay / release 2023-04-21 12:10:13 +12:00
.dockerignore Feature:: Add multi-arch docker image 2022-08-04 22:51:20 +12:00
.gitignore feature: Switch backend storage to use SQLite 2022-08-30 22:42:43 +12:00
CHANGELOG.md Release v1.6.4 2023-04-24 22:29:35 +12:00
Dockerfile Docker: Expose default ports (1025/tcp 8025/tcp) 2023-03-09 15:49:47 +13:00
esbuild.config.mjs Feature: OpenAPI / Swagger schema 2023-03-31 18:44:08 +13:00
go.mod Libs: Update Go modules 2023-04-21 12:12:14 +12:00
go.sum Libs: Update Go modules 2023-04-21 12:12:14 +12:00
install.sh Fix typo 2023-01-14 00:31:03 +13:00
LICENSE First commit 2022-07-29 23:23:08 +12:00
main.go Fix: Normalize running binary name detection (Windows) 2022-09-21 15:56:20 +12:00
package-lock.json Libs: Update node modules 2023-04-21 11:41:43 +12:00
package.json Feature: OpenAPI / Swagger schema 2023-03-31 18:44:08 +13:00
README.md Update README 2023-04-21 14:19:32 +12:00

Mailpit - email testing for developers

Tests Build status Docker builds CodeQL Go Report Card

Mailpit is a multi-platform email testing tool & API for developers.

It acts as both an SMTP server, and provides a web interface to view all captured emails.

Mailpit is inspired by MailHog, but much, much faster.

Mailpit

Features

  • Runs entirely from a single binary, no installation required
  • SMTP server (default 0.0.0.0:1025)
  • Web UI to view emails (formatted HTML, highlighted HTML source, text, headers, raw source and MIME attachments including image thumbnails)
  • Mobile and tablet HTML preview toggle in desktop mode
  • Advanced mail search (see wiki)
  • Message tagging (see wiki)
  • Real-time web UI updates using web sockets for new mail
  • Optional browser notifications for new mail (HTTPS only)
  • Configurable automatic email pruning (default keeps the most recent 500 emails)
  • Email storage either in a temporary or persistent database (see wiki)
  • Fast SMTP processing & storing - approximately 70-100 emails per second depending on CPU, network speed & email size, easily handling tens of thousands of emails
  • SMTP relaying / message release - relay messages via a different SMTP server (see wiki)
  • Optional SMTP with STARTTLS & SMTP authentication, including an "accept anything" mode (see wiki)
  • Optional HTTPS for web UI (see wiki)
  • Optional basic authentication for web UI (see wiki)
  • A simple REST API (see docs)
  • Multi-architecture Docker images

Installation

The Mailpit web UI listens by default on http://0.0.0.0:8025, and the SMTP port on 0.0.0.0:1025.

Mailpit runs as a single binary and can be installed in different ways:

Install via Brew (Mac)

Add the repository to your taps with brew tap axllent/apps, and then install Mailpit with brew install mailpit.

Install via bash script (Linux & Mac)

Linux & Mac users can install it directly to /usr/local/bin/mailpit with:

sudo bash < <(curl -sL https://raw.githubusercontent.com/axllent/mailpit/develop/install.sh)

Download static binary (Windows, Linux and Mac)

Static binaries can always be found on the releases. The mailpit binary can extracted and copied to your $PATH, or simply run as ./mailpit.

Docker

See Docker instructions.

Compile from source

To build Mailpit from source see building from source.

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

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).

You can use your default system sendmail binary to route directly to port 1025 (configurable) by calling /usr/sbin/sendmail -S localhost:1025.

You can build a Mailpit-specific sendmail binary from source (see building from source).

Why rewrite MailHog?

I had been using MailHog for a few years to intercept and test emails generated from several projects. MailHog has a number of performance issues, many of the frontend and Go modules are horribly out of date, and it is not actively developed.

Initially I tried 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 to its authors) poorly designed. It is in my opinion over-engineered (split over 9 separate projects), and performs very poorly when dealing with large amounts of emails or processing emails with an attachments (a single email with a 3MB attachment can take over a minute to ingest). Finally, the API transmits a lot of duplicate and unnecessary data on every browser request, and there is no HTTP compression.

In order to improve it I felt it needed to be completely rewritten, and so Mailpit was born.