aboutsummaryrefslogtreecommitdiff
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-master.tar.gz
two version of R2R are hereHEADmaster
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