Skip to main content

LocalStack Extension: MailHog

Project description

LocalStack Mailhog Extension

Install LocalStack Extension

Web and API based SMTP testing directly in LocalStack using MailHog.

If the standard configuration is used, LocalStack will serve the UI through http://mailhog.localhost.localstack.cloud:4566 or http://localhost:4566/mailhog/. It will also configure SMTP_HOST automatically, which points all services using SMTP, including SES, to MailHog.

Install

Install the extension either via our extensions manager at https://app.localstack.cloud, or via the CLI

localstack extensions install localstack-extension-mailhog

After starting LocalStack, you should see these lines in the log:

2023-07-26T10:00:08.072  INFO --- [  MainThread] mailhog.extension          : serving mailhog extension on host: http://mailhog.localhost.localstack.cloud:4566
2023-07-26T10:00:08.072  INFO --- [  MainThread] mailhog.extension          : serving mailhog extension on path: http://localhost:4566/mailhog/

Install from GitHub repository

Alternatively, you can install the latest unreleased version directly from the GitHub repository by running:

localstack extensions install "git+https://github.com/localstack/localstack-extensions/#egg=localstack-mailhog-extension&subdirectory=mailhog"

Integration with LocalStack

When using this extension, LocalStack is automatically configured to use the MailHog SMTP server when sending emails. For example, if you run the following SES commands:

$ awslocal ses verify-email-identity --email-address user1@yourdomain.com
$ awslocal ses send-email \                                              
    --from user1@yourdomain.com \
    --message 'Body={Text={Data="Hello from LocalStack to MailHog"}},Subject={Data=Test Email}' \
    --destination 'ToAddresses=recipient1@example.com'
{
    "MessageId": "ktrmpmhohorxfbjd-dzebwdgu-odnm-wyvz-pezg-mijejwlvaxtr-psfctr"
}

You should see the mail arriving in MailHog. Screenshot at 2023-07-26 12-08-54

Configure

You can use the MailHog configuration environment variables to configure the extension. When using the CLI, you can add them by using DOCKER_FLAGS='-e MH_<var>=<val> -e ...'. If you are using docker compose, simply add them as environment variables to the container.

Development

Install local development version

To install the extension into localstack in developer mode, you will need Python 3.10, and create a virtual environment in the extensions project.

In the newly generated project, simply run

make install

Then, to enable the extension for LocalStack, run

localstack extensions dev enable .

You can then start LocalStack with EXTENSION_DEV_MODE=1 to load all enabled extensions:

EXTENSION_DEV_MODE=1 localstack start

Known Limitations

The MailHog UI supports real-time updates through websockets, which is currently not supported through the default :4566 port. When you open the UI, you may see this error in the LocalStack logs, which is safe to ignore. The UI won't update automatically though, so you need to click the refresh button.

2023-07-25T18:23:12.465 ERROR --- [-functhread3] hypercorn.error            : Error in ASGI Framework
Traceback (most recent call last):
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/hypercorn/asyncio/task_group.py", line 23, in _handle
await app(scope, receive, send, sync_spawn, call_soon)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/hypercorn/app_wrappers.py", line 33, in __call__
await self.app(scope, receive, send)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/localstack/aws/serving/asgi.py", line 67, in __call__
return await self.wsgi(scope, receive, send)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/localstack/http/asgi.py", line 324, in __call__
raise NotImplementedError("Unhandled protocol %s" % scope["type"])
NotImplementedError: Unhandled protocol websocket
2023-07-25T18:23:12.465 ERROR --- [-functhread3] hypercorn.error            : Error in ASGI Framework
Traceback (most recent call last):
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/hypercorn/asyncio/task_group.py", line 23, in _handle
await app(scope, receive, send, sync_spawn, call_soon)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/hypercorn/app_wrappers.py", line 33, in __call__
await self.app(scope, receive, send)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/localstack/aws/serving/asgi.py", line 67, in __call__
return await self.wsgi(scope, receive, send)
File "/opt/code/localstack/.venv/lib/python3.10/site-packages/localstack/http/asgi.py", line 324, in __call__
raise NotImplementedError("Unhandled protocol %s" % scope["type"])

Licensing

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

localstack_extension_mailhog-0.2.0.tar.gz (7.0 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file localstack_extension_mailhog-0.2.0.tar.gz.

File metadata

File hashes

Hashes for localstack_extension_mailhog-0.2.0.tar.gz
Algorithm Hash digest
SHA256 d0ee01865a788f023a88b810d7154665bbf41d1d25040b6a933ef278ee9d24c2
MD5 80cdbca84c76b525060ef4a1a058ec2e
BLAKE2b-256 738a97308ff78ae698c3441221e7bf2dd97c43c621039246cb28d62d79e44a71

See more details on using hashes here.

File details

Details for the file localstack_extension_mailhog-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for localstack_extension_mailhog-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7e3445f89f10f4c623c053e206855213b7d1623a51cb2dbc6653687baabb87e0
MD5 0d6e4b7f115bde034470b5e2f5209cfc
BLAKE2b-256 722b184e4d04412f4373577a94ddaa2e278c2fd7fcbc8ac2a83a2b4cfa30a357

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page