-
Notifications
You must be signed in to change notification settings - Fork 30.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
doc: update documentation for FIPS support
When using OpenSSL 3, Node.js supports FIPS 140-2 when used with an appropriate OpenSSL 3 provider. It is no longer necessary to rebuild Node.js with different build time options. Add a section on how to configure Node.js to use an OpenSSL 3 FIPS provider to the documentation for the `crypto` module. PR-URL: #48194 Reviewed-By: Michael Dawson <[email protected]> Reviewed-By: James M Snell <[email protected]>
- Loading branch information
1 parent
fe76e09
commit 8aa02e8
Showing
2 changed files
with
88 additions
and
239 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -794,246 +794,12 @@ configure option: | |
|
||
## Building Node.js with FIPS-compliant OpenSSL | ||
|
||
The current version of Node.js supports FIPS when statically and | ||
dynamically linking with OpenSSL 3.0.0 by using the configuration flag | ||
`--openssl-is-fips`. | ||
Node.js supports FIPS when statically or dynamically linked with OpenSSL 3 via | ||
[OpenSSL's provider model](https://www.openssl.org/docs/man3.0/man7/crypto.html#OPENSSL-PROVIDERS). | ||
It is not necessary to rebuild Node.js to enable support for FIPS. | ||
|
||
### FIPS support when statically linking OpenSSL | ||
|
||
FIPS can be supported by specifying the configuration flag `--openssl-is-fips`: | ||
|
||
```bash | ||
./configure --openssl-is-fips | ||
make -j8 | ||
``` | ||
|
||
The above command will build and install the FIPS module into the out directory. | ||
This includes building fips.so, running the `installfips` command that generates | ||
the FIPS configuration file (fipsmodule.cnf), copying and updating openssl.cnf | ||
to include the correct path to fipsmodule.cnf and finally uncomment the fips | ||
section. | ||
|
||
We can then run node specifying `--enable-fips`: | ||
|
||
```console | ||
$ ./node --enable-fips -p 'crypto.getFips()' | ||
1 | ||
``` | ||
|
||
The above will use the Node.js default locations for OpenSSL 3.0: | ||
|
||
```console | ||
$ ./out/Release/openssl-cli version -m -d | ||
OPENSSLDIR: "/nodejs/openssl/out/Release/obj.target/deps/openssl" | ||
MODULESDIR: "/nodejs/openssl/out/Release/obj.target/deps/openssl/lib/openssl-modules" | ||
``` | ||
|
||
The OpenSSL configuration files will be found in `OPENSSLDIR` directory above: | ||
|
||
```console | ||
$ ls -w 1 out/Release/obj.target/deps/openssl/*.cnf | ||
out/Release/obj.target/deps/openssl/fipsmodule.cnf | ||
out/Release/obj.target/deps/openssl/openssl.cnf | ||
``` | ||
|
||
And the FIPS module will be located in the `MODULESDIR` directory: | ||
|
||
```console | ||
$ ls out/Release/obj.target/deps/openssl/lib/openssl-modules/ | ||
fips.so | ||
``` | ||
|
||
Running `configure` without `--openssl-is-fips` flag and rebuilding will reset | ||
the FIPS configuration. | ||
|
||
### FIPS support when dynamically linking OpenSSL | ||
|
||
For quictls/openssl 3.0 it is possible to enable FIPS when dynamically linking. | ||
If you want to build Node.js using openssl-3.0.0+quic, you can follow these | ||
steps: | ||
|
||
**clone OpenSSL source and prepare build** | ||
|
||
```bash | ||
git clone [email protected]:quictls/openssl.git | ||
|
||
cd openssl | ||
|
||
./config \ | ||
--prefix=/path/to/install/dir/ \ | ||
shared \ | ||
enable-fips \ | ||
linux-x86_64 | ||
``` | ||
|
||
The `/path/to/install/dir` is the path in which the `make install` instructions | ||
will publish the OpenSSL libraries and such. We will also use this path | ||
(and sub-paths) later when compiling Node.js. | ||
|
||
**compile and install OpenSSL** | ||
|
||
```bash | ||
make -j8 | ||
make install | ||
make install_ssldirs | ||
make install_fips | ||
``` | ||
|
||
After the OpenSSL (including FIPS) modules have been compiled and installed | ||
(into the `/path/to/install/dir`) by the above instructions we also need to | ||
update the OpenSSL configuration file located under | ||
`/path/to/install/dir/ssl/openssl.cnf`. Right next to this file, you should | ||
find the `fipsmodule.cnf` file - let's add the following to the end of the | ||
`openssl.cnf` file. | ||
|
||
**alter openssl.cnf** | ||
|
||
```text | ||
.include /absolute/path/to/fipsmodule.cnf | ||
# List of providers to load | ||
[provider_sect] | ||
default = default_sect | ||
# The fips section name should match the section name inside the | ||
# included /path/to/install/dir/ssl/fipsmodule.cnf. | ||
fips = fips_sect | ||
[default_sect] | ||
activate = 1 | ||
``` | ||
|
||
You can e.g. accomplish this by running the following command - be sure to | ||
replace `/path/to/install/dir/` with the path you have selected. Please make | ||
sure that you specify an absolute path for the `.include fipsmodule.cnf` line - | ||
using relative paths did not work on my system! | ||
|
||
**alter openssl.cnf using a script** | ||
|
||
```bash | ||
cat <<EOT >> /path/to/install/dir/ssl/openssl.cnf | ||
.include /path/to/install/dir/ssl/fipsmodule.cnf | ||
# List of providers to load | ||
[provider_sect] | ||
default = default_sect | ||
# The fips section name should match the section name inside the | ||
# included /path/to/install/dir/ssl/fipsmodule.cnf. | ||
fips = fips_sect | ||
[default_sect] | ||
activate = 1 | ||
EOT | ||
``` | ||
|
||
As you might have picked a non-custom path for your OpenSSL install dir, we | ||
have to export the following two environment variables in order for Node.js to | ||
find our OpenSSL modules we built beforehand: | ||
|
||
```bash | ||
export OPENSSL_CONF=/path/to/install/dir/ssl/openssl.cnf | ||
export OPENSSL_MODULES=/path/to/install/dir/lib/ossl-modules | ||
``` | ||
|
||
**build Node.js** | ||
|
||
```bash | ||
./configure \ | ||
--shared-openssl \ | ||
--shared-openssl-libpath=/path/to/install/dir/lib \ | ||
--shared-openssl-includes=/path/to/install/dir/include \ | ||
--shared-openssl-libname=crypto,ssl \ | ||
--openssl-is-fips | ||
|
||
export LD_LIBRARY_PATH=/path/to/install/dir/lib | ||
|
||
make -j8 | ||
``` | ||
|
||
**verify the produced executable** | ||
|
||
```console | ||
$ ldd ./node | ||
linux-vdso.so.1 (0x00007ffd7917b000) | ||
libcrypto.so.81.3 => /path/to/install/dir/lib/libcrypto.so.81.3 (0x00007fd911321000) | ||
libssl.so.81.3 => /path/to/install/dir/lib/libssl.so.81.3 (0x00007fd91125e000) | ||
libdl.so.2 => /usr/lib64/libdl.so.2 (0x00007fd911232000) | ||
libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00007fd911039000) | ||
libm.so.6 => /usr/lib64/libm.so.6 (0x00007fd910ef3000) | ||
libgcc_s.so.1 => /usr/lib64/libgcc_s.so.1 (0x00007fd910ed9000) | ||
libpthread.so.0 => /usr/lib64/libpthread.so.0 (0x00007fd910eb5000) | ||
libc.so.6 => /usr/lib64/libc.so.6 (0x00007fd910cec000) | ||
/lib64/ld-linux-x86-64.so.2 (0x00007fd9117f2000) | ||
``` | ||
|
||
If the `ldd` command says that `libcrypto` cannot be found one needs to set | ||
`LD_LIBRARY_PATH` to point to the directory used above for | ||
`--shared-openssl-libpath` (see previous step). | ||
|
||
**verify the OpenSSL version** | ||
|
||
```console | ||
$ ./node -p process.versions.openssl | ||
3.0.0-alpha16+quic | ||
``` | ||
|
||
**verify that FIPS is available** | ||
|
||
```console | ||
$ ./node -p 'process.config.variables.openssl_is_fips' | ||
true | ||
|
||
$ ./node --enable-fips -p 'crypto.getFips()' | ||
1 | ||
``` | ||
|
||
FIPS support can then be enable via the OpenSSL configuration file or | ||
using `--enable-fips` or `--force-fips` command line options to the Node.js | ||
executable. See sections | ||
[Enabling FIPS using Node.js options](#enabling-fips-using-node.js-options) and | ||
[Enabling FIPS using OpenSSL config](#enabling-fips-using-openssl-config) below. | ||
|
||
### Enabling FIPS using Node.js options | ||
|
||
This is done using one of the Node.js options `--enable-fips` or | ||
`--force-fips`, for example: | ||
|
||
```bash | ||
node --enable-fips -p 'crypto.getFips()' | ||
``` | ||
|
||
### Enabling FIPS using OpenSSL config | ||
|
||
This example show that using OpenSSL's configuration file, FIPS can be enabled | ||
without specifying the `--enable-fips` or `--force-fips` options by setting | ||
`default_properties = fips=yes` in the FIPS configuration file. See | ||
[link](https://github.com/openssl/openssl/blob/master/README-FIPS.md#loading-the-fips-module-at-the-same-time-as-other-providers) | ||
for details. | ||
|
||
For this to work the OpenSSL configuration file (default openssl.cnf) needs to | ||
be updated. The following shows an example: | ||
|
||
```text | ||
openssl_conf = openssl_init | ||
.include /path/to/install/dir/ssl/fipsmodule.cnf | ||
[openssl_init] | ||
providers = prov | ||
alg_section = algorithm_sect | ||
[prov] | ||
fips = fips_sect | ||
default = default_sect | ||
[default_sect] | ||
activate = 1 | ||
[algorithm_sect] | ||
default_properties = fips=yes | ||
``` | ||
|
||
After this change Node.js can be run without the `--enable-fips` or `--force-fips` | ||
options. | ||
See [FIPS mode](./doc/api/crypto.md#fips-mode) for more information on how to | ||
enable FIPS support in Node.js. | ||
|
||
## Building Node.js with external core modules | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters