summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorChristian Heimes <christian@python.org>2017-09-08 21:47:58 (GMT)
committerGitHub <noreply@github.com>2017-09-08 21:47:58 (GMT)
commit0915360b9ef765bf84d4471a8a079f48c49bad68 (patch)
treed667e3a0ad6039f5b2c5fb81ce4fecd85c4da325 /Modules
parentdb610e909b07ced88e73fb0c23e04eed0d4e1b0d (diff)
downloadcpython-0915360b9ef765bf84d4471a8a079f48c49bad68.zip
cpython-0915360b9ef765bf84d4471a8a079f48c49bad68.tar.gz
cpython-0915360b9ef765bf84d4471a8a079f48c49bad68.tar.bz2
bpo-28182: restore backwards compatibility (#3464)
b3ad0e5 broke backwards compatibility with OpenSSL < 1.0.2. Signed-off-by: Christian Heimes <christian@python.org>
Diffstat (limited to 'Modules')
-rw-r--r--Modules/_ssl.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/Modules/_ssl.c b/Modules/_ssl.c
index 5b27f2f..5ec31a7 100644
--- a/Modules/_ssl.c
+++ b/Modules/_ssl.c
@@ -485,18 +485,23 @@ fill_and_set_sslerror(PySSLSocket *sslsock, PyObject *type, int ssl_errno,
}
switch (verify_code) {
+#ifdef X509_V_ERR_HOSTNAME_MISMATCH
+ /* OpenSSL >= 1.0.2, LibreSSL >= 2.5.3 */
case X509_V_ERR_HOSTNAME_MISMATCH:
verify_obj = PyUnicode_FromFormat(
"Hostname mismatch, certificate is not valid for '%S'.",
sslsock->server_hostname
);
break;
+#endif
+#ifdef X509_V_ERR_IP_ADDRESS_MISMATCH
case X509_V_ERR_IP_ADDRESS_MISMATCH:
verify_obj = PyUnicode_FromFormat(
"IP address mismatch, certificate is not valid for '%S'.",
sslsock->server_hostname
);
break;
+#endif
default:
verify_str = X509_verify_cert_error_string(verify_code);
if (verify_str != NULL) {