Skip to content

Mailboar is an email test server written in Rust.

License

Notifications You must be signed in to change notification settings

aeyoll/mailboar

Repository files navigation

Mailboar

Mailboar

GitHub Actions workflow status Conventional Commits Minimum rustc version License

Mailboar is an email test server written in Rust.

In the backend, it uses a fork of Tiny MailCatcher, rewritten with the Axum framework, to provide extra features.

Features

  • Local SMTP server
  • REST API
  • Web interface to view emails as plain text, HTML or source code, download attachments.
  • SSE to receive new emails in real time.
  • Dark and light themes.
  • Allow to send emails to a specific address to view them in a real mailbox.

REST API

The REST API is the same as the one of MailCatcher and Tiny MailCatcher:

  • The GET/DELETE http://localhost:1080/messages endpoint returns/delete all messages in the repository.
  • The GET http://localhost:1080/messages/:id.json endpoint returns a single message in JSON format.
  • The GET http://localhost:1080/messages/:id.source endpoint returns the message source.
  • The GET http://localhost:1080/messages/:id.html endpoint returns the HTML version of this message.
  • The GET http://localhost:1080/messages/:id.eml endpoint returns the EML version of this message.
  • The GET http://localhost:1080/messages/:id.plain endpoint returns the text/plain version of this message.
  • The DELETE http://localhost:1080/messages/:id endpoint deletes a message.
  • The GET http://localhost:1080/messages/:id/parts/:cid endpoint returns attachments by content ID.

In addition, the following endpoints are available:

  • The POST http://localhost:1080/messages/:id/send endpoint sends a message to the specified address.
  • The GET http://localhost:1080/events endpoint returns SSE events.

Installation

Using Cargo, Git and pnpm

First, install mailboar using Cargo:

cargo install mailboar

Then, clone this repository, and build the static assets using https://pnpm.io/. Node >= 20 is required.

cd crates/frontend
pnpm i # Install dependencies
pnpm run build # Build static assets

This will create a static repository with all the assets.

Finally, launch mailboar from the cloned repository:

mailboar --ip 127.0.0.1 --smtp-port=1025 --api-port=1080 --http-port=8025 --assets-path=crates/frontend/static # default values

Environment variables configuration

To be able to send emails to a specific address, you need to configure the SMTP server to use. The following environment variables can be used to do so:

  • MAILBOAR_SMTP_DSN: The DSN of the SMTP server to use. Defaults to smtp://127.0.0.1:25.
  • MAILBOAR_SMTP_FROM: The email address to use as the sender. Defaults to mailboar@localhost.

The MAILBOAR_SMTP_DSN can be configured in multiple ways. Go to lettre documentation to see all the possible configurations.

Using Docker

There is also a small Docker image available, with all batteries included:

docker run --rm --init -t -p 1080:1080 -p 1025:1025 -p 8025:8025 aeyoll/mailboar:latest

Development

For easier development, use https://github.com/watchexec/cargo-watch to auto-compile on change:

cargo watch -x 'run'

Auto-compile static assets:

pnpm run start

Rust version requirements

1.71.0+