diff options
author | Kali Kaneko <kali@leap.se> | 2014-12-08 10:49:33 -0600 |
---|---|---|
committer | Kali Kaneko <kali@leap.se> | 2014-12-08 10:49:33 -0600 |
commit | 38cb4b7c04c7d6275f92268bcc45b32491660c11 (patch) | |
tree | 7f60ade5fa4d434b858dc7b174c3c4f78b2c1d11 /client | |
parent | 88c8d03a6f340fcf39c2cd579d7198166f5c10a7 (diff) | |
parent | 7496a78b2d82d27a7b2470f5393f0e531ef75360 (diff) |
Merge tag '0.6.1' into deb-0.6.1
Tag soledad version 0.6.1.
Diffstat (limited to 'client')
-rw-r--r-- | client/src/leap/soledad/client/__init__.py | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/client/src/leap/soledad/client/__init__.py b/client/src/leap/soledad/client/__init__.py index 586e3389..c350d021 100644 --- a/client/src/leap/soledad/client/__init__.py +++ b/client/src/leap/soledad/client/__init__.py @@ -1333,9 +1333,26 @@ class VerifiedHTTPSConnection(httplib.HTTPSConnection): self.sock = sock self._tunnel() - self.sock = ssl.wrap_socket(sock, - ca_certs=SOLEDAD_CERT, - cert_reqs=ssl.CERT_REQUIRED) + highest_supported = ssl.PROTOCOL_SSLv23 + + try: + # needs python 2.7.9+ + # negotiate the best available version, + # but explicitely disabled bad ones. + ctx = ssl.SSLContext(highest_supported) + ctx.options |= ssl.OP_NO_SSLv2 + ctx.options |= ssl.OP_NO_SSLv3 + + ctx.load_cert_chain(certfile=SOLEDAD_CERT) + ctx.verify_mode = ssl.CERT_REQUIRED + self.sock = ctx.wrap_socket( + sock, server_side=True, server_hostname=self.host) + + except AttributeError: + self.sock = ssl.wrap_socket( + sock, ca_certs=SOLEDAD_CERT, cert_reqs=ssl.CERT_REQUIRED, + ssl_version=highest_supported) + match_hostname(self.sock.getpeercert(), self.host) |