1*2175Sjp161948=pod
2*2175Sjp161948
3*2175Sjp161948=head1 NAME
4*2175Sjp161948
5*2175Sjp161948SSL_CTX_use_certificate, SSL_CTX_use_certificate_ASN1, SSL_CTX_use_certificate_file, SSL_use_certificate, SSL_use_certificate_ASN1, SSL_use_certificate_file, SSL_CTX_use_certificate_chain_file, SSL_CTX_use_PrivateKey, SSL_CTX_use_PrivateKey_ASN1, SSL_CTX_use_PrivateKey_file, SSL_CTX_use_RSAPrivateKey, SSL_CTX_use_RSAPrivateKey_ASN1, SSL_CTX_use_RSAPrivateKey_file, SSL_use_PrivateKey_file, SSL_use_PrivateKey_ASN1, SSL_use_PrivateKey, SSL_use_RSAPrivateKey, SSL_use_RSAPrivateKey_ASN1, SSL_use_RSAPrivateKey_file, SSL_CTX_check_private_key, SSL_check_private_key - load certificate and key data
6*2175Sjp161948
7*2175Sjp161948=head1 SYNOPSIS
8*2175Sjp161948
9*2175Sjp161948 #include <openssl/ssl.h>
10*2175Sjp161948
11*2175Sjp161948 int SSL_CTX_use_certificate(SSL_CTX *ctx, X509 *x);
12*2175Sjp161948 int SSL_CTX_use_certificate_ASN1(SSL_CTX *ctx, int len, unsigned char *d);
13*2175Sjp161948 int SSL_CTX_use_certificate_file(SSL_CTX *ctx, const char *file, int type);
14*2175Sjp161948 int SSL_use_certificate(SSL *ssl, X509 *x);
15*2175Sjp161948 int SSL_use_certificate_ASN1(SSL *ssl, unsigned char *d, int len);
16*2175Sjp161948 int SSL_use_certificate_file(SSL *ssl, const char *file, int type);
17*2175Sjp161948
18*2175Sjp161948 int SSL_CTX_use_certificate_chain_file(SSL_CTX *ctx, const char *file);
19*2175Sjp161948
20*2175Sjp161948 int SSL_CTX_use_PrivateKey(SSL_CTX *ctx, EVP_PKEY *pkey);
21*2175Sjp161948 int SSL_CTX_use_PrivateKey_ASN1(int pk, SSL_CTX *ctx, unsigned char *d,
22*2175Sjp161948				 long len);
23*2175Sjp161948 int SSL_CTX_use_PrivateKey_file(SSL_CTX *ctx, const char *file, int type);
24*2175Sjp161948 int SSL_CTX_use_RSAPrivateKey(SSL_CTX *ctx, RSA *rsa);
25*2175Sjp161948 int SSL_CTX_use_RSAPrivateKey_ASN1(SSL_CTX *ctx, unsigned char *d, long len);
26*2175Sjp161948 int SSL_CTX_use_RSAPrivateKey_file(SSL_CTX *ctx, const char *file, int type);
27*2175Sjp161948 int SSL_use_PrivateKey(SSL *ssl, EVP_PKEY *pkey);
28*2175Sjp161948 int SSL_use_PrivateKey_ASN1(int pk,SSL *ssl, unsigned char *d, long len);
29*2175Sjp161948 int SSL_use_PrivateKey_file(SSL *ssl, const char *file, int type);
30*2175Sjp161948 int SSL_use_RSAPrivateKey(SSL *ssl, RSA *rsa);
31*2175Sjp161948 int SSL_use_RSAPrivateKey_ASN1(SSL *ssl, unsigned char *d, long len);
32*2175Sjp161948 int SSL_use_RSAPrivateKey_file(SSL *ssl, const char *file, int type);
33*2175Sjp161948
34*2175Sjp161948 int SSL_CTX_check_private_key(const SSL_CTX *ctx);
35*2175Sjp161948 int SSL_check_private_key(const SSL *ssl);
36*2175Sjp161948
37*2175Sjp161948=head1 DESCRIPTION
38*2175Sjp161948
39*2175Sjp161948These functions load the certificates and private keys into the SSL_CTX
40*2175Sjp161948or SSL object, respectively.
41*2175Sjp161948
42*2175Sjp161948The SSL_CTX_* class of functions loads the certificates and keys into the
43*2175Sjp161948SSL_CTX object B<ctx>. The information is passed to SSL objects B<ssl>
44*2175Sjp161948created from B<ctx> with L<SSL_new(3)|SSL_new(3)> by copying, so that
45*2175Sjp161948changes applied to B<ctx> do not propagate to already existing SSL objects.
46*2175Sjp161948
47*2175Sjp161948The SSL_* class of functions only loads certificates and keys into a
48*2175Sjp161948specific SSL object. The specific information is kept, when
49*2175Sjp161948L<SSL_clear(3)|SSL_clear(3)> is called for this SSL object.
50*2175Sjp161948
51*2175Sjp161948SSL_CTX_use_certificate() loads the certificate B<x> into B<ctx>,
52*2175Sjp161948SSL_use_certificate() loads B<x> into B<ssl>. The rest of the
53*2175Sjp161948certificates needed to form the complete certificate chain can be
54*2175Sjp161948specified using the
55*2175Sjp161948L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>
56*2175Sjp161948function.
57*2175Sjp161948
58*2175Sjp161948SSL_CTX_use_certificate_ASN1() loads the ASN1 encoded certificate from
59*2175Sjp161948the memory location B<d> (with length B<len>) into B<ctx>,
60*2175Sjp161948SSL_use_certificate_ASN1() loads the ASN1 encoded certificate into B<ssl>.
61*2175Sjp161948
62*2175Sjp161948SSL_CTX_use_certificate_file() loads the first certificate stored in B<file>
63*2175Sjp161948into B<ctx>. The formatting B<type> of the certificate must be specified
64*2175Sjp161948from the known types SSL_FILETYPE_PEM, SSL_FILETYPE_ASN1.
65*2175Sjp161948SSL_use_certificate_file() loads the certificate from B<file> into B<ssl>.
66*2175Sjp161948See the NOTES section on why SSL_CTX_use_certificate_chain_file()
67*2175Sjp161948should be preferred.
68*2175Sjp161948
69*2175Sjp161948SSL_CTX_use_certificate_chain_file() loads a certificate chain from
70*2175Sjp161948B<file> into B<ctx>. The certificates must be in PEM format and must
71*2175Sjp161948be sorted starting with the subject's certificate (actual client or server
72*2175Sjp161948certificate), followed by intermediate CA certificates if applicable, and
73*2175Sjp161948ending at the highest level (root) CA.
74*2175Sjp161948There is no corresponding function working on a single SSL object.
75*2175Sjp161948
76*2175Sjp161948SSL_CTX_use_PrivateKey() adds B<pkey> as private key to B<ctx>.
77*2175Sjp161948SSL_CTX_use_RSAPrivateKey() adds the private key B<rsa> of type RSA
78*2175Sjp161948to B<ctx>. SSL_use_PrivateKey() adds B<pkey> as private key to B<ssl>;
79*2175Sjp161948SSL_use_RSAPrivateKey() adds B<rsa> as private key of type RSA to B<ssl>.
80*2175Sjp161948If a certificate has already been set and the private does not belong
81*2175Sjp161948to the certificate an error is returned. To change a certificate, private
82*2175Sjp161948key pair the new certificate needs to be set with SSL_use_certificate()
83*2175Sjp161948or SSL_CTX_use_certificate() before setting the private key with
84*2175Sjp161948SSL_CTX_use_PrivateKey() or SSL_use_PrivateKey().
85*2175Sjp161948
86*2175Sjp161948
87*2175Sjp161948SSL_CTX_use_PrivateKey_ASN1() adds the private key of type B<pk>
88*2175Sjp161948stored at memory location B<d> (length B<len>) to B<ctx>.
89*2175Sjp161948SSL_CTX_use_RSAPrivateKey_ASN1() adds the private key of type RSA
90*2175Sjp161948stored at memory location B<d> (length B<len>) to B<ctx>.
91*2175Sjp161948SSL_use_PrivateKey_ASN1() and SSL_use_RSAPrivateKey_ASN1() add the private
92*2175Sjp161948key to B<ssl>.
93*2175Sjp161948
94*2175Sjp161948SSL_CTX_use_PrivateKey_file() adds the first private key found in
95*2175Sjp161948B<file> to B<ctx>. The formatting B<type> of the certificate must be specified
96*2175Sjp161948from the known types SSL_FILETYPE_PEM, SSL_FILETYPE_ASN1.
97*2175Sjp161948SSL_CTX_use_RSAPrivateKey_file() adds the first private RSA key found in
98*2175Sjp161948B<file> to B<ctx>. SSL_use_PrivateKey_file() adds the first private key found
99*2175Sjp161948in B<file> to B<ssl>; SSL_use_RSAPrivateKey_file() adds the first private
100*2175Sjp161948RSA key found to B<ssl>.
101*2175Sjp161948
102*2175Sjp161948SSL_CTX_check_private_key() checks the consistency of a private key with
103*2175Sjp161948the corresponding certificate loaded into B<ctx>. If more than one
104*2175Sjp161948key/certificate pair (RSA/DSA) is installed, the last item installed will
105*2175Sjp161948be checked. If e.g. the last item was a RSA certificate or key, the RSA
106*2175Sjp161948key/certificate pair will be checked. SSL_check_private_key() performs
107*2175Sjp161948the same check for B<ssl>. If no key/certificate was explicitly added for
108*2175Sjp161948this B<ssl>, the last item added into B<ctx> will be checked.
109*2175Sjp161948
110*2175Sjp161948=head1 NOTES
111*2175Sjp161948
112*2175Sjp161948The internal certificate store of OpenSSL can hold two private key/certificate
113*2175Sjp161948pairs at a time: one key/certificate of type RSA and one key/certificate
114*2175Sjp161948of type DSA. The certificate used depends on the cipher select, see
115*2175Sjp161948also L<SSL_CTX_set_cipher_list(3)|SSL_CTX_set_cipher_list(3)>.
116*2175Sjp161948
117*2175Sjp161948When reading certificates and private keys from file, files of type
118*2175Sjp161948SSL_FILETYPE_ASN1 (also known as B<DER>, binary encoding) can only contain
119*2175Sjp161948one certificate or private key, consequently
120*2175Sjp161948SSL_CTX_use_certificate_chain_file() is only applicable to PEM formatting.
121*2175Sjp161948Files of type SSL_FILETYPE_PEM can contain more than one item.
122*2175Sjp161948
123*2175Sjp161948SSL_CTX_use_certificate_chain_file() adds the first certificate found
124*2175Sjp161948in the file to the certificate store. The other certificates are added
125*2175Sjp161948to the store of chain certificates using
126*2175Sjp161948L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>.
127*2175Sjp161948There exists only one extra chain store, so that the same chain is appended
128*2175Sjp161948to both types of certificates, RSA and DSA! If it is not intended to use
129*2175Sjp161948both type of certificate at the same time, it is recommended to use the
130*2175Sjp161948SSL_CTX_use_certificate_chain_file() instead of the
131*2175Sjp161948SSL_CTX_use_certificate_file() function in order to allow the use of
132*2175Sjp161948complete certificate chains even when no trusted CA storage is used or
133*2175Sjp161948when the CA issuing the certificate shall not be added to the trusted
134*2175Sjp161948CA storage.
135*2175Sjp161948
136*2175Sjp161948If additional certificates are needed to complete the chain during the
137*2175Sjp161948TLS negotiation, CA certificates are additionally looked up in the
138*2175Sjp161948locations of trusted CA certificates, see
139*2175Sjp161948L<SSL_CTX_load_verify_locations(3)|SSL_CTX_load_verify_locations(3)>.
140*2175Sjp161948
141*2175Sjp161948The private keys loaded from file can be encrypted. In order to successfully
142*2175Sjp161948load encrypted keys, a function returning the passphrase must have been
143*2175Sjp161948supplied, see
144*2175Sjp161948L<SSL_CTX_set_default_passwd_cb(3)|SSL_CTX_set_default_passwd_cb(3)>.
145*2175Sjp161948(Certificate files might be encrypted as well from the technical point
146*2175Sjp161948of view, it however does not make sense as the data in the certificate
147*2175Sjp161948is considered public anyway.)
148*2175Sjp161948
149*2175Sjp161948=head1 RETURN VALUES
150*2175Sjp161948
151*2175Sjp161948On success, the functions return 1.
152*2175Sjp161948Otherwise check out the error stack to find out the reason.
153*2175Sjp161948
154*2175Sjp161948=head1 SEE ALSO
155*2175Sjp161948
156*2175Sjp161948L<ssl(3)|ssl(3)>, L<SSL_new(3)|SSL_new(3)>, L<SSL_clear(3)|SSL_clear(3)>,
157*2175Sjp161948L<SSL_CTX_load_verify_locations(3)|SSL_CTX_load_verify_locations(3)>,
158*2175Sjp161948L<SSL_CTX_set_default_passwd_cb(3)|SSL_CTX_set_default_passwd_cb(3)>,
159*2175Sjp161948L<SSL_CTX_set_cipher_list(3)|SSL_CTX_set_cipher_list(3)>,
160*2175Sjp161948L<SSL_CTX_set_client_cert_cb(3)|SSL_CTX_set_client_cert_cb(3)>,
161*2175Sjp161948L<SSL_CTX_add_extra_chain_cert(3)|SSL_CTX_add_extra_chain_cert(3)>
162*2175Sjp161948
163*2175Sjp161948=head1 HISTORY
164*2175Sjp161948
165*2175Sjp161948Support for DER encoded private keys (SSL_FILETYPE_ASN1) in
166*2175Sjp161948SSL_CTX_use_PrivateKey_file() and SSL_use_PrivateKey_file() was added
167*2175Sjp161948in 0.9.8 .
168*2175Sjp161948
169*2175Sjp161948=cut
170