aboutsummaryrefslogtreecommitdiffstats
path: root/netlib
diff options
context:
space:
mode:
Diffstat (limited to 'netlib')
-rw-r--r--netlib/tcp.py23
1 files changed, 22 insertions, 1 deletions
diff --git a/netlib/tcp.py b/netlib/tcp.py
index 276d3162..c8ffefdf 100644
--- a/netlib/tcp.py
+++ b/netlib/tcp.py
@@ -53,11 +53,13 @@ class TCPClient:
self.connection, self.rfile, self.wfile = None, None, None
self.cert = None
- def convert_to_ssl(self, clientcert=None):
+ def convert_to_ssl(self, clientcert=None, sni=None):
context = SSL.Context(SSL.SSLv23_METHOD)
if clientcert:
context.use_certificate_file(self.clientcert)
self.connection = SSL.Connection(context, self.connection)
+ if sni:
+ self.connection.set_tlsext_host_name(sni)
self.connection.set_connect_state()
self.connection.do_handshake()
self.cert = self.connection.get_peer_certificate()
@@ -92,10 +94,12 @@ class BaseHandler:
def convert_to_ssl(self, cert, key):
ctx = SSL.Context(SSL.SSLv23_METHOD)
+ ctx.set_tlsext_servername_callback(self.handle_sni)
ctx.use_privatekey_file(key)
ctx.use_certificate_file(cert)
self.connection = SSL.Connection(ctx, self.connection)
self.connection.set_accept_state()
+ # SNI callback happens during do_handshake()
self.connection.do_handshake()
self.rfile = FileLike(self.connection)
self.wfile = FileLike(self.connection)
@@ -111,6 +115,23 @@ class BaseHandler:
except IOError: # pragma: no cover
pass
+ def handle_sni(self, connection):
+ """
+ Called if the client has given a server name indication.
+
+ Server name can be retrieved like this:
+
+ connection.get_servername()
+
+ And you can specify the connection keys as follows:
+
+ new_context = Context(TLSv1_METHOD)
+ new_context.use_privatekey(key)
+ new_context.use_certificate(cert)
+ connection.set_context(new_context)
+ """
+ pass
+
def handle(self): # pragma: no cover
raise NotImplementedError