3.1.1 Client certificate authentication should not be used for users

Warning! Audit Deprecated

This audit has been deprecated and will be removed in a future update.

View Next Audit Version

Information

Kubernetes provides the option to use client certificates for user authentication. However as there is no way to revoke these certificates when a user leaves an organization or loses their credential, they are not suitable for this purpose.

It is not possible to fully disable client certificate use within a cluster as it is used for component to component authentication.

Rationale:

With any authentication mechanism the ability to revoke credentials if they are compromised or no longer required, is a key control. Kubernetes client certificate authentication does not allow for this due to a lack of support for certificate revocation.

NOTE: Nessus has provided the target output to assist in reviewing the benchmark to ensure target compliance.

Solution

Alternative mechanisms provided by Kubernetes such as the use of OIDC should be implemented in place of client certificates.

Impact:

External mechanisms for authentication generally require additional software to be deployed.

Default Value:

Client certificate authentication is enabled by default.

Notes:

The lack of certificate revocation was flagged up as a high risk issue in the recent Kubernetes security audit. Without this feature, client certificate authentication is not suitable for end users.

See Also

https://workbench.cisecurity.org/files/2662

Item Details

Category: IDENTIFICATION AND AUTHENTICATION

References: 800-53|IA-5, CSCv7|14.8

Plugin: Unix

Control ID: 8f3f52ba44adcfa4ec83d3dd55a8a19c8670dd62174e9ed5d152631ff0937bfa