1
0
mirror of https://github.com/axllent/mailpit.git synced 2024-12-30 23:17:59 +02:00
An email and SMTP testing tool with API for developers
Go to file
2024-01-03 12:54:12 +13:00
.chglog Update git-chglog format 2023-03-10 14:52:35 +13:00
.github Bump wangyoucao577/go-release-action from 1.40 to 1.41 (#226) 2024-01-01 23:56:31 +13:00
cmd Feature: Add option to only allow SMTP recipients matching a regular expression (disable open-relay behaviour #219) 2024-01-03 12:06:36 +13:00
config Feature: Add option to only allow SMTP recipients matching a regular expression (disable open-relay behaviour #219) 2024-01-03 12:06:36 +13:00
internal UI: Automatically refresh connected browsers if Mailpit is upgraded (version change) 2024-01-03 12:54:12 +13:00
sendmail Chore: Update internal import paths 2023-09-25 19:29:30 +13:00
server UI: Automatically refresh connected browsers if Mailpit is upgraded (version change) 2024-01-03 12:54:12 +13:00
.dockerignore Feature:: Add multi-arch docker image 2022-08-04 22:51:20 +12:00
.gitignore Theme toggler (#136) 2023-06-30 17:13:12 +12:00
CHANGELOG.md Release v1.12.0 2024-01-02 20:05:54 +13:00
Dockerfile Docker: Expose default ports (1025/tcp 8025/tcp) 2023-03-09 15:49:47 +13:00
esbuild.config.mjs Build: Define Vue build options in esbuild 2023-06-30 22:16:43 +12:00
go.mod Libs: Update Go modules 2024-01-01 23:50:55 +13:00
go.sum Libs: Update Go modules 2024-01-01 23:50:55 +13: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 2024-01-03 12:24:33 +13:00
package.json Fix: New favicon notification badge to fix rendering issues (#210) 2023-12-04 21:32:59 +13:00
README.md Fix formatting 2024-01-02 19:01:50 +13:00

Mailpit - email testing for developers

CI Tests status CI build status CI Docker build status Code quality Go Report Card
Latest release Docker pulls

WebsiteDocumentationAPI


Mailpit is a small, fast, low memory, zero-dependency, multi-platform email testing tool & API for developers.

It acts as an SMTP server, provides a modern web interface to view & test captured emails, and includes an API for automated integration testing.

Mailpit was originally inspired by MailHog which is no longer maintained and hasn't seen active development or security updates for a few years now.

Mailpit

Features

  • Runs entirely from a single static binary
  • Modern web UI to view emails (formatted HTML, highlighted HTML source, text, headers, raw source, and MIME attachments including image thumbnails), including optional HTTPS
  • Optional basic authentication for web UI & API
  • HTML check to test & score mail client compatibility with HTML emails
  • Link check to test message links (HTML & text) & linked images
  • Create screenshots of HTML messages via web UI
  • Mobile and tablet HTML preview toggle in desktop mode
  • Advanced mail search
  • Message tagging
  • Real-time web UI updates using web sockets for new mail & optional browser notifications for new mail (when accessed via either HTTPS or localhost only)
  • SMTP server with optional STARTTLS & SMTP authentication (including an "accept any" mode)
  • SMTP relaying (message release) - relay messages via a different SMTP server including an optional allowlist of accepted recipients
  • Fast SMTP processing & storing - approximately 70-100 emails per second depending on CPU, network speed & email size, easily handling tens of thousands of emails
  • Configurable automatic email pruning (default keeps the most recent 500 emails)
  • A simple REST API for integration testing
  • Optional webhook for received messages
  • 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 package managers

  • Mac: brew install mailpit (to run automatically in the background: brew services start mailpit)
  • Arch Linux: available in the AUR as mailpit
  • FreeBSD: pkg 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 be extracted and copied to your $PATH, or simply run as ./mailpit.

Docker

See Docker instructions for 386, amd64 & arm64 images.

Compile from source

To build Mailpit from source, see Building from source.

Usage

Run mailpit -h to see options. More information can be seen in the docs.

If installed using homebrew, you may run brew services start mailpit to always run mailpit automatically.

Testing Mailpit

Please refer to the documentation on how to easily test email delivery to Mailpit.

Configuring sendmail

Mailpit's SMTP server (default on port 1025), so you will likely need to configure your sending application to deliver mail via that port. A common MTA (Mail Transfer Agent) that delivers system emails to an SMTP server is sendmail, used by many applications, including PHP. Mailpit can also act as substitute for sendmail. For instructions on how to set this up, please refer to the sendmail documentation.