about summary refs log tree commit diff
path: root/.venv/lib/python3.12/site-packages/msrest/configuration.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/configuration.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-4a52a71956a8d46fcb7294ac71734504bb09bcc2.tar.gz
two version of R2R are here HEAD master
Diffstat (limited to '.venv/lib/python3.12/site-packages/msrest/configuration.py')
-rw-r--r--.venv/lib/python3.12/site-packages/msrest/configuration.py103
1 files changed, 103 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/msrest/configuration.py b/.venv/lib/python3.12/site-packages/msrest/configuration.py
new file mode 100644
index 00000000..5133c7d9
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/msrest/configuration.py
@@ -0,0 +1,103 @@
+# --------------------------------------------------------------------------
+#
+# 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.
+#
+# --------------------------------------------------------------------------
+
+
+try:
+    import configparser
+    from configparser import NoOptionError
+except ImportError:
+    import ConfigParser as configparser  # type: ignore
+    from ConfigParser import NoOptionError  # type: ignore
+
+from typing import TYPE_CHECKING, Optional, Dict, List, Any, Callable, Union  # pylint: disable=unused-import
+
+from .pipeline import Pipeline
+from .universal_http.requests import (
+    RequestHTTPSenderConfiguration
+)
+from .pipeline.universal import (
+    UserAgentPolicy,
+    HTTPLogger,
+)
+
+if TYPE_CHECKING:
+    from .pipeline import AsyncPipeline
+
+class Configuration(RequestHTTPSenderConfiguration):
+    """Client configuration.
+
+    :param str baseurl: REST API base URL.
+    :param str filepath: Path to existing config file (optional).
+    """
+
+    def __init__(self, base_url, filepath=None):
+        # type: (str, Optional[str]) -> None
+
+        super(Configuration, self).__init__(filepath)
+        # Service
+        self.base_url = base_url
+
+        # User-Agent as a policy
+        self.user_agent_policy = UserAgentPolicy()
+
+        # HTTP logger policy
+        self.http_logger_policy = HTTPLogger()
+
+        # The pipeline. We don't know until a ServiceClient use this configuration if it will be sync or async
+        # We instantiate with a default empty Pipeline for mypy mostly, trying to use a pipeline from a pure
+        # configuration object doesn't make sense.
+        self.pipeline = Pipeline()  # type: Union[Pipeline, AsyncPipeline]
+
+        # If set to True, ServiceClient will own the sessionn
+        self.keep_alive = False
+
+        # Potential credentials pre-declared
+        self.credentials = None
+
+        if filepath:
+            self.load(filepath)
+
+    @property
+    def user_agent(self):
+        # type: () -> str
+        """The current user agent value."""
+        return self.user_agent_policy.user_agent
+
+    def add_user_agent(self, value):
+        # type: (str) -> None
+        """Add value to current user agent with a space.
+
+        :param str value: value to add to user agent.
+        """
+        self.user_agent_policy.add_user_agent(value)
+
+    @property
+    def enable_http_logger(self):
+        return self.http_logger_policy.enable_http_logger
+
+    @enable_http_logger.setter
+    def enable_http_logger(self, value):
+        self.http_logger_policy.enable_http_logger = value