Heimdall is a self-hosted email alias / forwarding service. I built this as a privacy tool to fight spam and also better manage access to my personal email address. As a self-hosted / managed solution, you have complete control over your data. With 3rd party email forwarding services, you are forced to trust a company with your emails.
This has also been a really fun project for me to learn more about AWS and the Serverless framework.
Check out: How I built Heimdall, an open-source personal email guardian.
- Heimdall is easy to run – it utilizes the idea of serverless computing, so there is zero server configuration or provisioning.
- Heimdall is easy to deploy – it uses the Serverless framework (not to be confused with small-letter serverless in Point 2 above) so you can deploy with a single command.
Setup
Pre-requisites: You need to own a domain and have an AWS account. For reasonable use cases, you should not exceed AWS’s free tier (which is very generous).
Optional: To be able to reply to emails, you need to request AWS Support to (un-sandbox your SES account
.
, and rename to . env . It is important that EMAIL matches your personal email exactly.
yarn global add serverless
Set up Serverless, then
serverless deploy
. Features
Receiving
Emails received on valid aliases will automatially be forwarded to your personal email address. Forwarded emails will preserve metadata information, such as any other recipients in the “to” or “CC” headers. The email subject will be prepended with the alias description in brackets [Some description] .
Reply
By default, your replies will be sent to the alias to be forwarded to the original sender. Other recipients in the original email will not receive your reply.
You can include other recipients in the “to” and “cc” list, either by manually inserting them, or using “reply-all”.
If you do that, you will disclose your email address to them. The original sender will still not be able to see your email address, or these other recipients (provided you reply to the alias).
Generate an alias
The description lets you identify an alias and its use. E.g. “Sign up for Service X”.
(
List aliases
Email [email protected] . You will receive a list of all aliases as a reply.
Dev note: This reads up to a maximum of 1MB of data (due to AWS’s limitations).
Remove an alias
Email [email protected] with the alias as the title (case-sensitive). You will receive the operation outcome (success / failure) as a reply.
Update an alias
Not supported yet.
Known Limitations
Currently, attachments are not supported.
GIPHY App Key not set. Please check settings