From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: James Ralston Date: Sun, 1 May 2022 16:15:23 -0700 Subject: [PATCH] Allow legacy renegotiation to fix PEAP issues with some servers Upstream: http://lists.infradead.org/pipermail/hostap/2022-May/040511.html --- src/crypto/tls_openssl.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/crypto/tls_openssl.c b/src/crypto/tls_openssl.c index b27c238ec864..59a1b0d9b9c7 100644 --- a/src/crypto/tls_openssl.c +++ b/src/crypto/tls_openssl.c @@ -1114,6 +1114,16 @@ void * tls_init(const struct tls_config *conf) SSL_CTX_set_options(ssl, SSL_OP_NO_SSLv2); SSL_CTX_set_options(ssl, SSL_OP_NO_SSLv3); + /* Many enterprise PEAP server implementations (e.g. used in large + corporations and universities) do not support RFC5746 secure + renegotiation, and starting with OpenSSL 3.0, + SSL_OP_LEGACY_SERVER_CONNECT is no longer set as part of SSL_OP_ALL. + So until we implement a way to request SSL_OP_LEGACY_SERVER_CONNECT + only in EAP peer mode, just set SSL_OP_LEGACY_SERVER_CONNECT + globally. */ + + SSL_CTX_set_options(ssl, SSL_OP_LEGACY_SERVER_CONNECT); + SSL_CTX_set_mode(ssl, SSL_MODE_AUTO_RETRY); #ifdef SSL_MODE_NO_AUTO_CHAIN