- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 9.6k
Open
Description
2.32.5 change 90fee08 breaks passing of custom ssl context using an adapter like this:
class SSLContextAdapter(requests.adapters.HTTPAdapter):
    @override
    def init_poolmanager(self, *args: Any, **kwargs: Any) -> Any:
        kwargs["ssl_context"] = ssl.create_default_context()
        return super().init_poolmanager(*args, **kwargs)  # type: ignore
ssl_adapter = SSLContextAdapter()
session.mount("https://", ssl_adapter)Now, if verify=True, the code in 
requests/src/requests/adapters.py
Lines 292 to 313 in 90fee08
| if url.lower().startswith("https") and verify: | |
| cert_loc = None | |
| # Allow self-specified cert location. | |
| if verify is not True: | |
| cert_loc = verify | |
| if not cert_loc: | |
| cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH) | |
| if not cert_loc or not os.path.exists(cert_loc): | |
| raise OSError( | |
| f"Could not find a suitable TLS CA certificate bundle, " | |
| f"invalid path: {cert_loc}" | |
| ) | |
| conn.cert_reqs = "CERT_REQUIRED" | |
| if not os.path.isdir(cert_loc): | |
| conn.ca_certs = cert_loc | |
| else: | |
| conn.ca_cert_dir = cert_loc | 
ca_certs, which causes urllib3 to modify the ssl_context by loading more certs into it here.
EDIT: I can be fixed by overriding also cert_verify:
class SSLContextAdapter(requests.adapters.HTTPAdapter):
    @override
    def init_poolmanager(self, *args: Any, **kwargs: Any) -> Any:
        kwargs["ssl_context"] = ssl.create_default_context()
        return super().init_poolmanager(*args, **kwargs)  # type: ignore
    @override
    def cert_verify(self, *_args: Any, **_kwargs: Any) -> None:
        pass
ssl_adapter = SSLContextAdapter()
session.mount("https://", ssl_adapter)I'd say this belongs to documentation and needs some tests, so that future changes don't break it again - will prepare a PR if I'll have time.
racinmat
Metadata
Metadata
Assignees
Labels
No labels