mrc0mmand / rpms / openldap

Forked from rpms/openldap 3 years ago
Clone

Blame SOURCES/openldap-openssl-ITS7595-Add-EC-support-2.patch

5ed10d
ITS#7595 don't try to use EC if OpenSSL lacks it
5ed10d
5ed10d
Cherry-picked upstream 721e46fe6695077d63a3df6ea2e397920a72308d
5ed10d
Author: Howard Chu <hyc@openldap.org>
5ed10d
Date: Sun Sep 8 06:32:23 2013 -0700
5ed10d
5ed10d
diff --git a/libraries/libldap/tls_o.c b/libraries/libldap/tls_o.c
5ed10d
index 1a81bc625..71c2b055c 100644
5ed10d
--- a/libraries/libldap/tls_o.c
5ed10d
+++ b/libraries/libldap/tls_o.c
5ed10d
@@ -321,8 +321,12 @@ tlso_ctx_init( struct ldapoptions *lo, struct ldaptls *lt, int is_server )
5ed10d
 		DH_free( dh );
5ed10d
 	}
5ed10d
 
5ed10d
-#ifdef SSL_OP_SINGLE_ECDH_USE
5ed10d
 	if ( is_server && lo->ldo_tls_ecname ) {
5ed10d
+#ifdef OPENSSL_NO_EC
5ed10d
+		Debug( LDAP_DEBUG_ANY,
5ed10d
+			"TLS: Elliptic Curves not supported.\n", 0,0,0 );
5ed10d
+		return -1;
5ed10d
+#else
5ed10d
 		EC_KEY *ecdh;
5ed10d
 
5ed10d
 		int nid = OBJ_sn2nid( lt->lt_ecname );
5ed10d
@@ -344,8 +348,8 @@ tlso_ctx_init( struct ldapoptions *lo, struct ldaptls *lt, int is_server )
5ed10d
 		SSL_CTX_set_tmp_ecdh( ctx, ecdh );
5ed10d
 		SSL_CTX_set_options( ctx, SSL_OP_SINGLE_ECDH_USE );
5ed10d
 		EC_KEY_free( ecdh );
5ed10d
-	}
5ed10d
 #endif
5ed10d
+	}
5ed10d
 
5ed10d
 	if ( tlso_opt_trace ) {
5ed10d
 		SSL_CTX_set_info_callback( ctx, tlso_info_cb );