Skip to content

Commit e7fd302

Browse files
azure-sdkmeghanagupta95ChenxiJiang333msyyc
authored
[AutoPR azure-mgmt-servicegroups]-generated-from-SDK Generation - Python-6074631 (#45969)
* Configurations: 'specification/management/resource-manager/Microsoft.Management/ServiceGroups/tspconfig.yaml', API Version: 2024-02-01-preview, SDK Release Type: beta, and CommitSHA: '37ddf2a815c7d15c52a7e8ddd5c1a1aa9689555c' in SpecRepo: 'https://github.com/Azure/azure-rest-api-specs' Pipeline run: https://dev.azure.com/azure-sdk/internal/_build/results?buildId=6074631 Refer to https://eng.ms/docs/products/azure-developer-experience/develop/sdk-release/sdk-release-prerequisites to prepare for SDK release. * Fix typos in README for Service Groups library * Update README to simplify client initialization Remove subscription ID from client initialization example. * update testcases * Update pyproject.toml * Configurations: 'specification/management/resource-manager/Microsoft.Management/ServiceGroups/tspconfig.yaml', API Version: 2024-02-01-preview, SDK Release Type: beta, and CommitSHA: '75b0c9a8539f7c64386ff6ff10cb6c75711bdefc' in SpecRepo: 'https://github.com/Azure/azure-rest-api-specs' Pipeline run: https://dev.azure.com/azure-sdk/internal/_build/results?buildId=6085541 Refer to https://eng.ms/docs/products/azure-developer-experience/develop/sdk-release/sdk-release-prerequisites to prepare for SDK release. * update config * Configurations: 'specification/management/resource-manager/Microsoft.Management/ServiceGroups/tspconfig.yaml', API Version: 2024-02-01-preview, SDK Release Type: beta, and CommitSHA: '75b0c9a8539f7c64386ff6ff10cb6c75711bdefc' in SpecRepo: 'https://github.com/Azure/azure-rest-api-specs' Pipeline run: https://dev.azure.com/azure-sdk/internal/_build/results?buildId=6085554 Refer to https://eng.ms/docs/products/azure-developer-experience/develop/sdk-release/sdk-release-prerequisites to prepare for SDK release. --------- Co-authored-by: Meghana Gupta <93553451+meghanagupta95@users.noreply.github.com> Co-authored-by: ChenxiJiang333 <v-chenjiang@microsoft.com> Co-authored-by: Yuchao Yan <yuchaoyan@microsoft.com>
1 parent 4250900 commit e7fd302

49 files changed

Lines changed: 7015 additions & 0 deletions

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
# Release History
2+
3+
## 1.0.0b1 (2026-03-31)
4+
5+
### Other Changes
6+
7+
- Initial version
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
Copyright (c) Microsoft Corporation.
2+
3+
MIT License
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in all
13+
copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
SOFTWARE.
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
include *.md
2+
include LICENSE
3+
include azure/mgmt/servicegroups/py.typed
4+
recursive-include tests *.py
5+
recursive-include samples *.py *.md
6+
include azure/__init__.py
7+
include azure/mgmt/__init__.py
Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
# Microsoft Azure SDK for Python
2+
3+
This is the Microsoft Azure Service Groups Management Client Library.
4+
This package has been tested with Python 3.9+.
5+
For a more complete view of Azure libraries, see the [azure sdk python release](https://aka.ms/azsdk/python/all).
6+
7+
## _Disclaimer_
8+
9+
_Azure SDK Python packages support for Python 2.7 has ended 01 January 2022. For more information and questions, please refer to https://github.com/Azure/azure-sdk-for-python/issues/20691_
10+
11+
## Getting started
12+
13+
### Prerequisites
14+
15+
- Python 3.9+ is required to use this package.
16+
- [Azure subscription](https://azure.microsoft.com/free/)
17+
18+
### Install the package
19+
20+
```bash
21+
pip install azure-mgmt-servicegroups
22+
pip install azure-identity
23+
```
24+
25+
### Authentication
26+
27+
By default, [Azure Active Directory](https://aka.ms/awps/aad) token authentication depends on correct configuration of the following environment variables.
28+
29+
- `AZURE_CLIENT_ID` for Azure client ID.
30+
- `AZURE_TENANT_ID` for Azure tenant ID.
31+
- `AZURE_CLIENT_SECRET` for Azure client secret.
32+
33+
With above configuration, client can be authenticated by following code:
34+
35+
```python
36+
from azure.identity import DefaultAzureCredential
37+
from azure.mgmt.servicegroups import ServiceGroupsMgmtClient
38+
39+
client = ServiceGroupsMgmtClient(credential=DefaultAzureCredential())
40+
```
41+
42+
## Examples
43+
44+
Code samples for this package can be found at:
45+
- [Search Service Groups Management](https://docs.microsoft.com/samples/browse/?languages=python&term=Getting%20started%20-%20Managing&terms=Getting%20started%20-%20Managing) on docs.microsoft.com
46+
- [Azure Python Mgmt SDK Samples Repo](https://aka.ms/azsdk/python/mgmt/samples)
47+
48+
49+
## Troubleshooting
50+
51+
## Next steps
52+
53+
## Provide Feedback
54+
55+
If you encounter any bugs or have suggestions, please file an issue in the
56+
[Issues](https://github.com/Azure/azure-sdk-for-python/issues)
57+
section of the project.
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
{
2+
"apiVersion": "2024-02-01-preview",
3+
"apiVersions": {
4+
"Microsoft.Management": "2024-02-01-preview"
5+
},
6+
"commit": "75b0c9a8539f7c64386ff6ff10cb6c75711bdefc",
7+
"repository_url": "https://github.com/Azure/azure-rest-api-specs",
8+
"typespec_src": "specification/management/resource-manager/Microsoft.Management/ServiceGroups",
9+
"emitterVersion": "0.61.2"
10+
}
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
{
2+
"CrossLanguagePackageId": "Microsoft.Management",
3+
"CrossLanguageDefinitionId": {
4+
"azure.mgmt.servicegroups.models.ErrorAdditionalInfo": "Azure.ResourceManager.CommonTypes.ErrorAdditionalInfo",
5+
"azure.mgmt.servicegroups.models.ErrorDetail": "Azure.ResourceManager.CommonTypes.ErrorDetail",
6+
"azure.mgmt.servicegroups.models.ErrorResponse": "Azure.ResourceManager.CommonTypes.ErrorResponse",
7+
"azure.mgmt.servicegroups.models.ParentServiceGroupProperties": "Microsoft.Management.ParentServiceGroupProperties",
8+
"azure.mgmt.servicegroups.models.Resource": "Azure.ResourceManager.CommonTypes.Resource",
9+
"azure.mgmt.servicegroups.models.ProxyResource": "Azure.ResourceManager.CommonTypes.ProxyResource",
10+
"azure.mgmt.servicegroups.models.ServiceGroup": "Microsoft.Management.ServiceGroup",
11+
"azure.mgmt.servicegroups.models.ServiceGroupCollectionResponse": "Microsoft.Management.ServiceGroupCollectionResponse",
12+
"azure.mgmt.servicegroups.models.ServiceGroupProperties": "Microsoft.Management.ServiceGroupProperties",
13+
"azure.mgmt.servicegroups.models.SystemData": "Azure.ResourceManager.CommonTypes.SystemData",
14+
"azure.mgmt.servicegroups.models.CreatedByType": "Azure.ResourceManager.CommonTypes.createdByType",
15+
"azure.mgmt.servicegroups.models.ProvisioningState": "Microsoft.Management.ProvisioningState",
16+
"azure.mgmt.servicegroups.operations.ServiceGroupsOperations.get": "Microsoft.Management.ServiceGroups.get",
17+
"azure.mgmt.servicegroups.aio.operations.ServiceGroupsOperations.get": "Microsoft.Management.ServiceGroups.get",
18+
"azure.mgmt.servicegroups.operations.ServiceGroupsOperations.list_ancestors": "Microsoft.Management.ServiceGroups.listAncestors",
19+
"azure.mgmt.servicegroups.aio.operations.ServiceGroupsOperations.list_ancestors": "Microsoft.Management.ServiceGroups.listAncestors",
20+
"azure.mgmt.servicegroups.ServiceGroupsMgmtClient.begin_create_or_update_service_group": "Microsoft.Management.ServiceGroups.createOrUpdateServiceGroup",
21+
"azure.mgmt.servicegroups.aio.ServiceGroupsMgmtClient.begin_create_or_update_service_group": "Microsoft.Management.ServiceGroups.createOrUpdateServiceGroup",
22+
"azure.mgmt.servicegroups.ServiceGroupsMgmtClient.begin_update_service_group": "Microsoft.Management.ServiceGroups.updateServiceGroup",
23+
"azure.mgmt.servicegroups.aio.ServiceGroupsMgmtClient.begin_update_service_group": "Microsoft.Management.ServiceGroups.updateServiceGroup",
24+
"azure.mgmt.servicegroups.ServiceGroupsMgmtClient.begin_delete_service_group": "Microsoft.Management.ServiceGroups.deleteServiceGroup",
25+
"azure.mgmt.servicegroups.aio.ServiceGroupsMgmtClient.begin_delete_service_group": "Microsoft.Management.ServiceGroups.deleteServiceGroup"
26+
}
27+
}
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
__path__ = __import__("pkgutil").extend_path(__path__, __name__) # type: ignore
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
__path__ = __import__("pkgutil").extend_path(__path__, __name__) # type: ignore
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
# coding=utf-8
2+
# --------------------------------------------------------------------------
3+
# Copyright (c) Microsoft Corporation. All rights reserved.
4+
# Licensed under the MIT License. See License.txt in the project root for license information.
5+
# Code generated by Microsoft (R) Python Code Generator.
6+
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
7+
# --------------------------------------------------------------------------
8+
# pylint: disable=wrong-import-position
9+
10+
from typing import TYPE_CHECKING
11+
12+
if TYPE_CHECKING:
13+
from ._patch import * # pylint: disable=unused-wildcard-import
14+
15+
from ._client import ServiceGroupsMgmtClient # type: ignore
16+
from ._version import VERSION
17+
18+
__version__ = VERSION
19+
20+
try:
21+
from ._patch import __all__ as _patch_all
22+
from ._patch import *
23+
except ImportError:
24+
_patch_all = []
25+
from ._patch import patch_sdk as _patch_sdk
26+
27+
__all__ = [
28+
"ServiceGroupsMgmtClient",
29+
]
30+
__all__.extend([p for p in _patch_all if p not in __all__]) # pyright: ignore
31+
32+
_patch_sdk()
Lines changed: 132 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,132 @@
1+
# coding=utf-8
2+
# --------------------------------------------------------------------------
3+
# Copyright (c) Microsoft Corporation. All rights reserved.
4+
# Licensed under the MIT License. See License.txt in the project root for license information.
5+
# Code generated by Microsoft (R) Python Code Generator.
6+
# Changes may cause incorrect behavior and will be lost if the code is regenerated.
7+
# --------------------------------------------------------------------------
8+
9+
from copy import deepcopy
10+
from typing import Any, Optional, TYPE_CHECKING, cast
11+
from typing_extensions import Self
12+
13+
from azure.core.pipeline import policies
14+
from azure.core.rest import HttpRequest, HttpResponse
15+
from azure.core.settings import settings
16+
from azure.mgmt.core import ARMPipelineClient
17+
from azure.mgmt.core.policies import ARMAutoResourceProviderRegistrationPolicy
18+
from azure.mgmt.core.tools import get_arm_endpoints
19+
20+
from ._configuration import ServiceGroupsMgmtClientConfiguration
21+
from ._utils.serialization import Deserializer, Serializer
22+
from .operations import ServiceGroupsOperations, _ServiceGroupsMgmtClientOperationsMixin
23+
24+
if TYPE_CHECKING:
25+
from azure.core import AzureClouds
26+
from azure.core.credentials import TokenCredential
27+
28+
29+
class ServiceGroupsMgmtClient(_ServiceGroupsMgmtClientOperationsMixin):
30+
"""The Groups RP provides Service Groups as a construct to group multiple resources, resource
31+
groups, subscriptions and other service groups into an organizational hierarchy and centrally
32+
manage access control, policies, alerting and reporting for those resources.
33+
34+
:ivar service_groups: ServiceGroupsOperations operations
35+
:vartype service_groups: azure.mgmt.servicegroups.operations.ServiceGroupsOperations
36+
:param credential: Credential used to authenticate requests to the service. Required.
37+
:type credential: ~azure.core.credentials.TokenCredential
38+
:param base_url: Service host. Default value is None.
39+
:type base_url: str
40+
:keyword cloud_setting: The cloud setting for which to get the ARM endpoint. Default value is
41+
None.
42+
:paramtype cloud_setting: ~azure.core.AzureClouds
43+
:keyword api_version: The API version to use for this operation. Known values are
44+
"2024-02-01-preview". Default value is "2024-02-01-preview". Note that overriding this default
45+
value may result in unsupported behavior.
46+
:paramtype api_version: str
47+
:keyword int polling_interval: Default waiting time between two polls for LRO operations if no
48+
Retry-After header is present.
49+
"""
50+
51+
def __init__(
52+
self,
53+
credential: "TokenCredential",
54+
base_url: Optional[str] = None,
55+
*,
56+
cloud_setting: Optional["AzureClouds"] = None,
57+
**kwargs: Any
58+
) -> None:
59+
_endpoint = "{endpoint}"
60+
_cloud = cloud_setting or settings.current.azure_cloud # type: ignore
61+
_endpoints = get_arm_endpoints(_cloud)
62+
if not base_url:
63+
base_url = _endpoints["resource_manager"]
64+
credential_scopes = kwargs.pop("credential_scopes", _endpoints["credential_scopes"])
65+
self._config = ServiceGroupsMgmtClientConfiguration(
66+
credential=credential,
67+
base_url=cast(str, base_url),
68+
cloud_setting=cloud_setting,
69+
credential_scopes=credential_scopes,
70+
**kwargs
71+
)
72+
73+
_policies = kwargs.pop("policies", None)
74+
if _policies is None:
75+
_policies = [
76+
policies.RequestIdPolicy(**kwargs),
77+
self._config.headers_policy,
78+
self._config.user_agent_policy,
79+
self._config.proxy_policy,
80+
policies.ContentDecodePolicy(**kwargs),
81+
ARMAutoResourceProviderRegistrationPolicy(),
82+
self._config.redirect_policy,
83+
self._config.retry_policy,
84+
self._config.authentication_policy,
85+
self._config.custom_hook_policy,
86+
self._config.logging_policy,
87+
policies.DistributedTracingPolicy(**kwargs),
88+
policies.SensitiveHeaderCleanupPolicy(**kwargs) if self._config.redirect_policy else None,
89+
self._config.http_logging_policy,
90+
]
91+
self._client: ARMPipelineClient = ARMPipelineClient(base_url=cast(str, _endpoint), policies=_policies, **kwargs)
92+
93+
self._serialize = Serializer()
94+
self._deserialize = Deserializer()
95+
self._serialize.client_side_validation = False
96+
self.service_groups = ServiceGroupsOperations(self._client, self._config, self._serialize, self._deserialize)
97+
98+
def send_request(self, request: HttpRequest, *, stream: bool = False, **kwargs: Any) -> HttpResponse:
99+
"""Runs the network request through the client's chained policies.
100+
101+
>>> from azure.core.rest import HttpRequest
102+
>>> request = HttpRequest("GET", "https://www.example.org/")
103+
<HttpRequest [GET], url: 'https://www.example.org/'>
104+
>>> response = client.send_request(request)
105+
<HttpResponse: 200 OK>
106+
107+
For more information on this code flow, see https://aka.ms/azsdk/dpcodegen/python/send_request
108+
109+
:param request: The network request you want to make. Required.
110+
:type request: ~azure.core.rest.HttpRequest
111+
:keyword bool stream: Whether the response payload will be streamed. Defaults to False.
112+
:return: The response of your network call. Does not do error handling on your response.
113+
:rtype: ~azure.core.rest.HttpResponse
114+
"""
115+
116+
request_copy = deepcopy(request)
117+
path_format_arguments = {
118+
"endpoint": self._serialize.url("self._config.base_url", self._config.base_url, "str", skip_quote=True),
119+
}
120+
121+
request_copy.url = self._client.format_url(request_copy.url, **path_format_arguments)
122+
return self._client.send_request(request_copy, stream=stream, **kwargs) # type: ignore
123+
124+
def close(self) -> None:
125+
self._client.close()
126+
127+
def __enter__(self) -> Self:
128+
self._client.__enter__()
129+
return self
130+
131+
def __exit__(self, *exc_details: Any) -> None:
132+
self._client.__exit__(*exc_details)

0 commit comments

Comments
 (0)