This repository is a template that demonstrates how to automate the creation of aliases and group email addresses, and then forward those incoming emails to real email accounts—all using a Cloudflare Worker. The project is set up so that GitHub Actions handles the deployment process whenever code is pushed to (or merged into) the main branch.
Table of Contents
This project enables you to:
- Seamlessly create email aliases (e.g.
[email protected]
→[email protected]
). - Define group addresses (e.g.
[email protected]
→ multiple recipients). - Create child aliases (e.g.
[email protected]
→[email protected]
,[email protected]
, and[email protected]
). - Create easily identifiable spam aliases (e.g.
[email protected]
→[email protected]
).+
is also a default supported delimiter (like Gmail uses), you can configure your own delimiters in the config file. See config/email-config.yml.sample for an example.
- Automate routing logic through a single Cloudflare Worker.
- Maintain your email forwarding rules via code in a single repository.
The Worker listens for incoming emails on your domain(s) managed by Cloudflare and routes them to the appropriate real inbox(es), eliminating the need for manual configuration in traditional email forwarding solutions.
- Alias Creation: Define ephemeral or long-term aliases for your domain(s).
- Group Email: Forward incoming messages to multiple recipients based on group definitions.
- Automated Management: Update routing rules simply by pushing changes to this repository.
- Scalable: Cloudflare’s edge network handles large volumes of email with minimal latency.
- Secure & Configurable: Use environment variables to store secrets. TLS/SSL is handled by Cloudflare’s infrastructure.
Why use this project?
This project simplifies the management of email forwarding rules for your domain(s) by allowing you to define those rules in code and deploy them automatically.
How does this project work?
This project uses a Cloudflare Worker, set as a destination for a catch-all address, to listen for incoming emails and route them to the appropriate real inbox(es) based on the rules you define.
How do I define the routing rules?
You define the routing rules in a YAML file. The GitHub Action in this project will automatically convert the YAML into JSON for the Worker to consume.
How do I test the routing rules?
You can run tests locally to ensure the routing rules are correct. The GitHub Action in this project will also run the tests automatically when a PR is opened.
How do I deploy the routing rules?
The GitHub Action in this project will automatically deploy the routing rules to Cloudflare when code is pushed to the main branch. You can also manually deploy the routing rules using the wrangler
CLI.
What happens when I receive an email that matches an alias, but has a dot in it and then a bunch of other letters and numbers?
The Worker will ignore the dot and any characters that follow it when matching the alias. The mail will be forwarded to the correct email address, but maintain the dot and characters in the alias. This allows you to create spam aliases that are unique to each sender, but still route to the same email. Gmail does something similar with the +
character, which is also supported, but beware, it's easily identifiable and can be stripped out by the sender.
Can I create an alias for my child, and have the email forwarded to my child and me?
Yes, by default any alias that has the "child" type will be forwarded to that alias' email address as well as any parent aliases.
- A Cloudflare account with Workers enabled.
- A domain managed by Cloudflare with DNS records in place.
- Node.js >= 16.0 (for local development and testing).
- A basic understanding of GitHub Actions (used here to automate the deployment).
-
Use this Template
- Click the Use this template button on the GitHub repository page.
- Create a new repository under your GitHub account.
-
Clone Your New Repository
git clone https://github.com/<your-username>/<your-repo-name>.git cd <your-repo-name>
-
Install Dependencies
npm install
Installs the necessary dependencies for local testing.
-
Configure This Project for Your Cloudflare Account
- In your repository, locate
.github/workflows/deploy.yml
(or similarly named workflow file). - Create repository secrets for your Cloudflare account credentials:
CLOUDFLARE_ACCOUNT_ID
: Your Cloudflare account ID- Documentation for finding your account ID can be found here.
CLOUDFLARE_API_TOKEN
: Your Cloudflare API token or equivalent credentials- Documentation for creating an API token can be found here.
CLOUDFLARE_EMAIL
: The email account that is associated with your cloudflare accountCLOUDFLARE_API_KEY
: Your Cloudflare API key- Documentation for viewing your global API key can be found here.
- In your repository, locate
Pre-requisites:
-
Any email that you plan on forwarding to has to be added to your cloudflare account as a forwarding email address. You can use the "Add Verified Email to Cloudflare" action to add one by manually triggering this workflow: add-email-to-cloudflare.yml
-
Create a new email worker in your cloudflare account, under the target domain: https://dash.cloudflare.com///email/routing/workers
-
Name the email worker
email-forwarding-worker
, choose "Create my own" and click "Create". -
Go back to "Email Routing" and click "Routing rules".
-
Enable the "Catch-all address" and select the email-forwarding-worker from the "Destination" dropdown.
-
Save
Note: The worker must have the same name as the name that is set in the wrangler.toml
file.
Using the worker:
-
Defining Email Routing Rules in YAML
-
Instead of directly editing JSON, you must store your routing definitions in a YAML file.
-
The GitHub Action in this project will automatically convert this YAML into JSON for the Worker to consume.
-
Below is an example YAML configuration:
- domain: my-domain.io config: - aliases: - john - jacksr - senior emailAddress: [email protected] groups: - kids - parents - family - school type: parent - aliases: - jill - mom emailAddress: [email protected] groups: - kids - parents - family - school - basketball type: parent - aliases: - sally emailAddress: [email protected] groups: - kids - family type: child - aliases: - jack - jackjr - jr emailAddress: [email protected] groups: - kids - family type: child
-
You must save this YAML in a file called
config/email-config.yaml
. There is a sample file in this repository that you can use as a starting point. -
Commit and push your changes.
-
GitHub Actions will run the deployment process automatically and ensure your Worker code receives the correct JSON data.
-
-
Running Tests Locally
- If you only want to run tests locally:
npm test
- If you only want to run tests locally:
Deployment is automated via GitHub Actions.
When you push commits or merge pull requests into the main
branch (or whichever branch you configure), GitHub Actions will automatically:
- Build your project.
- Convert your YAML config into JSON.
- Upload the project and the config data to Cloudflare Workers using the credentials provided in your repository’s GitHub Secrets.
- Confirm the new version is deployed.
Contributions, issues, and feature requests are welcome! Feel free to check out the Issues section or open a Pull Request.
- Fork this repository.
- Create a new branch for your feature/bugfix.
- Make your changes.
- Submit a Pull Request for review.
This project is licensed under the MIT License. Feel free to use it as a starting point and modify it to suit your needs.
Happy email routing! If you run into any issues, please open an issue or submit a pull request.