1 @node More on certificate authentication
2 @chapter More on certificate authentication
3 @cindex certificate authentication
5 Certificates are not the only structures involved in a public key
6 infrastructure. Several other structures that are used for certificate
7 requests, encrypted private keys, revocation lists, GnuTLS abstract key
8 structures, etc., are discussed in this chapter.
11 * PKCS 10 certificate requests::
12 * PKIX certificate revocation lists::
13 * OCSP certificate status checking::
14 * Managing encrypted keys::
15 * certtool Invocation:: Invoking certtool
16 * ocsptool Invocation:: Invoking ocsptool
17 * danetool Invocation:: Invoking danetool
20 @node PKCS 10 certificate requests
21 @section @acronym{PKCS} #10 certificate requests
22 @cindex certificate requests
25 A certificate request is a structure, which contain information about
26 an applicant of a certificate service. It usually contains a private
27 key, a distinguished name and secondary data such as a challenge
28 password. @acronym{GnuTLS} supports the requests defined in
29 @acronym{PKCS} #10 @xcite{RFC2986}. Other formats of certificate requests
30 are not currently supported.
32 A certificate request can be generated by
33 associating it with a private key, setting the
34 subject's information and finally self signing it.
35 The last step ensures that the requester is in
36 possession of the private key.
38 @showfuncE{gnutls_x509_crq_set_version,gnutls_x509_crq_set_dn_by_oid,gnutls_x509_crq_set_key_usage,gnutls_x509_crq_set_key_purpose_oid,gnutls_x509_crq_set_basic_constraints}
40 The @funcref{gnutls_x509_crq_set_key} and @funcref{gnutls_x509_crq_sign2}
41 functions associate the request with a private key and sign it. If a
42 request is to be signed with a key residing in a PKCS #11 token it is recommended to use
43 the signing functions shown in @ref{Abstract key types}.
45 @showfuncdesc{gnutls_x509_crq_set_key}
46 @showfuncdesc{gnutls_x509_crq_sign2}
48 The following example is about generating a certificate request, and a
49 private key. A certificate request can be later be processed by a CA
50 which should return a signed certificate.
53 @verbatiminclude examples/ex-crq.c
55 @node PKIX certificate revocation lists
56 @section PKIX certificate revocation lists
57 @cindex certificate revocation lists
60 A certificate revocation list (CRL) is a structure issued by an authority
61 periodically containing a list of revoked certificates serial numbers.
62 The CRL structure is signed with the issuing authorities' keys. A typical
63 CRL contains the fields as shown in @ref{tab:crl}.
64 Certificate revocation lists are used to complement the expiration date of a certificate,
65 in order to account for other reasons of revocation, such as compromised keys, etc.
67 Each CRL is valid for limited amount of
68 time and is required to provide, except for the current issuing time, also
69 the issuing time of the next update.
72 @multitable @columnfractions .2 .7
74 @headitem Field @tab Description
77 The field that indicates the version of the CRL structure.
80 A signature by the issuing authority.
83 Holds the issuer's distinguished name.
86 The issuing time of the revocation list.
89 The issuing time of the revocation list that will update that one.
91 @item revokedCertificates @tab
92 List of revoked certificates serial numbers.
95 Optional CRL structure extensions.
98 @caption{Certificate revocation list fields.}
101 The basic CRL structure functions follow.
103 @showfuncD{gnutls_x509_crl_init,gnutls_x509_crl_import,gnutls_x509_crl_export,gnutls_x509_crl_export}
105 @subheading Reading a CRL
107 The most important function that extracts the certificate revocation
108 information from a CRL is @funcref{gnutls_x509_crl_get_crt_serial}. Other
109 functions that return other fields of the CRL structure are also provided.
111 @showfuncdesc{gnutls_x509_crl_get_crt_serial}
113 @showfuncE{gnutls_x509_crl_get_version,gnutls_x509_crl_get_issuer_dn,gnutls_x509_crl_get_this_update,gnutls_x509_crl_get_next_update,gnutls_x509_crl_get_crt_count}
116 @subheading Generation of a CRL
118 The following functions can be used to generate a CRL.
120 @showfuncB{gnutls_x509_crl_set_version,gnutls_x509_crl_set_crt_serial}
121 @showfuncC{gnutls_x509_crl_set_crt,gnutls_x509_crl_set_next_update,gnutls_x509_crl_set_this_update}
123 The @funcref{gnutls_x509_crl_sign2} and @funcref{gnutls_x509_crl_privkey_sign}
124 functions sign the revocation list with a private key. The latter function
125 can be used to sign with a key residing in a PKCS #11 token.
127 @showfuncdesc{gnutls_x509_crl_sign2}
128 @showfuncdesc{gnutls_x509_crl_privkey_sign}
130 Few extensions on the CRL structure are supported, including the
131 CRL number extension and the authority key identifier.
133 @showfuncB{gnutls_x509_crl_set_number,gnutls_x509_crl_set_authority_key_id}
135 @node OCSP certificate status checking
136 @section @acronym{OCSP} certificate status checking
137 @cindex certificate status
138 @cindex Online Certificate Status Protocol
141 Certificates may be revoked before their expiration time has been
142 reached. There are several reasons for revoking certificates, but a
143 typical situation is when the private key associated with a
144 certificate has been compromised. Traditionally, Certificate
145 Revocation Lists (CRLs) have been used by application to implement
146 revocation checking, however, several problems with CRLs have been
147 identified @xcite{RIVESTCRL}.
149 The Online Certificate Status Protocol, or @acronym{OCSP} @xcite{RFC2560},
150 is a widely implemented protocol to perform certificate revocation status
151 checking. An application that wish to verify the
152 identity of a peer will verify the certificate against a set of
153 trusted certificates and then check whether the certificate is listed
154 in a CRL and/or perform an OCSP check for the certificate.
156 Note that in the context of a TLS session the server may provide an
157 OCSP response that will used during the TLS certificate verification
158 (see @funcref{gnutls_certificate_verify_peers3}).
159 You may obtain this response using @funcref{gnutls_ocsp_status_request_get}.
161 Before performing the OCSP query, the application will need to figure
162 out the address of the OCSP server. The OCSP server address can be
163 provided by the local user in manual configuration or may be stored
164 in the certificate that is being checked. When stored in a certificate
165 the OCSP server is in the extension field called the Authority Information
166 Access (AIA). The following function
167 extracts this information from a certificate.
169 @showfuncA{gnutls_x509_crt_get_authority_info_access}
171 There are several functions in GnuTLS for creating and manipulating
172 OCSP requests and responses. The general idea is that a client
173 application create an OCSP request object, store some information
174 about the certificate to check in the request, and then export the
175 request in DER format. The request will then need to be sent to the
176 OCSP responder, which needs to be done by the application (GnuTLS does
177 not send and receive OCSP packets). Normally an OCSP response is
178 received that the application will need to import into an OCSP
179 response object. The digital signature in the OCSP response needs to
180 be verified against a set of trust anchors before the information in
181 the response can be trusted.
183 The ASN.1 structure of OCSP requests are briefly as follows. It is
184 useful to review the structures to get an understanding of which
185 fields are modified by GnuTLS functions.
188 OCSPRequest ::= SEQUENCE @{
189 tbsRequest TBSRequest,
190 optionalSignature [0] EXPLICIT Signature OPTIONAL @}
192 TBSRequest ::= SEQUENCE @{
193 version [0] EXPLICIT Version DEFAULT v1,
194 requestorName [1] EXPLICIT GeneralName OPTIONAL,
195 requestList SEQUENCE OF Request,
196 requestExtensions [2] EXPLICIT Extensions OPTIONAL @}
198 Request ::= SEQUENCE @{
200 singleRequestExtensions [0] EXPLICIT Extensions OPTIONAL @}
202 CertID ::= SEQUENCE @{
203 hashAlgorithm AlgorithmIdentifier,
204 issuerNameHash OCTET STRING, -- Hash of Issuer's DN
205 issuerKeyHash OCTET STRING, -- Hash of Issuers public key
206 serialNumber CertificateSerialNumber @}
209 The basic functions to initialize, import, export and deallocate OCSP
210 requests are the following.
212 @showfuncE{gnutls_ocsp_req_init,gnutls_ocsp_req_deinit,gnutls_ocsp_req_import,gnutls_ocsp_req_export,gnutls_ocsp_req_print}
214 To generate an OCSP request the issuer name hash, issuer key hash, and
215 the checked certificate's serial number are required. There are two
216 interfaces available for setting those in an OCSP request.
217 The is a low-level function when you have the
218 issuer name hash, issuer key hash, and certificate serial number in
219 binary form. The second is more useful if you have the
220 certificate (and its issuer) in a @code{gnutls_x509_crt_t} type.
221 There is also a function to extract this information from existing an OCSP
224 @showfuncC{gnutls_ocsp_req_add_cert_id,gnutls_ocsp_req_add_cert,gnutls_ocsp_req_get_cert_id}
226 Each OCSP request may contain a number of extensions. Extensions are
227 identified by an Object Identifier (OID) and an opaque data buffer
228 whose syntax and semantics is implied by the OID. You can extract or
229 set those extensions using the following functions.
231 @showfuncB{gnutls_ocsp_req_get_extension,gnutls_ocsp_req_set_extension}
233 A common OCSP Request extension is the nonce extension (OID
234 1.3.6.1.5.5.7.48.1.2), which is used to avoid replay attacks of
235 earlier recorded OCSP responses. The nonce extension carries a value
236 that is intended to be sufficiently random and unique so that an
237 attacker will not be able to give a stale response for the same nonce.
239 @showfuncC{gnutls_ocsp_req_get_nonce,gnutls_ocsp_req_set_nonce,gnutls_ocsp_req_randomize_nonce}
241 The OCSP response structures is a complex structure. A simplified overview
242 of it is in @ref{tab:ocsp-response}. Note that a response may contain
243 information on multiple certificates.
245 @float Table,tab:ocsp-response
246 @multitable @columnfractions .2 .7
248 @headitem Field @tab Description
251 The OCSP response version number (typically 1).
253 @item responder ID @tab
254 An identifier of the responder (DN name or a hash of its key).
256 @item issue time @tab
257 The time the response was generated.
259 @item thisUpdate @tab
260 The issuing time of the revocation information.
262 @item nextUpdate @tab
263 The issuing time of the revocation information that will update that one.
265 @item @tab Revoked certificates
267 @item certificate status @tab
268 The status of the certificate.
270 @item certificate serial @tab
271 The certificate's serial number.
273 @item revocationTime @tab
274 The time the certificate was revoked.
276 @item revocationReason @tab
277 The reason the certificate was revoked.
280 @caption{The most important OCSP response fields.}
284 We provide basic functions for initialization, importing, exporting
285 and deallocating OCSP responses.
287 @showfuncE{gnutls_ocsp_resp_init,gnutls_ocsp_resp_deinit,gnutls_ocsp_resp_import,gnutls_ocsp_resp_export,gnutls_ocsp_resp_print}
289 The utility function that extracts the revocation as well as other information
290 from a response is shown below.
292 @showfuncdesc{gnutls_ocsp_resp_get_single}
294 The possible revocation reasons available in an OCSP response are shown
297 @showenumdesc{gnutls_x509_crl_reason_t,The revocation reasons}
299 Note, that the OCSP response needs to be verified against some set of trust
300 anchors before it can be relied upon. It is also important to check
301 whether the received OCSP response corresponds to the certificate being checked.
303 @showfuncC{gnutls_ocsp_resp_verify,gnutls_ocsp_resp_verify_direct,gnutls_ocsp_resp_check_crt}
305 @node Managing encrypted keys
306 @section Managing encrypted keys
307 @cindex Encrypted keys
309 Transferring or storing private keys in plain may not be a
310 good idea, since any compromise is irreparable.
311 Storing the keys in hardware security modules (see @ref{Smart cards and HSMs})
312 could solve the storage problem but it is not always practical
313 or efficient enough. This section describes ways to store and
314 transfer encrypted private keys.
316 There are methods for key encryption, namely the
317 PKCS #8, PKCS #12 and OpenSSL's custom encrypted private key formats.
318 The PKCS #8 and the OpenSSL's method allow encryption of the private key,
319 while the PKCS #12 method allows, in addition, the bundling of accompanying
320 data into the structure. That is typically the corresponding certificate, as
321 well as a trusted CA certificate.
323 @subheading High level functionality
324 Generic and higher level private key import functions are available, that
325 import plain or encrypted keys and will auto-detect the encrypted key format.
327 @showfuncdesc{gnutls_x509_privkey_import2}
329 @showfuncdesc{gnutls_privkey_import_x509_raw}
331 @subheading @acronym{PKCS} #8 structures
334 PKCS #8 keys can be imported and exported as normal private keys using
335 the functions below. An addition to the normal import functions, are
336 a password and a flags argument. The flags can be any element of the @code{gnutls_pkcs_encrypt_flags_t}
337 enumeration. Note however, that GnuTLS only supports the PKCS #5 PBES2
338 encryption scheme. Keys encrypted with the obsolete PBES1 scheme cannot
341 @showfuncC{gnutls_x509_privkey_import_pkcs8,gnutls_x509_privkey_export_pkcs8,gnutls_x509_privkey_export2_pkcs8}
343 @showenumdesc{gnutls_pkcs_encrypt_flags_t,Encryption flags}
345 @subheading @acronym{PKCS} #12 structures
348 A @acronym{PKCS} #12 structure @xcite{PKCS12} usually contains a user's
349 private keys and certificates. It is commonly used in browsers to
350 export and import the user's identities.
352 In @acronym{GnuTLS} the @acronym{PKCS} #12 structures are handled
353 using the @code{gnutls_pkcs12_t} type. This is an abstract type that
354 may hold several @code{gnutls_pkcs12_bag_t} types. The bag types are
355 the holders of the actual data, which may be certificates, private
356 keys or encrypted data. A bag of type encrypted should be decrypted
357 in order for its data to be accessed.
359 To reduce the complexity in parsing the structures the simple
360 helper function @funcref{gnutls_pkcs12_simple_parse} is provided. For more
361 advanced uses, manual parsing of the structure is required using the
364 @showfuncD{gnutls_pkcs12_get_bag,gnutls_pkcs12_verify_mac,gnutls_pkcs12_bag_decrypt,gnutls_pkcs12_bag_get_count}
366 @showfuncdesc{gnutls_pkcs12_simple_parse}
367 @showfuncC{gnutls_pkcs12_bag_get_data,gnutls_pkcs12_bag_get_key_id,gnutls_pkcs12_bag_get_friendly_name}
369 The functions below are used to generate a PKCS #12 structure. An example
370 of their usage is also shown.
372 @showfuncC{gnutls_pkcs12_set_bag,gnutls_pkcs12_bag_encrypt,gnutls_pkcs12_generate_mac}
373 @showfuncE{gnutls_pkcs12_bag_set_data,gnutls_pkcs12_bag_set_crl,gnutls_pkcs12_bag_set_crt,gnutls_pkcs12_bag_set_key_id,gnutls_pkcs12_bag_set_friendly_name}
375 @verbatiminclude examples/ex-pkcs12.c
377 @subheading OpenSSL encrypted keys
378 @cindex OpenSSL encrypted keys
379 Unfortunately the structures discussed in the previous sections are
380 not the only structures that may hold an encrypted private key. For example
381 the OpenSSL library offers a custom key encryption method. Those structures
382 are also supported in GnuTLS with @funcref{gnutls_x509_privkey_import_openssl}.
384 @showfuncdesc{gnutls_x509_privkey_import_openssl}
386 @include invoke-certtool.texi
388 @include invoke-ocsptool.texi
390 @include invoke-danetool.texi