@lando/mailpit
v1.0.0-beta.4
Published
A Mailpit integration plugin for Lando.
Downloads
12
Readme
Mailpit Integration Plugin for Lando
The official Mailpit integration plugin for Lando.
This is a work in progress. PRs and feedback are appreciated!
Planned Features
- [x] A Mailpit service for receiving emails.
- [x] Mailpit UI accessible at http and https routes.
- [x] Automatic configuration of services to send mail to Mailpit.
- [x] Automatic installation of Mailpit sendmail client and configuration into services that need it.
- [x] A
lando mailpit
command that shows connection information. - [ ] Automatic proxy configuration for the Mailpit UI.
- [ ] A global mailpit service that multiple apps can use.
- [ ]
lando mailpit
subcommands that interact with the mailpit service. - [ ] Automatic configuration of popular frameworks to send mail to Mailpit.
- [ ] Add a mailpit service to a recipe with a single line of configuration.
Installation
Install the Mailpit plugin:
lando plugin-add @lando/mailpit
Add a mailpit service to your landofile:
name: mysite
services:
mailpit:
type: mailpit
mailFrom: # Optional. The services to send mail from. Defaults to appserver.
- appserver
proxy:
mailpit:
- mailpit.mysite.lndo.site
Send mail from your app:
<?php
$to = '[email protected]';
$subject = 'Test email from My App';
$message = 'This is a test email sent via PHP.';
$headers = [
'From: [email protected]',
'Content-Type: text/plain; charset=utf-8'
];
mail($to, $subject, $message, implode("\r\n", $headers));
// The email will be captured by Mailpit and viewable at:
// http://mailpit.mysite.lndo.site
Commands
lando mailpit
Shows connection information for the Mailpit service, including:
- SMTP server host and port
- Pre-configured services that use sendmail
- Environment variables available for custom configurations
Contributing
To get started with contributing to this project, follow these steps:
Clone the repository:
git clone https://github.com/lando/mailpit.git cd mailpit
Install dependencies:
npm install
Set up your development environment:
- Ensure you have Node.js 20 or later installed.
- If you're using VS Code, consider installing the ESLint extension for real-time linting feedback.
Run the tests to verify the current state of the project:
npm test
Now you're ready to start developing! Check the issues page for tasks to work on, or feel free to propose new features or improvements.
Repository Structure
This repository is structured as follows:
builders/
: Contains the main service builder for the Mailpit plugin.config/
: Contains configuration files used in services managed by the Mailpit plugin.tasks/
: Contains Lando command implementations.test/
: Contains unit test files.examples/
: Example configurations and usage scenarios executed by Leia for testing.utils/
: Utility functions used by the Mailpit plugin.
Linting
This project uses ESLint for code linting. The configuration is defined in eslint.config.js
using the new flat config format. We use the Google ESLint configuration as a base and extend it with custom rules, including JSDoc validation.
To run the linter, use:
npm run lint
Testing
This project uses Mocha for unit testing. To run the tests, follow these steps:
Ensure you have all dependencies installed:
npm install
Run the unit tests:
npm run test:unit
The test files are located in the test
directory. The main test files include:
test/mailpit.spec.js
- Tests for the Mailpit buildertest/mailpitTask.spec.js
- Tests for the mailpit command
We also use Leia for integration testing. Leia steps through the README files in the examples
directory,
executes the examples as if they were a user, and validates things are rolling as they should. To run these tests:
npm run test:leia
To run all tests (unit and Leia):
npm test