You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
1.9 KiB

  1. From eee374c28ea8ea22834ff14515b5584bc3e0c7b5 Mon Sep 17 00:00:00 2001
  2. From: =?UTF-8?q?J=C3=A9r=C3=A9mie=20Courr=C3=A8ges-Anglas?= <jca@wxcvbn.org>
  3. Date: Sat, 25 Jul 2015 16:50:52 -0600
  4. Subject: [PATCH 3/4] BUILD: ssl: Allow building against libssl without SSLv3.
  5. If SSLv3 is explicitely requested but not available, warn the user and
  6. bail out.
  7. (cherry picked from commit 17c3f6284cf605e47f6525c077bc644c45272849)
  8. ---
  9. src/ssl_sock.c | 16 ++++++++++++++--
  10. 1 file changed, 14 insertions(+), 2 deletions(-)
  11. diff --git a/src/ssl_sock.c b/src/ssl_sock.c
  12. index 7d77d36..2ae45ec 100644
  13. --- a/src/ssl_sock.c
  14. +++ b/src/ssl_sock.c
  15. @@ -1405,8 +1405,14 @@ int ssl_sock_prepare_ctx(struct bind_conf *bind_conf, SSL_CTX *ctx, struct proxy
  16. ssloptions |= SSL_OP_NO_TLSv1_2;
  17. if (bind_conf->ssl_options & BC_SSL_O_NO_TLS_TICKETS)
  18. ssloptions |= SSL_OP_NO_TICKET;
  19. - if (bind_conf->ssl_options & BC_SSL_O_USE_SSLV3)
  20. + if (bind_conf->ssl_options & BC_SSL_O_USE_SSLV3) {
  21. +#ifndef OPENSSL_NO_SSL3
  22. SSL_CTX_set_ssl_version(ctx, SSLv3_server_method());
  23. +#else
  24. + Alert("SSLv3 support requested but unavailable.\n");
  25. + cfgerr++;
  26. +#endif
  27. + }
  28. if (bind_conf->ssl_options & BC_SSL_O_USE_TLSV10)
  29. SSL_CTX_set_ssl_version(ctx, TLSv1_server_method());
  30. #if SSL_OP_NO_TLSv1_1
  31. @@ -1750,8 +1756,14 @@ int ssl_sock_prepare_srv_ctx(struct server *srv, struct proxy *curproxy)
  32. options |= SSL_OP_NO_TLSv1_2;
  33. if (srv->ssl_ctx.options & SRV_SSL_O_NO_TLS_TICKETS)
  34. options |= SSL_OP_NO_TICKET;
  35. - if (srv->ssl_ctx.options & SRV_SSL_O_USE_SSLV3)
  36. + if (srv->ssl_ctx.options & SRV_SSL_O_USE_SSLV3) {
  37. +#ifndef OPENSSL_NO_SSL3
  38. SSL_CTX_set_ssl_version(srv->ssl_ctx.ctx, SSLv3_client_method());
  39. +#else
  40. + Alert("SSLv3 support requested but unavailable.");
  41. + cfgerr++;
  42. +#endif
  43. + }
  44. if (srv->ssl_ctx.options & SRV_SSL_O_USE_TLSV10)
  45. SSL_CTX_set_ssl_version(srv->ssl_ctx.ctx, TLSv1_client_method());
  46. #if SSL_OP_NO_TLSv1_1
  47. --
  48. 2.3.6