Merge branch 'Kriechi-ssl-version-handling'
This commit is contained in:
commit
80dd703a2a
|
@ -16,13 +16,24 @@ from . import certutils
|
||||||
|
|
||||||
EINTR = 4
|
EINTR = 4
|
||||||
|
|
||||||
SSLv2_METHOD = SSL.SSLv2_METHOD
|
# To enable all SSL methods use: SSLv23
|
||||||
SSLv3_METHOD = SSL.SSLv3_METHOD
|
# then add options to disable certain methods
|
||||||
SSLv23_METHOD = SSL.SSLv23_METHOD
|
# https://bugs.launchpad.net/pyopenssl/+bug/1020632/comments/3
|
||||||
TLSv1_METHOD = SSL.TLSv1_METHOD
|
|
||||||
TLSv1_1_METHOD = SSL.TLSv1_1_METHOD
|
|
||||||
TLSv1_2_METHOD = SSL.TLSv1_2_METHOD
|
|
||||||
|
|
||||||
|
# Use ONLY for parsing of CLI arguments!
|
||||||
|
# All code internals should use OpenSSL constants directly!
|
||||||
|
SSL_VERSIONS = {
|
||||||
|
'TLSv1.2': SSL.TLSv1_2_METHOD,
|
||||||
|
'TLSv1.1': SSL.TLSv1_1_METHOD,
|
||||||
|
'TLSv1': SSL.TLSv1_METHOD,
|
||||||
|
'SSLv3': SSL.SSLv3_METHOD,
|
||||||
|
'SSLv2': SSL.SSLv2_METHOD,
|
||||||
|
'SSLv23': SSL.SSLv23_METHOD,
|
||||||
|
}
|
||||||
|
|
||||||
|
SSL_DEFAULT_VERSION = 'SSLv23'
|
||||||
|
|
||||||
|
SSL_DEFAULT_METHOD = SSL_VERSIONS[SSL_DEFAULT_VERSION]
|
||||||
|
|
||||||
SSL_DEFAULT_OPTIONS = (
|
SSL_DEFAULT_OPTIONS = (
|
||||||
SSL.OP_NO_SSLv2 |
|
SSL.OP_NO_SSLv2 |
|
||||||
|
@ -376,7 +387,7 @@ class _Connection(object):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def _create_ssl_context(self,
|
def _create_ssl_context(self,
|
||||||
method=SSLv23_METHOD,
|
method=SSL_DEFAULT_METHOD,
|
||||||
options=SSL_DEFAULT_OPTIONS,
|
options=SSL_DEFAULT_OPTIONS,
|
||||||
verify_options=SSL.VERIFY_NONE,
|
verify_options=SSL.VERIFY_NONE,
|
||||||
ca_path=certifi.where(),
|
ca_path=certifi.where(),
|
||||||
|
|
|
@ -83,10 +83,10 @@ class TServer(tcp.TCPServer):
|
||||||
OpenSSL.crypto.FILETYPE_PEM,
|
OpenSSL.crypto.FILETYPE_PEM,
|
||||||
open(raw_key, "rb").read())
|
open(raw_key, "rb").read())
|
||||||
if self.ssl.get("v3_only", False):
|
if self.ssl.get("v3_only", False):
|
||||||
method = tcp.SSLv3_METHOD
|
method = OpenSSL.SSL.SSLv3_METHOD
|
||||||
options = OpenSSL.SSL.OP_NO_SSLv2 | OpenSSL.SSL.OP_NO_TLSv1
|
options = OpenSSL.SSL.OP_NO_SSLv2 | OpenSSL.SSL.OP_NO_TLSv1
|
||||||
else:
|
else:
|
||||||
method = tcp.SSLv23_METHOD
|
method = OpenSSL.SSL.SSLv23_METHOD
|
||||||
options = None
|
options = None
|
||||||
h.convert_to_ssl(
|
h.convert_to_ssl(
|
||||||
cert, key,
|
cert, key,
|
||||||
|
|
Loading…
Reference in New Issue