Blame SOURCES/sblim-wbemcli-1.6.1-ssl-proto-option.patch

cad35d
diff -up sblim-wbemcli-1.6.1/CimCurl.cpp.orig sblim-wbemcli-1.6.1/CimCurl.cpp
cad35d
--- sblim-wbemcli-1.6.1/CimCurl.cpp.orig	2009-03-04 20:10:54.000000000 +0100
cad35d
+++ sblim-wbemcli-1.6.1/CimCurl.cpp	2015-08-10 13:59:47.312019828 +0200
cad35d
@@ -165,8 +165,36 @@ void CimomCurl::genRequest(URL &url, con
cad35d
     rv = curl_easy_setopt(mHandle, CURLOPT_SSL_VERIFYHOST, 0);
cad35d
     //    rv = curl_easy_setopt(mHandle, CURLOPT_SSL_VERIFYPEER, 0);
cad35d
     
cad35d
-    /* Force using SSL V3 */
cad35d
-    rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, 3);    
cad35d
+    /* Force use of a specific SSL/TLS version */
cad35d
+    char * curlSslVer = getenv("WBEMCLI_CURL_SSLVERSION");
cad35d
+    if (curlSslVer) {
cad35d
+      if (!strcasecmp(curlSslVer,"SSLv2"))
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_SSLv2);
cad35d
+      else if (!strcasecmp(curlSslVer,"SSLv3"))
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_SSLv3);
cad35d
+      else if (!strcasecmp(curlSslVer,"TLSv1"))
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1);
cad35d
+      else if (!strcasecmp(curlSslVer,"TLSv1.0") || !strcasecmp(curlSslVer,"TLSv1_0"))
cad35d
+#if LIBCURL_VERSION_NUM >= 0x072200
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_0);
cad35d
+#else
cad35d
+        throw URLException("WBEMCLI_CURL_SSLVERSION=TLSv1.0 requires libcurl 7.34 or greater");
cad35d
+#endif
cad35d
+      else if (!strcasecmp(curlSslVer,"TLSv1.1") || !strcasecmp(curlSslVer,"TLSv1_1"))
cad35d
+#if LIBCURL_VERSION_NUM >= 0x072200
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_1);
cad35d
+#else
cad35d
+        throw URLException("WBEMCLI_CURL_SSLVERSION=TLSv1.1 requires libcurl 7.34 or greater");
cad35d
+#endif
cad35d
+      else if (!strcasecmp(curlSslVer,"TLSv1.2") || !strcasecmp(curlSslVer,"TLSv1_2"))
cad35d
+#if LIBCURL_VERSION_NUM >= 0x072200
cad35d
+        rv = curl_easy_setopt(mHandle, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_2);
cad35d
+#else
cad35d
+        throw URLException("WBEMCLI_CURL_SSLVERSION=TLSv1.2 requires libcurl 7.34 or greater");
cad35d
+#endif
cad35d
+      else
cad35d
+        throw URLException("unknown WBEMCLI_CURL_SSLVERSION");
cad35d
+    }
cad35d
 
cad35d
     /* Set username and password */
cad35d
     if (url.user.length() > 0 && url.password.length() > 0) {
cad35d
diff -up sblim-wbemcli-1.6.1/man/wbemcli.1.pre.in.orig sblim-wbemcli-1.6.1/man/wbemcli.1.pre.in
cad35d
--- sblim-wbemcli-1.6.1/man/wbemcli.1.pre.in.orig	2015-08-10 14:00:11.217163540 +0200
cad35d
+++ sblim-wbemcli-1.6.1/man/wbemcli.1.pre.in	2015-08-10 14:00:31.215283763 +0200
cad35d
@@ -554,6 +554,13 @@ The example in the previous section can
cad35d
 	wbemcli gi 'myCimom/root/cimv2:rpm_package.name="glibc"'
cad35d
 .PP
cad35d
 
cad35d
+.SH ENVIRONMENT
cad35d
+.TP
cad35d
+.B WBEMCLI_CURL_SSLVERSION
cad35d
+Specifies the SSL protocol that will be used.
cad35d
+Valid values are SSLv2, SSLv3, TLSv1, TLSv1.0, TLSv1.1 or TLSv1.2.
cad35d
+If this variable is not set, wbemcli will attempt to figure out the
cad35d
+remote SSL protocol version.
cad35d
 .SH FILES
cad35d
 .TP
cad35d
 .I @CACERT@