Using Let's Encrypt Certificates
Background
To ensure authenticity and security, MailStore Server uses TLS certificates in all provided services. During installation MailStore Server allows to either
- create a self-signed certificate,
- use an existing certificate,
- or obtain a certificate from Let's Encrypt.
The default choice of creating a self-signed certificate is often used when installing MailStore Server for the very first time, since it does not come with any external dependencies to be resolved. While this is perfectly fine in a non-production setup, it is not recommended for production use, as self-signed certificates are not trusted by other client computers, due to no being signed by a trusted certificate authority, and user might get used to ignoring certificate warnings, making them prone to man in the middle attacks.
The following or a similar warning message is displayed when opening MailStore Web Access with a self-signed certificate in use.
To eliminate these warnings, increase security, as well as enhance usability, MailStore needs to be reconfigured to use a certificate that is singed by a trusted certificate authority.
The following describes how to obtain and use certificates from the free certificate authority Let's Encrypt. If you are already in possession of certificates (i.e. a wildcard certificate for your domain), that have been signed by a trusted certificate authority, or if you would like to manually request a certificate from you favorite CA, refer to Using Your Own SSL Certificate for detailed instructions.
About Let's Encrypt
Let's Encrypt is a free, automated, and open certificate authority, trusted by all major web browsers and operating systems. Many large, well known sponsors from the IT industry support Let's Encrypt effort to help making the internet a safer place.
A fully automated certificate approval process eliminates email or phone verification of traditional certificate authorities that often take days.
Let's Encrypt certificates are only valid for 90 days and thus need to be renewed regularly. The MailStore Server service handles the automatic renewals once the initial configuration is done.
Prerequisites
- A public DNS record (A or CNAME) for the MailStore Server computer must exist and point to its public IP address.
- The MailStore Server computer must be accessible from the Internet on TCP port 80 (HTTP) for Let's Encrypt's automatic domain approval process. A port forwarding on your firewall or gateway might be necessary. Since Let's Encrypt validates from different IP addresses, the potentially required firewall rule cannot be limited to certain source IP addresses.
Scenario 1: MailStore Server on Local Area Network (LAN)
The most common scenario for a MailStore Server installation is on a local network inside the organization's premises. Typically the MailStore Server computer has a private IP address (e.g. 192.168.0.10) and the Internet connection is established through a router, that masks all internal IP addresses with its own external IP address assigned by the ISP. This is known as Network Address Translation (NAT).
For this scenario, we assume that MailStore Server is running on a new, dedicated computer.
- Ask your Internet access provider to assign a static, public IP address to the router.
- Assign an available static IP Address from your local network to the MailStore Server computer.
- Create a port forwarding rule on the router, that forwards all connections to TCP port 80 on the public IP address, which was assigned in step 1, to the internal IP address of your MailStore Server computer assigned in step 2.
- Add an A or CNAME record to the DNS zone of your public domain, e.g. mailstore.example.com pointing to the public IP address, that was assigned in step 1.
- Depending on how DNS resolution is handled in your local network, you need to add a corresponding DNS record on your internal DNS server or router as well. This record should point to the internal IP address of the MailStore Server computer.
Scenario 2: MailStore Server on External Network
If the MailStore Server computer is already on a network that used public IP address, e.g. in a data center, or a DMZ it is much easier to fulfill the prerequisites.
For this scenario, we assume that MailStore Server is running on a new, dedicated computer.
- Assign an available public IP Address from your public network to the MailStore Server computer.
- If there is a firewall in place, create a firewall rule, that allows all connections to TCP port 80 on the public IP address to pass through.
- Add an A or CNAME record to the DNS zone of your public domain, e.g. mailstore.example.com pointing to the public IP address, that was assigned in step 1.
Obtaining the Certificate
- Open the MailStore Server Service Configuration.
- Select Network Settings
- In the certificate section, click on the ellipsis next to the certificate
- Select Request from Let's Encrypt...
- The prerequisites are shown.
- Click Next to proceed.
- Enter your email address and the server name into the corresponding fields
- Click on the link to open the Let's Encrypt Subscriber Agreement.
- Once you have read and understood the Let's Encrypt Subscriber Agreement, tick the checkbox I accept Let's Encrypt's Subscriber Agreement
- Click Next to continue.
- MailStore now tests the settings against Let's Encrypt's staging environment. If an issue occurs, MailStore will show a warning. Please review the log output, resolve the issue and try again.
- If the test was successful, MailStore will automatically request a certificate from Let's Encrypt's production system and confirm that setup was successful.
- Click on Finish.
- The automatic renewal of Let's Encrypt certificates every 60 days is active as long as no other certificate is selected manually.