forked from squeaky-pl/portable-pypy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathssl.py.patch
67 lines (59 loc) · 2.39 KB
/
ssl.py.patch
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
--- lib-python/2.7/ssl.orig.py 2016-08-28 02:28:24.000000000 -0300
+++ lib-python/2.7/ssl.py 2016-09-06 14:33:42.917950566 -0300
@@ -278,6 +278,25 @@
"subjectAltName fields were found")
+_cafile = None
+_capath = None
+
+# https://www.happyassassin.net/2015/01/12/a-note-about-ssltls-trusted-certificate-stores-and-platforms/
+def _find_cafile_and_capath():
+ global _cafile
+ global _capath
+
+ if not _cafile and not _capath:
+ if os.path.isfile('/etc/pki/tls/certs/ca-bundle.crt'):
+ _cafile = '/etc/pki/tls/certs/ca-bundle.crt'
+ elif os.path.isdir('/etc/ssl/certs'):
+ _capath = '/etc/ssl/certs'
+ else:
+ _cafile = os.path.dirname(__file__) + '/cacert.pem'
+
+ return _cafile, _capath
+
+
DefaultVerifyPaths = namedtuple("DefaultVerifyPaths",
"cafile capath openssl_cafile_env openssl_cafile openssl_capath_env "
"openssl_capath")
@@ -285,14 +304,19 @@
def get_default_verify_paths():
"""Return paths to default cafile and capath.
"""
- parts = _ssl.get_default_verify_paths()
+ parts = list(_ssl.get_default_verify_paths())
+ cafile, capath = _find_cafile_and_capath()
# environment vars shadow paths
- cafile = os.environ.get(parts[0], parts[1])
- capath = os.environ.get(parts[2], parts[3])
+ cafile = os.environ.get(parts[0], cafile)
+ capath = os.environ.get(parts[2], capath)
+
+ # overwrite what we get from bundled openssl since it's useless
+ parts[1] = None
+ parts[3] = None
- return DefaultVerifyPaths(cafile if os.path.isfile(cafile) else None,
- capath if os.path.isdir(capath) else None,
+ return DefaultVerifyPaths(cafile if os.path.isfile(cafile or '') else None,
+ capath if os.path.isdir(capath or '') else None,
*parts)
@@ -389,7 +413,12 @@
if sys.platform == "win32":
for storename in self._windows_cert_stores:
self._load_windows_store_certs(storename, purpose)
- self.set_default_verify_paths()
+
+ if not os.environ.get('SSL_CERT_FILE') and not os.environ.get('SSL_CERT_DIR'):
+ locations = _find_cafile_and_capath()
+ self.load_verify_locations(*locations)
+ else:
+ self.set_default_verify_paths()
def create_default_context(purpose=Purpose.SERVER_AUTH, cafile=None,