2001-07-21 19:02:17 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
SSL_CTX_set_tmp_dh_callback, SSL_CTX_set_tmp_dh, SSL_set_tmp_dh_callback, SSL_set_tmp_dh - handle DH keys for ephemeral key exchange
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/ssl.h>
|
|
|
|
|
|
|
|
void SSL_CTX_set_tmp_dh_callback(SSL_CTX *ctx,
|
2017-01-21 02:58:49 +08:00
|
|
|
DH *(*tmp_dh_callback)(SSL *ssl, int is_export,
|
|
|
|
int keylength));
|
2001-07-21 19:02:17 +08:00
|
|
|
long SSL_CTX_set_tmp_dh(SSL_CTX *ctx, DH *dh);
|
|
|
|
|
2014-07-03 10:42:40 +08:00
|
|
|
void SSL_set_tmp_dh_callback(SSL *ctx,
|
2017-01-21 02:58:49 +08:00
|
|
|
DH *(*tmp_dh_callback)(SSL *ssl, int is_export,
|
|
|
|
int keylength));
|
2001-07-21 19:02:17 +08:00
|
|
|
long SSL_set_tmp_dh(SSL *ssl, DH *dh)
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
SSL_CTX_set_tmp_dh_callback() sets the callback function for B<ctx> to be
|
|
|
|
used when a DH parameters are required to B<tmp_dh_callback>.
|
|
|
|
The callback is inherited by all B<ssl> objects created from B<ctx>.
|
|
|
|
|
|
|
|
SSL_CTX_set_tmp_dh() sets DH parameters to be used to be B<dh>.
|
|
|
|
The key is inherited by all B<ssl> objects created from B<ctx>.
|
|
|
|
|
|
|
|
SSL_set_tmp_dh_callback() sets the callback only for B<ssl>.
|
|
|
|
|
2001-09-07 14:13:40 +08:00
|
|
|
SSL_set_tmp_dh() sets the parameters only for B<ssl>.
|
2001-07-21 19:02:17 +08:00
|
|
|
|
|
|
|
These functions apply to SSL/TLS servers only.
|
|
|
|
|
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
When using a cipher with RSA authentication, an ephemeral DH key exchange
|
2001-07-31 23:04:50 +08:00
|
|
|
can take place. Ciphers with DSA keys always use ephemeral DH keys as well.
|
|
|
|
In these cases, the session data are negotiated using the
|
2001-07-21 19:02:17 +08:00
|
|
|
ephemeral/temporary DH key and the key supplied and certified
|
|
|
|
by the certificate chain is only used for signing.
|
2001-07-31 23:04:50 +08:00
|
|
|
Anonymous ciphers (without a permanent server key) also use ephemeral DH keys.
|
2001-07-21 19:02:17 +08:00
|
|
|
|
|
|
|
Using ephemeral DH key exchange yields forward secrecy, as the connection
|
|
|
|
can only be decrypted, when the DH key is known. By generating a temporary
|
|
|
|
DH key inside the server application that is lost when the application
|
|
|
|
is left, it becomes impossible for an attacker to decrypt past sessions,
|
|
|
|
even if he gets hold of the normal (certified) key, as this key was
|
|
|
|
only used for signing.
|
|
|
|
|
|
|
|
In order to perform a DH key exchange the server must use a DH group
|
2015-12-17 10:57:20 +08:00
|
|
|
(DH parameters) and generate a DH key. The server will always generate
|
|
|
|
a new DH key during the negotiation.
|
2001-07-21 19:02:17 +08:00
|
|
|
|
|
|
|
As generating DH parameters is extremely time consuming, an application
|
|
|
|
should not generate the parameters on the fly but supply the parameters.
|
|
|
|
DH parameters can be reused, as the actual key is newly generated during
|
|
|
|
the negotiation. The risk in reusing DH parameters is that an attacker
|
2001-07-31 23:04:50 +08:00
|
|
|
may specialize on a very often used DH group. Applications should therefore
|
2001-09-07 14:13:40 +08:00
|
|
|
generate their own DH parameters during the installation process using the
|
2015-08-18 03:21:33 +08:00
|
|
|
openssl L<dhparam(1)> application. This application
|
2015-05-12 22:10:05 +08:00
|
|
|
guarantees that "strong" primes are used.
|
2001-07-31 23:04:50 +08:00
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
Files dh2048.pem, and dh4096.pem in the 'apps' directory of the current
|
2001-07-31 23:04:50 +08:00
|
|
|
version of the OpenSSL distribution contain the 'SKIP' DH parameters,
|
|
|
|
which use safe primes and were generated verifiably pseudo-randomly.
|
|
|
|
These files can be converted into C code using the B<-C> option of the
|
2015-08-18 03:21:33 +08:00
|
|
|
L<dhparam(1)> application. Generation of custom DH
|
2015-05-12 22:10:05 +08:00
|
|
|
parameters during installation should still be preferred to stop an
|
2015-05-18 19:57:01 +08:00
|
|
|
attacker from specializing on a commonly used group. File dh1024.pem
|
|
|
|
contains old parameters that must not be used by applications.
|
2001-07-31 23:04:50 +08:00
|
|
|
|
|
|
|
An application may either directly specify the DH parameters or
|
2015-05-12 22:10:05 +08:00
|
|
|
can supply the DH parameters via a callback function.
|
2001-07-21 19:02:17 +08:00
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
Previous versions of the callback used B<is_export> and B<keylength>
|
|
|
|
parameters to control parameter generation for export and non-export
|
2017-03-30 05:38:30 +08:00
|
|
|
cipher suites. Modern servers that do not support export cipher suites
|
2015-12-17 10:57:20 +08:00
|
|
|
are advised to either use SSL_CTX_set_tmp_dh() or alternatively, use
|
|
|
|
the callback but ignore B<keylength> and B<is_export> and simply
|
|
|
|
supply at least 2048-bit parameters in the callback.
|
2001-07-21 19:02:17 +08:00
|
|
|
|
|
|
|
=head1 EXAMPLES
|
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
Setup DH parameters with a key length of 2048 bits. (Error handling
|
2001-07-21 19:02:17 +08:00
|
|
|
partly left out.)
|
|
|
|
|
2016-11-19 07:10:05 +08:00
|
|
|
Command-line parameter generation:
|
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
$ openssl dhparam -out dh_param_2048.pem 2048
|
|
|
|
|
2016-11-19 07:10:05 +08:00
|
|
|
Code for setting up parameters during server initialization:
|
2001-07-21 19:02:17 +08:00
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
SSL_CTX ctx = SSL_CTX_new();
|
2016-11-19 07:10:05 +08:00
|
|
|
|
2015-05-12 22:10:05 +08:00
|
|
|
DH *dh_2048 = NULL;
|
2017-01-21 02:58:49 +08:00
|
|
|
FILE *paramfile = fopen("dh_param_2048.pem", "r");
|
|
|
|
|
2001-07-21 19:02:17 +08:00
|
|
|
if (paramfile) {
|
2016-11-19 07:10:05 +08:00
|
|
|
dh_2048 = PEM_read_DHparams(paramfile, NULL, NULL, NULL);
|
|
|
|
fclose(paramfile);
|
2015-05-12 22:10:05 +08:00
|
|
|
} else {
|
2016-11-19 07:10:05 +08:00
|
|
|
/* Error. */
|
2001-07-21 19:02:17 +08:00
|
|
|
}
|
2016-11-19 07:10:05 +08:00
|
|
|
if (dh_2048 == NULL)
|
|
|
|
/* Error. */
|
|
|
|
if (SSL_CTX_set_tmp_dh(ctx, dh_2048) != 1)
|
|
|
|
/* Error. */
|
2015-05-12 22:10:05 +08:00
|
|
|
...
|
2001-07-21 19:02:17 +08:00
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
SSL_CTX_set_tmp_dh_callback() and SSL_set_tmp_dh_callback() do not return
|
|
|
|
diagnostic output.
|
|
|
|
|
|
|
|
SSL_CTX_set_tmp_dh() and SSL_set_tmp_dh() do return 1 on success and 0
|
|
|
|
on failure. Check the error queue to find out the reason of failure.
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2016-11-11 16:33:09 +08:00
|
|
|
L<ssl(7)>, L<SSL_CTX_set_cipher_list(3)>,
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_CTX_set_options(3)>,
|
|
|
|
L<ciphers(1)>, L<dhparam(1)>
|
2001-07-21 19:02:17 +08:00
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
|
|
|
Copyright 2001-2016 The OpenSSL Project Authors. All Rights Reserved.
|
|
|
|
|
|
|
|
Licensed under the OpenSSL license (the "License"). You may not use
|
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|