Blame SOURCES/update-ca-trust.8.txt

3c42f9
////
3c42f9
Copyright (C) 2013 Red Hat, Inc.
3c42f9
3c42f9
This program is free software; you can redistribute it and/or modify
3c42f9
it under the terms of the GNU General Public License as published by
3c42f9
the Free Software Foundation; either version 2 of the License, or
3c42f9
(at your option) any later version.
3c42f9
3c42f9
This program is distributed in the hope that it will be useful,
3c42f9
but WITHOUT ANY WARRANTY; without even the implied warranty of
3c42f9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
3c42f9
GNU General Public License for more details.
3c42f9
////
3c42f9
3c42f9
3c42f9
update-ca-trust(8)
3c42f9
==================
3c42f9
:doctype: manpage
3c42f9
:man source: update-ca-trust
3c42f9
3c42f9
3c42f9
NAME
3c42f9
----
3c42f9
update-ca-trust - manage consolidated and dynamic configuration of CA 
3c42f9
certificates and associated trust
3c42f9
3c42f9
3c42f9
SYNOPSIS
3c42f9
--------
3c42f9
*update-ca-trust* ['COMMAND']
3c42f9
3c42f9
3c42f9
DESCRIPTION
3c42f9
-----------
3c42f9
update-ca-trust(8) is used to manage a consolidated and dynamic configuration 
3c42f9
feature of Certificate Authority (CA) certificates and associated trust.
3c42f9
3c42f9
The feature is available for new applications that read the
3c42f9
consolidated configuration files found in the /etc/pki/ca-trust/extracted directory
3c42f9
or that load the PKCS#11 module p11-kit-trust.so
3c42f9
3c42f9
Parts of the new feature are also provided in a way to make it useful
3c42f9
for legacy applications.
3c42f9
3c42f9
Many legacy applications expect CA certificates and trust configuration
3c42f9
in a fixed location, contained in files with particular path and name,
3c42f9
or by referring to a classic PKCS#11 trust module provided by the 
3c42f9
NSS cryptographic library.
3c42f9
3c42f9
The dynamic configuration feature provides functionally compatible replacements 
3c42f9
for classic configuration files and for the classic NSS trust module named libnssckbi.
3c42f9
3c42f9
In order to enable legacy applications, that read the classic files or 
3c42f9
access the classic module, to make use of the new consolidated and dynamic configuration 
3c42f9
feature, the classic filenames have been changed to symbolic links.
3c42f9
The symbolic links refer to dynamically created and consolidated 
3c42f9
output stored below the /etc/pki/ca-trust/extracted directory hierarchy.
3c42f9
3c42f9
The output is produced using the 'update-ca-trust' command (without parameters),
3c42f9
or using the 'update-ca-trust extract' command.
3c42f9
In order to produce the output, a flexible set of source configuration
3c42f9
is read, as described in section <<sourceconf,SOURCE CONFIGURATION>>.
3c42f9
3c42f9
In addition, the classic PKCS#11 module 
3c42f9
is replaced with a new PKCS#11 module (p11-kit-trust.so) that dynamically 
3c42f9
reads the same source configuration.
3c42f9
3c42f9
3c42f9
[[sourceconf]]
3c42f9
SOURCE CONFIGURATION
3c42f9
--------------------
3c42f9
The dynamic configuration feature uses several source directories that
3c42f9
will be scanned for any number of source files. *It is important to select 
3c42f9
the correct subdirectory for adding files, as the subdirectory defines how 
3c42f9
contained certificates will be trusted or distrusted, and which file formats are read.*
3c42f9
3c42f9
Files in *subdirectories below the directory hierarchy /usr/share/pki/ca-trust-source/* contain CA certificates and 
3c42f9
trust settings in the PEM file format. The trust settings found here will be
3c42f9
interpreted with a *low priority*.
3c42f9
3c42f9
Files in *subdirectories below the directory hierarchy /etc/pki/ca-trust/source/* contain CA certificates and 
3c42f9
trust settings in the PEM file format. The trust settings found here will be
3c42f9
interpreted with a *high priority*.
3c42f9
3c42f9
.You may use the following rules of thumb to decide, whether your configuration files should be added to the /etc or rather to the /usr directory hierarchy:
3c42f9
* If you are manually adding a configuration file to a system, you probably 
3c42f9
want it to override any other default configuration, and you most likely should
3c42f9
add it to the respective subdirectory in the /etc hierarchy.
3c42f9
* If you are creating a package that provides additional root CA certificates,
3c42f9
that is intended for distribution to several computer systems, but you still
3c42f9
want to allow the administrator to override your list, then your package should 
3c42f9
add your files to the respective subdirectory in the /usr hierarchy.
3c42f9
* If you are creating a package that is supposed to override the default system
3c42f9
trust settings, that is intended for distribution to several computer systems, then your package should install the files to the respective
3c42f9
subdirectory in the /etc hierarchy.
3c42f9
3c42f9
.*QUICK HELP 1*: To add a certificate in the simple PEM or DER file formats to the list of CAs trusted on the system:
3c42f9
* add it as a new file to directory /etc/pki/ca-trust/source/anchors/
3c42f9
* run 'update-ca-trust extract'
3c42f9
3c42f9
.*QUICK HELP 2*: If your certificate is in the extended BEGIN TRUSTED file format (which may contain distrust/blacklist trust flags, or trust flags for usages other than TLS) then:
3c42f9
* add it as a new file to directory /etc/pki/ca-trust/source/
3c42f9
* run 'update-ca-trust extract'
3c42f9
3c42f9
.In order to offer simplicity and flexibility, the way certificate files are treated depends on the subdirectory they are installed to.
3c42f9
* simple trust anchors subdirectory: /usr/share/pki/ca-trust-source/anchors/ or /etc/pki/ca-trust/source/anchors/
3c42f9
* simple blacklist (distrust) subdirectory: /usr/share/pki/ca-trust-source/blacklist/ or /etc/pki/ca-trust/source/blacklist/
3c42f9
* extended format directory: /usr/share/pki/ca-trust-source/ or /etc/pki/ca-trust/source/
3c42f9
3c42f9
.In the main directories /usr/share/pki/ca-trust-source/ or /etc/pki/ca-trust/source/ you may install one or multiple files in the following file formats:
3c42f9
* certificate files that include trust flags,
3c42f9
  in the BEGIN/END TRUSTED CERTIFICATE file format
3c42f9
  (any file name), which have been created using the openssl x509 tool
3c42f9
  and the -addreject -addtrust options.
3c42f9
  Bundle files with multiple certificates are supported.
3c42f9
* files in the p11-kit file format using the .p11-kit file name
3c42f9
  extension, which can (e.g.) be used to distrust certificates
3c42f9
  based on serial number and issuer name, without having the
3c42f9
  full certificate available.
3c42f9
  (This is currently an undocumented format, to be extended later.
3c42f9
   For examples of the supported formats, see the files
3c42f9
   shipped with the ca-certificates package.)
3c42f9
* certificate files without trust flags in either the DER file format or in
3c42f9
  the PEM (BEGIN/END CERTIFICATE) file format (any file name). Such files 
3c42f9
  will be added with neutral trust, neither trusted nor distrusted.
3c42f9
  They will simply be known to the system, which might be helpful to
3c42f9
  assist cryptographic software in constructing chains of certificates.
3c42f9
  (If you want a CA certificate in these file formats to be trusted, you 
3c42f9
   should remove it from this directory and move it to the 
3c42f9
   ./anchors subdirectory instead.)
3c42f9
3c42f9
In the anchors subdirectories /usr/share/pki/ca-trust-source/anchors/ or /etc/pki/ca-trust/source/anchors/
3c42f9
you may install one or multiple certificates in either the DER file
3c42f9
format or in the PEM (BEGIN/END CERTIFICATE) file format.
3c42f9
Each certificate will be treated as *trusted* for all purposes.
3c42f9
3c42f9
In the blacklist subdirectories /usr/share/pki/ca-trust-source/blacklist/ or /etc/pki/ca-trust/source/blacklist/
3c42f9
you may install one or multiple certificates in either the DER file
3c42f9
format or in the PEM (BEGIN/END CERTIFICATE) file format.
3c42f9
Each certificate will be treated as *distrusted* for all purposes.
3c42f9
3c42f9
Please refer to the x509(1) manual page for the documentation of the 
3c42f9
BEGIN/END CERTIFICATE and BEGIN/END TRUSTED CERTIFICATE file formats.
3c42f9
3c42f9
Applications that rely on a static file for a list of trusted CAs
3c42f9
may load one of the files found in the /etc/pki/ca-trust/extracted
3c42f9
directory. After modifying any file in the
3c42f9
/usr/share/pki/ca-trust-source/ or /etc/pki/ca-trust/source/
3c42f9
directories or in any of their subdirectories, or after adding a file, 
3c42f9
it is necessary to run the 'update-ca-trust extract' command,
3c42f9
in order to update the consolidated files in /etc/pki/ca-trust/extracted/ .
3c42f9
3c42f9
Applications that load the classic PKCS#11 module using filename libnssckbi.so 
3c42f9
(which has been converted into a symbolic link pointing to the new module)
3c42f9
and any application capable of 
3c42f9
loading PKCS#11 modules and loading p11-kit-trust.so, will benefit from
3c42f9
the dynamically merged set of certificates and trust information stored in the
3c42f9
/usr/share/pki/ca-trust-source/ and /etc/pki/ca-trust/source/ directories.
3c42f9
3c42f9
3c42f9
[[extractconf]]
3c42f9
EXTRACTED CONFIGURATION
3c42f9
-----------------------
3c42f9
The directory /etc/pki/ca-trust/extracted/ contains generated CA certificate 
3c42f9
bundle files which are created and updated, based on the <<sourceconf,SOURCE CONFIGURATION>> 
3c42f9
by running the 'update-ca-trust extract' command.
3c42f9
3c42f9
If your application isn't able to load the PKCS#11 module p11-kit-trust.so,
3c42f9
then you can use these files in your application to load a list of global
3c42f9
root CA certificates.
3c42f9
3c42f9
Please never manually edit the files stored in this directory,
3c42f9
because your changes will be lost and the files automatically overwritten,
3c42f9
each time the 'update-ca-trust extract' command gets executed.
3c42f9
3c42f9
In order to install new trusted or distrusted certificates,
3c42f9
please rather install them in the respective subdirectory below the
3c42f9
/usr/share/pki/ca-trust-source/ or /etc/pki/ca-trust/source/
3c42f9
directories, as described in the <<sourceconf,SOURCE CONFIGURATION>> section.
3c42f9
3c42f9
The directory /etc/pki/ca-trust/extracted/java/ contains 
3c42f9
a CA certificate bundle in the java keystore file format.
3c42f9
Distrust information cannot be represented in this file format,
3c42f9
and distrusted certificates are missing from these files.
3c42f9
File cacerts contains CA certificates trusted for TLS server authentication.
3c42f9
3c42f9
The directory /etc/pki/ca-trust/extracted/openssl/ contains 
3c42f9
CA certificate bundle files in the extended BEGIN/END TRUSTED CERTIFICATE file format, 
3c42f9
as described in the x509(1) manual page.
3c42f9
File ca-bundle.trust.crt contains the full set of all trusted
3c42f9
or distrusted certificates, including the associated trust flags.
3c42f9
3c42f9
The directory /etc/pki/ca-trust/extracted/pem/ contains 
3c42f9
CA certificate bundle files in the simple BEGIN/END CERTIFICATE file format, 
3c42f9
as described in the x509(1) manual page.
3c42f9
Distrust information cannot be represented in this file format,
3c42f9
and distrusted certificates are missing from these files.
3c42f9
File tls-ca-bundle.pem contains CA certificates 
3c42f9
trusted for TLS server authentication.
3c42f9
File email-ca-bundle.pem contains CA certificates 
3c42f9
trusted for E-Mail protection.
3c42f9
File objsign-ca-bundle.pem contains CA certificates 
3c42f9
trusted for code signing.
3c42f9
3c42f9
The directory /etc/pki/ca-trust/extracted/edk2/ contains a CA
3c42f9
certificate bundle ("cacerts.bin") in the "sequence of
3c42f9
EFI_SIGNATURE_LISTs" format, defined in the UEFI-2.7 specification,
3c42f9
sections "31.4.1 Signature Database" and
3c42f9
"EFI_CERT_X509_GUID". Distrust information cannot be represented in
3c42f9
this file format, and distrusted certificates are missing from these
3c42f9
files. File "cacerts.bin" contains CA certificates trusted for TLS
3c42f9
server authentication.
3c42f9
3c42f9
3c42f9
COMMANDS
3c42f9
--------
3c42f9
(absent/empty command)::
3c42f9
    Same as the *extract* command described below. (However, the command may
3c42f9
    print fewer warnings, as this command is being run during rpm package 
3c42f9
    installation, where non-fatal status output is undesired.)
3c42f9
3c42f9
*extract*::
3c42f9
    Instruct update-ca-trust to scan the <<sourceconf,SOURCE CONFIGURATION>> and produce 
3c42f9
    updated versions of the consolidated configuration files stored below
3c42f9
    the /etc/pki/ca-trust/extracted directory hierarchy.
3c42f9
3c42f9
FILES
3c42f9
-----
3c42f9
/etc/pki/tls/certs/ca-bundle.crt::
3c42f9
	Classic filename, file contains a list of CA certificates trusted for TLS server authentication usage, in the simple BEGIN/END CERTIFICATE file format, without distrust information.
3c42f9
	This file is a symbolic link that refers to the consolidated output created by the update-ca-trust command.
3c42f9
3c42f9
/etc/pki/tls/certs/ca-bundle.trust.crt::
3c42f9
	Classic filename, file contains a list of CA certificates in the extended BEGIN/END TRUSTED CERTIFICATE file format, which includes trust (and/or distrust) flags specific to certificate usage.
3c42f9
	This file is a symbolic link that refers to the consolidated output created by the update-ca-trust command.
3c42f9
3c42f9
/etc/pki/java/cacerts::
3c42f9
	Classic filename, file contains a list of CA certificates trusted for TLS server authentication usage, in the Java keystore file format, without distrust information.
3c42f9
	This file is a symbolic link that refers to the consolidated output created by the update-ca-trust command.
3c42f9
3c42f9
/usr/share/pki/ca-trust-source::
3c42f9
	Contains multiple, low priority source configuration files as explained in section <<sourceconf,SOURCE CONFIGURATION>>. Please pay attention to the specific meanings of the respective subdirectories.
3c42f9
3c42f9
/etc/pki/ca-trust/source::
3c42f9
	Contains multiple, high priority source configuration files as explained in section <<sourceconf,SOURCE CONFIGURATION>>. Please pay attention to the specific meanings of the respective subdirectories.
3c42f9
3c42f9
/etc/pki/ca-trust/extracted::
3c42f9
	Contains consolidated and automatically generated configuration files for consumption by applications, 
3c42f9
	which are created using the 'update-ca-trust extract' command. Don't edit files in this directory, because they will be overwritten.
3c42f9
	See section <<extractconf,EXTRACTED CONFIGURATION>> for additional details.
3c42f9
3c42f9
AUTHOR
3c42f9
------
3c42f9
Written by Kai Engert and Stef Walter.