Skip to content
This repository has been archived by the owner on Jan 14, 2025. It is now read-only.

Latest commit

 

History

History
72 lines (38 loc) · 5.93 KB

README.md

File metadata and controls

72 lines (38 loc) · 5.93 KB

openssl-fips

This repository is archived and Perforce will no longer be updating this repository. For more information, see this Puppet blog post.

This repo contains a vanagon based project to build the OpenSSL fips provider, producing a dynamically loadable library fips.so (or fips.dll on Windows).

OpenSSL 3 introduced a provider architecture for cryptographic operations. OpenSSL supports several standard providers: default, fips, etc. See OSSL_PROVIDER-FIPS for more information about the fips provider.

FIPS Compliance

Terminology

Validated: The source code has gone through the Cryptographic Module Validation Program (CMVP) and been issued a certificate

Certificate: Specifies the module, vendor, expiration date, etc that was validated. For example, https://csrc.nist.gov/projects/cryptographic-module-validation-program/certificate/4282

Security Policy: Describes how the code was validated and contains instructions that must be followed to be FIPS compliant

Compliant: Built from validated source code, following the instructions in the Security Policy

OpenSSL 3.0

Only specific versions of the fips provider are FIPS 140-2 validated. The term validated has a specific meaning as described in README-FIPS.md

A cryptographic module is only FIPS validated after it has gone through the complex FIPS 140 validation process. As this process takes a very long time, it is not possible to validate every minor release of OpenSSL. If you need a FIPS validated module then you must ONLY generate a FIPS provider using OpenSSL versions that have valid FIPS certificates.

The list of validated providers is available from https://openssl.org/source/index.html.

In other words, you cannot build the fips provider from the latest 3.0.x source! For more details:

Since the base openssl code and the fips provider are released and validated, respectively, at different times, we build the openssl-fips module in this repo, separate from the openssl component in the puppet-runtime.

Finally, building the fips provider from validated source is not sufficient to be FIPS compliant as specified in the README:

A FIPS certificate contains a link to a Security Policy, and you MUST follow the instructions in the Security Policy in order to be FIPS compliant.

OpenSSL 3.1

OpenSSL 3.1 was recently released. It introduces a FIPS 140-3 fips provider, however, it is not validated yet.

There are two notable changes in OpenSSL 3.1 relating to FIPS:

  • The fips module performs a self-test every time it's loaded, not once when it's installed.
  • Applications must explicitly request fips compatible crypto functions either explicitly in code or in configuration using default_properties. See EVP configuration.

Encoders & Decoders

The fips provider does not implement serialization routines, like reading an RSA key from PEM, as described in section Using Encoders and Decoders with the FIPS module:

The built-in OpenSSL encoders and decoders are implemented in both the default and base providers and are not in the FIPS module boundary. However since they are not cryptographic algorithms themselves it is still possible to use them in conjunction with the FIPS module, and therefore these encoders/decoders have the fips=yes property against them. You should ensure that either the default or base provider is loaded into the library context in this case.

Since the agent serializes keys to disk and crypto parameters during TLS, we have to enable fips and default providers. Additionally, if fips is enabled, then default must be explicitly enabled. See Default provider and activation:

If you add a section explicitly activating any other provider(s), you most probably need to explicitly activate the default provider, otherwise it becomes unavailable in openssl. It may make the system remotely unavailable.

Configuration

OpenSSL supports different ways for an application to use FIPS algorithms. The simpliest, and the one we follow, is to FIPS enable the entire application, see Making all applications use the FIPS module by default:

One simple approach is to cause all applications that are using OpenSSL to only use the FIPS module for cryptographic algorithms by default. This approach can be done purely via configuration. ... To do this the default OpenSSL config file will have to be modified.

Installation

As described in the Appendix A of the OpenSSL FIPS 140-2 Security Policy:

The Module shall have the self-tests run, and the Module config file output generated on each platform where it is intended to be used. The Module config file output data shall not be copied from one machine to another.

Therefore, we have to use a post install action to install the fips.so shared library, run the self-tests, generate the fipsmodule.cnf configuration file and enable the fips provider via configuration in the main openssl.cnf.