Mercurial > repos > shellac > sam_consensus_v3
comparison env/lib/python3.9/site-packages/urllib3/util/proxy.py @ 0:4f3585e2f14b draft default tip
"planemo upload commit 60cee0fc7c0cda8592644e1aad72851dec82c959"
| author | shellac |
|---|---|
| date | Mon, 22 Mar 2021 18:12:50 +0000 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:4f3585e2f14b |
|---|---|
| 1 from .ssl_ import create_urllib3_context, resolve_cert_reqs, resolve_ssl_version | |
| 2 | |
| 3 | |
| 4 def connection_requires_http_tunnel( | |
| 5 proxy_url=None, proxy_config=None, destination_scheme=None | |
| 6 ): | |
| 7 """ | |
| 8 Returns True if the connection requires an HTTP CONNECT through the proxy. | |
| 9 | |
| 10 :param URL proxy_url: | |
| 11 URL of the proxy. | |
| 12 :param ProxyConfig proxy_config: | |
| 13 Proxy configuration from poolmanager.py | |
| 14 :param str destination_scheme: | |
| 15 The scheme of the destination. (i.e https, http, etc) | |
| 16 """ | |
| 17 # If we're not using a proxy, no way to use a tunnel. | |
| 18 if proxy_url is None: | |
| 19 return False | |
| 20 | |
| 21 # HTTP destinations never require tunneling, we always forward. | |
| 22 if destination_scheme == "http": | |
| 23 return False | |
| 24 | |
| 25 # Support for forwarding with HTTPS proxies and HTTPS destinations. | |
| 26 if ( | |
| 27 proxy_url.scheme == "https" | |
| 28 and proxy_config | |
| 29 and proxy_config.use_forwarding_for_https | |
| 30 ): | |
| 31 return False | |
| 32 | |
| 33 # Otherwise always use a tunnel. | |
| 34 return True | |
| 35 | |
| 36 | |
| 37 def create_proxy_ssl_context( | |
| 38 ssl_version, cert_reqs, ca_certs=None, ca_cert_dir=None, ca_cert_data=None | |
| 39 ): | |
| 40 """ | |
| 41 Generates a default proxy ssl context if one hasn't been provided by the | |
| 42 user. | |
| 43 """ | |
| 44 ssl_context = create_urllib3_context( | |
| 45 ssl_version=resolve_ssl_version(ssl_version), | |
| 46 cert_reqs=resolve_cert_reqs(cert_reqs), | |
| 47 ) | |
| 48 if ( | |
| 49 not ca_certs | |
| 50 and not ca_cert_dir | |
| 51 and not ca_cert_data | |
| 52 and hasattr(ssl_context, "load_default_certs") | |
| 53 ): | |
| 54 ssl_context.load_default_certs() | |
| 55 | |
| 56 return ssl_context |
