diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2011-05-06 13:20:55 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-05-06 13:20:55 (GMT) |
commit | ff9bfca4827a6ad323c9eff359e34e10655fdc93 (patch) | |
tree | 50abe56e6fb9b479202372880c9e938346db812e /Lib/ssl.py | |
parent | b4dc2502ad0a3497a4a6628ab1dd2b1e077ae157 (diff) | |
parent | 1c86b4450689cc9ecef6c99ad8e55bae67931e59 (diff) | |
download | cpython-ff9bfca4827a6ad323c9eff359e34e10655fdc93.zip cpython-ff9bfca4827a6ad323c9eff359e34e10655fdc93.tar.gz cpython-ff9bfca4827a6ad323c9eff359e34e10655fdc93.tar.bz2 |
Issue #12000: When a SSL certificate has a subjectAltName without any
dNSName entry, ssl.match_hostname() should use the subject's commonName.
Patch by Nicolas Bareil.
Diffstat (limited to 'Lib/ssl.py')
-rw-r--r-- | Lib/ssl.py | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -122,8 +122,9 @@ def match_hostname(cert, hostname): if _dnsname_to_pat(value).match(hostname): return dnsnames.append(value) - if not san: - # The subject is only checked when subjectAltName is empty + if not dnsnames: + # The subject is only checked when there is no dNSName entry + # in subjectAltName for sub in cert.get('subject', ()): for key, value in sub: # XXX according to RFC 2818, the most specific Common Name |