uffizzi
uffizzi copied to clipboard
Change preview hostname construction, enabling wildcard TLS certificates
We want to use "wildcard" TLS certificates to stop relying upon third-party certificate authorities for each new deployment. This should increase reliability and sometimes speed of new deployments. The easiest way to implement this is to use a single wildcard TLS certificate for all deployments. This requires that all deployments be subdomains of a single domain.
For example, a certificate for *.example.com
will match foo.example.com
but will not match foo.bar.example.com
. As Wikipedia says:
[...] the wildcard only covers one level of subdomains (the asterisk doesn't match full stops.)
Maybe we can easily change how our app generates hostnames to only use a single level of subdomain. This could be as easy as replacing .
with -
. Other tickets will describe changes to our controller and infrastructure.
This is a feature we want to become the most common case, so I don't think we need a feature "gate" like an environment variable.
Be mindful of RFC 1035 which specifies "Labels must be 63 characters or less."! https://datatracker.ietf.org/doc/html/rfc1035
For QA:
- The hostname construction is changed so it consists of a single subdomain
- If the subdomain length is bigger than 63 characters it gets cut
TESTED - OK
data:image/s3,"s3://crabby-images/83ae4/83ae48e018f2915a48475911e8f69de0cd0b9068" alt="image"
TESTED on prod - OK
data:image/s3,"s3://crabby-images/ba5ff/ba5ffa74e4a66ecdcc8f2af4d170354af6272456" alt="image"