Certificate Discovery
Introduction
Digital certificates have a limited validity period. In most cases they are rendered useless once they expire. As a consequence, services that rely upon those certificates do not function properly, or go completely out of service. Several similar incidents have been observed in the past. Therefore, a reliable mechanism to locate and manage such certificates is necessary to avoid such situations. Additionally, keeping track of all certificates in a system and/or infrastructure is beneficial, because it allows to locate mis-issued certificates. It is also possible to enforce policies in an easier manner, tied to cryptographic mechanisms or other aspects of certificates.
MTG Certificate Lifecycle Manager
The MTG Certificate Lifecycle Manager (MTG CLM) consists of two components, amongst others. The server and the clients. The server is the standard MTG CLM application which is the central component of the MTG ERS system. For an illustration of the graphical interface of this component, see Figure 1. This component also provides a REST-API that can be securely accessed by authenticated and authorised clients.
data:image/s3,"s3://crabby-images/32d14/32d14784a2a41d457ff0f3b394d31d3d39c06635" alt="ra"
The clients are the so-called ERS CLI (Command Line Interface) clients. A CLI client is a program that consumes the REST-API of CLM. This CLI-client is able to log in to CLM and request a certificate. Additionally, it can scan certain ports or port ranges of several other systems located near its network. This can be configured on the command-line interface of the system where an ers client is installed. The installation of an ers client uses typical mechanisms of modern operating systems like rpm or debian packages, or exe files and contains all its dependencies without depending on other resources. Examples to configure the servers, IPs, and ports to scan can be found below:
ers discover --servers mail.example.com
ers discover --servers "mail.example.com,web.example.com" --ports "8443,9443"
ers discover --servers server1.example.com --ports "8000-9000,9443"
ers discover --ips 198.51.100.0/24 --ports "8000-9000"
Consecutive calls of ers discover
lead to adding additional servers or re-configuring the ports to scan.
The standard ports where the CLI client scans are shown below:
Service | Port |
---|---|
WEB |
443 |
SMTP |
465 |
LDAP |
636 |
DNS |
853 |
FTP |
989 |
FTP |
990 |
Telnet |
992 |
IMAP |
993 |
POP |
995 |
To scan the configured servers and ports, execute:
ers scan
In most cases the command ers scan
is placed in a crontab statement with the desired execution time.
When the ers client scans, it tries to establish a TLS connection to the specified server and ports. If it succeeds into establishing a TLS connection it downloads the certificates of the server and pushes them to the CLM component along with some metadata, via a call to the REST-API. The CLM verifies the identity of the client and stores the certificates and metadata into its database. Below is a simplified UML sequence diagram of the calls, responsibilities, and involved systems:
Imported certificates and metadata are administered by the application. Examples of metadata is the URL and port where the certificates have been discovered. Typical administration tasks are:
-
Send notifications of about-to-expire certificates
-
Search certificates according to their metadata
-
Search certificates according to their data
-
Display statistics (see charts below)
data:image/s3,"s3://crabby-images/8e0b0/8e0b0f4f3e96e3be9823eaead3d369513f6db3d2" alt="ra"
data:image/s3,"s3://crabby-images/a9bba/a9bbad963ccf457caeb417a3c5e9207e0d4177cb" alt="ra"
All CLI clients can be seen and managed in the GUI of CLM.