Skip to content
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 16 additions & 4 deletions httpx/_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import logging
import time
import typing
import re
import warnings
from contextlib import asynccontextmanager, contextmanager
from types import TracebackType
Expand Down Expand Up @@ -91,6 +92,17 @@ def _same_origin(url: URL, other: URL) -> bool:
)


SANITIZE_URL_PATTERN = re.compile(r"://([^:@]+):([^:@]+)@")


def sanitize_url(url):
"""
Removes credentials (password) from URLs while preserving username if present.
Example: 'http://user:pass@example.com' -> 'http://user@example.com'
"""
return SANITIZE_URL_PATTERN.sub(r"://\1@", url)


class UseClientDefault:
"""
For some parameters such as `auth=...` and `timeout=...` we need to be able
Expand Down Expand Up @@ -1022,10 +1034,10 @@ def _send_single_request(self, request: Request) -> Response:
self.cookies.extract_cookies(response)
response.default_encoding = self._default_encoding

logger.info(
logger.debug(
'HTTP Request: %s %s "%s %d %s"',
request.method,
request.url,
sanitize_url(request.url),
response.http_version,
response.status_code,
response.reason_phrase,
Expand Down Expand Up @@ -1737,10 +1749,10 @@ async def _send_single_request(self, request: Request) -> Response:
self.cookies.extract_cookies(response)
response.default_encoding = self._default_encoding

logger.info(
logger.debug(
'HTTP Request: %s %s "%s %d %s"',
request.method,
request.url,
sanitize_url(request.url),
response.http_version,
response.status_code,
response.reason_phrase,
Expand Down
Loading