diff options
author | S. Solomon Darnell | 2025-03-28 21:52:21 -0500 |
---|---|---|
committer | S. Solomon Darnell | 2025-03-28 21:52:21 -0500 |
commit | 4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch) | |
tree | ee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/msrest/http_logger.py | |
parent | cc961e04ba734dd72309fb548a2f97d67d578813 (diff) | |
download | gn-ai-master.tar.gz |
Diffstat (limited to '.venv/lib/python3.12/site-packages/msrest/http_logger.py')
-rw-r--r-- | .venv/lib/python3.12/site-packages/msrest/http_logger.py | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/msrest/http_logger.py b/.venv/lib/python3.12/site-packages/msrest/http_logger.py new file mode 100644 index 00000000..a246ce41 --- /dev/null +++ b/.venv/lib/python3.12/site-packages/msrest/http_logger.py @@ -0,0 +1,105 @@ +# -------------------------------------------------------------------------- +# +# Copyright (c) Microsoft Corporation. All rights reserved. +# +# The MIT License (MIT) +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the ""Software""), to +# deal in the Software without restriction, including without limitation the +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +# sell copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +# IN THE SOFTWARE. +# +# -------------------------------------------------------------------------- + +import logging +import re +import types + +from typing import Any, Optional, TYPE_CHECKING # pylint: disable=unused-import + +if TYPE_CHECKING: + from .universal_http import ClientRequest, ClientResponse # pylint: disable=unused-import + +_LOGGER = logging.getLogger(__name__) + + +def log_request(_, request, *_args, **_kwargs): + # type: (Any, ClientRequest, str, str) -> None + """Log a client request. + + :param _: Unused in current version (will be None) + :param requests.Request request: The request object. + """ + if not _LOGGER.isEnabledFor(logging.DEBUG): + return + + try: + _LOGGER.debug("Request URL: %r", request.url) + _LOGGER.debug("Request method: %r", request.method) + _LOGGER.debug("Request headers:") + for header, value in request.headers.items(): + if header.lower() == 'authorization': + value = '*****' + _LOGGER.debug(" %r: %r", header, value) + _LOGGER.debug("Request body:") + + # We don't want to log the binary data of a file upload. + if isinstance(request.body, types.GeneratorType): + _LOGGER.debug("File upload") + else: + _LOGGER.debug(str(request.body)) + except Exception as err: # pylint: disable=broad-except + _LOGGER.debug("Failed to log request: %r", err) + + +def log_response(_, _request, response, *_args, **kwargs): + # type: (Any, ClientRequest, ClientResponse, str, Any) -> Optional[ClientResponse] + """Log a server response. + + :param _: Unused in current version (will be None) + :param requests.Request request: The request object. + :param requests.Response response: The response object. + """ + if not _LOGGER.isEnabledFor(logging.DEBUG): + return None + + try: + _LOGGER.debug("Response status: %r", response.status_code) + _LOGGER.debug("Response headers:") + for res_header, value in response.headers.items(): + _LOGGER.debug(" %r: %r", res_header, value) + + # We don't want to log binary data if the response is a file. + _LOGGER.debug("Response content:") + pattern = re.compile(r'attachment; ?filename=["\w.]+', re.IGNORECASE) + header = response.headers.get('content-disposition') + + if header and pattern.match(header): + filename = header.partition('=')[2] + _LOGGER.debug("File attachments: %s", filename) + elif response.headers.get("content-type", "").endswith("octet-stream"): + _LOGGER.debug("Body contains binary data.") + elif response.headers.get("content-type", "").startswith("image"): + _LOGGER.debug("Body contains image data.") + else: + if kwargs.get('stream', False): + _LOGGER.debug("Body is streamable") + else: + _LOGGER.debug(response.text()) + return response + except Exception as err: # pylint: disable=broad-except + _LOGGER.debug("Failed to log response: %s", repr(err)) + return response |