Free & Automatic SSL for Tenant Domains for a SaaS Service !!
As a developer, one of the challenges we often face is provisioning and renewing SSL certificates for domains. For some of our SaaS project we need to provision SSL for our clients domains.
Recently, after lots of trial and error, I found a brilliant approach to automatically provide SSL certificates to tenant domains for our SaaS service without any hassle.
I used the Caddy web server and its on-demand TLS feature, which allows us to obtain SSL certificates for tenant domains on-the-fly.
Caddy is an open-source web server that simplifies HTTPS configuration and certificate management. It automates the process of obtaining and renewing SSL certificates, making it an ideal choice for our SaaS platform.
On-Demand TLS for Tenant Domains
To enable on-demand TLS for tenant domains, we'll use Caddy's Caddyfile, which is a configuration file written in JSON or the simplified Caddyfile format. Let's dive into the code:
Breaking Down the Code
- The first section is responsible for checking if a domain belongs to our domain list. We provide an email address (
myemail@example.test
) to receive important notifications related to certificate issuance or renewal. - The
on_demand_tls
directive is where the magic happens. We specify an endpoint (https://api.example.test/check-domain
) responsible for validating the tenant domains. Caddy will reach out to this endpoint to verify if the domain is valid before issuing an SSL certificate. The code for end point is below. - The
interval
, set to2m
, determines how often Caddy should check for updates regarding the domain's status. It ensures that certificates are renewed promptly and stay up-to-date. - The
burst
parameter, set to5
, indicates the maximum number of certificates Caddy can request at once in case many tenants require certificates simultaneously. - The next section handles specific domains (
app.example.test
in this case) and proxies traffic to the backend server (xxx.xxx.xxx.xxx:4000
) securely over HTTPS. - The final section handles any other domains (
https://
), and thetls
block withon_demand
enables on-demand TLS for these domains. Thehandle
block ensures that all incoming traffic is proxied securely to the backend server (xxx.xxx.xxx.xxx:5000
).
Domain Validation Script
In conclusion, the combination of Caddy web server and on-demand TLS is a game-changer for SaaS developers, as it ensures seamless and automatic SSL certificate provisioning for tenant domains. Embrace this solution to stay ahead in the competitive SaaS landscape while prioritizing security and user trust.
Feel free to explore Caddy's documentation and experiment with different configurations to suit your specific use case. Happy coding and stay secure!