This blog post explains how an MTA-STS policy works and how to implement it on GitHub Pages.
MTA-STS (Mail Transfer Agent Strict Transport Security) is a security protocol that enforces the use of secure TLS connections for email communication. It helps protect against attacks such as TLS downgrade and man-in-the-middle attacks by ensuring that emails are only delivered over encrypted channels with properly validated TLS certificates.
While SPF, DKIM, and DMARC focus on verifying the authenticity of email messages and ensuring they originate from authorized domains, MTA-STS specifically focuses on securing the transport layer between mail servers. By using a policy file retrieved over HTTPS, MTA-STS allows receiving domains to specify their requirement for encrypted connections, ensuring that sending mail servers only deliver mail over verified secure channels, thereby enhancing the overall security of email transport.
How MTA-STS Works
-
Discovery:
- When a sending mail server (MTA) wants to deliver an email to a domain, it first checks for the presence of the
_mta-sts.example.com
DNS TXT record. - If the record exists, the sending server retrieves the policy file from
https://mta-sts.example.com/.well-known/mta-sts.txt
.
- When a sending mail server (MTA) wants to deliver an email to a domain, it first checks for the presence of the
-
Policy Evaluation:
- The sending server reads the policy file and checks the mode (enforce, testing, or none).
- If the mode is “enforce,” the sending server must use TLS and verify the certificate of the receiving server.
-
TLS Enforcement:
- The sending server attempts to establish a TLS connection with the receiving server.
- If the connection cannot be established securely according to the policy, the sending server may defer delivery and try again later.
MTA-STS benefits:
- Emails are transfered over a secure TLS connection
- Must use TLS-Version 1.2 or higher
- For the TLS Certificates they need to:
- Certificate Subject needs to match the MX-Entry
- They need to be signed and issued by a public trusthworthy CA
- They need to be valid (valid from / valid until)
MTA-STS consists of:
- MTA STS DNS TXT Record (
_mta-sts.example.com
) - MTA-STS Policy (
https://mta-sts.example.com/.well-known/mta-sts.txt
) - SMTP TLS Reporting DNS TXT Record (
_smtp._tls.example.com
)
Implement an MTA-STS policy for a domain
Adding the DNS TXT Record for the MTA STS Policy
This TXT
record is placed at _mta-sts.example.com
and signals the presence of an MTA-STS policy.
_mta-sts.example.com IN TXT "v=STSv1; id=20240728"
v=STSv1:
Indicates the version of the MTA-STS policy.id=2024072801
: A unique identifier for the policy. This can be a date-based identifier or any other unique string. It must be updated whenever the policy file is changed.
Host the MTA-STS Policy on Github Pages
- Create a new public repository called
mta-sts
- Disabling Jekyll, GitHub Pages is powered by Jekyll, a static website generator. However, Jekyll does not serve folders that begin with a dot. In order to do so, we’ll add a single empty file called
.nojekyll
to the repo. - Creating the MTA-STS Policy in
.well-known/mta-sts.txt
with the folliwing content:
version: STSv1
mode: testing
mx: your-mx.com
mx: your-mx.com
max_age: 604800
-
Activating GitHub Pages for the subdomain:
mta-sts
- Go to your DNS provider and add a
CNAME
record with the following details:
Host: mta-sts.example.com Value: github-username.github.io.
- After adding the record, return to your GitHub repository, click Settings in the repository navigation, and scroll down to Pages.
- Under Build and deployment, change the Branch to be the
main
and selectroot
as the publishing folder. Click Save, this will activate Github pages. - Under Custom domain add
mta-sts.example.com
, this will create a commit that adds aCNAME
file directly to the root of your repository.
- Under Build and deployment, change the Branch to be the
- Go to your DNS provider and add a
-
Once your custom domain is set up, GitHub will begin the process of issuing an SSL certificate using Let’s Encrypt. This process typically takes around 15 minutes but can take up to 24 hours. Once the certificate is issued, the Enforce HTTPS checkbox will be clickable. Please enable this setting if you are allowed to do so. After enabling this setting, the policy is deployed. You can verify this by navigating to:
https://mta-sts.example.com/.well-known/mta-sts.txt
- you should see the policy, and it should have loaded overHTTPS
.
Example:
- MTA-STS policy for
vand3rlinden.com
: https://mta-sts.vand3rlinden.com/.well-known/mta-sts.txt - Repository of the MTA-STS policy for
mta-sts.vand3rlinden.com
: https://github.com/vand3rlinden/mta-sts
Detailed Explanation of the Policy File
version: STSv1
: Indicates the version of the MTA-STS policy.mode: enforce
: Specifies that the policy should be strictly enforced. Other modes aretesting
(send report only) andnone
(do nothing).mx
: Lists each of the MX servers that handle email for your domain. If needed, wildcards are allowd, such as*.j-v1.mx.microsoft
max_age: 604800
: Specifies the duration (in seconds) that the policy is valid. After this time, the sending MTA should refresh the policy.
In the mta-sts.txt
file, you should list all MX servers that are used for receiving emails for your domain and that support TLS. This ensures that sending MTAs know which servers to establish secure connections with when delivering emails to your domain.
Recommendations
- Start with Testing Mode: It’s advisable to start with the
testing
mode. This allows you to monitor and log the results without affecting email delivery. It helps you ensure that your MX servers are correctly configured to support TLS before enforcing the policy. - Transition to Enforce Mode: Once you are confident that your MX servers support TLS and that email can be securely delivered, you can switch to
enforce
mode to enhance your email security. - Activate TLS Reporting (TLSRPT): TLSRPT records are DNS
TXT
records that specify how to report issues with TLS encryption for SMTP. When an email server experiences issues delivering emails securely to another server, it can refer to the TLSRPT record to know where to send the report of the problem.
Activate TLS Reporting (TLSRPT)
TLS Reporting (TLSRPT) is a standard that provides a way to report when the TLS connection could not be established during email transmission.
Implementation of TLSRPT
- Log in to your DNS hosting provider’s management console.
- Add a new TXT record with the following details:
Host | Type | Value |
---|---|---|
_smtp._tls.example.com |
TXT |
v=TLSRPTv1; rua=mailto:tlsrpt@example.com |
TLSRPT report handling
If a sending mail server is having trouble securely delivering mail to a receiving mail server, the sending mail server can use the receiving mail server’s TLSRPT record to find out where to send a report about the problem or to report a successful session.
The reports are received in .json
, you can look for the summary
tag to check if the TLS connection was failed or successful:
"summary":{"total-successful-session-count":1,"total-failure-session-count":0}
MTA-STS vs. SMTP DANE
Neither SMTP DANE nor MTA-STS is universally “better”; the choice depends on the specific context and needs of the organization. SMTP DANE provides stronger security, but requires DNSSEC, and not every DNS provider supports DNSSEC yet. MTA-STS, on the other hand, is easier to implement and provides good security through HTTPS and DNS. Using the two together can provide the best of both worlds, increasing security through a layered approach.