diff options
author | Thomas Kriechbaumer <thomas@kriechbaumer.name> | 2015-08-16 11:41:34 +0200 |
---|---|---|
committer | Thomas Kriechbaumer <thomas@kriechbaumer.name> | 2015-08-16 11:41:34 +0200 |
commit | 85cede47aa8f9ffd770ad2830084e53b04b4e77e (patch) | |
tree | 43b622c47c9490ac1581cd81ecd35c2bb0ebe8b6 /netlib/tcp.py | |
parent | b7e6e1c9b2c57270ee0c49af9235a2b119600056 (diff) | |
download | mitmproxy-85cede47aa8f9ffd770ad2830084e53b04b4e77e.tar.gz mitmproxy-85cede47aa8f9ffd770ad2830084e53b04b4e77e.tar.bz2 mitmproxy-85cede47aa8f9ffd770ad2830084e53b04b4e77e.zip |
allow direct ALPN callback method
Diffstat (limited to 'netlib/tcp.py')
-rw-r--r-- | netlib/tcp.py | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/netlib/tcp.py b/netlib/tcp.py index c355cfdd..b3171a1c 100644 --- a/netlib/tcp.py +++ b/netlib/tcp.py @@ -403,6 +403,7 @@ class _Connection(object): cipher_list=None, alpn_protos=None, alpn_select=None, + alpn_select_callback=None, ): """ Creates an SSL Context. @@ -457,7 +458,7 @@ class _Connection(object): if alpn_protos is not None: # advertise application layer protocols context.set_alpn_protos(alpn_protos) - elif alpn_select is not None: + elif alpn_select is not None and alpn_select_callback is None: # select application layer protocol def alpn_select_callback(conn_, options): if alpn_select in options: @@ -465,6 +466,10 @@ class _Connection(object): else: # pragma no cover return options[0] context.set_alpn_select_callback(alpn_select_callback) + elif alpn_select_callback is not None and alpn_select is None: + context.set_alpn_select_callback(alpn_select_callback) + elif alpn_select_callback is not None and alpn_select is not None: + raise NetLibError("ALPN error: only define alpn_select (string) OR alpn_select_callback (method).") return context |