about summary refs log tree commit diff
path: root/.venv/lib/python3.12/site-packages/msrest/http_logger.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/msrest/http_logger.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-master.tar.gz
two version of R2R are here HEAD master
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.py105
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