Skip to main content

TLS certificates

Where technically suitable, all new HMCTS domains must use automated certificate techniques and services, such as Microsoft managed certificates (most preferred) or LetsEncrypt (uses ACME).

Over time, existing HMCTS domains must also be considered for migration to automated certificate provisioning and management techniques (preferably on their next certificate renewal cycle in advance of expiry) in order to reduce the consequences and management overheads of manual certificate renewal.

HMCTS acknowledges that not all systems support automated certificate management, but leveraging such technology where possible reduces management overheads, the costs of such overheads and the consequences of unexpected certificate expiry.

If your site is being hosted on:

Then you must use Microsoft managed certificates

You can automatically generate/deploy an Azure-manged certificate by copying an existing site in Azure Platform Terraform

Please note, if the certificate status on ‘domains’ under Frontdoor in Azure portal does not show as ‘deployed’, you will need to manually validate the certificate by creating a TXT record on Azure-public-DNS like in this example PR

You can view the TXT record that needs created by clicking on the status under ‘validation state’

Domain validation TXT record

Manual certificate requests

If you cannot use a managed certificate then please raise a request in #platops-help, the ticket should contain the following information:

  • Where the certificate is to be hosted
  • DNS Name and SANS

ACME Certificates

Let’s Encrypt is a free, automated and open CA. ACME protocol is used to automate the certificate issuance. We are using Key Vault Acmebot function app as an ACME client.

Key Vault Acmebot is deployed from this repository azure-enterprise-acme via this azure-devops pipeline, there is one instance per subscription.

The naming convention for keyvaults and function App are acme<subscription name without hyphens>, sharedservices is replaced with sds because of length limits. e.g. acmedtssdstest.

The naming convention for certificate name in Key Vault is <DNS Name/wildcard>-<DNSZone> separated by hyphen. E.g. hmi-apim-test-platform-hmcts-net, wildcard-test-platform-hmcts-net.

You may need to use ACME certificate due to managed certificate limitations in Front Door by updating the ssl_mode and custom_domain attributes in the Front Door config, here is an example in azure-platform-terraform.

see Create Certificates to create and renew certificates.

This page was last reviewed on 10 October 2024. It needs to be reviewed again on 10 April 2025 by the page owner platops-build-notices .
This page was set to be reviewed before 10 April 2025 by the page owner platops-build-notices. This might mean the content is out of date.