Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
ae5b953d
Commit
ae5b953d
authored
Nov 23, 2014
by
Benjamin Peterson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
pep 476: verify certificates by default (#22417)
parent
3b01c5de
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
69 additions
and
14 deletions
+69
-14
Doc/library/httplib.rst
Doc/library/httplib.rst
+5
-3
Doc/library/xmlrpclib.rst
Doc/library/xmlrpclib.rst
+3
-4
Doc/whatsnew/2.7.rst
Doc/whatsnew/2.7.rst
+23
-0
Lib/httplib.py
Lib/httplib.py
+1
-1
Lib/ssl.py
Lib/ssl.py
+9
-2
Lib/test/test_httplib.py
Lib/test/test_httplib.py
+1
-2
Lib/test/test_urllib2_localnet.py
Lib/test/test_urllib2_localnet.py
+25
-2
Misc/NEWS
Misc/NEWS
+2
-0
No files found.
Doc/library/httplib.rst
View file @
ae5b953d
...
...
@@ -90,9 +90,6 @@ The module provides the following classes:
server's certificate. If you want to change that behaviour, you can
explicitly set *check_hostname* to False.
.. warning::
This does not do any verification of the server's certificate.
.. versionadded:: 2.0
.. versionchanged:: 2.6
...
...
@@ -104,6 +101,11 @@ The module provides the following classes:
.. versionchanged:: 2.7.9
*context* and *check_hostname* was added.
This class now performs all the necessary certificate and hostname checks
by default. To revert to the previous, unverified, behavior
:func:`ssl._create_unverified_context` can be passed to the *context*
parameter.
.. class:: HTTPResponse(sock, debuglevel=0, strict=0)
...
...
Doc/library/xmlrpclib.rst
View file @
ae5b953d
...
...
@@ -34,11 +34,10 @@ between conformable Python objects and XML on the wire.
constructed data. If you need to parse untrusted or unauthenticated data see
:ref:`xml-vulnerabilities`.
.. warning::
In the case of https URIs, :mod:`xmlrpclib` does not do any verification of
the server's certificate.
.. versionchanged:: 2.7.9
For https URIs, :mod:`xmlrpclib` now performs all the necessary certificate
and hostname checks by default
.. class:: ServerProxy(uri[, transport[, encoding[, verbose[, allow_none[, use_datetime]]]]])
...
...
Doc/whatsnew/2.7.rst
View file @
ae5b953d
...
...
@@ -2646,6 +2646,29 @@ and :ref:`distutils-index`.
PEP written by Donald Stufft and Nick Coghlan, implemented by
Donald Stufft, Nick Coghlan, Martin von Löwis and Ned Deily.
PEP 476: Enabling certificate verification by default for stdlib http clients
-----------------------------------------------------------------------------
:mod:`httplib` and modules which use it, such as :mod:`urllib2` and
:mod:`xmlrpclib`, will now verify that the server presents a certificate
which is signed by a CA in the platform trust store and whose hostname matches
the hostname being requested by default, significantly improving security for
many applications.
For applications which require the old previous behavior, they can pass an
alternate context::
import urllib2
import ssl
# This disables all verification
context = ssl._create_unverified_context()
# This allows using a specific certificate for the host, which doesn't need
# to be in the trust store
context = ssl.create_default_context(cafile="/path/to/file.crt")
urllib2.urlopen("https://invalid-cert", context=context)
.. ======================================================================
...
...
Lib/httplib.py
View file @
ae5b953d
...
...
@@ -1193,7 +1193,7 @@ else:
self
.
key_file
=
key_file
self
.
cert_file
=
cert_file
if
context
is
None
:
context
=
ssl
.
create_default
_context
()
context
=
ssl
.
_create_default_https
_context
()
will_verify
=
context
.
verify_mode
!=
ssl
.
CERT_NONE
if
check_hostname
is
None
:
check_hostname
=
will_verify
...
...
Lib/ssl.py
View file @
ae5b953d
...
...
@@ -427,8 +427,7 @@ def create_default_context(purpose=Purpose.SERVER_AUTH, cafile=None,
context
.
load_default_certs
(
purpose
)
return
context
def
_create_stdlib_context
(
protocol
=
PROTOCOL_SSLv23
,
cert_reqs
=
None
,
def
_create_unverified_context
(
protocol
=
PROTOCOL_SSLv23
,
cert_reqs
=
None
,
check_hostname
=
False
,
purpose
=
Purpose
.
SERVER_AUTH
,
certfile
=
None
,
keyfile
=
None
,
cafile
=
None
,
capath
=
None
,
cadata
=
None
):
...
...
@@ -469,6 +468,14 @@ def _create_stdlib_context(protocol=PROTOCOL_SSLv23, cert_reqs=None,
return
context
# Used by http.client if no context is explicitly passed.
_create_default_https_context
=
create_default_context
# Backwards compatibility alias, even though it's not a public name.
_create_stdlib_context
=
_create_unverified_context
class
SSLSocket
(
socket
):
"""This class implements a subtype of socket.socket that wraps
the underlying OS socket in an SSL context when necessary, and
...
...
Lib/test/test_httplib.py
View file @
ae5b953d
import
httplib
import
array
import
httplib
import
os
import
StringIO
import
socket
import
errno
import
os
import
unittest
TestCase
=
unittest
.
TestCase
...
...
Lib/test/test_urllib2_localnet.py
View file @
ae5b953d
...
...
@@ -5,6 +5,7 @@ import urllib2
import
BaseHTTPServer
import
unittest
import
hashlib
import
ssl
from
test
import
test_support
...
...
@@ -562,15 +563,37 @@ class TestUrlopen(BaseTestCase):
cafile
=
CERT_localhost
)
self
.
assertEqual
(
data
,
b"we care a bit"
)
# Bad cert
with
self
.
assertRaises
(
urllib2
.
URLError
)
as
cm
:
with
self
.
assertRaises
(
urllib2
.
URLError
):
self
.
urlopen
(
"https://localhost:%s/bizarre"
%
handler
.
port
,
cafile
=
CERT_fakehostname
)
# Good cert, but mismatching hostname
handler
=
self
.
start_https_server
(
certfile
=
CERT_fakehostname
)
with
self
.
assertRaises
(
ssl
.
CertificateError
)
as
cm
:
with
self
.
assertRaises
(
ssl
.
CertificateError
):
self
.
urlopen
(
"https://localhost:%s/bizarre"
%
handler
.
port
,
cafile
=
CERT_fakehostname
)
def
test_https_with_cadefault
(
self
):
handler
=
self
.
start_https_server
(
certfile
=
CERT_localhost
)
# Self-signed cert should fail verification with system certificate store
with
self
.
assertRaises
(
urllib2
.
URLError
):
self
.
urlopen
(
"https://localhost:%s/bizarre"
%
handler
.
port
,
cadefault
=
True
)
def
test_https_sni
(
self
):
if
ssl
is
None
:
self
.
skipTest
(
"ssl module required"
)
if
not
ssl
.
HAS_SNI
:
self
.
skipTest
(
"SNI support required in OpenSSL"
)
sni_name
=
[
None
]
def
cb_sni
(
ssl_sock
,
server_name
,
initial_context
):
sni_name
[
0
]
=
server_name
context
=
ssl
.
SSLContext
(
ssl
.
PROTOCOL_TLSv1
)
context
.
set_servername_callback
(
cb_sni
)
handler
=
self
.
start_https_server
(
context
=
context
,
certfile
=
CERT_localhost
)
context
=
ssl
.
create_default_context
(
cafile
=
CERT_localhost
)
self
.
urlopen
(
"https://localhost:%s"
%
handler
.
port
,
context
=
context
)
self
.
assertEqual
(
sni_name
[
0
],
"localhost"
)
def
test_sending_headers
(
self
):
handler
=
self
.
start_server
([(
200
,
[],
"we don't care"
)])
...
...
Misc/NEWS
View file @
ae5b953d
...
...
@@ -42,6 +42,8 @@ Core and Builtins
Library
-------
-
Issue
#
22417
:
Verify
certificates
by
default
in
httplib
(
PEP
476
).
-
Issue
#
22927
:
Allow
urllib
.
urlopen
to
take
a
*
context
*
parameter
to
control
SSL
settings
for
HTTPS
connections
.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment